/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** 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/style.scss?ngGlobalStyle ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Montserrat:wght@500&display=swap);
/*!**********************************************************************************************************************************************************************************************************************************!*\
  !*** 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 ***!
  \**********************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
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-default-dynamic-font: -apple-system-body;
  --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;
  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 {
  /* 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: 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;
  /**
   * The containing element itself should be clickable but
   * everything inside of it should not clickable when menu is open
   *
   * Setting pointer-events after scrolling has already started
   * will not cancel scrolling which is why we also set
   * overflow-y below.
   */
  pointer-events: none;
  /**
   * This accounts for scenarios where the main content itself
   * is scrollable.
   */
  overflow-y: hidden;
}

/**
 * Setting overflow cancels any in-progress scrolling
 * when the menu opens. This prevents users from accidentally
 * scrolling the main content while also dragging the menu open.
 * The code below accounts for both ion-content and then custom
 * scroll containers within ion-content (such as virtual scroll)
 */
.menu-content-open ion-content {
  --overflow: hidden;
}

.menu-content-open .ion-content-scroll-host {
  overflow: hidden;
}

.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 ***!
  \***************************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
* {
  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 ***!
  \****************************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
html {
  font-family: var(--ion-font-family);
}

/**
 * Dynamic Type is an iOS-only feature, so
 * this should only be enabled on iOS devices.
 */
@supports (-webkit-touch-callout: none) {
  html {
    /**
     * Includes fallback if Dynamic Type is not enabled.
     */
    font: var(--ion-dynamic-font, 16px 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: 1.625rem;
}

h2 {
  margin-top: 18px;
  font-size: 1.5rem;
}

h3 {
  font-size: 1.375rem;
}

h4 {
  font-size: 1.25rem;
}

h5 {
  font-size: 1.125rem;
}

h6 {
  font-size: 1rem;
}

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 ***!
  \*************************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
.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 ***!
  \*************************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
.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-inline-start: var(--ion-padding, 16px);
  padding-inline-end: var(--ion-padding, 16px);
  padding-top: var(--ion-padding, 16px);
  padding-bottom: 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-inline-start: var(--ion-padding, 16px);
}

.ion-padding-end {
  --padding-end: var(--ion-padding, 16px);
  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-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-inline-start: var(--ion-margin, 16px);
  margin-inline-end: var(--ion-margin, 16px);
  margin-top: var(--ion-margin, 16px);
  margin-bottom: 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-inline-start: var(--ion-margin, 16px);
}

.ion-margin-end {
  --margin-end: var(--ion-margin, 16px);
  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-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 ***!
  \********************************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
.ion-float-left {
  float: left !important;
}

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

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

[dir=rtl] .ion-float-start {
  float: right !important;
}

@supports selector(:dir(rtl)) {
  .ion-float-start:dir(rtl) {
    float: right !important;
  }
}

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

[dir=rtl] .ion-float-end {
  float: left !important;
}

@supports selector(:dir(rtl)) {
  .ion-float-end:dir(rtl) {
    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;
  }
  :host-context([dir=rtl]) .ion-float-sm-start {
    float: right !important;
  }

  [dir=rtl] .ion-float-sm-start {
    float: right !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-sm-start:dir(rtl) {
      float: right !important;
    }
  }

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

  [dir=rtl] .ion-float-sm-end {
    float: left !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-sm-end:dir(rtl) {
      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;
  }
  :host-context([dir=rtl]) .ion-float-md-start {
    float: right !important;
  }

  [dir=rtl] .ion-float-md-start {
    float: right !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-md-start:dir(rtl) {
      float: right !important;
    }
  }

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

  [dir=rtl] .ion-float-md-end {
    float: left !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-md-end:dir(rtl) {
      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;
  }
  :host-context([dir=rtl]) .ion-float-lg-start {
    float: right !important;
  }

  [dir=rtl] .ion-float-lg-start {
    float: right !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-lg-start:dir(rtl) {
      float: right !important;
    }
  }

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

  [dir=rtl] .ion-float-lg-end {
    float: left !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-lg-end:dir(rtl) {
      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;
  }
  :host-context([dir=rtl]) .ion-float-xl-start {
    float: right !important;
  }

  [dir=rtl] .ion-float-xl-start {
    float: right !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-xl-start:dir(rtl) {
      float: right !important;
    }
  }

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

  [dir=rtl] .ion-float-xl-end {
    float: left !important;
  }

  @supports selector(:dir(rtl)) {
    .ion-float-xl-end:dir(rtl) {
      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 ***!
  \********************************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
.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 ***!
  \*************************************************************************************************************************************************************************************************************************************************/
/**
 * Convert a font size to a dynamic font size.
 * Fonts that participate in Dynamic Type should use
 * dynamic font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param unit (optional) - The unit to convert to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a maximum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * a minimum font size.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * Convert a font size to a dynamic font size but impose
 * maximum and minimum font sizes.
 * @param size - The initial font size including the unit (i.e. px or pt)
 * @param minScale - The minimum scale of the font (i.e. 0.8 for a minimum 80% scale).
 * @param maxScale - The maximum scale of the font (i.e. 2.5 for a maximum 250% scale).
 * @param unit (optional) - The unit to convert the initial font size to. Use this if you want to
 * convert to a unit other than $baselineUnit.
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to tablet
 * viewports.
 *
 * Usage:
 * @include tablet-viewport() {
 *   :host {
 *     background-color: green;
 *   }
 * }
 */
/**
 * A heuristic that applies CSS to mobile
 * viewports (i.e. phones, not tablets).
 *
 * Usage:
 * @include mobile-viewport() {
 *   :host {
 *     background-color: blue;
 *   }
 * }
 */
.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/@ng-select/ng-select/themes/material.theme.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************/
.ng-select{padding-bottom:1.25em}.ng-select.ng-select-disabled .ng-select-container:after{border-bottom-color:transparent;background-image:linear-gradient(to right, rgba(0,0,0,0.42) 0%, rgba(0,0,0,0.42) 33%, transparent 0%);background-size:4px 1px;background-repeat:repeat-x}.ng-select.ng-select-disabled .ng-select-container .ng-value-container .ng-value{color:rgba(0,0,0,0.38)}.ng-select.ng-select-disabled .ng-select-container .ng-value-container .ng-placeholder{color:rgba(0,0,0,0.38)}.ng-select.ng-select-disabled .ng-arrow-wrapper .ng-arrow,.ng-select.ng-select-disabled .ng-clear-wrapper{color:rgba(0,0,0,0.38)}.ng-select.ng-select-focused .ng-select-container:after{border-color:#3f51b5;border-width:2px}.ng-select.ng-select-focused .ng-select-container.ng-appearance-outline:after,.ng-select.ng-select-focused .ng-select-container.ng-appearance-outline:hover:after{border-color:#3f51b5;border-width:2px}.ng-select.ng-select-focused .ng-select-container .ng-value-container .ng-placeholder{transform:translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px);color:#3f51b5}.ng-select.ng-select-focused .ng-select-container .ng-arrow-wrapper .ng-arrow{color:#3f51b5}.ng-select .ng-has-value .ng-placeholder,.ng-select.ng-select-filtered .ng-select-container .ng-placeholder{display:initial}.ng-select .ng-has-value .ng-placeholder,.ng-select.ng-select-opened .ng-placeholder{transform:translateY(-1.28125em) scale(0.75) perspective(100px) translateZ(0.001px)}.ng-select .ng-select-container{color:rgba(0,0,0,0.87);align-items:baseline;min-height:51.5px}.ng-select .ng-select-container:after{border-bottom:thin solid rgba(0,0,0,0.42);content:'';bottom:0;left:0;right:0;position:absolute;transition:border-color 0.3s cubic-bezier(0.55, 0, 0.55, 0.2)}.ng-select .ng-select-container.ng-appearance-outline{padding:0 .5em;min-height:60px}.ng-select .ng-select-container.ng-appearance-outline:after{border:solid 1px rgba(0,0,0,0.12);border-radius:5px;height:calc(100% - .5em);pointer-events:none;transition:border-color 0.3s cubic-bezier(0.25, 0.8, 0.25, 1)}.ng-select .ng-select-container.ng-appearance-outline:hover:after{border-color:rgba(0,0,0,0.87);border-width:2px}.ng-select .ng-select-container.ng-appearance-outline .ng-placeholder{padding:0 .25em;background-color:#fff;z-index:1}.ng-select .ng-select-container.ng-appearance-outline .ng-value{padding-left:.25em}.ng-select .ng-select-container .ng-value-container{align-items:stretch;padding:.4375em 0;border-top:.84375em solid transparent}.ng-select .ng-select-container .ng-value-container .ng-placeholder{position:absolute;color:rgba(0,0,0,0.54);transform-origin:left 0;transition:transform 0.4s cubic-bezier(0.25, 0.8, 0.25, 1),color 0.4s cubic-bezier(0.25, 0.8, 0.25, 1),width 0.4s cubic-bezier(0.25, 0.8, 0.25, 1)}[dir="rtl"] .ng-select .ng-select-container .ng-value-container .ng-placeholder{transform-origin:right 0}.ng-select .ng-select-container .ng-value-container .ng-input{bottom:.4375em}.ng-select.ng-select-single .ng-select-container.ng-appearance-outline .ng-arrow-wrapper{bottom:17px}.ng-select.ng-select-single .ng-select-container.ng-appearance-outline .ng-clear-wrapper{bottom:14px}.ng-select.ng-select-single .ng-select-container .ng-arrow-wrapper{align-self:flex-end;bottom:9px}.ng-select.ng-select-single .ng-select-container .ng-clear-wrapper{align-self:flex-end;bottom:7px}.ng-select.ng-select-multiple.ng-select-disabled .ng-select-container .ng-value-container .ng-value{background-color:rgba(0,0,0,0.12);color:rgba(0,0,0,0.26)}.ng-select.ng-select-multiple.ng-select-disabled .ng-appearance-outline:after,.ng-select.ng-select-multiple.ng-select-disabled .ng-appearance-outline:hover:after{background-image:none;border:dotted 1px rgba(0,0,0,0.12)}.ng-select.ng-select-multiple .ng-select-container.ng-appearance-outline.ng-has-value .ng-arrow-wrapper,.ng-select.ng-select-multiple .ng-select-container.ng-appearance-outline.ng-has-value .ng-clear-wrapper{border-top:none}.ng-select.ng-select-multiple .ng-select-container.ng-appearance-outline .ng-arrow-wrapper{top:0}.ng-select.ng-select-multiple .ng-select-container.ng-appearance-outline .ng-clear-wrapper{top:4px}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{background-color:#3f51b5;border-radius:2px;color:#fff;padding:2px 5px;margin:0 0.4375em 0.4375em 0}[dir="rtl"] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value{margin:0 0 0.4375em 0.4375em}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value.ng-value-disabled{background-color:rgba(0,0,0,0.12);color:rgba(0,0,0,0.26)}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-label{font-size:14px;font-weight:500}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon{color:rgba(255,255,255,0.54);padding-right:5px}[dir="rtl"] .ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon{padding-left:5px;padding-right:0}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-value .ng-value-icon:hover{color:rgba(255,255,255,0.87)}.ng-select.ng-select-multiple .ng-select-container .ng-value-container .ng-input{line-height:1.375em}.ng-select.ng-select-multiple .ng-select-container.ng-has-value{align-items:center}.ng-select.ng-select-multiple .ng-select-container.ng-has-value .ng-value-container{padding-bottom:0;padding-top:.1875em}.ng-select.ng-select-multiple .ng-select-container.ng-has-value .ng-clear-wrapper,.ng-select.ng-select-multiple .ng-select-container.ng-has-value .ng-arrow-wrapper{border-top:.84375em solid transparent}.ng-select .ng-clear-wrapper{color:rgba(0,0,0,0.54)}.ng-select .ng-clear-wrapper:hover{color:rgba(0,0,0,0.87)}.ng-select .ng-clear-wrapper:focus{color:rgba(0,0,0,0.87);outline:none}.ng-select .ng-arrow-wrapper{bottom:2px}.ng-select .ng-arrow-wrapper .ng-arrow{border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid;margin:0 4px;color:rgba(0,0,0,0.54)}.ng-select .ng-spinner-zone{top:3px}.ng-dropdown-panel{background:#fff;left:0}.ng-dropdown-panel.ng-select-top{bottom:calc(100% - .84375em);box-shadow:0 -5px 5px -3px rgba(0,0,0,0.2),0 -8px 10px 1px rgba(0,0,0,0.14),0 -3px 14px 2px rgba(0,0,0,0.12)}.ng-dropdown-panel.ng-select-right{left:100%;top:calc(0% + .84375em);box-shadow:0 -5px 5px -3px rgba(0,0,0,0.2),0 -8px 10px 1px rgba(0,0,0,0.14),0 -3px 14px 2px rgba(0,0,0,0.12);margin-left:4px}.ng-dropdown-panel.ng-select-bottom{top:calc(100% - 1.25em);box-shadow:0 5px 5px -3px rgba(0,0,0,0.2),0 8px 10px 1px rgba(0,0,0,0.14),0 3px 14px 2px rgba(0,0,0,0.12)}.ng-dropdown-panel.ng-select-left{left:calc(-100% - 4px);top:calc(0% + .84375em);box-shadow:0 -5px 5px -3px rgba(0,0,0,0.2),0 -8px 10px 1px rgba(0,0,0,0.14),0 -3px 14px 2px rgba(0,0,0,0.12)}.ng-dropdown-panel.multiple .ng-option.selected{background:#fff}.ng-dropdown-panel.multiple .ng-option.marked{background:rgba(0,0,0,0.04)}.ng-dropdown-panel .ng-dropdown-header{border-bottom:1px solid rgba(0,0,0,0.12);padding:0 16px;line-height:3em;min-height:3em}.ng-dropdown-panel .ng-dropdown-footer{border-top:1px solid rgba(0,0,0,0.12);padding:0 16px;line-height:3em;min-height:3em}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup{-webkit-user-select:none;user-select:none;cursor:pointer;line-height:3em;height:3em;padding:0 16px;color:rgba(0,0,0,0.54);font-weight:500}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup.ng-option-marked{background:rgba(0,0,0,0.04)}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup.ng-option-disabled{cursor:default}.ng-dropdown-panel .ng-dropdown-panel-items .ng-optgroup.ng-option-selected{background:rgba(0,0,0,0.12);color:#3f51b5}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option{line-height:3em;min-height:3em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 16px;text-decoration:none;position:relative;color:rgba(0,0,0,0.87);text-align:left}[dir="rtl"] .ng-dropdown-panel .ng-dropdown-panel-items .ng-option{text-align:right}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-marked{background:rgba(0,0,0,0.04);color:rgba(0,0,0,0.87)}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-selected{background:rgba(0,0,0,0.12);color:#3f51b5}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-disabled{color:rgba(0,0,0,0.38)}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-child{padding-left:32px}[dir="rtl"] .ng-dropdown-panel .ng-dropdown-panel-items .ng-option.ng-option-child{padding-right:32px;padding-left:0}.ng-dropdown-panel .ng-dropdown-panel-items .ng-option .ng-tag-label{padding-right:5px;font-size:80%;font-weight:400;color:rgba(0,0,0,0.38)}[dir="rtl"] .ng-dropdown-panel .ng-dropdown-panel-items .ng-option .ng-tag-label{padding-left:5px;padding-right:0}

/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** 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/style.scss?ngGlobalStyle (1) ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
:root {
  /**
    IONIC VARIABLES
  **/
  --ion-text-color: #000;
  --ion-text-color-rgb: 0, 0, 0;
  /** primary **/
  --ion-color-primary: #56a4d5;
  --ion-color-primary-rgb: 86, 164, 213;
  --ion-color-primary-contrast: #ffffff;
  --ion-color-primary-contrast-rgb: 255, 255, 255;
  --ion-color-primary-shade: #4c90bb;
  --ion-color-primary-tint: #67add9;
  /** accent **/
  --ion-color-accent: #d24283;
  --ion-color-accent-rgb: 210, 66, 131;
  --ion-color-accent-contrast: #ffffff;
  --ion-color-accent-contrast-rgb: 255, 255, 255;
  --ion-color-accent-shade: #b93a73;
  --ion-color-accent-tint: #d7558f;
  /** secondary **/
  --ion-color-secondary: #418991;
  --ion-color-secondary-rgb: 65, 137, 145;
  --ion-color-secondary-contrast: #ffffff;
  --ion-color-secondary-contrast-rgb: 255, 255, 255;
  --ion-color-secondary-shade: #397980;
  --ion-color-secondary-tint: #54959c;
  /** tertiary **/
  --ion-color-tertiary: #3d4d66;
  --ion-color-tertiary-rgb: 61, 77, 102;
  --ion-color-tertiary-contrast: #ffffff;
  --ion-color-tertiary-contrast-rgb: 255, 255, 255;
  --ion-color-tertiary-shade: #36445a;
  --ion-color-tertiary-tint: #505f75;
  /** 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: #e36d00;
  --ion-color-warning-rgb: 227, 109, 0;
  --ion-color-warning-contrast: #000000;
  --ion-color-warning-contrast-rgb: 0, 0, 0;
  --ion-color-warning-shade: #c86000;
  --ion-color-warning-tint: #e67c1a;
  /** danger **/
  --ion-color-danger: #eb445a;
  --ion-color-danger-rgb: 235, 68, 90;
  --ion-color-danger-contrast: #ffffff;
  --ion-color-danger-contrast-rgb: 255, 255, 255;
  --ion-color-danger-shade: #cf3c4f;
  --ion-color-danger-tint: #ed576b;
  /** dark **/
  --ion-color-dark: #222428;
  --ion-color-dark-rgb: 34, 36, 40;
  --ion-color-dark-contrast: #ffffff;
  --ion-color-dark-contrast-rgb: 255, 255, 255;
  --ion-color-dark-shade: #1e2023;
  --ion-color-dark-tint: #383a3e;
  /** medium **/
  --ion-color-medium: #92949c;
  --ion-color-medium-rgb: 146, 148, 156;
  --ion-color-medium-contrast: #ffffff;
  --ion-color-medium-contrast-rgb: 255, 255, 255;
  --ion-color-medium-shade: #808289;
  --ion-color-medium-tint: #9d9fa6;
  /** light **/
  --ion-color-light: #f4f5f8;
  --ion-color-light-rgb: 244, 245, 248;
  --ion-color-light-contrast: #000000;
  --ion-color-light-contrast-rgb: 0, 0, 0;
  --ion-color-light-shade: #d7d8da;
  --ion-color-light-tint: #f5f6f9;
  /** page bg color **/
  --ion-background-color: #f3f3f3;
  /** spacing **/
  --ion-margin: 20px;
  --ion-padding: 20px;
  /** item **/
  --ion-item-border-color: rgba(0, 0, 0, 0.13);
  /**
    QINETIC VARIABLES
  **/
  --qin-content-max-width: 800px;
  /** colors **/
  --qin-highlight-color: #ecc352;
  /** content **/
  --qin-content-bg: linear-gradient(120deg, #56a4d5, 60%, #418991, #3d4d66);
  --qin-dark-content-bg: #3d4d66;
  --qin-content-color: #fff;
  /** footer */
  --qin-footer-height: 86px;
  --qin-footer-shadow: 0px 5px 63px 0px rgba(112, 112, 112, 0.5);
  /** card **/
  --qin-card-border-radius: 16px;
  --qin-card-background-color: #fff;
  --qin-card-shadow: 0 19px 60px 15px rgba(0, 0, 0, 0.3);
  /** button **/
  --qin-button-height: 60px;
  --qin-button-border-radius: 30px;
  --qin-button-small-height: 38px;
  --qin-button-small-border-radius: 19px;
  /** icons **/
  --qin-icon-size-xl: 48px;
  --qin-icon-size-xxl: 64px;
  --qin-icon-size-picture: 128px;
  --qin-icon-color-primary: var(--ion-color-primary);
  --qin-icon-color-secondary: var(--ion-color-secondary);
  /** testo **/
  --qin-text-background-color: #f2f2f2;
  /**  logo **/
  --qin-logo-height: 40px;
  --qin-logo-width: 120px;
  --qin-logo-sm-height: 20px;
  --qin-logo-sm-width: 60px;
  /** typography **/
  --qin-text-line-height: 1.4;
  --qin-title-font-size-1: 22px;
  --qin-title-font-size-2: 20px;
  --qin-title-font-size-3: 18px;
  --qin-title-font-size-4: 16px;
  --qin-title-font-size-5: 14px;
  --qin-display-font-size-1: 36px;
  --qin-display-font-size-2: 28px;
  --qin-display-font-size-3: 24px;
  --qin-small-font-size: 12px;
  --qin-button-font-size: 14px;
  --qin-label-font-size: 14px;
  --qin-input-font-size: 14px;
  --qin-body-font-size: 14px;
  /** wizard widget **/
  --qin-wizard-widget-square-lg: 36px;
  --qin-wizard-widget-square-md: 24px;
  --qin-wizard-widget-square-sm: 20px;
  --qin-wizard-widget-line-md: 36px;
  --qin-wizard-widget-line-sm: 26px;
  --qin-input-placeholder-color: rgba(0, 0, 0, 0.33);
  --qin-input-filled-color: var(--ion-text-color);
}

/* Core CSS required for Ionic components to work properly */
/* Basic CSS for apps built with Ionic */
/* Optional CSS utils that can be commented out */
/* stile custom */
[hidden] {
  display: none !important;
}

.fullheight {
  height: 100vh; /* Fallback for browsers that do not support Custom Properties */
  height: calc(var(--vh, 1vh) * 100);
}

.demo-content {
  position: relative;
}
.demo-content::before {
  content: "Demo";
  position: absolute;
  top: 2px;
  left: 2px;
  background-color: var(--ion-color-warning);
  color: var(--ion-color-warning-contrast);
  font-size: 8px;
  padding: 2px 4px;
  border-radius: 4px;
  z-index: 999;
}

@keyframes jumpFromBottom {
  from {
    opacity: 0;
    transform: translateY(20%);
  }
  to {
    opacity: 1;
    transform: translateY(0%);
  }
}
@keyframes jumpFromTop {
  from {
    opacity: 0;
    transform: translateY(-20%);
  }
  to {
    opacity: 1;
    transform: translateY(0%);
  }
}
@keyframes rotateUp {
  from {
    transform: scale(0) rotate(360deg);
  }
  to {
    transform: scale(1) rotate(0deg);
  }
}
@keyframes flipX {
  from {
    opacity: 0;
    transform: rotateX(90deg);
  }
  to {
    opacity: 1;
    transform: rotateX(0deg);
  }
}
@keyframes flipY {
  from {
    opacity: 0;
    transform: rotateY(90deg);
  }
  to {
    opacity: 1;
    transform: rotateY(0deg);
  }
}
@keyframes slideFromLeft {
  0% {
    opacity: 0;
    transform: translateX(-100%);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes bounceUp {
  0% {
    transform: scale(1, 1) translateY(0);
  }
  10% {
    transform: scale(1.1, 0.9) translateY(0);
  }
  30% {
    transform: scale(0.9, 1.1) translateY(-50%);
  }
  50% {
    transform: scale(1.05, 0.95) translateY(0);
  }
  57% {
    transform: scale(1, 1) translateY(-5%);
  }
  64% {
    transform: scale(1, 1) translateY(0);
  }
  100% {
    transform: scale(1, 1) translateY(0);
  }
}
@keyframes grow {
  0% {
    transform: scale(0);
  }
  100% {
    transform: scale(1);
  }
}
.input-alert-message ion-item {
  --padding-start: 0px;
  --padding-end: 0px;
}
.input-alert-message ion-item ion-label {
  margin: 0px;
  line-height: 1.2 !important;
}

ion-button {
  font-weight: bold;
  font-size: var(--qin-button-font-size);
  height: var(--qin-button-height);
  --border-radius: var(--qin-button-border-radius);
}
ion-button.button-small {
  height: var(--qin-button-small-height);
  --border-radius: var(--qin-button-small-border-radius);
}
ion-button.button-circle {
  width: var(--qin-button-height);
  --padding-start: 0px;
  --padding-end: 0px;
}
ion-button.button-circle.button-small {
  width: var(--qin-button-small-height);
}
ion-button.fixed-left-top {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 10;
}
ion-button.tooltip-btn {
  height: 28px;
}

.card-confirm-img {
  max-width: 278px;
  margin-left: auto;
  margin-right: auto;
}
.card-confirm-item {
  --inner-padding-end: 0;
}
.card-confirm-item-value {
  display: flex;
  align-items: center;
}
.card-confirm-item-value ion-text h2 {
  font-weight: bold;
}
.card-confirm-item-text {
  white-space: normal !important;
}

ion-card {
  animation: jumpFromBottom 0.3s;
  border-radius: var(--qin-card-border-radius);
  box-shadow: var(--qin-card-shadow);
  --background: var(--qin-card-background-color);
  --ion-item-background: var(--qin-card-background-color);
  z-index: 5;
}
ion-card ion-card-title {
  font-size: var(--qin-title-font-size-2);
}
ion-card ion-card-subtitle {
  font-size: var(--qin-title-font-size-4);
}

.skip-card-entry ion-card {
  animation: none !important;
}

ion-card.dashboard-card ion-card-header {
  position: relative;
  --background: var(--ion-color-tertiary);
  --color: var(--ion-color-tertiary-contrast);
  text-align: center;
  margin-bottom: var(--ion-margin);
}
ion-card.dashboard-card ion-card-header ion-badge {
  position: absolute;
  right: var(--ion-margin);
  top: 50%;
  transform: translateY(-50%);
}
ion-card.dashboard-card ion-card-title {
  --color: var(--ion-text-color);
}

app-tab-documents ion-card.dashboard-card ion-card-header {
  background-color: transparent;
}

ion-card.centered-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

ion-card.hint {
  --background: var(--qin-text-background-color, --qin-card-background-color);
}
ion-card.hint ion-card-subtitle {
  color: var(--ion-color-primary);
}
ion-card.hint .link {
  font-size: var(--qin-title-font-size-4);
}

ion-card.dynamic-form-card ion-col {
  --ion-grid-column-padding: 0;
  --ion-grid-column-padding-md: 6px;
  --ion-grid-column-padding-lg: 6px;
  --ion-grid-column-padding-xl: 6px;
  padding-top: 0px;
  padding-bottom: 0px;
}

ion-card.dynamic-form-card ion-grid {
  --ion-grid-padding: 0;
}

ion-card.dynamic-form-card {
  overflow: visible;
}

ion-card.result-item-card ion-card-content {
  display: flex;
  align-items: center;
}
ion-card.result-item-card .result-item-card-info {
  flex-grow: 1;
  margin-right: var(--ion-margin);
}
ion-card.result-item-card .result-item-card-btn {
  flex-shrink: 0;
}

.ion-color-accent {
  --ion-color-base: var(--ion-color-accent);
  --ion-color-base-rgb: var(--ion-color-accent-rgb);
  --ion-color-contrast: var(--ion-color-accent-contrast);
  --ion-color-contrast-rgb: var(--ion-color-accent-contrast-rgb);
  --ion-color-shade: var(--ion-color-accent-shade);
  --ion-color-tint: var(--ion-color-accent-tint);
}

body[data-area-theme=reserved-area] ion-app,
body[data-area-theme=after-sales] ion-app {
  --qin-content-bg: var(--qin-dark-content-bg);
}

ion-content::part(background)::before {
  content: "";
  display: block;
  height: 50%;
  width: 100%;
  background: var(--qin-content-bg);
}

ion-content.full-bg {
  --color: var(--ion-color-tertiary-contrast);
}

ion-content.full-bg::part(background)::before {
  height: 100%;
}

ion-content.full-bg-transparent::part(background)::before {
  height: 100%;
  background: transparent;
}

ion-content.with-footer {
  --padding-bottom: calc(var(--qin-footer-height) + var(--ion-margin));
}

.container {
  max-width: var(--qin-content-max-width);
  margin: auto;
}
.container ion-card:not(.keep-size) {
  min-height: 56vh;
}
.container .half-content {
  min-height: 50vh;
}

.doc-viewer {
  height: 100%;
  display: flex;
  flex-direction: column;
  background: var(--qin-card-background-color);
  color: var(--ion-color-light-contrast);
}
.doc-viewer .tools {
  flex-shrink: 0;
  width: 100%;
}
.doc-viewer .preview {
  flex-grow: 1;
  overflow: hidden;
  width: 100%;
  position: relative;
}
.doc-viewer .preview pdf-viewer {
  display: block;
  height: 100%;
}

.footer {
  background: var(--qin-content-color);
  box-shadow: var(--qin-footer-shadow);
}
.footer .footer-content {
  max-width: var(--qin-content-max-width);
  height: var(--qin-footer-height);
  padding: 0 var(--ion-padding);
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.footer p.footer-tip {
  font-size: 14px;
  margin-top: 0px;
  margin-bottom: 0px;
  margin-right: calc(var(--ion-margin, 16px) * 2);
}
.footer .footer-spacer {
  flex-grow: 1;
}
.footer ion-button.footer-primary-action,
.footer ion-button.footer-secondary-action {
  flex-shrink: 0;
}
.footer ion-button.footer-primary-action {
  --box-shadow: none;
  animation: flipX 0.6s;
}
.footer ion-button.footer-primary-action:not(.button-circle) {
  --padding-start: var(--ion-padding, 16px);
  --padding-end: var(--ion-padding, 16px);
}

.footer.fixed-bottom {
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  z-index: 99;
}

.dynamic-input .dynamic-input-label {
  display: flex;
  justify-content: normal;
  align-items: center;
}
.dynamic-input .dynamic-input-label .field-title {
  flex-grow: 1;
}
.dynamic-input .dynamic-input-label ion-button {
  flex-shrink: 0;
}

.dynamic-input ion-item {
  border-bottom: 1px solid var(--ion-text-color);
  --border-style: none;
}
.dynamic-input ion-radio-group ion-item,
.dynamic-input app-input-document ion-item,
.dynamic-input app-error-message ion-item {
  border-bottom: none;
}
.dynamic-input ion-item ion-input,
.dynamic-input ion-item ion-select {
  min-height: 0 !important;
}
.dynamic-input app-input-select ion-icon,
.dynamic-input app-input-calendar ion-icon {
  margin: 0;
  color: var(--ion-color-primary);
}
.dynamic-input app-input-select ion-icon {
  font-size: 14px;
}
.dynamic-input app-input-calendar ion-icon {
  font-size: 24px;
}
.dynamic-input ion-select::part(icon) {
  color: var(--ion-color-primary);
  opacity: 1;
  position: absolute;
  right: 0;
  transform: none;
}
.dynamic-input ion-select::part(text),
.dynamic-input ion-select::part(placeholder),
.dynamic-input ion-input,
.dynamic-input app-input-calendar ion-item,
.dynamic-input ion-textarea {
  font-size: var(--qin-input-font-size) !important;
}
.dynamic-input ion-input input,
.dynamic-input ion-textarea textarea {
  caret-color: #000 !important;
}
.dynamic-input ion-textarea,
.dynamic-input ion-input {
  --placeholder-color: var(--qin-input-placeholder-color) !important;
  --placeholder-opacity: 1 !important;
  --color: var(--qin-input-filled-color);
}
.dynamic-input ion-select {
  --placeholder-color: var(--qin-input-placeholder-color) !important;
  --placeholder-opacity: 1 !important;
  color: var(--qin-input-filled-color);
}
.dynamic-input app-input-calendar ion-item,
.dynamic-input app-input-calendar .item-input-display-placeholder {
  --color: var(--qin-input-placeholder-color);
  margin: 0;
}
.dynamic-input.form-field--filled app-input-calendar ion-item,
.dynamic-input .item-input-display-text {
  --color: var(--qin-input-filled-color);
}
.dynamic-input .item-input-display-text {
  margin: 0;
}
.dynamic-input .field-title {
  color: var(--ion-text-color);
  line-height: var(--qin-text-line-height);
  font-size: var(--qin-label-font-size) !important;
}
.dynamic-input input::-webkit-outer-spin-button,
.dynamic-input input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.dynamic-input input[type=number] {
  -moz-appearance: textfield !important;
}
.dynamic-input ion-input.titlecase {
  text-transform: capitalize;
}
.dynamic-input ion-input.uppercase {
  text-transform: uppercase;
}
.dynamic-input ion-input.uppercase input::placeholder, .dynamic-input ion-input.titlecase input::placeholder {
  text-transform: initial;
}
.dynamic-input ion-select {
  width: 100%;
  justify-content: space-between;
}

ion-range.pin-visible::part(pin) {
  transform: translate3d(0px, -24px, 0px) scale(1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 25px;
  color: var(--pin-color, var(--bar-background));
  background-color: transparent;
}
ion-range.pin-visible::part(pin)::before {
  background-color: transparent;
}
ion-range.pin-visible::part(pin)::after {
  content: "mesi";
  margin-left: 5px;
  font-size: 10px;
}

.select-popover {
  --backdrop-opacity: 0;
}
.select-popover ion-select-popover.popover-viewport.sc-ion-popover-md {
  overflow-y: auto;
}
.select-popover ion-list.sc-ion-select-popover ion-radio.sc-ion-select-popover {
  opacity: 0;
}

.calendar-popover {
  --backdrop-opacity: 0;
}

.popover-calendar-content {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.popover-calendar-content .popover-calendar-row {
  flex-grow: 1;
  overflow: hidden;
  width: 100%;
  height: 30vh;
  display: flex;
  align-items: flex-start;
}
.popover-calendar-content .popover-calendar-col {
  overflow: auto;
  height: 100%;
  flex: 0 1 50%;
  width: 50%;
}
.popover-calendar-content .popover-calendar-col ion-button.popover-calendar-option:not(.active) {
  font-weight: normal;
  color: var(--ion-text-color);
}
.popover-calendar-content .popover-calendar-buttons {
  flex-shrink: 0;
  text-align: right;
}

ion-item.selection-choice {
  --border-width: 2px;
  --border-color: transparent;
  --ripple-color: var(--ion-color-primary);
  --color: var(--ion-color-muted);
  --min-height: none;
}
ion-item.selection-choice ion-icon {
  font-size: 88px;
}
ion-item.selection-choice p {
  margin-top: 10px;
  margin-bottom: 0px;
  font-size: var(--qin-title-font-size-4);
}
ion-item.selection-choice::part(native) {
  flex-direction: column;
  border-radius: var(--qin-card-border-radius);
  --padding-top: var(--ion-padding);
  --padding-bottom: var(--ion-padding);
}
ion-item.selection-choice:hover::part(native) {
  --border-color: transparent;
}
ion-item.selection-choice.selected {
  --color: var(--ion-color-primary);
}
ion-item.selection-choice.selected::part(native) {
  --border-color: var(--ion-color-primary);
}

.input-number-step {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 1px solid var(--ion-color-light);
  border-radius: var(--qin-card-border-radius);
  padding: calc(var(--ion-padding) / 2);
}
.input-number-step ion-item input,
.input-number-step ion-item .input-number-step-unit {
  font-size: var(--qin-display-font-size-2);
}
.input-number-step ion-button {
  flex-shrink: 0;
}
.input-number-step ion-item {
  --background: transparent;
  flex-grow: 1;
  text-align: center;
  position: relative;
}
.input-number-step ion-button + ion-item {
  margin-left: var(--ion-margin);
  margin-right: var(--ion-margin);
}
.input-number-step .input-number-step-unit {
  display: block;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.input-range {
  display: flex;
  align-items: flex-start;
}
.input-range > ion-button {
  flex-shrink: 0;
}
.input-range .input-range-center {
  flex-grow: 1;
}
.input-range .input-range-modifiers {
  display: flex;
  align-items: center;
}
.input-range .range {
  --padding-start: 0px;
  --padding-end: 0px;
  --inner-padding-start: 0px;
  --inner-padding-end: 0px;
  overflow: visible;
}
.input-range .range ion-range {
  --knob-box-shadow: 0;
  padding: 0;
}
.input-range .range ion-range::part(knob)::before {
  transform: scale(0);
}
.input-range .range,
.input-range .input-range-modifiers {
  --min-height: 48px;
  --height: 48px;
  height: 48px;
}
.input-range .extremes {
  display: flex;
  justify-content: space-between;
  font-size: var(--qin-title-font-size-4);
}

ion-range.knob-lg {
  --knob-size: 42px;
}

ion-toggle {
  --track-background: var(--ion-color-step-50);
  --track-background-checked: var(--ion-color-primary);
  --handle-background: var(--ion-color-primary-contrast);
  --handle-background-checked: var(--ion-color-primary-contrast);
  --border-radius: 10px;
  --handle-height: 17px;
  --handle-width: 17px;
  --handle-spacing: 2px;
}
ion-toggle::part(track) {
  height: 21px;
  width: 34px;
}

ion-icon.primary-icon {
  color: var(--qin-icon-color-primary);
}
ion-icon.secondary-icon {
  color: var(--qin-icon-color-secondary);
}
ion-icon.xl {
  font-size: var(--qin-icon-size-xl);
}
ion-icon.xxl {
  font-size: var(--qin-icon-size-xxl);
}
ion-icon.picture {
  font-size: var(--qin-icon-size-picture);
}
ion-icon.rotate-up {
  animation: rotateUp 0.6s;
}
ion-icon.flip-x {
  animation: flipX 0.6;
}
ion-icon.bounce-up {
  animation-duration: 1s;
  animation-iteration-count: infinite;
  animation-name: bounceUp;
  animation-timing-function: cubic-bezier(0.28, 0.84, 0.42, 1);
  transform-origin: bottom;
}
ion-icon.input-icon {
  font-size: 12px;
}

.infrastructure-content {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.infrastructure-content .update-required-img {
  display: block;
  margin: var(--ion-margin) auto;
}
.infrastructure-content .maintenance-img {
  display: block;
  margin: var(--ion-margin) auto;
}

.small-divider::after {
  content: "";
  display: block;
  width: 30%;
  height: 4px;
  border-radius: 2px;
  background: var(--ion-color-medium);
  margin: 0 auto;
}

.bullet-list .bullet-item {
  display: flex;
  align-items: center;
}
.bullet-list .bullet-item:not(:last-child) {
  margin-bottom: var(--ion-margin);
}
.bullet-list .bullet-item > ion-icon {
  flex-shrink: 0;
  margin-right: var(--ion-margin);
}
.bullet-list .bullet-item > div {
  flex-grow: 1;
}
.bullet-list .bullet-item .bullet-item-message {
  display: inline;
}

.olist {
  list-style: none;
  padding: 0;
}
.olist .olist-item {
  display: flex;
  align-items: center;
  padding: calc(var(--ion-padding) / 2) 0;
}
.olist .olist-item-num {
  font-weight: bold;
  color: var(--ion-color-secondary);
  width: 30px;
}
.olist .olist-item-label {
  margin: 0;
}

.logo {
  height: var(--qin-logo-height);
  width: var(--qin-logo-width);
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.logo-sm {
  height: var(--qin-logo-sm-height);
  width: var(--qin-logo-sm-width);
  display: block;
  margin-left: auto;
  margin-right: auto;
}

app-fullscreen,
.fullscreen-inner {
  height: 100%;
  display: block;
}

.fullscreen-inner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.fullscreen-inner .fullscreen-header,
.fullscreen-inner .fullscreen-footer {
  flex-shrink: 0;
}
.fullscreen-inner .fullscreen-body {
  flex-grow: 1;
  overflow: auto;
}

.fullscreen-body .feedback {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.fullscreen-body .feedback > * {
  width: 100%;
}

.feedback {
  padding: var(--ion-padding, 16px);
}
.feedback .feedback-title {
  font-size: var(--qin-title-font-size-2);
}
.feedback .feedback-message {
  font-size: var(--qin-title-font-size-4);
  line-height: 1.4;
}
.feedback .feedback-code {
  font-size: var(--qin-small-font-size);
  line-height: 1.4;
}
.feedback .feedback-icon {
  font-size: 64px;
}
.feedback .feedback-title + .feedback-message {
  margin-top: 0;
}
.feedback .feedback-message + .feedback-message {
  margin-top: 0;
}
.feedback .feedback-icon + .feedback-title {
  margin-top: var(--ion-margin);
}

.preface-slides {
  height: 100%;
  width: 100%;
  overflow: hidden;
}
.preface-slides swiper-container {
  height: 100%;
  width: 100%;
  --swiper-pagination-color: #fff;
}
.preface-slides swiper-slide {
  display: block;
  overflow: auto;
}
.preface-slides ul {
  padding-inline-start: var(--ion-padding, 16px);
}
.preface-slides ul li {
  margin: var(--ion-margin, 16px) 0;
}

.modal-state .modal-state-content {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.modal-state .hint ion-card-header {
  font-size: var(--qin-title-font-size-3);
}
.modal-state .hint ion-label p {
  font-size: var(--qin-small-font-size);
}

app-modal-quote-edit ion-range::part(knob)::before {
  transform: scale(0);
}

app-modal-tooltip ion-toolbar {
  --background: var(--ion-color-secondary);
  --color: var(--ion-color-secondary-contrast);
}

app-obligations .obligation-detail {
  display: flex;
  align-items: center;
}

/* preview preventivo in conferma preventivo */
.quotation-preview .quotation-preview-standard .quotation-preview-row {
  align-items: center;
  margin: calc(var(--ion-margin, 16px) / 2) 0;
}
.quotation-preview .quotation-preview-standard .quotation-preview-row--tooltip {
  margin-top: calc(var(--ion-margin, 16px) / 2 * -1);
}
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-left {
  text-align: right;
}
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-right {
  text-align: left;
  padding-left: var(--ion-padding, 16px);
  animation-duration: 0.3s;
  animation-name: slideFromLeft;
  animation-timing-function: cubic-bezier(0.28, 0.84, 0.42, 1);
}
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-labels__title {
  font-size: 16px;
  font-weight: 500;
}
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-labels__unit {
  font-size: 12px;
  text-transform: uppercase;
}
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-labels--bold .quotation-preview-labels__title, .quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-labels--bold .quotation-preview-labels__unit {
  font-weight: 600;
}
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-value {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-tooltip ion-icon,
.quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-tooltip small {
  display: inline-block;
  vertical-align: middle;
}

/* preview compatta preventivo in conferma preventivo */
.quotation-preview .quotation-preview-compact {
  text-align: center;
  position: relative;
}
.quotation-preview .quotation-preview-compact .quotation-preview-edit-btn {
  position: absolute;
  right: 0;
  top: 0;
  margin: 0;
  z-index: 5;
}
.quotation-preview .quotation-preview-compact .quotation-amount {
  margin-bottom: calc(var(--ion-margin) / 2);
}
.quotation-preview .quotation-preview-compact .quotation-amount span,
.quotation-preview .quotation-preview-compact .quotation-data-title {
  font-size: var(--qin-title-font-size-4);
}
.quotation-preview .quotation-preview-compact .quotation-amount h1 {
  font-size: var(--qin-display-font-size-3);
  color: var(--ion-color-accent);
  font-weight: 600;
}
.quotation-preview .quotation-preview-compact .quotation-data .quotation-data-value {
  font-size: var(--qin-display-font-size-3);
  color: var(--ion-color-accent);
}

/* preview preventivo in calcolo preventivo */
.quotation-overview .quotation-overview-item app-amount-counter {
  font-size: var(--qin-display-font-size-1);
}
.quotation-overview .quotation-overview-item .quotation-overview-item-header {
  font-size: var(--qin-title-font-size-4);
}
.quotation-overview .quotation-overview-loader {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: var(--qin-card-background-color);
}
.quotation-overview .quotation-overview-grid ion-col:nth-child(3),
.quotation-overview .quotation-overview-grid ion-col:nth-child(5) {
  border-left: 1px solid var(--ion-item-border-color);
}
.quotation-overview .quotation-overview-grid ion-col:nth-child(2),
.quotation-overview .quotation-overview-grid ion-col:nth-child(3) {
  border-bottom: 1px solid var(--ion-item-border-color);
}
.quotation-overview .quotation-overview-item-header {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 46px;
}
.quotation-overview .quotation-overview-item-header ion-button {
  --color: var(--ion-color-primary);
}
.quotation-overview .quotation-overview-item-header ion-icon {
  color: var(--ion-color-primary);
}

app-dashboard ion-toolbar {
  --background: var(--ion-color-tertiary);
  padding-top: 0 !important;
}
app-dashboard ion-title {
  --color: var(--qin-content-color);
}
app-dashboard .step-header-container {
  background-color: var(--ion-color-tertiary);
}
app-dashboard .step-header-container .step-header-btn ion-icon {
  color: var(--ion-color-light);
}
app-dashboard .dashboard-tab {
  --indicator-color: var(--qin-content-color);
  --indicator-height: 4px;
  --padding-start: 0;
  --padding-end: 0;
}
app-dashboard .dashboard-tab ion-label,
app-dashboard .dashboard-tab ion-icon {
  color: var(--ion-color-medium);
  margin: 0;
}
app-dashboard .dashboard-tab ion-label {
  margin-bottom: 18px;
}
app-dashboard .dashboard-tab.segment-button-checked ion-label,
app-dashboard .dashboard-tab.segment-button-checked ion-icon {
  color: var(--qin-content-color);
}
app-dashboard app-tab-dashboard h4 {
  text-align: center;
}

app-tfr-list .tfr-list-text-container {
  display: flex;
}
app-tfr-list .tfr-list-text-currency {
  flex-grow: 1;
  text-align: right;
}

.ng-select {
  padding: 0;
  position: relative;
}
.ng-select.ng-select-single .ng-select-container .ng-arrow-wrapper {
  align-self: center;
  bottom: 0;
}
.ng-select.ng-select-focused .ng-placeholder {
  display: none !important;
}
.ng-select .ng-select-container {
  font-size: var(--qin-input-font-size);
  padding: 0 var(--ion-padding) 0 var(--ion-padding);
}
.ng-select .ng-select-container:hover {
  background-color: var(--qin-text-background-color);
}
.ng-select .ng-select-container:after {
  border: 0;
}
.ng-select .ng-select-container .ng-value-container {
  padding: 0;
  border: 0;
  margin-top: auto;
  margin-bottom: auto;
  color: var(--ion-text-color);
  font-weight: bold;
}
.ng-select .ng-input,
.ng-select .ng-placeholder {
  top: 50%;
  transform: translateY(-50%);
  padding: 0;
}
.ng-select .ng-input input {
  padding: 0 0 0 var(--ion-padding) !important;
  height: 100%;
}
.ng-select .ng-placeholder {
  font-weight: normal;
}
.ng-select .ng-has-value .ng-placeholder {
  display: none !important;
}
.ng-select .ng-arrow-wrapper {
  width: 16px;
  height: 8px;
  background-image: url('chevron-down.svg');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  align-self: center;
  bottom: 0;
}
.ng-select .ng-arrow-wrapper .ng-arrow {
  color: transparent !important;
}
.ng-select .ng-dropdown-panel {
  margin-top: var(--ion-margin);
  transform-origin: top left;
  animation-duration: 0.3s;
  animation-name: grow;
}
.ng-select .ng-dropdown-panel.ng-select-bottom {
  top: unset;
  box-shadow: none;
}
.ng-select .ng-dropdown-panel-items {
  background-color: var(--ion-background-color);
  box-shadow: none;
  margin: 0 auto;
}
.ng-select .ng-dropdown-panel-items .ng-option.ng-option-marked {
  background-color: transparent;
}
.ng-select .ng-dropdown-panel-items .ng-option.ng-option-selected {
  background: transparent;
  color: var(--ion-text-color);
}
.ng-select .ng-dropdown-panel-items .ng-option.ng-option-marked:hover {
  background-color: var(--qin-text-background-color);
}

ion-popover [popover]:not(:popover-open):not(dialog[open]) {
  display: contents;
}

ion-spinner.ion-spinner-sm {
  height: 16px;
  width: 16px;
}

.spinner--medium ion-spinner {
  height: 46px;
  width: 46px;
}
.spinner--large ion-spinner {
  height: 56px;
  width: 56px;
}

.step-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 -4px;
}
.step-bar .step {
  padding: 0 4px;
  animation: slideToEnd 0.3s;
}
.step-bar .step .step-content {
  height: 6px;
  border-radius: 2px;
  overflow: hidden;
  position: relative;
  background: rgba(255, 255, 255, 0.25);
}
.step-bar .step .step-filler {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 0%;
  background: #fff;
  transition: width 0.3s;
}
.step-bar .step .step-filler.active {
  width: 100%;
}

@keyframes slideToEnd {
  from {
    opacity: 0;
    transform: translateX(-50%);
  }
  to {
    opacity: 1;
    transform: translateX(0%);
  }
}
.step-header {
  position: relative;
}
.step-header .logo {
  display: block;
  margin-left: auto;
  margin-right: auto;
  outline: none;
  width: auto;
  height: auto;
}
.step-header ion-button.step-header-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  --padding-start: var(--ion-margin);
  --padding-end: var(--ion-margin);
}
.step-header ion-button.step-header-btn--left {
  left: calc(var(--ion-margin) * -1);
}
.step-header ion-button.step-header-btn--right {
  right: calc(var(--ion-margin) * -1);
}
.step-header .step-header-title {
  text-transform: uppercase;
  font-weight: 600;
}

ion-toast.complete-error-toast::part(container) {
  align-items: flex-start;
}

ion-toast.complete-error-toast::part(header) {
  font-weight: bold;
}

ion-toast.complete-error-toast::part(message) {
  font-size: 12px;
  opacity: 0.85;
  border-top: 1px solid rgba(var(--ion-color-light-rgb), 0.7);
  padding-top: 4px;
  margin-top: 4px;
}

body {
  font-size: var(--qin-body-font-size);
}

p {
  line-height: var(--qin-text-line-height);
}

/* titoli super large */
.display-1 {
  font-size: var(--qin-display-font-size-1) !important;
}

.display-2 {
  font-size: var(--qin-display-font-size-2) !important;
}

.display-3 {
  font-size: var(--qin-display-font-size-3) !important;
}

/* titoli */
.title-1 {
  font-size: var(--qin-title-font-size-1) !important;
}

.title-2 {
  font-size: var(--qin-title-font-size-2) !important;
}

.title-3 {
  font-size: var(--qin-title-font-size-3) !important;
}

.title-4 {
  font-size: var(--qin-title-font-size-4) !important;
}

.title-5 {
  font-size: var(--qin-title-font-size-5) !important;
}

.text-small {
  font-size: var(--qin-small-font-size) !important;
}

.ion-bold-text {
  font-weight: bold !important;
}

.nice-amount {
  font-size: 32px !important;
  font-weight: 600 !important;
  color: var(--ion-color-primary);
}
.nice-amount .decimal {
  font-size: 22px !important;
}
.nice-amount--relevant {
  font-size: 40px !important;
  color: var(--ion-color-accent);
}

.upload-hint {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
}
.upload-hint .upload-hint-item {
  flex: 1 1 0px;
  opacity: 0.5;
}
.upload-hint .upload-hint-item ion-img {
  height: 100px;
  margin: 0 auto;
}
.upload-hint .upload-hint-item--current {
  opacity: 1;
}
.upload-hint .upload-hint-item--current ion-img {
  animation: flipY 0.6s;
}
.upload-hint .upload-hint-num {
  display: inline-block;
  height: 24px;
  width: 24px;
  border-radius: 12px;
  line-height: 22px;
  font-size: 12px;
  border: 1px solid var(--ion-color-light);
}

.upload-list-item .upload-list-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: calc(var(--ion-margin, 16px) / 2);
}

.upload-preview .upload-preview-content {
  padding-top: 100%;
  position: relative;
  background: var(--ion-color-dark);
  color: var(--ion-color-dark-contrast);
}
.upload-preview .upload-preview-content ion-img,
.upload-preview .upload-preview-content pdf-viewer {
  border: 1px solid var(--ion-item-border-color);
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.upload-preview .upload-preview-content .upload-preview-placeholder,
.upload-preview .upload-preview-content .upload-preview-loader {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.upload-preview .upload-preview-content .upload-preview-loader {
  background: rgba(var(--ion-color-primary-rgb), 0.5);
  z-index: 10;
  overflow: hidden;
}
.upload-preview .upload-preview-content .upload-preview-placeholder {
  color: var(--ion-color-dark-contrast);
  z-index: 5;
}
.upload-preview .upload-preview-content .upload-preview-placeholder ion-icon {
  opacity: 0.3;
}
.upload-preview .upload-preview-footer p {
  line-height: var(--qin-button-small-height);
}

.wizard-widget .step .step-row {
  display: flex;
  align-items: center;
}
.wizard-widget .step .step-left {
  width: var(--qin-wizard-widget-square-lg, 36px);
}
.wizard-widget .step .step-square {
  margin: 0 auto;
  width: var(--qin-wizard-widget-square-lg, 36px);
  height: var(--qin-wizard-widget-square-lg, 36px);
  border: 4px solid var(--ion-color-primary);
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.65;
}
.wizard-widget .step .step-square .numeration {
  color: var(--ion-color-primary-contrast);
}
.wizard-widget .step .step-square ion-icon {
  display: none;
  font-size: var(--qin-wizard-widget-square-md, 22px);
  color: var(--ion-color-primary-contrast);
  flex-shrink: 0;
}
.wizard-widget .step .step-square .step-square-inner {
  display: none;
  width: var(--qin-wizard-widget-square-md, 22px);
  height: var(--qin-wizard-widget-square-md, 22px);
  border: 4px solid var(--ion-color-primary);
  border-radius: 5px;
  flex-shrink: 0;
}
.wizard-widget .step .step-line {
  height: var(--qin-wizard-widget-line-md, 36px);
  width: 0px;
  border-left: 2px dashed var(--ion-color-primary);
  margin: 0 auto;
}
.wizard-widget .step .step-title {
  margin-left: var(--ion-margin);
  color: var(--ion-color-medium);
}
.wizard-widget .step.step--small .step-square {
  width: var(--qin-wizard-widget-square-sm, 16px);
  height: var(--qin-wizard-widget-square-sm, 16px);
}
.wizard-widget .step.step--small .step-square ion-icon {
  display: none;
}
.wizard-widget .step.step--small .step-line {
  height: var(--qin-wizard-widget-line-sm, 26px);
}
.wizard-widget .step.step--small .step-title {
  margin-left: var(--ion-margin);
}
.wizard-widget .step.step--completed .step-square {
  background-color: var(--ion-color-primary);
  opacity: 1;
}
.wizard-widget .step.step--completed .step-line {
  border-left: 3px solid var(--ion-color-primary);
}
.wizard-widget .step.step--completed .step-title {
  color: var(--ion-text-color);
}
.wizard-widget .step.step--completed:not(.step--small) .step-square {
  width: var(--qin-wizard-widget-square-md, 22px);
  height: var(--qin-wizard-widget-square-md, 22px);
}
.wizard-widget .step.step--completed:not(.step--small) .step-square ion-icon {
  display: block;
}
.wizard-widget .step.step--active .step-square {
  opacity: 1;
}
.wizard-widget .step.step--active .step-title {
  font-weight: 600;
  color: var(--ion-text-color);
}
.wizard-widget .step.step--active:not(.step--small) .step-square {
  border: 4px solid var(--qin-highlight-color);
}
.wizard-widget .step.step--active:not(.step--small) .step-square .step-square-inner {
  display: block;
}

:root,
body {
  --ion-font-family: "Montserrat", sans-serif;
  --ion-color-primary: #2b5a92;
  --ion-color-primary-rgb: 43, 90, 146;
  --ion-color-primary-contrast: #ffffff;
  --ion-color-primary-contrast-rgb: 255, 255, 255;
  --ion-color-primary-shade: #264f80;
  --ion-color-primary-tint: #406b9d;
  --ion-color-secondary: #f6f7f9;
  --ion-color-secondary-rgb: 246, 247, 249;
  --ion-color-secondary-contrast: #000000;
  --ion-color-secondary-contrast-rgb: 0, 0, 0;
  --ion-color-secondary-shade: #d8d9db;
  --ion-color-secondary-tint: #f7f8fa;
  --ion-color-medium: #c1c6ce;
  --ion-color-medium-rgb: 193, 198, 206;
  --ion-color-medium-contrast: #000000;
  --ion-color-medium-contrast-rgb: 0, 0, 0;
  --ion-color-medium-shade: #aaaeb5;
  --ion-color-medium-tint: #c7ccd3;
  --ion-color-accent: #cf3078;
  --ion-color-accent-rgb: 207, 48, 120;
  --ion-color-accent-contrast: #ffffff;
  --ion-color-accent-contrast-rgb: 255, 255, 255;
  --ion-color-accent-shade: #b62a6a;
  --ion-color-accent-tint: #d44586;
  --ion-color-success: #61810e;
  --ion-color-success-rgb: 97, 129, 14;
  --ion-color-success-contrast: #000000;
  --ion-color-success-contrast-rgb: 0, 0, 0;
  --ion-color-success-shade: #55720c;
  --ion-color-success-tint: #718e26;
  --ion-color-danger: #ed0000;
  --ion-color-danger-rgb: 237, 0, 0;
  --ion-color-danger-contrast: #000000;
  --ion-color-danger-contrast-rgb: 0, 0, 0;
  --ion-color-danger-shade: #d10000;
  --ion-color-danger-tint: #ef1a1a;
  --ion-color-warning: #cc4700;
  --ion-color-warning-rgb: 204, 71, 0;
  --ion-color-warning-contrast: #ffffff;
  --ion-color-warning-contrast-rgb: 255, 255, 255;
  --ion-color-warning-shade: #b43e00;
  --ion-color-warning-tint: #d1591a;
  --ion-color-success-light: #95c11f;
  --ion-color-success-light-rgb: 149, 193, 31;
  --ion-color-success-light-contrast: #000000;
  --ion-color-success-light-contrast-rgb: 0, 0, 0;
  --ion-color-success-light-shade: #83aa1b;
  --ion-color-success-light-tint: #a0c735;
  --ion-color-light: #fff;
  --ion-color-light-rgb: 255, 255, 255;
  --ion-color-light-contrast: #000000;
  --ion-color-light-contrast-rgb: 0, 0, 0;
  --ion-color-light-shade: #e0e0e0;
  --ion-color-light-tint: #ffffff;
  --qin-input-placeholder-color: var(--ion-color-medium);
  --qin-input-filled-color: var(--ion-text-color);
  --qin-input-disabled-background: var(--ion-color-secondary);
  --qin-input-disabled-background-dark: #c1c6ce;
  --qin-input-disabled-color: #6e6f72;
  --qin-input-hover-background: var(--ion-color-secondary);
  --qin-input-active-background: #e3e8ef;
  --qin-button-font-size: 16px;
  --qin-card-border-radius: 10px;
  --ion-text-color: #063267;
  --ion-background-color: #fff;
  --qin-footer-bg: var(--ion-color-secondary);
  --qin-btn-solid-hover-background: #952356;
  --qin-btn-solid-active-background: #bb3170;
  --qin-btn-clear-hover-color: #1a6c93;
  --qin-btn-clear-active-color: #10445c;
  --qin-content-bg: var(--ion-color-primary);
  --qin-input-font-size: 16px;
  --qin-label-font-size: 14px;
  --qin-display-font-size-1: 56px;
  --qin-display-font-size-2: 30px;
  --qin-display-font-size-3: 26px;
  --qin-body-font-size: 16px;
  --ion-margin: 30px;
  --ion-padding: 22px;
  --qin-text-letter-spacing: 0.5px;
}

.dynamic-input .input-alert-message ion-item {
  --background: transparent !important;
  --padding-start: 0;
  --padding-top: 0;
  --padding-bottom: 0;
  border-color: transparent !important;
  margin-top: 10px;
}
.dynamic-input .input-alert-message ion-item small {
  font-size: var(--qin-small-font-size);
  color: var(--ion-color-danger);
}

.app-info p {
  font-size: var(--qin-label-font-size);
  margin: 0;
  font-weight: bold;
  text-transform: uppercase;
}

ion-button {
  --box-shadow: 0;
  --background: var(--ion-color-accent);
  --background-hover-opacity: 0;
  --color: var(--ion-color-light);
  --background-focused-opacity: 0;
  --ripple-color: transparent;
}
ion-button.ion-focused {
  outline: 1px solid var(--ion-color-success);
  outline-offset: 2px;
}
ion-button:hover::part(native) {
  background-color: var(--qin-btn-solid-hover-background);
}
ion-button:active::part(native) {
  background-color: var(--qin-btn-solid-active-background);
}

ion-button[fill=clear] {
  --padding-start: 20px;
  --padding-top: 20px;
  --padding-bottom: 20px;
  --padding-end: 20px;
  --background-hover-opacity: 0;
  --background: transparent;
  --color: var(--ion-color-primary);
  --ripple-color: transparent;
  text-decoration: underline;
  font-weight: bold;
}
ion-button[fill=clear]:hover::part(native) {
  background-color: transparent;
  color: var(--qin-btn-clear-hover-color);
}
ion-button[fill=clear]:active::part(native) {
  background-color: transparent;
  color: var(--qin-btn-clear-active-color);
}

ion-button[fill=outline] {
  --color: var(--ion-color-accent);
  --background: transparent;
  --border-color: var(--ion-color-accent);
}
ion-button[fill=outline]:hover::part(native) {
  background-color: transparent;
}
ion-button[fill=outline]:active::part(native) {
  background-color: transparent;
}

ion-button[expand=block] {
  max-width: 400px;
  margin-left: auto;
  margin-right: auto;
}

ion-card {
  --color: var(--ion-text-color);
  box-shadow: none;
  margin: 20px 0 0 0 !important;
  border-radius: 0px 40px 0px 0px;
}
@media only screen and (min-width: 768px) {
  ion-card {
    border-radius: 10px 40px 10px 10px;
  }
}
ion-card ion-card-header {
  padding: var(--ion-margin) var(--ion-padding) 0 var(--ion-padding);
}
ion-card ion-card-content {
  padding: var(--ion-margin) var(--ion-padding) var(--ion-padding) var(--ion-padding) !important;
}
ion-card ion-card-title,
ion-card ion-card-subtitle {
  --color: var(--ion-text-color);
  font-size: var(--qin-title-font-size-3);
  font-weight: 500;
  text-align: left;
}
@media only screen and (min-width: 768px) {
  ion-card ion-card-title,
  ion-card ion-card-subtitle {
    text-align: center;
  }
}

app-documents-request ion-card-subtitle,
app-page-picker ion-card-subtitle {
  display: none;
}

ion-card.dashboard-card .dashboard-title {
  text-align: center;
  color: var(--ion-color-primary);
  font-weight: bold;
  font-size: var(--qin-title-font-size-1);
  text-transform: uppercase;
}
ion-card.dashboard-card ion-card-content > div {
  margin: 0 !important;
}
ion-card.dashboard-card ion-card-header {
  background: transparent;
  padding: 30px var(--ion-padding) 20px var(--ion-padding);
  margin: 0;
}
ion-card.dashboard-card ion-card-title {
  text-align: center;
  color: var(--ion-color-primary);
  font-weight: bold;
  font-size: var(--qin-title-font-size-1);
  text-transform: uppercase;
}

ion-card.hint {
  margin: 0 !important;
  text-align: center;
  --background: var(--qin-content-color);
}
ion-card.hint .hint-content {
  margin: 0 !important;
}
ion-card.hint .hint-content-message {
  margin: 0;
  font-size: var(--qin-body-font-size);
}
ion-card.hint .hint-content-icon {
  color: var(--ion-color-primary);
  font-size: 13px;
}

ion-card.result-item-card {
  border-bottom-right-radius: 40px;
}
ion-card.result-item-card ion-card-content {
  padding: var(--ion-padding) !important;
}
ion-card.result-item-card .result-item-card-info ion-item {
  --padding-start: 0;
}
ion-card.result-item-card .result-item-card-info ion-item:not(:last-child) {
  margin-bottom: var(--ion-margin);
}
ion-card.result-item-card .result-item-card-info-text {
  margin: 0;
}
ion-card.result-item-card .result-item-card-info-text-title {
  margin-bottom: 12px;
  font-weight: bold;
  color: var(--ion-text-color);
}
ion-card.result-item-card .result-item-card-info-text-message {
  font-size: var(--qin-body-font-size);
}
ion-card.result-item-card .result-item-card-btn {
  height: 46px;
  width: 46px;
  --border-radius: 50%;
}

app-valutation-methods-list ion-card ion-card-subtitle,
app-valutation-methods-list ion-card .hint {
  display: none;
}

app-atc-search .atc-vat-number {
  margin: 0 0 var(--ion-margin) 0;
}
app-atc-search .atc-toggle {
  margin: 0 0 var(--ion-padding) 0;
}
app-atc-search .atc-toggle-enable,
app-atc-search .atc-toggle-disable {
  font-size: var(--qin-input-font-size);
}
app-atc-search ion-card.hint .hint-content-message {
  margin: 8px 0 40px 0;
}

app-method-select .hint,
app-page-picker .hint {
  margin-top: 50px !important;
}

ion-card.quotation-view-card ion-card-header,
app-obligations app-quotation-view > ion-card ion-card-header {
  display: none;
}
ion-card.quotation-view-card ion-card-content,
app-obligations app-quotation-view > ion-card ion-card-content {
  background: var(--ion-color-secondary);
  border-radius: 10px;
  margin: var(--ion-margin) var(--ion-padding);
  padding: 24px !important;
}

app-summary .container > ion-card {
  margin: 0;
}

app-register .hint {
  --background: transparent;
}
app-register .hint .hint-content-icon,
app-register .hint .hint-content-message {
  color: var(--ion-color-light);
}

app-recognition app-method-select > div {
  background: var(--ion-color-light);
  margin: 0 !important;
  padding-bottom: var(--ion-padding);
}
@media only screen and (min-width: 768px) {
  app-recognition app-method-select > div {
    border-radius: 0 0 10px 10px;
  }
}
app-recognition app-method-select ion-card {
  border-radius: 10px 40px 0 0;
}
app-recognition small {
  font-size: var(--qin-small-font-size);
}

app-waiting ion-card {
  margin: 0 !important;
  height: 100%;
}
app-waiting ion-card-title {
  text-align: center;
}
app-waiting ion-card .progress-circle-container {
  text-align: center;
  margin-bottom: var(--ion-margin);
}
app-waiting p {
  text-align: center;
  margin-top: var(--ion-margin);
}

app-summary app-wizard-widget ion-card {
  --background: transparent;
  padding: 0 !important;
}
app-summary app-wizard-widget ion-card ion-card-content {
  padding: 0 !important;
}

app-uses-report ion-card-content {
  margin: 0 !important;
}

app-instalment ion-card.hint p,
app-duration ion-card.hint p,
app-total-amount ion-card.hint p {
  margin: var(--ion-margin) 0 0 0 !important;
}
@media (min-width: 768px) {
  app-instalment ion-card.hint,
  app-duration ion-card.hint,
  app-total-amount ion-card.hint {
    --background: transparent;
  }
  app-instalment ion-card.hint p,
  app-duration ion-card.hint p,
  app-total-amount ion-card.hint p {
    color: var(--ion-color-light);
  }
  app-instalment ion-card.hint ion-icon,
  app-duration ion-card.hint ion-icon,
  app-total-amount ion-card.hint ion-icon {
    display: none;
  }
}

@media (max-width: 768px) {
  .logon ion-card {
    margin: 0 !important;
    border-radius: 0;
  }
}

ion-content.full-bg-transparent::part(background)::before {
  background: var(--ion-color-primary);
}
@media (max-width: 768px) {
  ion-content.full-bg-transparent::part(background)::before {
    background: white;
  }
}

@media (max-width: 768px) {
  ion-content.with-footer {
    --padding-bottom: var(--qin-footer-height);
  }
}

ion-content::part(background)::before {
  height: 100%;
  background: var(--ion-color-primary);
}
@media (max-width: 768px) {
  ion-content::part(background)::before {
    background: white;
  }
  ion-content .container {
    background: var(--ion-color-primary);
  }
}

app-atc-choice ion-content.atc-choice-results {
  --padding-bottom: 0;
}
app-atc-choice ion-content.atc-choice-results::part(background)::before {
  background: var(--ion-color-primary);
}

app-finish ion-content {
  --padding-bottom: 0;
}
app-finish ion-content::part(background)::before {
  background: var(--ion-color-primary);
}
app-finish ion-content .fullscreen-header {
  display: none;
}

.feedback {
  display: flex;
  flex-direction: column;
  justify-content: flex-start !important;
  padding: 87px var(--ion-padding) 0 var(--ion-padding);
}
.feedback .feedback-title,
.feedback .feedback-message {
  margin: 0 !important;
  font-size: var(--qin-title-font-size-3);
  font-weight: normal;
}
.feedback .feedback-icon,
.feedback ion-spinner {
  font-size: 80px;
  margin: 80px auto 0 auto;
  order: 3;
}

app-welcome .container > div {
  margin: 0;
}

.register::part(background)::before {
  background: var(--ion-color-primary);
}

app-waiting .feedback {
  padding: 87px 0 0 0;
}

app-summary .container {
  min-height: 100%;
}

app-modal-otp .container {
  background: var(--ion-color-primary);
}
app-modal-otp ion-content::part(background)::before {
  background: var(--ion-color-light);
}

app-modal-add-fund .add-fund-results {
  --padding-bottom: 0;
}
app-modal-add-fund .add-fund-results::part(background)::before {
  background: var(--ion-color-primary);
}

.footer {
  box-shadow: none;
  background: var(--qin-footer-bg);
}
.footer ion-button.ion-focused {
  outline-color: var(--ion-color-success) !important;
}
.footer ion-button.footer-primary-action {
  --ripple-color: transparent;
  animation: none;
  font-size: 18px;
}
.footer ion-button.footer-secondary-action {
  --border-width: 0;
  --ripple-color: transparent;
  --background-hover: transparent;
  --background-focused: transparent;
  --background-activated: transparent;
  text-decoration: underline;
}
.footer .footer-tip {
  display: none;
}

form ion-col {
  padding: 0;
}

/* input, select e datetime */
.dynamic-input ion-item {
  --min-height: 0;
  --padding-end: 12px;
  --padding-start: 0;
  --highlight-color-invalid: transparent;
  --highlight-color-valid: transparent;
  --highlight-color-focused: transparent;
  --color-focused: transparent;
  --ripple-color: transparent;
  --border-style: none;
}
.dynamic-input ion-item ion-input input {
  padding: 15px 0 15px 12px !important;
}
.dynamic-input ion-item ion-datetime {
  padding: 0;
}
.dynamic-input ion-item ion-select::part(icon) {
  color: var(--ion-color-success);
  transform: rotate(0);
}
.dynamic-input ion-item ion-icon {
  color: var(--ion-color-success);
}

.dynamic-input app-input-calendar ion-item,
.dynamic-input .field-COMBO_BOX ion-item, .dynamic-input.survey-question--select ion-item {
  --padding-start: 12px;
  --padding-top: 15px;
  --padding-bottom: 15px;
}

/* contenitore campi */
.dynamic-input {
  margin-bottom: var(--ion-margin);
  /* generale */
}
.dynamic-input ion-item {
  border-bottom: 1px solid var(--ion-color-accent);
}
.dynamic-input.input-focused ion-item {
  outline: 1px solid transparent;
  outline-offset: 3px;
}
.dynamic-input.form-field--DOCUMENT ion-item, .dynamic-input.survey-question--document ion-item, .dynamic-input.survey-question--radio-button ion-item, .dynamic-input.form-field--RADIO_BOX ion-item {
  border: none;
}
.dynamic-input.input-focused.survey-question--radio-button ion-item, .dynamic-input.input-focused.form-field--RADIO_BOX ion-item, .dynamic-input.input-focused.form-field--DOCUMENT ion-item, .dynamic-input.input-focused.survey-question--document ion-item {
  outline: none;
}
.dynamic-input ion-item {
  --inner-padding-end: 0;
}
.dynamic-input ion-list {
  padding: 0;
}
.dynamic-input.form-field--TEXT_AREA ion-item, .dynamic-input.survey-question--text ion-item {
  --background: var(--qin-input-hover-background);
}
.dynamic-input.form-field--TEXT_AREA ion-textarea textarea, .dynamic-input.survey-question--text ion-textarea textarea {
  padding: 0 !important;
}
.dynamic-input .field-title {
  font-weight: bold;
  margin: 0 0 8px 0;
  color: var(--ion-color-accent);
}
.dynamic-input.form-field--DOCUMENT_INFO ion-item, .dynamic-input.form-field--DOCUMENT ion-item, .dynamic-input.survey-question--document {
  border-width: 0;
}
.dynamic-input.form-field--DOCUMENT_INFO .dynamic-input-label, .dynamic-input.form-field--DOCUMENT .dynamic-input-label, .dynamic-input.survey-question--document .dynamic-input-label {
  display: none;
}
.dynamic-input.form-field--RADIO_BOX, .dynamic-input.survey-question--radio-button {
  margin-bottom: 35px;
}
.dynamic-input.form-field--RADIO_BOX .field-title, .dynamic-input.survey-question--radio-button .field-title {
  margin-bottom: 0;
}
.dynamic-input.form-field--PARAGRAPH p {
  font-size: var(--qin-title-font-size-3);
  font-weight: 500;
}
@media only screen and (min-width: 768px) {
  .dynamic-input:hover ion-item {
    --background: var(--qin-input-hover-background);
  }
}
.dynamic-input.input-activated ion-item {
  --background: var(--qin-input-active-background);
}
.dynamic-input.field--filled .field-title, .dynamic-input.form-field--filled .field-title, .dynamic-input.survey-question--filled .field-title {
  color: var(--ion-text-color);
}
.dynamic-input.field--filled ion-item, .dynamic-input.form-field--filled ion-item, .dynamic-input.survey-question--filled ion-item {
  border-bottom-color: var(--qin-input-filled-color);
}
.dynamic-input.form-field--RADIO_BOX .field-title, .dynamic-input.survey-question--radio-button .field-title {
  color: var(--ion-text-color);
}
.dynamic-input.field--disabled ion-item *, .dynamic-input.form-field--disabled ion-item *, .dynamic-input.survey-question--disabled ion-item * {
  opacity: 1 !important;
}
.dynamic-input.field--disabled.form-field--filled ion-item > *:first-child, .dynamic-input.form-field--disabled.form-field--filled ion-item > *:first-child, .dynamic-input.survey-question--disabled.form-field--filled ion-item > *:first-child {
  color: var(--qin-input-disabled-color);
}
.dynamic-input.field--disabled ion-item, .dynamic-input.form-field--disabled ion-item, .dynamic-input.survey-question--disabled ion-item {
  --background: var(--qin-input-disabled-background);
  opacity: 1;
  border-bottom-color: var(--qin-input-disabled-color);
}
.dynamic-input.field--disabled ion-item ion-icon, .dynamic-input.form-field--disabled ion-item ion-icon, .dynamic-input.survey-question--disabled ion-item ion-icon {
  color: var(--qin-input-placeholder-color);
}
.dynamic-input.field--disabled ion-item ion-select::part(icon), .dynamic-input.form-field--disabled ion-item ion-select::part(icon), .dynamic-input.survey-question--disabled ion-item ion-select::part(icon) {
  color: var(--qin-input-placeholder-color);
}
.dynamic-input.field--disabled .field-title, .dynamic-input.form-field--disabled .field-title, .dynamic-input.survey-question--disabled .field-title {
  color: var(--qin-input-disabled-color);
}
.dynamic-input.form-field--RADIO_BOX.form-field--disabled ion-item, .dynamic-input.survey-question--radio-button.survey-question--disabled ion-item {
  --background: transparent;
}
.dynamic-input.form-field--RADIO_BOX.form-field--disabled ion-radio::part(container), .dynamic-input.survey-question--radio-button.survey-question--disabled ion-radio::part(container) {
  background-color: var(--qin-input-disabled-background-dark);
  border-color: var(--qin-input-disabled-background-dark);
}
.dynamic-input.form-field--RADIO_BOX.form-field--disabled ion-radio::part(label), .dynamic-input.survey-question--radio-button.survey-question--disabled ion-radio::part(label) {
  opacity: 1;
  color: var(--ion-text-color);
}
.dynamic-input.form-field--RADIO_BOX.input-activated ion-item, .dynamic-input.survey-question--radio-button.input-activated ion-item {
  --background: transparent;
}
.dynamic-input.form-field--RADIO_BOX.input-activated ion-item.ion-activated ion-radio::part(container), .dynamic-input.survey-question--radio-button.input-activated ion-item.ion-activated ion-radio::part(container) {
  border-color: var(--ion-color-success);
}
.dynamic-input.form-field--RADIO_BOX.input-activated ion-item.ion-activated ion-radio::part(mark), .dynamic-input.survey-question--radio-button.input-activated ion-item.ion-activated ion-radio::part(mark) {
  background-color: var(--ion-color-success);
}
.dynamic-input.form-field--RADIO_BOX.input-activated ion-item.ion-activated ion-radio::part(label), .dynamic-input.survey-question--radio-button.input-activated ion-item.ion-activated ion-radio::part(label) {
  color: var(--ion-color-primary);
}
@media only screen and (min-width: 768px) {
  .dynamic-input.form-field--RADIO_BOX ion-item:hover ion-radio::part(container), .dynamic-input.survey-question--radio-button ion-item:hover ion-radio::part(container) {
    border-color: var(--ion-color-success-light);
  }
  .dynamic-input.form-field--RADIO_BOX ion-item:hover ion-radio::part(mark), .dynamic-input.survey-question--radio-button ion-item:hover ion-radio::part(mark) {
    background-color: var(--ion-color-success-light);
  }
  .dynamic-input.form-field--RADIO_BOX ion-item:hover ion-radio::part(label), .dynamic-input.survey-question--radio-button ion-item:hover ion-radio::part(label) {
    color: var(--ion-color-success);
  }
}
.dynamic-input.form-field--RADIO_BOX:hover ion-item, .dynamic-input.survey-question--radio-button:hover ion-item {
  --background: transparent;
}
.dynamic-input.form-field--CHECKED_EMAIL:hover ion-item {
  --background: transparent;
}

@media only screen and (min-width: 768px) {
  .module-list-checkbox:hover ion-checkbox::part(container),
  .acknowledgment ion-item:not(.item-interactive-disabled):hover ion-checkbox::part(container) {
    border-color: var(--ion-color-success-light);
  }
  .module-list-checkbox:hover ion-checkbox.checkbox-checked::part(container),
  .acknowledgment ion-item:not(.item-interactive-disabled):hover ion-checkbox.checkbox-checked::part(container) {
    background: var(--ion-color-success-light);
  }
  .module-list-checkbox:hover ion-label,
  .acknowledgment ion-item:not(.item-interactive-disabled):hover ion-label {
    color: var(--ion-color-success);
  }
}
.module-list-checkbox.ion-activated ion-label,
.acknowledgment ion-item:not(.item-interactive-disabled).ion-activated ion-label {
  color: var(--ion-color-primary);
}
.module-list-checkbox.ion-activated ion-checkbox::part(container),
.acknowledgment ion-item:not(.item-interactive-disabled).ion-activated ion-checkbox::part(container) {
  border-color: var(--ion-color-success);
}
.module-list-checkbox.ion-activated ion-checkbox.checkbox-checked::part(container),
.acknowledgment ion-item:not(.item-interactive-disabled).ion-activated ion-checkbox.checkbox-checked::part(container) {
  background-color: var(--ion-color-success);
}

.module-list-checkbox.ion-focused,
.acknowledgment ion-item.ion-focused {
  --background-focused-opacity: 0;
  outline: 1px solid transparent !important;
  outline-offset: 3px;
}
.module-list-checkbox.ion-focused ion-checkbox::part(label),
.acknowledgment ion-item.ion-focused ion-checkbox::part(label) {
  color: var(--ion-text-color);
}

/* radio */
.form-field--RADIO_BOX ion-item,
.survey-question--radio-button ion-item {
  --min-height: 0;
  --highlight-color-invalid: transparent;
  --highlight-color-valid: transparent;
  --ripple-color: transparent;
  --background-hover: transparent;
  --background-focused: transparent;
  --ripple-color: transparent;
  --padding-start: 0;
  --padding-top: 0;
  --padding-bottom: 0;
  --padding-end: 0;
  margin: 20px 0 20px 5px;
}
.form-field--RADIO_BOX ion-radio::part(label),
.survey-question--radio-button ion-radio::part(label) {
  margin: 0 0 0 15px;
}
.form-field--RADIO_BOX ion-label,
.survey-question--radio-button ion-label {
  margin: 0;
}
.form-field--RADIO_BOX ion-item.ion-focused,
.survey-question--radio-button ion-item.ion-focused {
  outline: 1px solid transparent !important;
  outline-offset: 3px;
}
.form-field--RADIO_BOX ion-item.ion-focused ion-radio::part(label),
.survey-question--radio-button ion-item.ion-focused ion-radio::part(label) {
  color: var(--ion-text-color);
}

app-validation-messages ion-item {
  outline: none !important;
  border: none;
}

/* documenti */
.module-item ion-thumbnail ion-icon {
  font-size: 56px;
}

/* ricerca atc */
app-atc-search .atc-toggle .field-title {
  color: var(--ion-text-color);
}
app-atc-search ion-row {
  margin-top: 22px;
}
app-atc-search ion-col {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
app-atc-search ion-col:first-child {
  justify-content: end;
}
app-atc-search ion-col:last-child {
  justify-content: start;
}
app-atc-search ion-toggle {
  --handle-background: var(--qin-input-disabled-color);
  padding: 8px;
}
app-atc-search ion-toggle:not(.toggle-checked)::part(track) {
  border: 1px solid var(--qin-input-disabled-color);
}
app-atc-search ion-toggle::part(track) {
  height: 22px;
  width: 47px;
}

/* selection choice */
app-selection-choice ion-grid,
app-selection-choice ion-row,
app-selection-choice ion-col {
  padding: 0;
}
app-selection-choice p {
  text-transform: uppercase;
  font-weight: bold !important;
  color: var(--ion-color-primary);
  font-size: var(--qin-label-font-size) !important;
}
app-selection-choice ion-item.selection-choice {
  --inner-padding-end: 0;
  --padding-start: 10px;
  --padding-end: 10px;
  --padding-top: 12px;
  --padding-bottom: 12px;
  height: 100%;
}
app-selection-choice ion-item.selection-choice p {
  margin-top: 10px;
}
app-selection-choice ion-item.selection-choice::part(native) {
  height: 100%;
}
app-selection-choice ion-item.selection-choice ion-icon {
  font-size: 92px;
}

app-input-otp ion-chip {
  background: transparent;
  margin: 0;
  text-transform: uppercase;
  font-size: var(--qin-body-font-size);
}
app-input-otp ion-chip ion-icon {
  display: none;
}

.calendar-popover ion-button {
  text-decoration: none;
}
.calendar-popover ion-content::part(scroll) {
  padding: 0;
}

.register .dynamic-input ion-item {
  border-bottom-color: var(--ion-color-light);
}
.register .dynamic-input ion-item.login-checkbox {
  border-bottom-color: transparent;
}
.register .dynamic-input.input-focused ion-item {
  outline-color: transparent;
}
.register .dynamic-input.input-activated ion-item {
  --background: transparent;
}
.register .dynamic-input .field-title {
  color: var(--ion-color-light);
}
.register .dynamic-input ion-input {
  --color: var(--ion-color-light);
  --placeholder-color: var(--ion-color-light) !important;
}
@media only screen and (min-width: 768px) {
  .register .dynamic-input:hover ion-item {
    --background: transparent;
  }
}
.register form ion-item {
  --background: transparent;
}
.register form ion-item ion-input input {
  caret-color: var(--ion-color-light) !important;
}
.register .login-checkbox {
  --background-hover: transparent;
  --ripple-color: transparent;
  --background-focused: transparent;
  --background-activated: transparent;
  margin: 13px 0 60px 0;
}
.register .login-checkbox::part(native) {
  min-height: auto;
}
.register .login-checkbox ion-checkbox {
  color: var(--ion-color-light);
  --checkbox-background-checked: var(--ion-color-light);
  --border-color-checked: var(--ion-color-light);
  --border-color: var(--ion-color-light);
  --checkmark-color: var(--ion-color-primary);
}
.register .login-checkbox ion-checkbox::part(container) {
  height: 26px;
  width: 26px;
}
.register .login-checkbox ion-checkbox::part(label) {
  font-size: var(--qin-small-font-size);
  margin-left: 12px;
}

#survey-ADEGUATAVERIFICA ion-card-subtitle {
  display: none;
}

#survey-FORBORNE ion-card-subtitle {
  display: none;
}

app-customer-info .customer-info-privacy::part(native) {
  padding: 10px;
}

.input-range {
  padding: 0 var(--ion-padding) 0 var(--ion-padding);
}
.input-range ion-range {
  --knob-size: 40px;
}
.input-range ion-range::part(knob) {
  transform: scale(1);
}
.input-range .extremes span {
  font-size: var(--qin-label-font-size);
  font-weight: 600;
}

.input-number-step .input-number-step-btn:hover::part(native) {
  background-color: var(--ion-color-light);
}
.input-number-step .input-number-step-btn:active::part(native) {
  background-color: var(--ion-color-light);
}

ion-action-sheet .action-sheet-wrapper {
  max-width: var(--qin-content-max-width) !important;
}

.info-detail {
  text-align: center;
  height: 100%;
  padding: 10px;
  background: var(--ion-color-secondary);
  border-radius: var(--qin-card-border-radius);
  margin: 0 6px;
}
.info-detail > span {
  color: var(--ion-color-accent);
  font-size: var(--qin-label-font-size);
  text-transform: uppercase;
  font-weight: bold;
  margin-bottom: 6px;
}
.info-detail h2 span {
  font-weight: bold;
  font-size: var(--qin-title-font-size-1);
  margin-bottom: 4px;
}
.info-detail small {
  color: var(--ion-color-primary);
  font-size: var(--qin-small-font-size);
}

.infrastructure-content .infrastructure-content-title {
  margin: 18px 0 20px 0;
  font-size: var(--qin-title-font-size-3);
  font-weight: 500;
}
.infrastructure-content .infrastructure-content-message {
  margin: 0 0 26px 0;
  font-size: var(--qin-title-font-size-3);
  font-weight: 500;
}
.infrastructure-content .update-required-img {
  width: 230px;
  height: 242px;
}
.infrastructure-content .maintenance-img {
  width: 330px;
  height: 450px;
}
.infrastructure-content ion-button {
  margin-bottom: 74px;
  font-size: 14px;
  height: 50px;
}
.infrastructure-content ion-button::part(native) {
  color: var(--ion-color-primary);
}
.infrastructure-content ion-spinner {
  color: var(--ion-color-light);
}

app-detail-row ion-item {
  --inner-padding-bottom: 0;
  --inner-padding-top: 0;
  --min-height: 0;
  --background: transparent;
  margin: 0 0 10px 0;
}
app-detail-row ion-item.detail-row-highlight h2 {
  color: var(--ion-color-accent);
}
app-detail-row ion-label {
  text-transform: uppercase;
  color: var(--ion-text-color) !important;
  font-size: var(--qin-label-font-size) !important;
  margin: 0;
}
app-detail-row ion-text h2 {
  font-size: var(--qin-title-font-size-3) !important;
}
app-detail-row ion-text h2.ion-bold-text {
  font-weight: 500 !important;
}

.uses-report-details {
  padding: 12px;
  background-color: var(--ion-color-secondary);
  margin-bottom: 20px;
  border-radius: 10px;
}
.uses-report-details h2 {
  text-transform: uppercase;
  margin-bottom: 7px;
  font-weight: normal !important;
}

@media (min-width: 768px) {
  ion-modal {
    --border-radius: var(--qin-card-border-radius);
  }
}
ion-modal .step-header-container {
  padding: 0 var(--ion-padding) 0 var(--ion-padding);
}

.modal-upload .upload-list-item .upload-list-item-header {
  margin-bottom: 10px;
}
.modal-upload .upload-page-which_page > div {
  padding: 0 var(--ion-padding);
}
.modal-upload .upload-page-which_page .upload-page-subtitle {
  display: none;
}
.modal-upload .upload-page-title {
  font-size: var(--qin-title-font-size-3) !important;
  margin: 87px 0 80px 0;
}
.modal-upload .upload-hint {
  padding: 0;
}
.modal-upload .upload-hint-icon {
  margin: 0 0 var(--ion-margin) 0;
}
.modal-upload .upload-preview-btn {
  margin: 10px 0 0 0;
}
.modal-upload .upload-preview-btn::part(native) {
  padding: 0;
}
.modal-upload app-pages-check ion-card-header {
  display: none;
}

.upload-view-picker .upload-page-which_page,
.upload-view-picker .container,
.upload-view-picker .container > div,
.upload-view-picker .layout-content,
.upload-view-picker ion-card,
.upload-view-picker .upload-page-acquisition,
.upload-view-picker .upload-page-mode,
.upload-view-success .layout-content,
.upload-view-success .container {
  height: 100%;
}

.upload-page-which_page {
  overflow: hidden;
}

app-modal-preface-steps .preface-slides {
  background: var(--ion-color-primary);
}
app-modal-preface-steps .modal-slide {
  padding: 0 var(--ion-padding);
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
}
app-modal-preface-steps .modal-slide ion-icon {
  margin: 80px 0 0 0;
  font-size: 80px;
}
app-modal-preface-steps .modal-slide p {
  margin: 87px 0 0 0;
  font-size: var(--qin-title-font-size-3);
}

app-modal-upload .feedback ion-icon {
  order: 0;
}

.search-modal ion-header {
  box-shadow: none !important;
}
.search-modal ion-content::part(scroll) {
  background: var(--ion-color-light);
}
.search-modal ion-searchbar {
  padding: 0 var(--ion-padding) !important;
}
.search-modal .searchbar-input-container {
  border: 1px solid var(--ion-color-medium);
  border-radius: var(--qin-card-border-radius);
}
.search-modal ion-searchbar input {
  box-shadow: none !important;
  border-radius: var(--qin-card-border-radius) !important;
}
.search-modal ion-item {
  --padding-start: var(--ion-padding);
  --padding-end: var(--ion-padding);
  --border-color: var(--ion-color-medium);
  --color: var(--ion-text-color);
  --ripple-color: transparent;
  --background-hover: transparent;
}
.search-modal ion-buttons {
  margin: 3px;
}
.search-modal ion-button {
  text-decoration: unset;
}

.checklist > div {
  margin: 0;
}

.modal-state {
  --border-radius: 0;
  --height: 100%;
  --min-height: 100%;
  --width: 100%;
  --min-width: 100%;
}
.modal-state ion-header {
  background-color: var(--ion-color-primary);
  padding: 0;
}
.modal-state ion-buttons {
  margin: 0;
}
.modal-state ion-toolbar {
  --background: var(--ion-color-primary);
  --min-height: 0;
  max-width: var(--qin-content-max-width);
  padding: 0 0 20px 0;
  margin: var(--ion-padding) auto 0 auto;
}
@media (max-width: 768px) {
  .modal-state ion-toolbar {
    padding: 0 var(--ion-padding) 20px var(--ion-padding);
  }
}
.modal-state .btn-close {
  min-height: 0;
  height: auto !important;
  width: auto !important;
}
.modal-state .btn-close::part(native) {
  min-height: 0;
  height: unset;
  transform: translate(12px, -12px);
}
.modal-state ion-button.ion-focused {
  outline-color: var(--ion-color-success-light);
}
.modal-state h2 {
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 40px;
  color: var(--ion-color-light);
}
.modal-state .modal-state-content {
  padding: 0 0 var(--ion-padding) 0;
  background: var(--ion-color-primary);
  max-width: var(--qin-content-max-width);
  margin: 0 auto;
}
@media (max-width: 768px) {
  .modal-state .modal-state-content {
    padding: 0 var(--ion-padding) var(--ion-padding) var(--ion-padding);
  }
}
.modal-state .modal-state-user ion-card {
  --background: transparent;
  margin: 0 !important;
}
.modal-state .modal-state-user p {
  color: var(--ion-color-light);
  margin: 0 0 20px 0;
  font-weight: 500;
  font-size: var(--qin-title-font-size-3);
}
.modal-state .modal-state-user ion-card-content {
  padding: 0 !important;
}
.modal-state .modal-state-user ion-label {
  --color: var(--ion-color-light) !important;
  text-transform: lowercase;
  margin: 0 0 20px 0;
  font-weight: 500;
  font-size: var(--qin-title-font-size-3) !important;
}
.modal-state .modal-state-user ion-label.customer-profile-title {
  text-transform: uppercase;
}
.modal-state .modal-state-user ion-icon {
  color: var(--ion-color-light);
  margin: 0 10px 20px 0;
  height: 20px;
  width: 17px;
}
.modal-state .modal-state-user ion-button.modal-state-btn-logout {
  margin: 20px;
  margin-left: 3px;
}
.modal-state .modal-state-user ion-button.modal-state-btn-logout:hover::part(native) {
  background-color: transparent;
  color: var(--ion-color-light);
}
.modal-state .modal-state-user ion-button.modal-state-btn-logout:active::part(native) {
  background-color: transparent;
  color: var(--ion-color-light);
}
.modal-state .modal-state-user ion-item {
  --background: transparent;
}
.modal-state .modal-state-user ion-item::part(native) {
  min-height: 0;
}
.modal-state .modal-state-info ion-button {
  --background: var(--ion-color-light);
  --color: var(--ion-color-primary);
  margin-bottom: 74px;
}
.modal-state .modal-state-info ion-button:hover::part(native) {
  background-color: var(--ion-color-light);
  color: var(--ion-color-primary);
}
.modal-state .modal-state-info ion-button:active::part(native) {
  background-color: var(--ion-color-light);
  color: var(--ion-color-primary);
}
.modal-state .modal-state-wizard,
.modal-state .modal-state-help {
  display: none;
}
.modal-state .modal-state-header-logo {
  transform: translateY(-12px);
}

app-modal-quote-edit .title-1 {
  font-size: var(--qin-body-font-size) !important;
}
app-modal-quote-edit .title-2 {
  font-size: var(--qin-display-font-size-2) !important;
  font-weight: bold !important;
  color: var(--ion-color-primary);
}
app-modal-quote-edit ion-range {
  --knob-background: var(--ion-color-accent);
}
app-modal-quote-edit ion-card.hint {
  margin-top: 86px !important;
}

app-modal-otp ion-card {
  min-height: unset !important;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
app-modal-otp .step-bar-container {
  display: none;
}
app-modal-otp .otp-not-received-text {
  margin-right: 20px;
  color: var(--ion-text-color);
}
app-modal-otp small {
  font-size: var(--qin-small-font-size);
  margin-right: 20px;
}

.btn-add-obligation {
  text-decoration: underline;
}

app-obligations .obligation-item {
  --padding-top: 12px;
  --padding-end: 12px;
  --padding-bottom: 12px;
  --padding-start: 12px;
  --inner-padding-end: 0;
  --border-color: transparent;
  --background: var(--ion-color-secondary);
  --border-radius: var(--qin-card-border-radius);
  margin-bottom: 20px;
}
app-obligations .obligation-item ion-label {
  margin: 0;
}
app-obligations .obligation-type {
  font-size: var(--qin-body-font-size);
  text-transform: uppercase;
  margin: 0;
  color: var(--ion-color-primary);
  font-weight: 400;
}
app-obligations .obligation-company {
  font-weight: 400;
  font-size: var(--qin-body-font-size);
  text-transform: uppercase;
  color: var(--ion-color-success);
}
app-obligations .obligation-date {
  font-weight: bold;
  font-size: var(--qin-label-font-size);
  color: var(--ion-color-primary);
}
app-obligations .obligation-detail {
  flex-direction: column-reverse;
  align-items: end;
}
app-obligations .obligation-detail ion-icon {
  margin-bottom: 10px;
  height: 30px;
  width: 30px;
  color: var(--ion-color-accent);
}
app-obligations .obligation-detail ion-badge {
  --padding-top: 0;
  --padding-right: 0;
  --padding-bottom: 0;
  --padding-start: 0;
  padding: 0;
  background: transparent;
  color: var(--ion-text-color);
  font-weight: bold;
  font-size: var(--qin-label-font-size);
}
app-obligations .acknowledgment ion-item {
  --highlight-color-focused: transparent;
  --background-hover: transparent;
  --ripple-color: transparent;
  margin: 0;
}
app-obligations ion-checkbox::part(label) {
  margin: 0 0 0 12px;
  opacity: 1;
  font-size: var(--qin-small-font-size);
}
app-obligations ion-checkbox.checkbox-disabled::part(container) {
  border-color: var(--qin-input-disabled-background);
  background: var(--qin-input-disabled-background);
}
app-obligations ion-checkbox::part(container) {
  height: 26px;
  width: 26px;
}

ion-progress-bar {
  border-radius: 14px;
  border: 1px solid var(--ion-color-accent) !important;
}

ion-progress-bar::part(track) {
  background-color: transparent;
}

ion-progress-bar::part(progress) {
  background-color: var(--ion-color-accent);
}

/* preventivo */
app-quotation-view .quotation-view-details,
app-quotation-view .quotation-view-btn-details {
  display: none;
}
app-quotation-view .quotation-preview .quotation-preview-standard .quotation-preview-row {
  margin: 0 0 20px 0;
}
app-quotation-view .quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-left {
  text-align: left;
}
app-quotation-view .quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-right {
  align-items: flex-end;
}
app-quotation-view .quotation-preview .quotation-preview-standard .quotation-preview-row .quotation-preview-labels__title {
  margin: 0;
  color: var(--ion-color-accent);
  font-size: var(--qin-label-font-size);
  font-weight: bold;
}
app-quotation-view .quotation-preview-standard {
  margin: 0;
}
app-quotation-view .quotation-module-section .quotation-module-section-text {
  display: none;
}
app-quotation-view .quotation-preview-labels__unit small {
  font-size: var(--qin-small-font-size);
}
app-quotation-view .nice-amount {
  font-size: var(--qin-display-font-size-3) !important;
}
app-quotation-view .nice-amount--relevant {
  font-size: var(--qin-display-font-size-2) !important;
}
app-quotation-view .nice-amount--relevant,
app-quotation-view .quotation-preview-labels__unit {
  color: var(--ion-color-primary);
}

.quotation-module-section-text {
  display: none;
}

.module-list ion-item {
  --highlight-color-focused: transparent;
  --background-hover: transparent;
  --ripple-color: transparent;
}

app-input-document ion-item,
app-checklist-item ion-item {
  --ripple-color: transparent;
  --background-hover: transparent;
}
app-input-document ion-item::part(native),
app-checklist-item ion-item::part(native) {
  background-color: transparent;
}

/* visualizzazione documenti */
.module-list .module-list-item,
app-input-document .module-list-item,
app-checklist-item .module-list-item,
app-documents-view .module-list-item {
  margin: 0;
}
.module-list .module-item,
app-input-document .module-item,
app-checklist-item .module-item,
app-documents-view .module-item {
  --padding-start: 0;
  --padding-top: 0;
  --padding-bottom: 0;
  --inner-padding-end: 0;
  --background-focused-opacity: 0;
}
.module-list .module-item ion-button,
app-input-document .module-item ion-button,
app-checklist-item .module-item ion-button,
app-documents-view .module-item ion-button {
  margin-right: 3px;
}
.module-list .module-item small,
app-input-document .module-item small,
app-checklist-item .module-item small,
app-documents-view .module-item small {
  font-size: var(--qin-small-font-size);
  margin-left: 4px;
}
.module-list .module-item-btn-text,
app-input-document .module-item-btn-text,
app-checklist-item .module-item-btn-text,
app-documents-view .module-item-btn-text {
  display: none;
}
.module-list .module-list-checkbox,
.module-list .acknowledgment ion-item,
.module-list .module-list-view-message,
app-input-document .module-list-checkbox,
app-input-document .acknowledgment ion-item,
app-input-document .module-list-view-message,
app-checklist-item .module-list-checkbox,
app-checklist-item .acknowledgment ion-item,
app-checklist-item .module-list-view-message,
app-documents-view .module-list-checkbox,
app-documents-view .acknowledgment ion-item,
app-documents-view .module-list-view-message {
  --padding-start: 0;
  --padding-top: 0;
  --padding-bottom: 0;
  --padding-end: 0;
  margin-top: 12px;
  font-size: var(--qin-small-font-size);
}
.module-list .module-list-checkbox,
app-input-document .module-list-checkbox,
app-checklist-item .module-list-checkbox,
app-documents-view .module-list-checkbox {
  margin: var(--ion-margin) 0 0 0;
}
.module-list .module-list-view-message,
app-input-document .module-list-view-message,
app-checklist-item .module-list-view-message,
app-documents-view .module-list-view-message {
  margin: 0;
}
.module-list .module-list-view-message small,
app-input-document .module-list-view-message small,
app-checklist-item .module-list-view-message small,
app-documents-view .module-list-view-message small {
  font-size: 100%;
}
.module-list .module-item ion-thumbnail ion-icon,
app-input-document .module-item ion-thumbnail ion-icon,
app-checklist-item .module-item ion-thumbnail ion-icon,
app-documents-view .module-item ion-thumbnail ion-icon {
  font-size: 44px;
}
.module-list .module-item.ion-focused h3,
app-input-document .module-item.ion-focused h3,
app-checklist-item .module-item.ion-focused h3,
app-documents-view .module-item.ion-focused h3 {
  color: var(--ion-text-color);
}
.module-list .module-item-btn ion-icon,
app-input-document .module-item-btn ion-icon,
app-checklist-item .module-item-btn ion-icon,
app-documents-view .module-item-btn ion-icon {
  margin: 0;
  color: var(--ion-color-success);
}
.module-list .module-item ion-label h3,
app-input-document .module-item ion-label h3,
app-checklist-item .module-item ion-label h3,
app-documents-view .module-item ion-label h3 {
  font-size: var(--qin-label-font-size) !important;
  font-weight: bold !important;
  margin: 4px;
}
.module-list .module-item.ion-focused h3,
app-input-document .module-item.ion-focused h3,
app-checklist-item .module-item.ion-focused h3,
app-documents-view .module-item.ion-focused h3 {
  outline: 1px solid var(--ion-color-success);
  outline-offset: 3px;
  color: var(--ion-text-color);
}
.module-list ion-label,
app-input-document ion-label,
app-checklist-item ion-label,
app-documents-view ion-label {
  margin: 0;
}
.module-list ion-thumbnail,
app-input-document ion-thumbnail,
app-checklist-item ion-thumbnail,
app-documents-view ion-thumbnail {
  margin: 0 11px 0 0;
  height: 44px;
  width: 44px;
}
.module-list ion-checkbox::part(label),
app-input-document ion-checkbox::part(label),
app-checklist-item ion-checkbox::part(label),
app-documents-view ion-checkbox::part(label) {
  margin: 0 0 0 12px;
  opacity: 1;
  font-size: var(--qin-small-font-size);
}
.module-list ion-checkbox.checkbox-disabled::part(container),
app-input-document ion-checkbox.checkbox-disabled::part(container),
app-checklist-item ion-checkbox.checkbox-disabled::part(container),
app-documents-view ion-checkbox.checkbox-disabled::part(container) {
  border-color: var(--qin-input-disabled-background-dark);
  background: var(--qin-input-disabled-background-dark);
}
.module-list ion-checkbox::part(container),
app-input-document ion-checkbox::part(container),
app-checklist-item ion-checkbox::part(container),
app-documents-view ion-checkbox::part(container) {
  height: 26px;
  width: 26px;
}
.module-list ion-col,
app-input-document ion-col,
app-checklist-item ion-col,
app-documents-view ion-col {
  padding: 0;
}

app-documents-view ion-card-content > div {
  margin: 0 0 var(--ion-margin) 0 !important;
}

app-calculator app-total-amount .calculator-section-header p {
  display: none;
}
app-calculator app-duration .calculator-section-header p {
  display: none;
}
app-calculator app-instalment .calculator-section-header p {
  display: none;
}
app-calculator ion-card.hint .hint-content {
  padding: var(--ion-padding);
}
app-calculator ion-card.hint .hint-content-icon {
  font-size: 40px;
}
app-calculator ion-card.quotation-overview ion-card-content {
  padding-top: 0 !important;
  margin: 0 -6px;
}
app-calculator app-input-number-step ion-item {
  --inner-border-width: 0;
}
app-calculator ion-col {
  border: 0 !important;
  padding: 0;
  margin-bottom: 6px;
  margin-top: 6px;
}
app-calculator .input-number-step-input {
  color: var(--ion-color-light);
}
app-calculator ion-range {
  --knob-background: var(--ion-color-light);
  --bar-background: var(--ion-color-light);
  --bar-background-active: var(--ion-color-light);
}
app-calculator .quotation-overview .quotation-overview-item .quotation-overview-item-header {
  color: var(--ion-color-accent);
  font-size: var(--qin-label-font-size);
  letter-spacing: 0.55px;
  text-transform: uppercase;
  height: auto;
  font-weight: 600;
  margin-bottom: 11px;
}
app-calculator .quotation-overview .quotation-overview-item app-amount-counter span {
  font-size: var(--qin-title-font-size-1);
  font-weight: bold;
}
app-calculator .calculator-section-header {
  color: var(--ion-color-light);
}
app-calculator .extremes {
  color: var(--ion-color-light);
}
app-calculator .quotation-overview-item {
  padding: 12px 0;
  height: 100%;
  margin: 6px;
  background: var(--ion-color-secondary);
}
app-calculator .quotation-overview-item-btn-info {
  display: none;
}
app-calculator .overview-details-btn {
  display: none;
}
app-calculator .input-number-step ion-item {
  --border-width: 0;
}
app-calculator app-overview-item ion-button[fill=clear] {
  --padding-top: 0;
  --padding-start: 0;
  --padding-end: 0;
  --padding-bottom: 0;
  margin-left: 5px;
  min-height: auto;
  height: auto;
}
app-calculator .quotation-overview-item-main app-amount-counter span {
  font-size: var(--qin-display-font-size-2) !important;
}
app-calculator app-overview-item ion-button ion-icon {
  font-size: 20px;
}
app-calculator app-overview-item div > p {
  font-size: var(--qin-small-font-size) !important;
  margin-top: 6px !important;
}
app-calculator .input-number-step-unit {
  color: var(--ion-color-light);
}
app-calculator .amount-input-display {
  color: var(--ion-color-light);
}
app-calculator .quotation-overview .quotation-overview-item app-amount-counter {
  font-size: var(--qin-display-font-size-2);
}
app-calculator .quotation-overview-item > h1 {
  font-size: var(--qin-display-font-size-2) !important;
}
app-calculator app-overview > div {
  background: var(--ion-color-light);
}

app-dashboard .step-header-container {
  background-color: var(--ion-color-primary);
}
app-dashboard .dashboard-tabs {
  padding-top: 20px;
}
app-dashboard ion-header {
  box-shadow: none !important;
}
app-dashboard ion-toolbar {
  --background: var(--ion-color-primary);
  margin-top: 20px;
}
app-dashboard ion-toolbar ion-segment {
  margin: 0 auto;
}
app-dashboard app-empty-placeholder ion-icon {
  fill: var(--ion-color-success);
}
app-dashboard app-empty-placeholder ion-text {
  color: var(--ion-color-light);
}
app-dashboard .dashboard-tab {
  --indicator-color: var(--ion-color-success-light);
}
app-dashboard .dashboard-title {
  margin-bottom: 20px;
}

app-dashboard app-tab-dashboard ion-grid {
  padding: 0;
}
app-dashboard app-tab-dashboard ion-col {
  padding: 0;
  margin-bottom: 12px;
}
app-dashboard app-tab-dashboard .action-details {
  margin: 0 -6px;
}
app-dashboard app-tab-dashboard h4 {
  margin: 0 0 20px 20px !important;
  text-align: left;
  color: var(--ion-color-light);
  font-weight: bold;
  text-transform: uppercase;
  font-size: var(--qin-title-font-size-1);
}
app-dashboard app-tab-dashboard ion-icon {
  color: var(--ion-color-success) !important;
  height: 40px;
  width: 40px;
  margin-bottom: 20px;
}
app-dashboard app-tab-dashboard ion-button {
  font-size: 14px;
  height: 50px;
  margin-bottom: 20px !important;
}

app-dashboard app-tab-dashboard app-action .action-progress-container {
  padding: 10px 12px !important;
  background: var(--ion-color-secondary);
  border-radius: var(--qin-card-border-radius);
}
app-dashboard app-tab-dashboard app-action .plafond-title {
  color: var(--ion-color-accent);
  font-size: var(--qin-label-font-size);
  text-transform: uppercase;
  font-weight: bold;
  margin-bottom: 26px;
}
app-dashboard app-tab-dashboard app-action .small-divider {
  display: none;
}
app-dashboard app-tab-dashboard app-action .action-plafond {
  margin-bottom: 0;
}
app-dashboard app-tab-dashboard app-action .action-warning {
  margin-top: 18px;
  margin-bottom: 20px;
}

app-dashboard app-tab-dashboard app-usages .dashboard-title {
  margin: 50px 0 20px 0;
}
app-dashboard app-tab-dashboard app-usages ion-grid {
  padding: 0;
  margin-bottom: 20px;
}

app-dashboard app-tab-dashboard app-usages app-history-usage .history-usage-container {
  padding: 12px;
  margin-bottom: 20px;
  border-radius: 10px;
  background-color: var(--ion-color-secondary);
}
app-dashboard app-tab-dashboard app-usages app-history-usage .history-usage-container ion-item {
  --min-height: 0;
  margin-bottom: 8px;
}
app-dashboard app-tab-dashboard app-usages app-history-usage .history-usage-container .history-usage-title {
  color: var(--ion-color-primary);
}
app-dashboard app-tab-dashboard app-usages app-history-usage .history-usage-container h3 {
  text-transform: uppercase;
  font-size: var(--qin-body-font-size) !important;
  font-weight: bold !important;
}
app-dashboard app-tab-dashboard app-usages app-history-usage .history-usage-container ion-item {
  --background: transparent;
}

app-dashboard app-tab-documents .dashboard-title:not(:first-child) {
  padding-top: 20px;
}
app-dashboard app-tab-documents .module-item {
  margin-bottom: 20px;
}
app-dashboard app-tab-documents .module-item p {
  display: none;
}
app-dashboard app-tab-documents .dashboard-card {
  margin: 0 !important;
}

app-dashboard app-tab-messages .dashboard-card {
  margin: 0 !important;
}
app-dashboard app-tab-messages ion-item {
  --background: transparent;
  --background-hover: transparent;
  --ripple-color: transparent;
  --padding-start: 0;
  --inner-padding-start: 0;
  margin: 0 0 var(--ion-margin) 0 !important;
}
app-dashboard app-tab-messages ion-item::part(native) {
  align-items: baseline;
}
app-dashboard app-tab-messages ion-icon {
  margin: 0;
  fill: var(--ion-color-success);
}
app-dashboard app-tab-messages ion-label {
  margin: 0;
}
app-dashboard app-tab-messages ion-text {
  font-size: var(--qin-small-font-size);
  color: var(--ion-color-accent);
}
app-dashboard app-tab-messages p {
  font-size: var(--qin-body-font-size) !important;
  margin: 7px 0 0 0 !important;
  color: var(--ion-text-color) !important;
}

app-tfr-list ion-item {
  --background: var(--ion-color-secondary);
  --border-radius: var(--qin-card-border-radius);
  margin-bottom: var(--ion-margin);
  --padding-start: 12px;
  --padding-top: 12px;
  --padding-bottom: 12px;
  --padding-end: 12px;
}
app-tfr-list ion-label {
  margin: 0;
}
app-tfr-list ion-progress-bar {
  border-radius: 14px;
  border: 1px solid var(--ion-color-primary);
}
app-tfr-list ion-progress-bar::part(track) {
  background-color: transparent;
}
app-tfr-list .tfr-list-title,
app-tfr-list .tfr-list-name {
  font-size: var(--qin-body-font-size);
}
app-tfr-list .tfr-list-text-container p {
  font-size: var(--qin-title-font-size-3);
  margin-top: 4px;
}
app-tfr-list .tfr-list-title,
app-tfr-list .tfr-list-name {
  text-transform: uppercase;
}
app-tfr-list .tfr-list-name {
  color: var(--ion-color-success);
}
app-tfr-list .tfr-list-text-currency {
  color: var(--qin-input-disabled-color);
  text-transform: uppercase;
}
app-tfr-list .tfr-list-text-currency p {
  font-size: var(--qin-small-font-size);
}

.step-bar .step .step-filler {
  background: var(--ion-color-success-light);
}
.step-bar .step .step-content {
  border-radius: 20px;
  background: var(--ion-color-medium);
}

.step-header-container {
  display: flex;
  flex-direction: column;
  padding: 0;
}
@media (max-width: 768px) {
  .step-header-container {
    padding: 0 var(--ion-padding) 0 var(--ion-padding);
  }
}
.step-header-container .step-bar-container {
  margin-top: 20px;
}
.step-header-container .step-header {
  margin-top: var(--ion-padding);
}
.step-header-container .step-header-btn--left ion-icon, .step-header-container .step-header-btn--right ion-icon {
  color: var(--qin-content-color);
}
.step-header-container .step-header-title {
  font-size: var(--qin-title-font-size-1) !important;
}
.step-header-container .step-header .logo {
  height: 27px;
}
.step-header-container .step-header ion-button.step-header-btn.ion-focused {
  outline-color: var(--ion-color-success-light);
}

.plt-ios .step-header-container,
.plt-ios ion-toolbar {
  padding-top: var(--ion-safe-area-top);
}

app-summary h1 {
  text-transform: uppercase;
  font-weight: bold;
}

app-switch-to-app ion-img {
  height: 300px;
  width: 300px;
  margin: 100px auto 0 auto;
  display: block;
}

body {
  letter-spacing: var(--qin-text-letter-spacing);
}

.wizard-widget .step.step--completed .step-title {
  color: var(--ion-color-light);
}
.wizard-widget .step.step--completed .step-line {
  border-color: var(--ion-color-light);
}
.wizard-widget .step.step--active .step-title {
  color: var(--ion-color-light);
}
.wizard-widget .step.step--active:not(.step--small) .step-square {
  border-color: var(--ion-color-success-light);
}
.wizard-widget .step.step--completed .step-square {
  background-color: var(--ion-color-light);
}
.wizard-widget .step .step-title {
  color: var(--ion-color-light);
}
.wizard-widget .step .step-square {
  border-color: var(--ion-color-light);
}
.wizard-widget .step .step-line {
  border-color: var(--ion-color-light);
}
.wizard-widget .step .step-square .step-square-inner {
  border-color: var(--ion-color-light);
}
.wizard-widget .step .step-square ion-icon {
  color: var(--ion-color-primary);
}

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