/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** 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/critical.scss?ngGlobalStyle ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
:root {
  --ion-color-primary: #0054e9;
  --ion-color-primary-rgb: 0, 84, 233;
  --ion-color-primary-contrast: #fff;
  --ion-color-primary-contrast-rgb: 255, 255, 255;
  --ion-color-primary-shade: #004acd;
  --ion-color-primary-tint: #1a65eb;
  --ion-color-secondary: #0163aa;
  --ion-color-secondary-rgb: 1, 99, 170;
  --ion-color-secondary-contrast: #fff;
  --ion-color-secondary-contrast-rgb: 255, 255, 255;
  --ion-color-secondary-shade: #015796;
  --ion-color-secondary-tint: #1a73b3;
  --ion-color-tertiary: #6030ff;
  --ion-color-tertiary-rgb: 96, 48, 255;
  --ion-color-tertiary-contrast: #fff;
  --ion-color-tertiary-contrast-rgb: 255, 255, 255;
  --ion-color-tertiary-shade: #542ae0;
  --ion-color-tertiary-tint: #7045ff;
  --ion-color-success: #2dd55b;
  --ion-color-success-rgb: 45, 213, 91;
  --ion-color-success-contrast: #000;
  --ion-color-success-contrast-rgb: 0, 0, 0;
  --ion-color-success-shade: #28bb50;
  --ion-color-success-tint: #42d96b;
  --ion-color-warning: #ffc409;
  --ion-color-warning-rgb: 255, 196, 9;
  --ion-color-warning-contrast: #000;
  --ion-color-warning-contrast-rgb: 0, 0, 0;
  --ion-color-warning-shade: #e0ac08;
  --ion-color-warning-tint: #ffca22;
  --ion-color-danger: #c5000f;
  --ion-color-danger-rgb: 197, 0, 15;
  --ion-color-danger-contrast: #fff;
  --ion-color-danger-contrast-rgb: 255, 255, 255;
  --ion-color-danger-shade: #ad000d;
  --ion-color-danger-tint: #cb1a27;
  --ion-color-light: #f4f5f8;
  --ion-color-light-rgb: 244, 245, 248;
  --ion-color-light-contrast: #000;
  --ion-color-light-contrast-rgb: 0, 0, 0;
  --ion-color-light-shade: #d7d8da;
  --ion-color-light-tint: #f5f6f9;
  --ion-color-medium: #636469;
  --ion-color-medium-rgb: 99, 100, 105;
  --ion-color-medium-contrast: #fff;
  --ion-color-medium-contrast-rgb: 255, 255, 255;
  --ion-color-medium-shade: #57585c;
  --ion-color-medium-tint: #737478;
  --ion-color-dark: #222428;
  --ion-color-dark-rgb: 34, 36, 40;
  --ion-color-dark-contrast: #fff;
  --ion-color-dark-contrast-rgb: 255, 255, 255;
  --ion-color-dark-shade: #1e2023;
  --ion-color-dark-tint: #383a3e;
}

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-dynamic-font: -apple-system-body;
  --ion-font-family: var(--ion-default-font);
}

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

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

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, html.ios ion-footer.modal-footer-moving ion-toolbar:first-of-type {
  padding-top: 6px;
}

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;
}

html.ios ion-modal ion-toolbar, html.ios .modal-footer-moving ion-toolbar {
  padding-right: calc(var(--ion-safe-area-right) + 8px);
  padding-left: calc(var(--ion-safe-area-left) + 8px);
}

@media screen and (min-width: 768px) {
  html.ios ion-modal.modal-card:first-of-type {
    --backdrop-opacity: 0.18;
  }
}
ion-modal.modal-default.show-modal ~ ion-modal.modal-default {
  --backdrop-opacity: 0;
  --box-shadow: none;
}

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, #0054e9) !important;
  --ion-color-base-rgb: var(--ion-color-primary-rgb, 0, 84, 233) !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, #004acd) !important;
  --ion-color-tint: var(--ion-color-primary-tint, #1a65eb) !important;
}

.ion-color-secondary {
  --ion-color-base: var(--ion-color-secondary, #0163aa) !important;
  --ion-color-base-rgb: var(--ion-color-secondary-rgb, 1, 99, 170) !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, #015796) !important;
  --ion-color-tint: var(--ion-color-secondary-tint, #1a73b3) !important;
}

.ion-color-tertiary {
  --ion-color-base: var(--ion-color-tertiary, #6030ff) !important;
  --ion-color-base-rgb: var(--ion-color-tertiary-rgb, 96, 48, 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, #542ae0) !important;
  --ion-color-tint: var(--ion-color-tertiary-tint, #7045ff) !important;
}

.ion-color-success {
  --ion-color-base: var(--ion-color-success, #2dd55b) !important;
  --ion-color-base-rgb: var(--ion-color-success-rgb, 45, 213, 91) !important;
  --ion-color-contrast: var(--ion-color-success-contrast, #000) !important;
  --ion-color-contrast-rgb: var(--ion-color-success-contrast-rgb, 0, 0, 0) !important;
  --ion-color-shade: var(--ion-color-success-shade, #28bb50) !important;
  --ion-color-tint: var(--ion-color-success-tint, #42d96b) !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, #c5000f) !important;
  --ion-color-base-rgb: var(--ion-color-danger-rgb, 197, 0, 15) !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, #ad000d) !important;
  --ion-color-tint: var(--ion-color-danger-tint, #cb1a27) !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, #636469) !important;
  --ion-color-base-rgb: var(--ion-color-medium-rgb, 99, 100, 105) !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, #57585c) !important;
  --ion-color-tint: var(--ion-color-medium-tint, #737478) !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;
}

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 {
  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;
  pointer-events: none;
  overflow-y: hidden;
}

.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 {
    transition: none !important;
  }
}
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;
}

.ion-datetime-button-overlay {
  --width: fit-content;
  --height: fit-content;
}

.ion-datetime-button-overlay ion-datetime.datetime-grid {
  width: 320px;
  min-height: 320px;
}

[ion-last-focus], header[tabindex="-1"]:focus, [role=banner][tabindex="-1"]:focus, main[tabindex="-1"]:focus, [role=main][tabindex="-1"]:focus, h1[tabindex="-1"]:focus, [role=heading][aria-level="1"][tabindex="-1"]:focus {
  outline: none;
}

.popover-viewport:has(> ion-content) {
  overflow: hidden;
}

@supports not selector(:has(> ion-content)) {
  .popover-viewport {
    overflow: hidden;
  }
} 
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;
} 
* {
  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%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
}

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%;
  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;
  -moz-text-size-adjust: none;
       text-size-adjust: none;
} 
html {
  font-family: var(--ion-font-family);
}

@supports (-webkit-touch-callout: none) {
  html {
    font: var(--ion-dynamic-font, 16px var(--ion-font-family));
  }
}
a {
  background-color: transparent;
  color: var(--ion-color-primary, #0054e9);
}

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;
} 
* {
  font-size: 16px;
  letter-spacing: -0.4px;
  --border: none !important;
}
* big {
  font-size: 1rem !important;
  vertical-align: top;
}
* sup {
  font-size: 0.9rem !important;
  font-weight: normal !important;
  top: 10px !important;
  vertical-align: top;
}
* small {
  font-size: 0.75rem !important;
  vertical-align: inherit !important;
}

html,
body {
  height: 100%;
}

body {
  margin: 0;
}

ul {
  color: var(--ion-color-dark);
}

[hidden] {
  display: none !important;
}

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

ion-back-button {
  --color: var(--ion-color-always-white);
}

ion-button {
  text-transform: none;
  border-radius: 0.625rem;
  min-height: unset !important;
}

ion-button.button-has-icon-only {
  min-width: 0 !important;
  min-height: 0 !important;
}

ion-button[disabled],
ion-button.button-disabled {
  pointer-events: none;
  --ripple-color: transparent;
  --background-activated: var(--background);
  --background-focused: var(--background);
  --background-hover: var(--background);
  --box-shadow: none;
}

ion-button[disabled]::part(native),
ion-button[disabled]::part(native):hover,
ion-button[disabled]::part(native):active,
ion-button[disabled]::part(native):focus-visible {
  box-shadow: none !important;
  outline: none;
  transition: none;
}

ion-card {
  background: var(--ion-color-white);
  margin: 0.5rem;
  padding: 0;
  border-radius: 0.625rem;
  overflow: hidden;
}

ion-card-content {
  padding: 0.5rem 1rem !important;
}

ion-card-header {
  font-size: 1.1rem;
  --color: var(--ion-color-secondary-contrast);
  --background: var(--ion-color-secondary);
  width: 100%;
  text-align: center;
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem;
}

ion-chip {
  min-height: unset;
}

ion-datetime::part(calendar-day) {
  color: var(--ion-color-always-dark);
}

ion-datetime::part(calendar-day today) {
  color: var(--ion-color-always-dark);
  border: 1px solid var(--ion-color-accent);
}

ion-datetime::part(calendar-day active) {
  color: var(--ion-color-accent-contrast);
  background: var(--ion-color-accent);
  border: var(--ion-color-accent);
}

ion-datetime-button::part(native) {
  color: var(--ion-color-dark);
  background: transparent;
  font-size: 0.9rem;
  padding-inline-start: 0.25rem;
  padding-inline-end: 0.25rem;
}

ion-icon {
  color: var(--ion-color-dark);
}

ion-input {
  min-height: 66.5px !important;
  color: var(--ion-color-dark) !important;
  --highlight-color-focused: var(--ion-color-dark) !important;
  --highlight-color-valid: var(--ion-color-dark) !important;
  --highlight-color-invalid: var(--ion-color-dark) !important;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  appearance: textfield;
}

ion-item {
  --padding-start: 1rem;
  --padding-end: 1rem;
  --color: var(--ion-color-white);
  --ion-background-color: var(--ion-color-white);
  --background-focused: var(--ion-color-white);
  --ion-item-border-color: var(--ion-color-gray-50);
}
ion-item .ion-valid {
  --highlight-color-valid: var(--ion-color-dark) !important;
}

ion-item-divider {
  min-height: 0.5rem;
  --background: transparent;
  border-bottom: 2px solid var(--ion-color-secondary) !important;
}

ion-label {
  color: var(--ion-color-dark) !important;
  white-space: normal !important;
}

.label-stacked.sc-ion-label-md-h {
  font-size: 0.8rem !important;
  transform: translateY(30%) !important;
}

ion-list {
  background: var(--ion-color-white);
}

ion-loading.loading-message .loading-wrapper {
  border-radius: 0.5rem !important;
}

ion-modal {
  --height: auto !important;
  --width: 34rem !important;
  --max-height: 90vh;
  --max-width: 90vw;
  --border-radius: 1rem;
}

ion-modal.nested-modal {
  --width: 28rem !important;
}

body ion-modal.modal-default.show-modal:last-of-type {
  --box-shadow: var(--ion-overlay-box-shadow, 0 16px 48px rgba(0, 0, 0, 0.2)) !important;
  --backdrop-opacity: var(--ion-backdrop-opacity, 0.32) !important;
}

.popover-on-top {
  z-index: 99999 !important;
  --border-radius: 1rem !important;
}

.popover-on-top::part(content) {
  border-radius: 1rem;
  overflow: hidden;
}

ion-progress-bar {
  --background: var(--ion-color-gray-20);
  --progress-background: var(--ion-color-gray-80);
}

ion-radio {
  color: var(--ion-color-dark) !important;
  --color-checked: var(--ion-color-dark);
}

ion-searchbar {
  padding: 0 !important;
  --box-shadow: none !important;
}

ion-searchbar .searchbar-input-container .searchbar-input {
  font-size: 1rem;
  height: 36px !important;
  --border-radius: 6px;
  --placeholder-color: var(--ion-color-always-dark);
  --background: var(--ion-color-always-light);
  padding-inline-start: 3rem !important;
}

ion-searchbar .searchbar-search-icon.sc-ion-searchbar-md {
  top: 7px;
}

ion-searchbar .searchbar-clear-icon {
  color: var(--ion-color-always-dark);
}

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

ion-segment-button {
  min-width: 0;
  color: var(--ion-color-always-black);
  --indicator-color: var(--ion-color-always-white);
  --background: var(--ion-color-segment);
  margin: 3px 1px;
}
ion-segment-button ion-label {
  color: var(--ion-color-always-black) !important;
}

ion-select {
  color: var(--ion-color-dark);
  height: 4rem !important;
}

ion-select::part(icon) {
  color: var(--ion-color-dark);
  right: 0.5rem;
  top: 0.75rem;
}

ion-tab-bar {
  background: var(--ion-color-primary-dark) !important;
  --border: 0;
}

ion-tab-button {
  background: transparent;
}

ion-textarea {
  color: var(--ion-color-dark) !important;
  --highlight-color-focused: var(--ion-color-dark) !important;
  --highlight-color-valid: var(--ion-color-dark) !important;
  --highlight-color-invalid: var(--ion-color-dark) !important;
}

ion-title {
  color: var(--ion-color-primary-contrast);
  padding-inline: 1rem;
  font-size: 1.3rem;
}

ion-toggle {
  padding-left: 1rem;
  padding-top: 4px;
  --track-background-checked: var(--ion-color-light-green);
  --handle-background-checked: var(--ion-color-green);
  --track-background: var(--ion-color-negative-light);
}

ion-toolbar {
  --color: var(--ion-color-primary-contrast);
}

.ion-color-neutral {
  --ion-color-base: var(--ion-color-neutral) !important;
}

.custom-loader {
  border: 0.5rem solid var(--ion-color-primary);
  border-radius: 50%;
  width: 3rem;
  height: 3rem;
  aspect-ratio: 1;
  --_m: conic-gradient(#0000 10%, #000), linear-gradient(#000 0 0) content-box;
  mask: var(--_m);
  mask-composite: subtract;
  animation: l3 1s infinite linear;
}

.custom-left-justify {
  text-align: left !important;
}

.swal2-modal {
  padding-left: 0;
  padding-right: 0;
  background-color: var(--ion-color-always-white) !important;
  border: 3px solid var(--ion-color-accent) !important;
  border-radius: 1rem !important;
}
.swal2-modal .swal2-title {
  font-size: 1.3rem !important;
}
.swal2-modal .swal2-icon {
  font-size: 0.65rem !important;
}
.swal2-modal .swal2-icon.swal2-error [class^=swal2-x-mark-line] {
  font-size: 0.65rem !important;
}
.swal2-modal .swal2-icon.swal2-success [class^=swal2-success-line-tip] {
  font-size: 0.65rem !important;
}
.swal2-modal .swal2-icon.swal2-success [class^=swal2-success-circular-line-left] {
  font-size: 0.65rem !important;
}
.swal2-modal .swal2-icon.swal2-success [class^=swal2-success-line-long] {
  font-size: 0.65rem !important;
}
.swal2-modal .swal2-icon.swal2-success [class^=swal2-success-ring] {
  font-size: 0.65rem !important;
}
.swal2-modal .swal2-icon.swal2-success [class^=swal2-success-fix] {
  font-size: 0.65rem !important;
}
.swal2-modal .swal2-icon.swal2-success [class^=swal2-success-circular-line-right] {
  font-size: 0.65rem !important;
}

.swal2-container {
  width: auto !important;
  background: rgba(255, 255, 255, 0.8);
}

.swal2-loading {
  max-width: 18rem !important;
}

.swal2-html-container b {
  font-size: 18px !important;
}

.swal2-styled.swal2-cancel {
  height: 2.4rem;
  padding: 0.6375rem 1rem !important;
  color: var(--ion-color-accent) !important;
  background-color: var(--ion-color-always-white) !important;
  border-width: 2px !important;
  border-color: var(--ion-color-accent) !important;
  border-style: solid !important;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes pulse {
  0% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(117, 218, 173, 0.7);
  }
  70% {
    transform: scale(1);
    box-shadow: 0 0 0 0.5rem rgba(0, 0, 0, 0);
  }
  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  }
}
@keyframes fade {
  0% {
    opacity: 0.4;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0.4;
  }
}
@keyframes l3 {
  to {
    transform: rotate(1turn);
  }
}
.mat-elevation-z0, .mat-mdc-elevation-specific.mat-elevation-z0 {
  box-shadow: var(--mat-app-elevation-shadow-level-0, 0px 0px 0px 0px --mat-sys-shadow, 0px 0px 0px 0px --mat-sys-shadow, 0px 0px 0px 0px --mat-sys-shadow);
}

.mat-elevation-z1, .mat-mdc-elevation-specific.mat-elevation-z1 {
  box-shadow: var(--mat-app-elevation-shadow-level-1, 0px 2px 1px -1px --mat-sys-shadow, 0px 1px 1px 0px --mat-sys-shadow, 0px 1px 3px 0px --mat-sys-shadow);
}

.mat-elevation-z2, .mat-mdc-elevation-specific.mat-elevation-z2 {
  box-shadow: var(--mat-app-elevation-shadow-level-2, 0px 3px 1px -2px --mat-sys-shadow, 0px 2px 2px 0px --mat-sys-shadow, 0px 1px 5px 0px --mat-sys-shadow);
}

.mat-elevation-z3, .mat-mdc-elevation-specific.mat-elevation-z3 {
  box-shadow: var(--mat-app-elevation-shadow-level-3, 0px 3px 3px -2px --mat-sys-shadow, 0px 3px 4px 0px --mat-sys-shadow, 0px 1px 8px 0px --mat-sys-shadow);
}

.mat-elevation-z4, .mat-mdc-elevation-specific.mat-elevation-z4 {
  box-shadow: var(--mat-app-elevation-shadow-level-4, 0px 2px 4px -1px --mat-sys-shadow, 0px 4px 5px 0px --mat-sys-shadow, 0px 1px 10px 0px --mat-sys-shadow);
}

.mat-elevation-z5, .mat-mdc-elevation-specific.mat-elevation-z5 {
  box-shadow: var(--mat-app-elevation-shadow-level-5, 0px 3px 5px -1px --mat-sys-shadow, 0px 5px 8px 0px --mat-sys-shadow, 0px 1px 14px 0px --mat-sys-shadow);
}

.mat-elevation-z6, .mat-mdc-elevation-specific.mat-elevation-z6 {
  box-shadow: var(--mat-app-elevation-shadow-level-6, 0px 3px 5px -1px --mat-sys-shadow, 0px 6px 10px 0px --mat-sys-shadow, 0px 1px 18px 0px --mat-sys-shadow);
}

.mat-elevation-z7, .mat-mdc-elevation-specific.mat-elevation-z7 {
  box-shadow: var(--mat-app-elevation-shadow-level-7, 0px 4px 5px -2px --mat-sys-shadow, 0px 7px 10px 1px --mat-sys-shadow, 0px 2px 16px 1px --mat-sys-shadow);
}

.mat-elevation-z8, .mat-mdc-elevation-specific.mat-elevation-z8 {
  box-shadow: var(--mat-app-elevation-shadow-level-8, 0px 5px 5px -3px --mat-sys-shadow, 0px 8px 10px 1px --mat-sys-shadow, 0px 3px 14px 2px --mat-sys-shadow);
}

.mat-elevation-z9, .mat-mdc-elevation-specific.mat-elevation-z9 {
  box-shadow: var(--mat-app-elevation-shadow-level-9, 0px 5px 6px -3px --mat-sys-shadow, 0px 9px 12px 1px --mat-sys-shadow, 0px 3px 16px 2px --mat-sys-shadow);
}

.mat-elevation-z10, .mat-mdc-elevation-specific.mat-elevation-z10 {
  box-shadow: var(--mat-app-elevation-shadow-level-10, 0px 6px 6px -3px --mat-sys-shadow, 0px 10px 14px 1px --mat-sys-shadow, 0px 4px 18px 3px --mat-sys-shadow);
}

.mat-elevation-z11, .mat-mdc-elevation-specific.mat-elevation-z11 {
  box-shadow: var(--mat-app-elevation-shadow-level-11, 0px 6px 7px -4px --mat-sys-shadow, 0px 11px 15px 1px --mat-sys-shadow, 0px 4px 20px 3px --mat-sys-shadow);
}

.mat-elevation-z12, .mat-mdc-elevation-specific.mat-elevation-z12 {
  box-shadow: var(--mat-app-elevation-shadow-level-12, 0px 7px 8px -4px --mat-sys-shadow, 0px 12px 17px 2px --mat-sys-shadow, 0px 5px 22px 4px --mat-sys-shadow);
}

.mat-elevation-z13, .mat-mdc-elevation-specific.mat-elevation-z13 {
  box-shadow: var(--mat-app-elevation-shadow-level-13, 0px 7px 8px -4px --mat-sys-shadow, 0px 13px 19px 2px --mat-sys-shadow, 0px 5px 24px 4px --mat-sys-shadow);
}

.mat-elevation-z14, .mat-mdc-elevation-specific.mat-elevation-z14 {
  box-shadow: var(--mat-app-elevation-shadow-level-14, 0px 7px 9px -4px --mat-sys-shadow, 0px 14px 21px 2px --mat-sys-shadow, 0px 5px 26px 4px --mat-sys-shadow);
}

.mat-elevation-z15, .mat-mdc-elevation-specific.mat-elevation-z15 {
  box-shadow: var(--mat-app-elevation-shadow-level-15, 0px 8px 9px -5px --mat-sys-shadow, 0px 15px 22px 2px --mat-sys-shadow, 0px 6px 28px 5px --mat-sys-shadow);
}

.mat-elevation-z16, .mat-mdc-elevation-specific.mat-elevation-z16 {
  box-shadow: var(--mat-app-elevation-shadow-level-16, 0px 8px 10px -5px --mat-sys-shadow, 0px 16px 24px 2px --mat-sys-shadow, 0px 6px 30px 5px --mat-sys-shadow);
}

.mat-elevation-z17, .mat-mdc-elevation-specific.mat-elevation-z17 {
  box-shadow: var(--mat-app-elevation-shadow-level-17, 0px 8px 11px -5px --mat-sys-shadow, 0px 17px 26px 2px --mat-sys-shadow, 0px 6px 32px 5px --mat-sys-shadow);
}

.mat-elevation-z18, .mat-mdc-elevation-specific.mat-elevation-z18 {
  box-shadow: var(--mat-app-elevation-shadow-level-18, 0px 9px 11px -5px --mat-sys-shadow, 0px 18px 28px 2px --mat-sys-shadow, 0px 7px 34px 6px --mat-sys-shadow);
}

.mat-elevation-z19, .mat-mdc-elevation-specific.mat-elevation-z19 {
  box-shadow: var(--mat-app-elevation-shadow-level-19, 0px 9px 12px -6px --mat-sys-shadow, 0px 19px 29px 2px --mat-sys-shadow, 0px 7px 36px 6px --mat-sys-shadow);
}

.mat-elevation-z20, .mat-mdc-elevation-specific.mat-elevation-z20 {
  box-shadow: var(--mat-app-elevation-shadow-level-20, 0px 10px 13px -6px --mat-sys-shadow, 0px 20px 31px 3px --mat-sys-shadow, 0px 8px 38px 7px --mat-sys-shadow);
}

.mat-elevation-z21, .mat-mdc-elevation-specific.mat-elevation-z21 {
  box-shadow: var(--mat-app-elevation-shadow-level-21, 0px 10px 13px -6px --mat-sys-shadow, 0px 21px 33px 3px --mat-sys-shadow, 0px 8px 40px 7px --mat-sys-shadow);
}

.mat-elevation-z22, .mat-mdc-elevation-specific.mat-elevation-z22 {
  box-shadow: var(--mat-app-elevation-shadow-level-22, 0px 10px 14px -6px --mat-sys-shadow, 0px 22px 35px 3px --mat-sys-shadow, 0px 8px 42px 7px --mat-sys-shadow);
}

.mat-elevation-z23, .mat-mdc-elevation-specific.mat-elevation-z23 {
  box-shadow: var(--mat-app-elevation-shadow-level-23, 0px 11px 14px -7px --mat-sys-shadow, 0px 23px 36px 3px --mat-sys-shadow, 0px 9px 44px 8px --mat-sys-shadow);
}

.mat-elevation-z24, .mat-mdc-elevation-specific.mat-elevation-z24 {
  box-shadow: var(--mat-app-elevation-shadow-level-24, 0px 11px 15px -7px --mat-sys-shadow, 0px 24px 38px 3px --mat-sys-shadow, 0px 9px 46px 8px --mat-sys-shadow);
}

html {
  --mat-sys-on-surface: initial;
}

.mat-app-background {
  background-color: var(--mat-app-background-color, var(--mat-sys-background, transparent));
  color: var(--mat-app-text-color, var(--mat-sys-on-background, inherit));
}

:root {
  --shared-font-family: "Open Sans", sans-serif;
  --shared-tracking: -0.4px;
  --mat-sys-body-large-font: var(--shared-font-family);
  --mat-sys-body-medium-font: var(--shared-font-family);
  --mat-sys-body-small-font: var(--shared-font-family);
  --mat-app-body-large-font: var(--shared-font-family);
  --mat-app-body-medium-font: var(--shared-font-family);
  --mat-app-body-small-font: var(--shared-font-family);
  --mat-sys-title-large-font: var(--shared-font-family);
  --mat-sys-title-medium-font: var(--shared-font-family);
  --mat-sys-title-small-font: var(--shared-font-family);
  --mat-app-title-large-font: var(--shared-font-family);
  --mat-app-title-medium-font: var(--shared-font-family);
  --mat-app-title-small-font: var(--shared-font-family);
  --mat-sys-body-large-tracking: var(--shared-tracking);
  --mat-sys-body-medium-tracking: var(--shared-tracking);
  --mat-sys-body-small-tracking: var(--shared-tracking);
  --mat-app-body-large-tracking: var(--shared-tracking);
  --mat-app-body-medium-tracking: var(--shared-tracking);
  --mat-app-body-small-tracking: var(--shared-tracking);
  --mat-theme-primary: var(--ion-color-primary);
  --mat-theme-secondary: var(--ion-color-secondary);
  --mat-theme-accent: var(--ion-color-accent);
  --mat-datepicker-calendar-header-text-color: var(--ion-color-dark);
  --mat-datepicker-calendar-date-text-color: var(--ion-color-dark);
  --mat-datepicker-calendar-date-disabled-state-text-color: var(--ion-color-gray-50);
  --mat-datepicker-calendar-period-button-icon-color: var(--ion-color-dark);
  --mat-expansion-header-expanded-state-height: auto;
  --mat-expansion-header-indicator-color: var(--ion-color-dark);
  --mat-icon-button-disabled-icon-color: var(--ion-color-gray-50);
  --mat-menu-item-leading-spacing: 0 !important;
  --mat-menu-item-trailing-spacing: 0 !important;
  --mat-select-enabled-trigger-text-color: var(--ion-color-dark);
  --mat-select-disabled-trigger-text-color: var(--ion-color-gray-50);
}

body.dark {
  --mat-datepicker-calendar-header-text-color: var(--ion-color-dark);
  --mat-datepicker-calendar-date-text-color: var(--ion-color-dark);
  --mat-datepicker-calendar-date-disabled-state-text-color: var(--ion-color-gray-50);
  --mat-datepicker-calendar-period-button-icon-color: var(--ion-color-dark);
  --mat-expansion-header-indicator-color: var(--ion-color-dark);
  --mat-icon-button-disabled-icon-color: var(--ion-color-gray-50);
  --mat-select-enabled-trigger-text-color: var(--ion-color-dark);
  --mat-select-disabled-trigger-text-color: var(--ion-color-gray-50);
}

.mdc-checkbox__native-control:enabled:checked ~ .mdc-checkbox__background {
  color: var(--ion-color-accent-contrast) !important;
  background-color: var(--ion-color-accent) !important;
  border-color: var(--ion-color-accent) !important;
}

.mat-mdc-chip.mat-mdc-chip-option {
  height: 32px;
  margin: 4px !important;
}

.mat-mdc-chip-action-label {
  font-size: 0.875rem !important;
}

.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-selected {
  color: transparent !important;
  background: linear-gradient(var(--ion-color-chip-selected-light), var(--ion-color-chip-selected));
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-selected .mat-mdc-chip-action-label {
  color: var(--ion-color-chip-selected-contrast) !important;
}

.mat-mdc-chip.mat-mdc-chip-option.mat-primary:not(.mat-mdc-chip-selected) {
  color: transparent !important;
  background: linear-gradient(var(--ion-color-chip-light), var(--ion-color-chip));
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary:not(.mat-mdc-chip-selected) .mat-mdc-chip-action-label {
  color: var(--ion-color-chip-contrast) !important;
}

.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-disabled {
  background: var(--ion-color-chip-disabled) !important;
  border: 1px solid var(--ion-color-chip-disabled-light) !important;
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-disabled .mat-mdc-chip-action-label {
  color: var(--ion-color-chip-disabled-contrast) !important;
}

.mat-mdc-chip-graphic {
  width: 0 !important;
}

.mdc-evolution-chip__checkmark {
  display: none !important;
}

.mat-mdc-standard-chip {
  --mat-chip-container-shape-radius: 16px 16px 16px 16px;
}

.mat-calendar-body-cell-content {
  border-width: 0 !important;
}

.mat-calendar-body-selected {
  color: var(--ion-color-accent-contrast) !important;
  background-color: var(--ion-color-accent) !important;
}

.mat-calendar-controls {
  margin-top: 0 !important;
}

.mat-expansion-indicator svg {
  color: var(--ion-color-dark);
  width: 2.2rem !important;
  height: 3rem !important;
  margin-top: 4px !important;
}

.mat-mdc-expansion-indicator::after {
  margin-top: 1.75rem !important;
  padding: 6px !important;
  transform-origin: 180% 50%;
  color: var(--ion-color-always-black);
}

.mat-accordion .mat-expansion-panel {
  margin: 0.5rem;
  border-radius: 0.5rem;
}

.mat-expansion-panel .mat-expansion-panel-header {
  height: auto;
  padding: 0.5rem 1rem;
  background: var(--ion-color-white) !important;
  border-radius: 0.5rem 0 0 0;
  display: flex;
  align-items: flex-start;
}

.mat-expansion-panel .mat-expansion-panel-content .mat-expansion-panel-body {
  background: var(--ion-color-white) !important;
  padding-bottom: 0.5rem;
}

.mat-mdc-form-field-subscript-wrapper {
  display: none;
}

.mat-mdc-menu-item-text {
  color: var(--ion-color-dark);
}

.mat-mdc-menu-panel {
  background-color: var(--ion-color-background) !important;
  padding-left: 1rem;
  padding-right: 1rem;
  border-radius: 1rem !important;
}
.mat-mdc-menu-panel ion-icon {
  margin-right: 0.5rem;
}

.mat-mdc-menu-panel .mat-pseudo-checkbox {
  display: none;
}

.short-menu {
  height: 14.5rem !important;
}

.mat-mdc-paginator {
  background-color: var(--ion-color-white) !important;
}
.mat-mdc-paginator .mat-mdc-paginator-container {
  min-height: 40px !important;
}

.cdk-overlay-pane:has(.mat-mdc-select-panel) {
  min-width: fit-content;
}

.mdc-line-ripple {
  color: var(--ion-color-gray-50) !important;
}

.mdc-list-item__primary-text {
  width: 100%;
}

mat-select-trigger,
.mat-mdc-select-value-text,
.mat-mdc-select-min-line,
.mdc-list-item__primary-text {
  font-size: 0.9rem !important;
}

.mat-mdc-select-panel {
  background-color: var(--ion-color-background) !important;
  max-height: 50vh !important;
}

.mat-mdc-select-panel .mat-pseudo-checkbox {
  display: none;
}

.mat-mdc-option {
  color: var(--ion-color-dark) !important;
}

.mdc-text-field {
  font-size: 0.875rem !important;
  padding: 0 !important;
}

.mdc-text-field--filled {
  height: 2rem !important;
}

.mat-mdc-form-field-infix {
  padding: 0.25rem 0 0 0 !important;
}

.mat-sort-header-arrow {
  margin-left: 2px !important;
  margin-right: 2px !important;
}

.mat-mdc-table {
  background-color: transparent !important;
}

.mat-mdc-header-cell,
.mat-mdc-cell,
.mat-mdc-footer-cell {
  padding: 0 !important;
  color: var(--ion-color-dark);
}

.mat-mdc-tooltip {
  white-space: pre-line;
  max-width: 15rem;
}

.cdk-overlay-pane.mat-mdc-tooltip-panel .mat-mdc-tooltip {
  color: var(--ion-color-white);
  background-color: rgba(var(--ion-color-dark-rgb), 0.8);
  font-size: 0.8rem;
}

.user-bubble p,
.user-bubble p strong {
  margin: 0 0.4rem !important;
}

.assistant-message h1 {
  color: var(--ion-color-black);
  font-size: 1.2rem;
  font-weight: bold;
  margin: 1rem 0;
}

.assistant-message h2,
.assistant-message h2 strong {
  color: var(--ion-color-dark);
  font-size: 1.1rem;
  font-weight: 700;
  font-style: bold;
  margin: 1rem 0;
}

.assistant-message h3 {
  color: var(--ion-color-dark);
  font-size: 1rem;
  font-weight: bold;
  margin: 0.8rem 0;
}

.assistant-message h4,
.assistant-message h5,
.assistant-message h6 {
  color: var(--ion-color-dark);
  font-size: 1rem;
  font-weight: normal;
  margin: 0.6rem 0;
}

.assistant-message ul,
.assistant-message ol {
  margin: 0.5rem 0 1rem 0;
  padding-left: 1.5rem;
}
@media (max-width: 600px) {
  .assistant-message ul,
  .assistant-message ol {
    padding-left: 1rem;
  }
}

.assistant-message ul li,
.assistant-message ul li strong,
.assistant-message ul li em,
.assistant-message ul li a,
.assistant-message ol li,
.assistant-message ol li strong,
.assistant-message ol li em,
.assistant-message ol li a {
  margin-bottom: 0.4rem;
  font-size: 0.9rem;
}

.assistant-message p,
.assistant-message p strong,
.assistant-message p em,
.assistant-message p a {
  font-size: 0.9rem !important;
  margin: 0.5rem 0 !important;
}

.assistant-message table {
  border-collapse: collapse;
  margin: 0.5rem auto;
  border: 1px solid var(--ion-color-accent);
  display: inline-block;
  max-width: 100%;
  overflow-x: auto;
  white-space: nowrap;
  vertical-align: top;
}

.assistant-message th,
.assistant-message td {
  font-size: 0.8rem;
  padding: 0.4rem 0.7rem;
  text-align: left;
}

.assistant-message td {
  white-space: normal;
  word-break: break-word;
}

.assistant-message th {
  color: var(--ion-color-accent-contrast);
  background: var(--ion-color-accent);
}

.assistant-message td {
  font-size: 0.8rem;
}

.assistant-message td.numeric {
  text-align: center;
}

.assistant-message td.currency {
  text-align: right;
}

.assistant-message tr:nth-child(even) td {
  background: rgba(var(--ion-color-accent-rgb), var(--ion-color-accent-bg-alpha));
}

.assistant-message pre code {
  font-size: 0.8rem;
}

blockquote {
  font-style: italic;
  border-left: 6px solid var(--ion-color-accent);
  background: rgba(var(--ion-color-accent-rgb), var(--ion-color-accent-bg-alpha));
  color: var(--ion-color-dark);
  padding: 0.5rem 1rem;
  margin: 1rem 0;
  border-radius: 0 0.5rem 0.5rem 0;
}

blockquote strong,
blockquote b {
  color: inherit;
}

.language-error {
  display: block;
  font-family: "Open Sans", sans-serif;
  font-size: 1rem !important;
  border-left: 6px solid var(--ion-color-danger);
  border-right: 0;
  background: rgba(231, 76, 60, 0.08);
  color: var(--ion-color-dark);
  padding: 0.75rem 1rem 0.75rem 3rem;
  border-radius: 0 0.5rem 0.5rem 0;
  position: relative;
  white-space: normal;
  overflow: visible;
  word-break: break-word;
}

.language-error::before {
  content: "⚠️";
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-style: normal;
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  height: 1.5rem; /* Ensures icon stays centered */
  width: 1.5rem; /* Optional: for consistent size */
  pointer-events: none;
}

.language-error strong,
.language-error b {
  color: inherit;
}

.stream-status {
  font-size: 0.9rem;
  font-style: italic;
  color: var(--ion-color-dark);
  margin-top: 1rem;
  margin-left: 0.5rem;
  margin-bottom: 1.5rem;
}

@keyframes pulse2 {
  0%, 100% {
    opacity: 0.9;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.15);
  }
}
@keyframes searchCorners {
  0% {
    transform: translate(-1px, -4px);
  }
  25% {
    transform: translate(1px, -4px);
  }
  50% {
    transform: translate(1px, -2px);
  }
  75% {
    transform: translate(-1px, -2px);
  }
  100% {
    transform: translate(-1px, -4px);
  }
}
@keyframes shake {
  0%, 100% {
    transform: rotate(-5deg);
  }
  50% {
    transform: rotate(5deg);
  }
}
.stream-status .dots {
  display: inline-block;
  font-weight: bold;
  margin-left: 0.25rem;
}

.stream-status .dots span {
  opacity: 0.5;
  animation: blink 1.4s infinite both;
}

.stream-status .dots span:nth-child(2) {
  animation-delay: 0.2s;
}

.stream-status .dots span:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes blink {
  0%, 80%, 100% {
    opacity: 0.2;
  }
  40% {
    opacity: 1;
  }
}
.stream-cursor.blink {
  animation: cursor-blink 1s steps(2, start) infinite;
  margin-bottom: 1.5rem;
}

@keyframes cursor-blink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}
.chip-line,
.chip-line b,
.chip-line strong,
.chip-line-second,
.chip-line-second b,
.chip-line-second strong {
  font-size: 0.8rem;
}

:root {
  --app-narrow-margin: 12px;
  --app-fair-margin: 16px;
  --app-broad-margin: 20px;
  --app-narrow-radius: 4px;
  --app-fair-radius: 8px;
  --app-broad-radius: 12px;
  --ion-font-family: "Open Sans", sans-serif;
  --ion-margin: var(--app-fair-margin);
  --ion-color-primary: #8b0000;
  --ion-color-primary-dark: #660000;
  --ion-color-primary-light: #a30000;
  --ion-color-primary-contrast: #ffffff;
  --ion-color-accent: #008b8b;
  --ion-color-accent-light: #00a3a3;
  --ion-color-accent-dark: #006f6f;
  --ion-color-accent-contrast: #ffffff;
  --ion-color-accent-rgb: 0, 139, 139;
  --ion-color-accent-bg-alpha: 0.075;
  --ion-color-secondary: #262626;
  --ion-color-secondary-light: #404040;
  --ion-color-secondary-dark: #0d0d0d;
  --ion-color-secondary-contrast: #ffffff;
  --ion-color-tertiary: #d11345;
  --ion-color-tertiary-contrast: #ffffff;
  --ion-color-warning: #ffa726;
  --ion-color-warning-contrast: #000000;
  --ion-color-danger: #e12d39;
  --ion-color-dark: #262626;
  --ion-color-dark-light: #0d0d0d;
  --ion-color-dark-rgb: 38, 38, 38;
  --ion-color-light: var(--ion-color-gray-15);
  --ion-color-light-light: var(--ion-color-gray-10);
  --ion-color-light-contrast: var(--ion-color-black);
  --ion-color-light-rgb: 217, 217, 217;
  --ion-color-positive: #4daf1b;
  --ion-color-positive-light: #5dd421;
  --ion-color-positive-arrow: #80e34f;
  --ion-color-negative: #e12d39;
  --ion-color-negative-light: #f7c9cd;
  --ion-color-negative-background: #e6e6e6;
  --ion-color-negative-arrow: #ff4652;
  --ion-color-neutral: #f4f4f4;
  --ion-color-drilldown: #ffffdc;
  --ion-color-black: #000000;
  --ion-color-gray-95: #0d0d0d;
  --ion-color-gray-90: #1a1a1a;
  --ion-color-gray-85: #262626;
  --ion-color-gray-80: #333333;
  --ion-color-gray-75: #404040;
  --ion-color-gray-70: #4d4d4d;
  --ion-color-gray-65: #595959;
  --ion-color-gray-60: #666666;
  --ion-color-gray-55: #737373;
  --ion-color-gray-50: #808080;
  --ion-color-gray-45: #8c8c8c;
  --ion-color-gray-40: #999999;
  --ion-color-gray-35: #a6a6a6;
  --ion-color-gray-30: #b3b3b3;
  --ion-color-gray-25: #bfbfbf;
  --ion-color-gray-20: #cccccc;
  --ion-color-gray-15: #d9d9d9;
  --ion-color-gray-10: #e6e6e6;
  --ion-color-gray-05: #f2f2f2;
  --ion-color-gray-01: #f9f9f9;
  --ion-color-white: #ffffff;
  --ion-color-chip: var(--ion-color-gray-15);
  --ion-color-chip-light: var(--ion-color-gray-10);
  --ion-color-chip-contrast: var(--ion-color-black);
  --ion-color-chip-selected: var(--ion-color-black);
  --ion-color-chip-selected-light: var(--ion-color-gray-85);
  --ion-color-chip-selected-contrast: var(--ion-color-white);
  --ion-color-chip-disabled: var(--ion-color-gray-10);
  --ion-color-chip-disabled-light: var(--ion-color-gray-15);
  --ion-color-chip-disabled-contrast: var(--ion-color-gray-35);
  --ion-color-segment: #f2f2f2;
  --ion-color-calendar-background: #ffffff;
  --ion-color-background: #f2f2f2;
  --ion-color-background-light: #fbfbfb;
  --ion-color-divider: #c8c8c8;
  --ion-background-color: var(--ion-color-white);
  --ion-tab-bar-background: var(--ion-color-white);
  --ion-tab-bar-border-color: var(--ion-color-primary);
  --ion-tab-bar-color-activated: var(--ion-color-primary);
  --ion-tab-bar-color: var(--ion-color-tertiary);
  --ion-color-always-black: #000000;
  --ion-color-always-dark: #262626;
  --ion-color-always-light: #ededed;
  --ion-color-always-light-light: #f2f2f2;
  --ion-color-always-white: #ffffff;
  --ion-color-green: #008000;
  --ion-color-light-green: #c6e6e1;
  --ion-color-mint-green: #75daad;
  --ion-color-aqua: #54c0eb;
  --ion-color-google: #4285f4;
}

/** Dark Mode Colors **/
body.dark {
  --ion-color-primary: #cc0000;
  --ion-color-primary-dark: #a30000;
  --ion-color-primary-light: #f50000;
  --ion-color-accent: #00a3a3;
  --ion-color-accent-light: #00c4c4;
  --ion-color-accent-dark: #008b8b;
  --ion-color-accent-contrast: #ffffff;
  --ion-color-accent-rgb: 0, 163, 163;
  --ion-color-accent-bg-alpha: 0.25;
  --ion-color-secondary: #737373;
  --ion-color-secondary-light: #666666;
  --ion-color-secondary-contrast: #ffffff;
  --ion-color-tertiary: #d11345;
  --ion-color-tertiary-contrast: #ffffff;
  --ion-color-warning: #ffce00;
  --ion-color-warning-contrast: #000000;
  --ion-color-dark: #ffffff;
  --ion-color-dark-light: #e6e6e6;
  --ion-color-dark-rgb: 255, 255, 255;
  --ion-color-light: var(--ion-color-gray-15);
  --ion-color-light-light: var(--ion-color-gray-10);
  --ion-color-light-contrast: var(--ion-color-black);
  --ion-color-black: #ffffff;
  --ion-color-gray-95: #f5f5f5;
  --ion-color-gray-90: #ececec;
  --ion-color-gray-85: #e2e2e2;
  --ion-color-gray-80: #d9d9d9;
  --ion-color-gray-75: #cfcfcf;
  --ion-color-gray-70: #c6c6c6;
  --ion-color-gray-65: #bcbcbc;
  --ion-color-gray-60: #b2b2b2;
  --ion-color-gray-55: #a9a9a9;
  --ion-color-gray-50: #a0a0a0;
  --ion-color-gray-45: #969696;
  --ion-color-gray-40: #8c8c8c;
  --ion-color-gray-35: #828282;
  --ion-color-gray-30: #7a7a7a;
  --ion-color-gray-25: #707070;
  --ion-color-gray-20: #666666;
  --ion-color-gray-15: #5c5c5c;
  --ion-color-gray-10: #535353;
  --ion-color-gray-05: #4a4a4a;
  --ion-color-gray-01: #1f1f1f;
  --ion-color-white: #000000;
  --ion-color-chip: var(--ion-color-gray-45);
  --ion-color-chip-light: var(--ion-color-gray-40);
  --ion-color-chip-contrast: var(--ion-color-black);
  --ion-color-chip-selected: var(--ion-color-black);
  --ion-color-chip-selected-light: var(--ion-color-gray-95);
  --ion-color-chip-selected-contrast: var(--ion-color-white);
  --ion-color-chip-disabled: var(--ion-color-gray-20);
  --ion-color-chip-disabled-light: var(--ion-color-gray-30);
  --ion-color-chip-disabled-contrast: var(--ion-color-gray-45);
  --ion-color-segment: #cccccc;
  --ion-color-calendar-background: #424242;
  --ion-color-background: #424242;
  --ion-color-background-light: #4d4d4d;
  --ion-color-divider: #999999;
  --ion-background-color: var(--ion-color-white);
  --ion-tab-bar-background: var(--ion-color-white);
  --ion-tab-bar-border-color: var(--ion-color-primary);
  --ion-tab-bar-color-activated: var(--ion-color-primary);
  --ion-tab-bar-color: var(--ion-color-tertiary);
}

#splash {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  background: linear-gradient(to bottom, #1a0001, #270002, #380103, #4c0101); /* Dark fire base */
  z-index: 9999;
}

/* Fire-glows for offscreen haze - unchanged */
.fire-glow {
  position: absolute;
  filter: blur(100px);
}

.fire-glow-1 {
  width: 700px;
  height: 700px;
  left: -200px;
  bottom: -400px;
  opacity: 0.5;
}

.fire-glow-2 {
  width: 800px;
  height: 800px;
  right: -200px;
  bottom: -300px;
  opacity: 0.5;
}

.fire-glow-3 {
  width: 900px;
  height: 900px;
  left: 50%;
  bottom: -600px;
  transform: translateX(-50%);
  opacity: 0.7;
}

.fire-glow-4 {
  width: 1000px;
  height: 1000px;
  left: 10%;
  bottom: -600px;
  transform: translateX(-25%);
  opacity: 0.55;
}

.fire-glow-5 {
  width: 1100px;
  height: 1100px;
  right: 10%;
  bottom: -700px;
  transform: translateX(25%);
  opacity: 0.55;
}

.fire-glow-6 {
  width: 1200px;
  height: 1200px;
  bottom: -700px;
  left: -200px;
  transform: translateX(-50%);
  opacity: 0.7;
}

.container {
  position: relative;
  width: inherit;
  height: inherit;
}

.inner-glow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 100%;
}

.inner-glow-1 {
  height: 25%;
  width: 25%;
  background-color: #d86306;
  animation: flickerAnimation 4s ease-in-out infinite;
  z-index: 10;
}

.inner-glow-2 {
  height: 65%;
  width: 65%;
  background-color: #a62602;
  animation: flickerAnimation 3s ease-in-out infinite;
  z-index: 9;
}

.inner-glow-3 {
  height: 100%;
  width: 100%;
  background-color: #670101;
  animation: flickerAnimation 3.6s ease-in-out infinite;
}

@keyframes flickerAnimation {
  0%, 100% {
    opacity: 0.9;
    scale: 0.98;
  }
  15%, 80% {
    opacity: 1;
    scale: 1;
  }
  30%, 60% {
    opacity: 0.8;
    scale: 1.05;
  }
  45%, 75% {
    opacity: 0.95;
    scale: 0.97;
  }
}
/* Canvas styles for sparks */
#canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 999;
}

/* Logo styles - centered over the animation */
.splash-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -80%);
  z-index: 10000;
  width: 10rem;
  height: auto;
}

@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 400;
  src: url('open-sans-v40-latin-regular.f09ec2eb560436bd.woff2') format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 400;
  src: url('open-sans-v40-latin-italic.347de8c25a91ba76.woff2') format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 700;
  src: url('open-sans-v40-latin-700.d8af061eaee8281b.woff2') format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 700;
  src: url('open-sans-v40-latin-700italic.15ee806f51c48590.woff2') format("woff2");
}

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