@charset "UTF-8";

/* src/critical.scss */
: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-page.ion-page-overlay-passthrough {
  pointer-events: none;
}
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: var(--safe-area-inset-top, env(safe-area-inset-top));
    --ion-safe-area-bottom: var(--safe-area-inset-bottom, env(safe-area-inset-bottom));
    --ion-safe-area-left: var(--safe-area-inset-left, env(safe-area-inset-left));
    --ion-safe-area-right: var(--safe-area-inset-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%;
  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;
  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: var(--app-font-size-root);
  letter-spacing: var(--app-tracking-default);
  --border: none !important;
}
* big {
  font-size: var(--app-text-base) !important;
  vertical-align: top;
}
* sup {
  font-size: var(--app-text-md) !important;
  font-weight: normal !important;
  top: 10px !important;
  vertical-align: top;
}
* small {
  font-size: var(--app-text-xs) !important;
  vertical-align: inherit !important;
}
html,
body {
  height: 100%;
  background: var(--app-color-primary-dark);
}
body {
  margin: 0;
  background-color: var(--app-color-primary-dark);
}
ul {
  color: var(--app-color-dark);
}
[hidden] {
  display: none !important;
}
ion-content {
  --background: var(--app-color-background);
}
ion-app,
ion-header,
ion-toolbar {
  background: var(--app-color-primary-dark);
}
ion-back-button {
  --color: var(--app-color-always-white);
}
ion-button {
  text-transform: none;
  border-radius: var(--app-radius-md);
  min-height: unset !important;
  -webkit-user-select: none;
  user-select: none;
}
ion-back-button,
ion-fab-button,
ion-menu-toggle {
  -webkit-user-select: none;
  user-select: none;
}
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(--app-color-surface);
  border: var(--app-border-subtle);
  margin: var(--app-card-gap-x);
  padding: 0;
  border-radius: var(--app-radius-md);
  box-shadow: var(--app-shadow-none);
  overflow: hidden;
}
.nav-app-icon {
  width: 1.4rem;
  height: 1.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  flex: 0 0 auto;
  font-size: 1.4rem;
  --calendar-icon-size: 1.4rem;
}
ion-card-content {
  padding: var(--app-card-padding-y) var(--app-card-padding-x) !important;
}
ion-card-header {
  font-size: var(--app-text-lg);
  --color: var(--app-color-secondary-contrast);
  --background: var(--app-color-secondary);
  width: 100%;
  text-align: center;
  padding-top: var(--app-space-2) !important;
  padding-bottom: var(--app-space-2);
}
ion-chip {
  min-height: unset;
}
ion-datetime::part(calendar-day) {
  color: var(--app-color-dark);
}
ion-datetime::part(calendar-day today) {
  color: var(--app-color-dark);
  border: 1px solid var(--app-color-accent);
}
ion-datetime::part(calendar-day active) {
  color: var(--app-color-accent-contrast);
  background: var(--app-color-accent);
  border: var(--app-color-accent);
}
ion-datetime-button::part(native) {
  color: var(--app-color-dark);
  background: transparent;
  font-size: var(--app-text-md);
  padding-inline-start: var(--app-space-1);
  padding-inline-end: var(--app-space-1);
}
ion-icon {
  color: var(--app-color-dark);
}
ion-input {
  min-height: 66.5px !important;
  color: var(--app-color-dark) !important;
  --highlight-color-focused: var(--app-color-dark) !important;
  --highlight-color-valid: var(--app-color-dark) !important;
  --highlight-color-invalid: var(--app-color-dark) !important;
}
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
input[type=number] {
  -moz-appearance: textfield;
  appearance: textfield;
}
ion-item {
  --padding-start: var(--app-page-gutter);
  --padding-end: var(--app-page-gutter);
  --color: var(--app-color-dark);
  --background-focused: var(--app-color-surface);
  --ion-item-border-color: var(--app-color-divider);
}
ion-item .ion-valid {
  --highlight-color-valid: var(--app-color-dark) !important;
}
ion-item-divider {
  min-height: 0.5rem;
  --background: transparent;
  border-bottom: 2px solid var(--app-color-secondary) !important;
}
ion-label {
  color: var(--app-color-dark) !important;
  white-space: normal !important;
}
.label-stacked.sc-ion-label-md-h {
  font-size: var(--app-text-sm) !important;
  -webkit-transform: translateY(30%) !important;
  transform: translateY(30%) !important;
}
ion-list {
  background: var(--app-color-surface);
}
ion-loading.loading-message .loading-wrapper {
  border-radius: var(--app-radius-lg) !important;
}
ion-modal {
  --height: auto !important;
  --width: 34rem !important;
  --max-height: 90vh;
  --max-width: 90vw;
  --border-radius: var(--app-radius-lg);
  --backdrop-opacity: var(--app-overlay-backdrop-opacity);
  --box-shadow: var(--app-shadow-overlay);
}
ion-modal::part(content),
ion-popover::part(content) {
  background: var(--app-overlay-panel-surface);
  border: var(--app-border-strong);
  border-radius: var(--app-radius-lg);
  color: var(--app-overlay-text);
  overflow: hidden;
}
ion-modal.nested-modal {
  --width: 28rem !important;
}
.ai-button,
.ai-fab-button {
  --border-width: 1px;
  --border-style: solid;
  --border-color: var(--ai-button-border);
  --background:
    linear-gradient(
      
      180deg,
      var(--ai-button-surface-top) 0%,
      var(--ai-button-surface-mid) 58%,
      var(--ai-button-surface-bottom) 100% ) !important;
  --background-hover:
    linear-gradient(
      
      180deg,
      var(--ai-button-surface-top-hover) 0%,
      var(--ai-button-surface-mid-hover) 55%,
      var(--ai-button-surface-bottom-hover) 100% ) !important;
  --background-focused:
    linear-gradient(
      
      180deg,
      var(--ai-button-surface-top-hover) 0%,
      var(--ai-button-surface-mid-hover) 55%,
      var(--ai-button-surface-bottom-hover) 100% ) !important;
  --background-activated:
    linear-gradient(
      
      180deg,
      var(--ai-button-surface-top-active) 0%,
      var(--ai-button-surface-mid-active) 52%,
      var(--ai-button-surface-bottom-active) 100% ) !important;
  --color: var(--ai-button-text);
  text-transform: none;
}
.ai-button::part(native),
.ai-fab-button::part(native) {
  box-shadow: var(--ai-button-shadow-rest);
  transition:
    transform var(--app-motion-fast) var(--app-ease-standard),
    box-shadow var(--app-motion-fast) var(--app-ease-standard),
    border-color var(--app-motion-fast) var(--app-ease-standard),
    background var(--app-motion-fast) var(--app-ease-standard);
}
.ai-button:hover::part(native),
.ai-button.ion-focused::part(native),
.ai-button:focus-visible::part(native),
.ai-fab-button:hover::part(native),
.ai-fab-button.ion-focused::part(native),
.ai-fab-button:focus-visible::part(native) {
  transform: translateY(-1px);
  border-color: var(--ai-button-border-hover);
  box-shadow: var(--ai-button-shadow-hover);
}
.ai-button[disabled]::part(native),
.ai-fab-button[disabled]::part(native) {
  box-shadow: none;
  border-color: var(--ai-button-border-disabled);
  opacity: var(--app-disabled-opacity);
}
.ai-button-inline {
  min-height: 1.7rem;
  height: 1.7rem;
  --border-radius: var(--app-radius-pill);
  --padding-start: 0.5rem;
  --padding-end: 0.65rem;
  font-size: 0.8rem;
}
.ai-button-hero {
  height: 2.3rem;
  --border-radius: var(--app-radius-pill);
  --padding-start: 0.85rem;
  --padding-end: 1rem;
}
.ai-fab-button {
  width: 3.5rem;
  height: 3.5rem;
  --border-radius: var(--app-radius-circle);
  --padding-start: 0;
  --padding-end: 0;
}
.ai-button-icon {
  display: block;
}
.ai-button-icon-inline {
  width: 1rem;
  height: 1rem;
}
.ai-button-icon-hero {
  width: 1.45rem;
  height: 1.45rem;
}
.ai-button-icon-fab {
  width: 2rem;
  height: 2rem;
}
.ai-button-label {
  display: block;
  color: var(--ai-button-text);
  letter-spacing: 0.01em;
  text-align: left;
  white-space: normal;
}
.ai-button-label-inline {
  margin-left: 0.35rem;
  font-size: var(--app-text-sm);
  font-weight: var(--app-font-weight-medium);
}
.ai-button-label-hero {
  margin-left: 0.55rem;
  font-size: var(--app-text-base);
  font-weight: var(--app-font-weight-semibold);
}
.prompt-inline-token {
  display: inline-flex;
  align-items: center;
  border: 1px solid color-mix(in srgb, var(--app-color-mint-green) 34%, var(--app-color-gray-15));
  border-radius: var(--app-radius-xs);
  background: color-mix(in srgb, var(--app-color-light-green) 42%, var(--app-color-surface));
  color: color-mix(in srgb, var(--app-color-mint-green) 72%, var(--app-color-dark) 28%);
  box-shadow: inset 0 -1px 0 color-mix(in srgb, var(--app-color-mint-green) 12%, transparent);
  font-size: 0.92em;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: normal;
  padding: 0.05rem 0.35rem 0.08rem;
  vertical-align: baseline;
  white-space: nowrap;
}
body.dark .prompt-inline-token {
  border-color: color-mix(in srgb, var(--app-color-mint-green) 30%, var(--app-color-divider));
  background: color-mix(in srgb, var(--app-color-mint-green) 12%, var(--app-color-surface-raised));
  color: color-mix(in srgb, var(--app-color-mint-green) 62%, var(--app-color-dark) 38%);
  box-shadow: inset 0 -1px 0 color-mix(in srgb, var(--app-color-mint-green) 16%, transparent);
}
.modal-chip-group .mat-mdc-standard-chip .mdc-evolution-chip__text-label {
  font-size: var(--app-text-sm) !important;
}
.modal-chip-group .mat-mdc-standard-chip.mdc-evolution-chip--with-primary-graphic .mdc-evolution-chip__graphic {
  padding-left: 4px !important;
  padding-right: 4px !important;
}
.modal-chip-group .mat-mdc-standard-chip.mdc-evolution-chip--with-primary-graphic .mdc-evolution-chip__action--primary {
  padding-right: 8px;
}
.metrics-input-wrapper .native-input {
  font-size: var(--app-text-md) !important;
}
.native-input-offset .native-input {
  margin-top: 0.3rem;
}
.billing-action-sheet .action-sheet-group {
  background: var(--app-overlay-menu-surface) !important;
  border: var(--app-overlay-border);
  border-radius: var(--app-radius-lg);
  box-shadow: var(--app-shadow-overlay);
}
.billing-action-sheet .action-sheet-title {
  color: var(--app-overlay-text);
  font-size: var(--app-text-sm-plus);
  font-weight: var(--app-font-weight-semibold);
  letter-spacing: var(--app-tracking-default);
}
.billing-action-sheet .action-sheet-button {
  color: var(--app-color-dark) !important;
  min-height: 2.75rem;
  padding-inline: var(--app-space-4);
  background: transparent !important;
}
.billing-action-sheet .action-sheet-selected {
  background: var(--app-overlay-hover-state) !important;
}
.billing-action-sheet .action-sheet-button-inner,
.billing-action-sheet .action-sheet-button.sc-ion-action-sheet-md {
  color: var(--app-overlay-text);
  font-size: var(--app-text-md);
}
.billing-action-sheet .action-sheet-cancel {
  background: var(--app-overlay-menu-surface) !important;
  border: var(--app-overlay-border);
  border-radius: var(--app-radius-lg);
  box-shadow: var(--app-shadow-overlay);
}
.error-title :is(b, strong, span),
.error-text :is(a, b, strong, span) {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  vertical-align: baseline;
}
body ion-modal.modal-default.show-modal:last-of-type {
  --box-shadow: var(--app-shadow-overlay) !important;
  --backdrop-opacity: var(--app-overlay-backdrop-opacity) !important;
}
.popover-on-top {
  z-index: var(--app-z-overlay-top) !important;
  --border-radius: var(--app-radius-lg) !important;
}
.popover-on-top::part(content) {
  background: var(--app-overlay-panel-surface);
  border: var(--app-overlay-border);
  border-radius: var(--app-radius-lg);
  box-shadow: var(--app-shadow-overlay);
  overflow: hidden;
}
.overlay-editor-content {
  --background: transparent;
  --padding-top: var(--app-space-4);
  --padding-bottom: var(--app-space-3);
  --padding-start: 0;
  --padding-end: 0;
  color: var(--app-overlay-text);
}
.overlay-editor-panel {
  margin: 0 var(--app-space-4);
  padding: var(--app-space-4);
  background: var(--app-color-surface);
  border: var(--app-border-subtle);
  border-radius: var(--app-radius-md);
}
.overlay-editor-card {
  margin: 0 var(--app-space-4);
  background: var(--app-color-surface);
  box-shadow: none;
}
.overlay-editor-card ion-card-content {
  padding: 0;
}
.overlay-editor-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--app-space-2);
  padding: 0 var(--app-space-4);
  margin-top: var(--app-space-3);
}
.overlay-editor-actions ion-button {
  margin: 0;
}
.overlay-editor-copy {
  color: var(--app-color-dark);
}
.overlay-editor-note {
  color: var(--app-color-gray-55);
  font-size: var(--app-text-sm);
  line-height: 1.4;
}
.embedded-info-section {
  margin: 0 calc(-1 * var(--app-card-padding-x));
  padding: 0.8rem var(--app-card-padding-x) 0.95rem;
  background: color-mix(in srgb, var(--app-color-surface-sunken) 82%, var(--app-color-surface) 18%);
  border-top: 1px solid var(--app-border-strong-color);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--app-color-always-white) 5%, transparent);
}
.embedded-info-label {
  display: inline-flex;
  align-items: center;
  min-height: 1.45rem;
  border: 1px solid color-mix(in srgb, var(--app-color-accent) 24%, var(--app-border-subtle-color));
  border-radius: var(--app-radius-xs);
  background: color-mix(in srgb, var(--app-color-accent) 12%, var(--app-color-surface));
  color: color-mix(in srgb, var(--app-color-accent) 68%, var(--app-color-dark) 32%);
  padding: 0.15rem 0.55rem;
  font-size: var(--app-text-xs);
  font-weight: var(--app-font-weight-bold);
  letter-spacing: var(--app-tracking-label);
  text-transform: uppercase;
}
.embedded-info-body {
  margin-top: 0.65rem;
}
ion-progress-bar {
  --background: var(--app-color-gray-20);
  --progress-background: var(--app-color-gray-80);
}
ion-select-popover {
  color: var(--app-overlay-text);
}
ion-select-popover ion-list {
  background: transparent;
  padding: 0;
}
ion-select-popover ion-list-header {
  min-height: 2.75rem;
  padding-inline: var(--app-space-4);
  font-size: var(--app-text-sm-plus);
  font-weight: var(--app-font-weight-semibold);
  color: var(--app-overlay-text);
}
ion-select-popover ion-item {
  --background: transparent;
  --color: var(--app-overlay-text);
  --padding-start: var(--app-space-4);
  --padding-end: 0;
  --inner-padding-end: var(--app-space-4);
  --inner-border-width: 0;
  --min-height: 2.75rem;
  font-size: var(--app-text-md);
}
ion-select-popover ion-item.item-radio-checked,
ion-select-popover ion-item.item-checkbox-checked {
  --background: var(--app-overlay-hover-state);
  --background-hover: var(--app-overlay-hover-state);
  --background-focused: var(--app-overlay-focus-state);
  --background-focused-opacity: 1;
  --background-hover-opacity: 1;
}
ion-select-popover ion-item ion-label {
  color: inherit !important;
}
ion-select-popover ion-radio,
ion-select-popover ion-checkbox {
  --color: var(--app-color-accent);
  --color-checked: var(--app-color-accent);
}
ion-radio {
  color: var(--app-color-dark) !important;
  --color-checked: var(--app-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: var(--app-radius-sm);
  --placeholder-color: var(--app-color-dark-light);
  --background: var(--app-color-surface-sunken);
  border: var(--app-border-subtle);
  box-shadow: var(--app-shadow-none);
  color: var(--app-color-dark);
  padding-inline-start: 3rem !important;
}
ion-searchbar .searchbar-search-icon.sc-ion-searchbar-md {
  top: 7px;
}
ion-searchbar .searchbar-clear-icon {
  color: var(--app-color-dark-light);
}
ion-segment {
  --background: var(--app-color-segment);
  padding: 3px;
  border-radius: var(--app-radius-pill);
  box-shadow: inset 0 0 0 1px var(--app-color-chip-border);
}
ion-segment-button {
  min-width: 0;
  color: var(--app-color-dark-light);
  --color: var(--app-color-dark-light);
  --color-checked: var(--app-color-chip-selected-contrast);
  --indicator-color: var(--app-color-chip-selected);
  --indicator-box-shadow: var(--app-chip-shadow), inset 0 0 0 1px var(--app-color-chip-selected-border);
  --background: transparent;
  --border-radius: var(--app-radius-pill);
  margin: 0;
}
ion-segment-button ion-label {
  color: currentColor !important;
}
ion-segment-button.segment-button-checked {
  color: var(--app-color-chip-selected-contrast);
}
.segment-brand {
  --background: color-mix(in srgb, var(--app-color-gray-05) 88%, var(--app-color-surface) 12%);
}
.segment-brand ion-segment-button {
  color: var(--app-color-dark);
  --color: var(--app-color-dark);
  --color-checked: var(--app-color-dark);
  --indicator-color: var(--app-color-always-white);
  --indicator-box-shadow: var(--app-shadow-xs), inset 0 0 0 1px color-mix(in srgb, var(--app-color-divider) 86%, transparent);
}
.segment-brand ion-segment-button.segment-button-checked {
  color: var(--app-color-dark);
}
ion-select {
  color: var(--app-color-dark);
  height: 4rem !important;
}
ion-select::part(icon) {
  color: var(--app-color-dark);
  right: 0.5rem;
  top: 0.75rem;
}
ion-tab-bar {
  background: var(--app-color-primary-dark) !important;
  --border: 0;
}
ion-tab-button {
  background: transparent;
}
ion-textarea {
  color: var(--app-color-dark) !important;
  --highlight-color-focused: var(--app-color-dark) !important;
  --highlight-color-valid: var(--app-color-dark) !important;
  --highlight-color-invalid: var(--app-color-dark) !important;
}
ion-title {
  color: var(--app-color-primary-contrast);
  padding-inline: 1rem;
  font-size: var(--app-text-2xl);
}
ion-toggle {
  padding-left: 1rem;
  padding-top: 4px;
  --track-background-checked: var(--app-color-light-green);
  --handle-background-checked: var(--app-color-green);
  --track-background: var(--app-color-negative-light);
}
ion-toolbar {
  --color: var(--app-color-primary-contrast);
}
.ion-color-neutral {
  --ion-color-base: var(--app-color-neutral);
}
.ion-color-accent {
  --ion-color-base: var(--app-color-accent);
  --ion-color-contrast: var(--app-color-accent-contrast);
}
.ion-color-negative {
  --ion-color-base: var(--app-color-negative);
  --ion-color-contrast: var(--app-color-negative-contrast);
}
.custom-loader {
  border: 0.5rem solid var(--app-overlay-text);
  border-radius: var(--app-radius-circle);
  width: 3rem;
  height: 3rem;
  aspect-ratio: 1;
  --_m: conic-gradient(transparent 10%, var(--app-color-always-black)), linear-gradient(var(--app-color-always-black) 0 0) content-box;
  -webkit-mask: var(--_m);
  mask: var(--_m);
  -webkit-mask-composite: source-out;
  mask-composite: subtract;
  animation: l3 var(--app-motion-loader) infinite var(--app-ease-linear);
}
.custom-left-justify {
  text-align: left;
}
.swal2-modal {
  padding-left: 0;
  padding-right: 0;
  background-color: var(--app-color-surface-raised) !important;
  border: var(--app-border-strong) !important;
  border-radius: var(--app-radius-lg) !important;
  box-shadow: var(--app-shadow-overlay) !important;
  color: var(--app-color-dark) !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: color-mix(in srgb, var(--app-color-background) 72%, transparent);
}
.swal2-loading {
  max-width: 18rem !important;
}
.swal2-html-container b {
  font-size: var(--app-text-lg) !important;
}
.swal2-styled.swal2-cancel {
  height: 2.4rem;
  padding: 0.6375rem 1rem !important;
  color: var(--app-color-accent) !important;
  background-color: var(--app-color-surface) !important;
  border-width: 1px !important;
  border-color: var(--app-color-accent) !important;
  border-style: solid !important;
}
.app-loading {
  --spinner-color: var(--app-overlay-text);
}
ion-loading .loading-wrapper.sc-ion-loading-md {
  background: var(--app-overlay-panel-surface) !important;
  border: var(--app-overlay-border) !important;
  border-radius: var(--app-radius-lg);
  box-shadow: var(--app-shadow-overlay) !important;
}
ion-loading .loading-wrapper .loading-content {
  font-size: var(--app-text-lg);
  color: var(--app-overlay-text);
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes pulse {
  0% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--app-color-mint-green) 70%, transparent);
  }
  70% {
    transform: scale(1);
    box-shadow: 0 0 0 0.5rem transparent;
  }
  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 transparent;
  }
}
@keyframes fade {
  0% {
    opacity: var(--app-opacity-40);
  }
  50% {
    opacity: var(--app-opacity-100);
  }
  100% {
    opacity: var(--app-opacity-40);
  }
}
@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: var(--app-font-family);
  --shared-tracking: -0.2px;
  --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(--app-color-primary);
  --mat-theme-secondary: var(--app-color-secondary);
  --mat-theme-accent: var(--app-color-accent);
  --mat-datepicker-calendar-header-text-color: var(--app-color-dark);
  --mat-datepicker-calendar-date-text-color: var(--app-color-dark);
  --mat-datepicker-calendar-date-disabled-state-text-color: var(--app-color-gray-50);
  --mat-datepicker-calendar-period-button-icon-color: var(--app-color-dark);
  --mat-expansion-header-expanded-state-height: auto;
  --mat-expansion-header-indicator-color: var(--app-color-dark);
  --mat-icon-button-disabled-icon-color: var(--app-color-gray-50);
  --mat-menu-item-leading-spacing: 0;
  --mat-menu-item-trailing-spacing: 0;
  --mat-select-enabled-trigger-text-color: var(--app-color-dark);
  --mat-select-disabled-trigger-text-color: var(--app-color-gray-50);
}
body.dark {
  --mat-datepicker-calendar-header-text-color: var(--app-color-dark);
  --mat-datepicker-calendar-date-text-color: var(--app-color-dark);
  --mat-datepicker-calendar-date-disabled-state-text-color: var(--app-color-gray-50);
  --mat-datepicker-calendar-period-button-icon-color: var(--app-color-dark);
  --mat-expansion-header-indicator-color: var(--app-color-dark);
  --mat-icon-button-disabled-icon-color: var(--app-color-gray-50);
  --mat-select-enabled-trigger-text-color: var(--app-color-dark);
  --mat-select-disabled-trigger-text-color: var(--app-color-gray-50);
}
.mdc-checkbox__native-control:enabled:checked ~ .mdc-checkbox__background {
  color: var(--app-color-accent-contrast) !important;
  background-color: var(--app-color-accent) !important;
  border-color: var(--app-color-accent) !important;
}
.mat-mdc-chip.mat-mdc-chip-option {
  height: 32px;
  margin: 4px;
}
.mat-mdc-chip-action-label {
  font-size: var(--app-text-sm-plus);
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-selected {
  color: transparent !important;
  background: var(--app-color-chip-selected);
  border: 1px solid var(--app-color-chip-selected-border);
  box-shadow: var(--app-chip-shadow);
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-selected .mat-mdc-chip-action-label {
  color: var(--app-color-chip-selected-contrast) !important;
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary:not(.mat-mdc-chip-selected) {
  color: transparent !important;
  background: var(--app-color-chip);
  border: 1px solid var(--app-color-chip-border);
  box-shadow: var(--app-chip-shadow);
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary:not(.mat-mdc-chip-selected) .mat-mdc-chip-action-label {
  color: var(--app-color-chip-contrast) !important;
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-disabled {
  background: var(--app-color-chip-disabled) !important;
  border: 1px solid var(--app-color-chip-disabled-light) !important;
  box-shadow: none;
}
.mat-mdc-chip.mat-mdc-chip-option.mat-primary.mat-mdc-chip-disabled .mat-mdc-chip-action-label {
  color: var(--app-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: var(--app-radius-pill);
}
.mat-calendar-body-cell-content {
  border-width: 0 !important;
}
.mat-calendar-body-selected {
  color: var(--app-color-accent-contrast) !important;
  background-color: var(--app-color-accent) !important;
}
.mat-calendar-controls {
  margin-top: 0;
}
.mat-expansion-indicator svg {
  color: var(--app-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(--app-color-dark);
}
.mat-accordion .mat-expansion-panel {
  margin: 0.5rem;
  border: var(--app-border-subtle);
  border-radius: var(--app-radius-md);
  box-shadow: var(--app-shadow-none) !important;
}
.mat-expansion-panel .mat-expansion-panel-header {
  height: auto;
  padding: 0.5rem 1rem;
  background: var(--app-color-surface) !important;
  border-radius: var(--app-radius-md) var(--app-radius-md) 0 0;
  display: flex;
  align-items: flex-start;
}
.mat-expansion-panel .mat-expansion-panel-content .mat-expansion-panel-body {
  background: var(--app-color-surface) !important;
  padding-bottom: 0.5rem;
}
.mat-mdc-form-field-subscript-wrapper {
  display: none;
}
.centered-sorted-header .mat-sort-header-container {
  width: 100%;
  justify-content: center;
}
.mat-mdc-menu-panel {
  --mdc-menu-container-color: var(--app-overlay-menu-surface);
  --mat-menu-container-color: var(--app-overlay-menu-surface);
  --mat-menu-item-label-text-color: var(--app-overlay-text);
  --mat-menu-item-icon-color: var(--app-overlay-icon);
  --mat-menu-item-hover-state-layer-color: var(--app-overlay-hover-state);
  --mat-menu-item-focus-state-layer-color: var(--app-overlay-focus-state);
  background-color: var(--app-overlay-menu-surface) !important;
  color: var(--app-overlay-text);
  padding-left: 1rem;
  padding-right: 1rem;
  border: var(--app-overlay-border);
  border-radius: var(--app-radius-lg) !important;
  box-shadow: var(--app-shadow-overlay) !important;
}
.mat-mdc-menu-panel ion-icon {
  margin-right: 0.5rem;
}
.mat-mdc-menu-content {
  background: var(--app-overlay-menu-surface) !important;
}
.mat-mdc-menu-panel.mdc-menu-surface {
  background-color: var(--app-overlay-menu-surface) !important;
}
.mat-mdc-menu-item {
  background: transparent !important;
  -webkit-user-select: none;
  user-select: none;
}
.mat-mdc-menu-item:hover,
.mat-mdc-menu-item.cdk-program-focused,
.mat-mdc-menu-item.cdk-keyboard-focused,
.mat-mdc-menu-item.mat-mdc-menu-item-highlighted {
  background: var(--app-overlay-hover-state) !important;
}
.short-menu {
  height: 14.5rem !important;
}
.action-popup-menu,
.trends-action-menu {
  min-width: 16rem !important;
  max-width: calc(100vw - 2rem) !important;
}
.action-popup-menu .mat-mdc-menu-content,
.trends-action-menu .mat-mdc-menu-content {
  width: auto;
  min-width: 100%;
}
.action-popup-menu .mat-mdc-menu-item-text,
.trends-action-menu .mat-mdc-menu-item-text {
  display: block;
  width: 100%;
}
.menu-action-row {
  display: flex;
  align-items: center;
  gap: var(--app-space-2);
  line-height: 1;
  min-height: 3rem;
  width: 100%;
  color: inherit;
  background-color: transparent;
}
.menu-action-icon {
  color: inherit;
  align-self: center;
  display: block;
  flex: 0 0 1.5rem;
  width: 1.5rem;
  height: 1.5rem;
  font-size: 1.5rem;
}
.menu-action-text {
  display: block;
  color: inherit;
  line-height: 1.2;
  white-space: nowrap;
}
.mat-mdc-menu-panel .mat-mdc-menu-item,
.mat-mdc-menu-panel .mat-mdc-menu-item-text,
.mat-mdc-menu-panel .action-row,
.mat-mdc-menu-panel .action-text,
.mat-mdc-menu-panel .menu-action-row,
.mat-mdc-menu-panel .menu-action-text {
  color: var(--app-overlay-text) !important;
  -webkit-user-select: none;
  user-select: none;
}
body.dark .menu-action-icon,
body.dark .mat-mdc-menu-panel ion-icon {
  color: var(--app-color-accent-light) !important;
}
.mat-mdc-menu-panel .mat-pseudo-checkbox {
  display: none;
}
.mat-mdc-paginator {
  background-color: var(--app-color-surface) !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(--app-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: var(--app-text-md) !important;
}
.mat-mdc-select-panel {
  --mat-option-label-text-color: var(--app-overlay-text);
  --mat-option-selected-state-label-text-color: var(--app-overlay-text);
  --mat-option-hover-state-layer-color: var(--app-overlay-hover-state);
  --mat-option-focus-state-layer-color: var(--app-overlay-focus-state);
  --mat-option-selected-state-layer-color: color-mix( in srgb, var(--app-color-accent) 12%, var(--app-overlay-menu-surface) );
  background-color: var(--app-overlay-menu-surface) !important;
  border: var(--app-overlay-border);
  border-radius: var(--app-radius-md) !important;
  box-shadow: var(--app-shadow-overlay) !important;
  max-height: 50vh !important;
}
.mat-mdc-select-panel .mat-pseudo-checkbox {
  display: none;
}
.mat-mdc-option {
  color: var(--app-overlay-text) !important;
  -webkit-user-select: none;
  user-select: none;
}
.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;
  margin-right: 2px;
}
.mat-mdc-table {
  background-color: transparent !important;
}
.mat-mdc-header-cell,
.mat-mdc-cell,
.mat-mdc-footer-cell {
  padding: 0 !important;
  color: var(--app-color-dark);
}
.mat-mdc-tooltip {
  white-space: pre-line;
  max-width: 15rem;
}
.cdk-overlay-pane.mat-mdc-tooltip-panel .mat-mdc-tooltip {
  color: var(--app-tooltip-text);
  background-color: var(--app-tooltip-surface);
  border: var(--app-tooltip-border);
  box-shadow: var(--app-shadow-xs);
  font-size: 0.8rem;
}
.user-bubble p,
.user-bubble p strong {
  margin: 0 0.4rem !important;
}
.assistant-message h1 {
  color: var(--app-color-black);
  font-size: 1.2rem;
  font-weight: bold;
  margin: 1rem 0;
}
.assistant-message h2,
.assistant-message h2 strong {
  color: var(--app-color-dark);
  font-size: 1.1rem;
  font-weight: 700;
  margin: 1rem 0;
}
.assistant-message h3 {
  color: var(--app-color-dark);
  font-size: 1rem;
  font-weight: bold;
  margin: 0.8rem 0;
}
.assistant-message h4,
.assistant-message h5,
.assistant-message h6 {
  color: var(--app-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;
}
body.app-bp-below-sm .assistant-message ul,
body.app-bp-below-sm .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 ul li code,
.assistant-message ol li,
.assistant-message ol li strong,
.assistant-message ol li em,
.assistant-message ol li a,
.assistant-message ol li code {
  margin-bottom: 0.4rem;
  font-size: var(--app-text-md);
}
.assistant-message p,
.assistant-message p strong,
.assistant-message p em,
.assistant-message p a,
.assistant-message p code {
  font-size: var(--app-text-md) !important;
  margin: 0.5rem 0 !important;
}
.assistant-message ul li code,
.assistant-message ol li code {
  font-weight: bold;
}
.subparagraph-break {
  display: block;
  margin: 0.5rem 0;
}
.assistant-message table {
  border-collapse: collapse;
  margin: 0.5rem auto;
  border: 1px solid var(--app-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: var(--app-text-sm);
  padding: 0.4rem 0.7rem;
  text-align: left;
}
.assistant-message th strong,
.assistant-message td strong,
.assistant-message th em,
.assistant-message td em,
.assistant-message th a,
.assistant-message td a {
  font-size: var(--app-text-sm);
}
.assistant-message th {
  color: var(--app-color-accent-contrast);
  background: var(--app-color-accent);
}
.assistant-message td {
  white-space: normal;
  overflow-wrap: anywhere;
}
.assistant-message td.numeric {
  text-align: center;
  white-space: nowrap;
}
.assistant-message td.currency {
  text-align: right;
  white-space: nowrap;
}
.assistant-message th.date,
.assistant-message td.date,
.assistant-message th.time,
.assistant-message td.time {
  white-space: nowrap;
}
.assistant-message tr:nth-child(even) td {
  background: color-mix(in srgb, var(--app-color-accent) 10%, transparent);
}
.assistant-message pre code {
  font-size: var(--app-text-sm);
}
blockquote {
  font-style: italic;
  border-left: 6px solid var(--app-color-accent);
  background: color-mix(in srgb, var(--app-color-accent) 10%, transparent);
  color: var(--app-color-dark);
  padding: 0.5rem 1rem;
  margin: 1rem 0;
  border-radius: 0 var(--app-radius-sm) var(--app-radius-sm) 0;
}
blockquote strong,
blockquote b {
  color: inherit;
}
.language-error {
  display: block;
  font-size: var(--app-text-base) !important;
  border-left: 6px solid var(--app-color-negative);
  border-right: 0;
  background: color-mix(in srgb, var(--app-color-negative) 8%, transparent);
  color: var(--app-color-dark);
  padding: 0.75rem 1rem 0.75rem 3rem;
  border-radius: 0 var(--app-radius-sm) var(--app-radius-sm) 0;
  position: relative;
  white-space: normal;
  overflow: visible;
  overflow-wrap: anywhere;
}
.language-error::before {
  content: "\26a0\fe0f";
  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;
  width: 1.5rem;
  pointer-events: none;
}
.language-error strong,
.language-error b {
  color: inherit;
}
.stream-status {
  font-size: var(--app-text-md);
  font-style: italic;
  color: var(--app-color-dark);
  margin-top: 1rem;
  margin-left: 0.5rem;
  margin-bottom: 1.5rem;
}
@keyframes pulse2 {
  0%, 100% {
    opacity: var(--app-opacity-90);
    transform: scale(1);
  }
  50% {
    opacity: var(--app-opacity-100);
    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 sparklesTwinkle {
  0% {
    opacity: var(--app-opacity-70);
  }
  12% {
    opacity: var(--app-opacity-100);
  }
  24% {
    opacity: var(--app-opacity-85);
  }
  36% {
    opacity: var(--app-opacity-100);
  }
  48% {
    opacity: var(--app-opacity-95);
  }
  100% {
    opacity: var(--app-opacity-70);
  }
}
@keyframes shake {
  0%, 100% {
    transform: rotate(-5deg);
  }
  50% {
    transform: rotate(5deg);
  }
}
.stream-status .dots,
.waiting-status .dots {
  display: inline-block;
  font-weight: bold;
  margin-left: 0.25rem;
}
.stream-status .dots span,
.waiting-status .dots span {
  opacity: var(--app-opacity-50);
  animation: blink 1.4s infinite both;
}
.stream-status .dots span:nth-child(2),
.waiting-status .dots span:nth-child(2) {
  animation-delay: 0.2s;
}
.stream-status .dots span:nth-child(3),
.waiting-status .dots span:nth-child(3) {
  animation-delay: 0.4s;
}
@keyframes blink {
  0%, 80%, 100% {
    opacity: var(--app-opacity-20);
  }
  40% {
    opacity: var(--app-opacity-100);
  }
}
.stream-cursor.blink {
  animation: cursor-blink 1s steps(2, start) infinite;
  margin-bottom: 1.5rem;
}
@keyframes cursor-blink {
  0%, 100% {
    opacity: var(--app-opacity-100);
  }
  50% {
    opacity: var(--app-opacity-0);
  }
}
.chip-line,
.chip-line b,
.chip-line strong,
.chip-line-second,
.chip-line-second b,
.chip-line-second strong {
  font-size: var(--app-text-sm);
}
:root {
  --app-space-0: 0;
  --app-space-1: 4px;
  --app-space-2: 8px;
  --app-space-3: 12px;
  --app-space-4: 16px;
  --app-space-5: 24px;
  --app-space-6: 32px;
  --app-space-7: 48px;
  --app-page-gutter: var(--app-space-4);
  --app-section-gap-sm: var(--app-space-3);
  --app-section-gap-md: var(--app-space-4);
  --app-section-gap-lg: var(--app-space-5);
  --app-card-gap-x: var(--app-space-2);
  --app-card-gap-y: var(--app-space-1);
  --app-card-gap-x-wide: var(--app-space-4);
  --app-card-padding-x: var(--app-space-4);
  --app-card-padding-y: var(--app-space-3);
  --app-card-padding-dense-y: var(--app-space-2);
  --app-band-padding-x: var(--app-space-4);
  --app-band-gap-after: var(--app-space-2);
  --app-control-gap: var(--app-space-2);
  --app-control-gap-sm: var(--app-space-1);
  --app-control-height-sm: 1.8rem;
  --app-control-height-xs: 1.6rem;
  --app-inline-icon-gap: var(--app-space-2);
  --app-inline-icon-gap-sm: var(--app-space-1);
  --app-chip-gap-x: var(--app-space-2);
  --app-chip-gap-y: var(--app-space-1);
  --app-chip-padding-x: var(--app-space-3);
  --app-chip-padding-x-compact: var(--app-space-2);
  --app-numbered-indent: 1.6rem;
  --app-radius-xs: 4px;
  --app-radius-sm: 8px;
  --app-radius-md: 12px;
  --app-radius-lg: 16px;
  --app-radius-pill: 999px;
  --app-radius-circle: 50%;
  --app-font-family: "Open Sans", sans-serif;
  --app-font-size-root: 16px;
  --app-text-2xs: 0.625rem;
  --app-text-xs: 0.7rem;
  --app-text-sm: 0.8rem;
  --app-text-sm-plus: 0.875rem;
  --app-text-md: 0.9rem;
  --app-text-base: 1rem;
  --app-text-lg: 1.1rem;
  --app-text-xl: 1.2rem;
  --app-text-2xl: 1.3rem;
  --app-text-3xl: 1.5rem;
  --app-text-4xl: 1.625rem;
  --app-font-weight-regular: 400;
  --app-font-weight-medium: 500;
  --app-font-weight-semibold: 600;
  --app-font-weight-bold: 700;
  --app-tracking-default: -0.2px;
  --app-tracking-label: 0.04em;
  --app-tracking-label-wide: 0.08em;
  --app-tracking-section: 0.12em;
  --app-color-primary: #2f3942;
  --app-color-primary-dark: #232b33;
  --app-color-primary-light: #46525d;
  --app-color-primary-contrast: #ffffff;
  --app-color-accent: #5f7d96;
  --app-color-accent-light: #7697b0;
  --app-color-accent-dark: #49677f;
  --app-color-accent-contrast: #ffffff;
  --app-color-secondary: #252a2e;
  --app-color-secondary-light: #3a4249;
  --app-color-secondary-contrast: #ffffff;
  --app-color-warning: #ffa726;
  --app-color-warning-contrast: #000000;
  --app-color-positive: #4daf1b;
  --app-color-positive-light: #5dd421;
  --app-color-positive-arrow: #80e34f;
  --app-color-negative: #e12d39;
  --app-color-negative-contrast: #ffffff;
  --app-color-negative-light: #f7c9cd;
  --app-color-negative-background: #e6e6e6;
  --app-color-negative-arrow: #ff4652;
  --app-color-neutral: #f4f4f4;
  --app-color-surface: #ffffff;
  --app-color-surface-raised: #fbfbfb;
  --app-color-surface-sunken: #f6f7f8;
  --app-color-background: #f2f2f2;
  --app-color-background-light: #fbfbfb;
  --app-color-calendar-background: var(--app-color-surface);
  --app-color-segment: var(--app-color-surface-sunken);
  --app-color-divider: #c8c8c8;
  --app-color-dark: #252a2e;
  --app-color-dark-light: var(--app-color-gray-60);
  --app-color-dark-contrast: #ffffff;
  --app-color-dark-rgb:
    37,
    42,
    46;
  --app-color-light: var(--app-color-gray-15);
  --app-color-light-contrast: var(--app-color-black);
  --app-color-light-rgb:
    217,
    217,
    217;
  --app-color-black: #000000;
  --app-color-gray-95: #0d0d0d;
  --app-color-gray-90: #1a1a1a;
  --app-color-gray-85: #252a2e;
  --app-color-gray-80: #333333;
  --app-color-gray-75: #404040;
  --app-color-gray-70: #4d4d4d;
  --app-color-gray-65: #595959;
  --app-color-gray-60: #666666;
  --app-color-gray-55: #737373;
  --app-color-gray-50: #808080;
  --app-color-gray-45: #8c8c8c;
  --app-color-gray-40: #999999;
  --app-color-gray-35: #a6a6a6;
  --app-color-gray-30: #b3b3b3;
  --app-color-gray-25: #bfbfbf;
  --app-color-gray-20: #cccccc;
  --app-color-gray-15: #d9d9d9;
  --app-color-gray-10: #e6e6e6;
  --app-color-gray-05: #f2f2f2;
  --app-color-gray-01: #f9f9f9;
  --app-color-white: #ffffff;
  --app-color-chip: var(--app-color-surface-raised);
  --app-color-chip-border: color-mix(in srgb, var(--app-color-divider) 92%, transparent);
  --app-color-chip-contrast: var(--app-color-black);
  --app-color-chip-selected: var(--app-color-primary);
  --app-color-chip-selected-border: color-mix( in srgb, var(--app-color-always-white) 18%, var(--app-color-primary-dark) 82% );
  --app-color-chip-selected-contrast: var(--app-color-white);
  --app-color-chip-disabled: var(--app-color-gray-10);
  --app-color-chip-disabled-light: var(--app-color-gray-15);
  --app-color-chip-disabled-contrast: var(--app-color-gray-35);
  --app-chip-shadow:
    0 3px 1px -2px color-mix(in srgb, var(--app-color-always-black) 20%, transparent),
    0 2px 2px 0 color-mix(in srgb, var(--app-color-always-black) 14%, transparent),
    0 1px 5px 0 color-mix(in srgb, var(--app-color-always-black) 12%, transparent);
  --app-border-subtle-color: color-mix(in srgb, var(--app-color-divider) 58%, transparent);
  --app-border-strong-color: color-mix(in srgb, var(--app-color-divider) 88%, var(--app-color-primary-dark) 12%);
  --app-border-subtle: 1px solid var(--app-border-subtle-color);
  --app-border-strong: 1px solid var(--app-border-strong-color);
  --app-z-content: 1;
  --app-z-content-raised: 2;
  --app-z-floating-subtle: 9;
  --app-z-floating: 10;
  --app-z-sticky: 30;
  --app-z-fab: 999;
  --app-z-splash: 9999;
  --app-z-splash-brand: 10000;
  --app-z-overlay-top: 99999;
  --app-shadow-none: none;
  --app-shadow-xs: 0 1px 2px color-mix(in srgb, var(--app-color-always-black) 9%, transparent);
  --app-shadow-sm: 0 8px 20px color-mix(in srgb, var(--app-color-always-black) 9%, transparent);
  --app-shadow-overlay: 0 20px 48px color-mix(in srgb, var(--app-color-always-black) 18%, transparent), 0 8px 20px color-mix(in srgb, var(--app-color-always-black) 10%, transparent);
  --app-focus-ring: 0 0 0 3px color-mix(in srgb, var(--app-color-accent) 22%, transparent);
  --app-motion-fast: 140ms;
  --app-motion-quick: 200ms;
  --app-motion-base: 300ms;
  --app-motion-emphasized: 350ms;
  --app-motion-slow: 500ms;
  --app-motion-slower: 800ms;
  --app-motion-expand: 1000ms;
  --app-motion-loader: 1000ms;
  --app-ease-standard: ease;
  --app-ease-soft: ease-in-out;
  --app-ease-emphasized: cubic-bezier(0.4, 0, 0.2, 1);
  --app-ease-linear: linear;
  --app-overlay-panel-surface: var(--app-color-surface-raised);
  --app-overlay-menu-surface: var(--app-color-background);
  --app-overlay-text: var(--app-color-dark);
  --app-overlay-icon: var(--app-color-dark-light);
  --app-overlay-border: var(--app-border-strong);
  --app-overlay-hover-state: color-mix(in srgb, var(--app-color-accent) 10%, var(--app-overlay-menu-surface));
  --app-overlay-focus-state: color-mix(in srgb, var(--app-color-accent) 14%, var(--app-overlay-menu-surface));
  --app-tooltip-surface: color-mix(in srgb, var(--app-color-always-black) 84%, transparent);
  --app-tooltip-text: var(--app-color-always-white);
  --app-tooltip-border: 1px solid color-mix(in srgb, var(--app-color-always-white) 10%, transparent);
  --app-opacity-0: 0;
  --app-opacity-20: 0.2;
  --app-opacity-25: 0.25;
  --app-opacity-35: 0.35;
  --app-opacity-40: 0.4;
  --app-opacity-50: 0.5;
  --app-opacity-70: 0.7;
  --app-opacity-72: 0.72;
  --app-opacity-75: 0.75;
  --app-opacity-85: 0.85;
  --app-opacity-90: 0.9;
  --app-opacity-95: 0.95;
  --app-opacity-100: 1;
  --app-disabled-opacity: var(--app-opacity-72);
  --app-overlay-backdrop-opacity: 0.32;
  --app-color-always-black: #000000;
  --app-color-always-dark: #252a2e;
  --app-color-always-light: #ededed;
  --app-color-always-white: #ffffff;
  --app-color-green: #008000;
  --app-color-light-green: #c6e6e1;
  --app-color-mint-green: #75daad;
  --app-color-aqua: #54c0eb;
  --app-color-google: #4285f4;
  --ion-font-family: var(--app-font-family);
  --ion-color-primary: var(--app-color-primary);
  --ion-color-primary-contrast: var(--app-color-primary-contrast);
  --ion-color-secondary: var(--app-color-secondary);
  --ion-color-secondary-contrast: var(--app-color-secondary-contrast);
  --ion-color-warning: var(--app-color-warning);
  --ion-color-warning-contrast: var(--app-color-warning-contrast);
  --ion-color-dark: var(--app-color-dark);
  --ion-color-dark-rgb: var(--app-color-dark-rgb);
  --ion-color-light: var(--app-color-light);
  --ion-color-light-contrast: var(--app-color-light-contrast);
  --ion-color-light-rgb: var(--app-color-light-rgb);
  --ion-background-color: var(--app-color-surface);
  --ion-tab-bar-background: var(--app-color-white);
  --ion-tab-bar-border-color: var(--app-color-primary);
  --ion-tab-bar-color-activated: var(--app-color-primary);
  --ion-tab-bar-color: var(--app-color-accent);
  --ai-button-surface-top: #fffefd;
  --ai-button-surface-mid: #fdfaf1;
  --ai-button-surface-bottom: #faf3e1;
  --ai-button-surface-top-hover: #ffffff;
  --ai-button-surface-mid-hover: #fefbf3;
  --ai-button-surface-bottom-hover: #fbf5e5;
  --ai-button-surface-top-active: #fefbf2;
  --ai-button-surface-mid-active: #faf2df;
  --ai-button-surface-bottom-active: #f4e7c7;
  --ai-button-border: color-mix(in srgb, #ab8b50 28%, transparent);
  --ai-button-border-hover: color-mix(in srgb, #ab8b50 40%, transparent);
  --ai-button-border-disabled: color-mix(in srgb, #ab8b50 22%, transparent);
  --ai-button-shadow-rest:
    inset 0 1px 0 color-mix(in srgb, var(--app-color-always-white) 98%, transparent),
    0 6px 14px color-mix(in srgb, var(--app-color-black) 9%, transparent),
    0 2px 4px color-mix(in srgb, #ab8b50 12%, transparent);
  --ai-button-shadow-hover:
    inset 0 1px 0 color-mix(in srgb, var(--app-color-always-white) 99%, transparent),
    0 8px 18px color-mix(in srgb, var(--app-color-black) 12%, transparent),
    0 0 0 3px color-mix(in srgb, #ab8b50 12%, transparent);
  --ai-button-text: var(--app-color-always-dark);
}
body.dark {
  --app-color-primary: #4b5f70;
  --app-color-primary-dark: #394b59;
  --app-color-primary-light: #607487;
  --app-color-accent: #84a6bf;
  --app-color-accent-light: #99b7cc;
  --app-color-accent-dark: #6b899f;
  --app-color-accent-contrast: #ffffff;
  --app-color-secondary: #32404d;
  --app-color-secondary-light: #40505f;
  --app-color-secondary-contrast: #f5f8fb;
  --app-color-warning: #ffce00;
  --app-color-warning-contrast: #000000;
  --app-color-surface: #1c242e;
  --app-color-surface-raised: #27313f;
  --app-color-surface-sunken: #18202a;
  --app-color-background: var(--app-color-gray-01);
  --app-color-background-light: var(--app-color-gray-05);
  --app-color-calendar-background: var(--app-color-surface-sunken);
  --app-color-segment: var(--app-color-surface-sunken);
  --app-color-divider: #3a4654;
  --app-color-dark: #eaf0f5;
  --app-color-dark-light: #b0bcc8;
  --app-color-dark-contrast: var(--app-color-gray-01);
  --app-color-dark-rgb:
    234,
    240,
    245;
  --app-color-light: var(--app-color-surface-raised);
  --app-color-light-contrast: var(--app-color-dark);
  --app-color-light-rgb:
    39,
    49,
    63;
  --app-color-black: #f5f8fb;
  --app-color-gray-95: #f4f7fa;
  --app-color-gray-90: #e8edf2;
  --app-color-gray-85: #d9e2ea;
  --app-color-gray-80: #c7d1db;
  --app-color-gray-75: #b5c0cb;
  --app-color-gray-70: #a4b0bc;
  --app-color-gray-65: #92a0ad;
  --app-color-gray-60: #80909f;
  --app-color-gray-55: #718191;
  --app-color-gray-50: #627283;
  --app-color-gray-45: #546475;
  --app-color-gray-40: #465566;
  --app-color-gray-35: #3a4757;
  --app-color-gray-30: #303b4a;
  --app-color-gray-25: #27313f;
  --app-color-gray-20: #212a35;
  --app-color-gray-15: #1c242e;
  --app-color-gray-10: #18202a;
  --app-color-gray-05: #141b23;
  --app-color-gray-01: #10161d;
  --app-color-white: var(--app-color-surface);
  --app-color-chip: var(--app-color-surface-raised);
  --app-color-chip-border: color-mix(in srgb, var(--app-color-always-white) 30%, transparent);
  --app-color-chip-contrast: var(--app-color-dark);
  --app-color-chip-selected: var(--app-color-primary);
  --app-color-chip-selected-border: color-mix( in srgb, var(--app-color-always-white) 24%, var(--app-color-primary-light) 76% );
  --app-color-chip-selected-contrast: var(--app-color-primary-contrast);
  --app-color-chip-disabled: var(--app-color-gray-10);
  --app-color-chip-disabled-light: var(--app-color-gray-15);
  --app-color-chip-disabled-contrast: var(--app-color-gray-65);
  --app-chip-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--app-color-always-white) 8%, transparent),
    0 3px 7px color-mix(in srgb, var(--app-color-always-black) 38%, transparent),
    0 0 0 1px color-mix(in srgb, var(--app-color-always-white) 4%, transparent);
  --app-overlay-panel-surface: var(--app-color-surface-raised);
  --app-overlay-menu-surface: var(--app-color-surface-raised);
  --app-overlay-text: var(--app-color-dark);
  --app-overlay-icon: var(--app-color-dark-light);
  --app-overlay-border: var(--app-border-strong);
  --app-overlay-hover-state: color-mix(in srgb, var(--app-color-accent) 10%, var(--app-overlay-menu-surface));
  --app-overlay-focus-state: color-mix(in srgb, var(--app-color-accent) 14%, var(--app-overlay-menu-surface));
  --app-border-subtle-color: color-mix(in srgb, var(--app-color-divider) 76%, transparent);
  --app-border-strong-color: color-mix(in srgb, var(--app-color-divider) 86%, var(--app-color-always-white) 14%);
  --app-shadow-xs: 0 1px 2px color-mix(in srgb, var(--app-color-background) 55%, transparent);
  --app-shadow-sm: 0 10px 24px color-mix(in srgb, var(--app-color-background) 54%, transparent);
  --app-shadow-overlay: 0 22px 52px color-mix(in srgb, var(--app-color-background) 84%, transparent), 0 10px 24px color-mix(in srgb, var(--app-color-background-light) 72%, transparent);
  --app-focus-ring: 0 0 0 3px color-mix(in srgb, var(--app-color-accent) 30%, transparent);
  --ion-background-color: var(--app-color-surface);
  --ion-tab-bar-background: var(--app-color-primary-dark);
  --ion-tab-bar-border-color: var(--app-color-primary);
  --ion-tab-bar-color-activated: var(--app-color-primary);
  --ion-tab-bar-color: var(--app-color-accent);
  --ai-button-surface-top: #fffdf7;
  --ai-button-surface-mid: #f7edd6;
  --ai-button-surface-bottom: #e9d6ab;
  --ai-button-surface-top-hover: #fffeef;
  --ai-button-surface-mid-hover: #fbf1db;
  --ai-button-surface-bottom-hover: #eddcb7;
  --ai-button-surface-top-active: #fbf0d7;
  --ai-button-surface-mid-active: #efdfb8;
  --ai-button-surface-bottom-active: #ddc58c;
  --ai-button-border: color-mix(in srgb, #e7c983 42%, transparent);
  --ai-button-border-hover: color-mix(in srgb, #f0d998 58%, transparent);
  --ai-button-border-disabled: color-mix(in srgb, #d5bb7a 28%, transparent);
  --ai-button-shadow-rest:
    inset 0 1px 0 color-mix(in srgb, var(--app-color-always-white) 84%, transparent),
    0 10px 22px color-mix(in srgb, var(--app-color-background) 82%, transparent),
    0 3px 7px color-mix(in srgb, var(--app-color-background-light) 68%, transparent);
  --ai-button-shadow-hover:
    inset 0 1px 0 color-mix(in srgb, var(--app-color-always-white) 92%, transparent),
    0 12px 24px color-mix(in srgb, var(--app-color-background) 88%, transparent),
    0 0 0 3px color-mix(in srgb, #f0d998 18%, transparent);
  --ai-button-text: #1f1a10;
}
#splash {
  --splash-haze-bottom-strong: color-mix(in srgb, #7697b0 18%, transparent);
  --splash-haze-bottom-soft: color-mix(in srgb, #7697b0 4%, transparent);
  --splash-haze-upper-left: color-mix(in srgb, #607487 22%, transparent);
  --splash-haze-upper-right: color-mix(in srgb, #46525d 20%, transparent);
  --splash-haze-clear: transparent;
  --splash-bg-top: #161e26;
  --splash-bg-mid-top: #202831;
  --splash-bg-mid-bottom: #2a333d;
  --splash-bg-bottom: #232b33;
  --splash-inner-glow-core: #88a8bf;
  --splash-inner-glow-mid: #55697b;
  --splash-inner-glow-outer: #2b3640;
  --splash-tagline-color: color-mix(in srgb, var(--app-color-warning) 32%, var(--app-color-always-white) 68%);
  --splash-tagline-gloss-clear: transparent;
  --splash-tagline-gloss-mid: color-mix(in srgb, #fff4c4 45%, transparent);
  --splash-tagline-gloss-peak: #fffce6;
  --splash-tagline-shadow: color-mix(in srgb, #fff4c4 35%, transparent);
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  background:
    radial-gradient(
      circle at 50% 82%,
      var(--splash-haze-bottom-strong) 0%,
      var(--splash-haze-bottom-soft) 26%,
      var(--splash-haze-clear) 56%),
    radial-gradient(
      circle at 18% 14%,
      var(--splash-haze-upper-left) 0%,
      var(--splash-haze-clear) 34%),
    radial-gradient(
      circle at 82% 12%,
      var(--splash-haze-upper-right) 0%,
      var(--splash-haze-clear) 30%),
    linear-gradient(
      180deg,
      var(--splash-bg-top) 0%,
      var(--splash-bg-mid-top) 34%,
      var(--splash-bg-mid-bottom) 68%,
      var(--splash-bg-bottom) 100%);
  z-index: var(--app-z-splash);
}
.fire-glow {
  position: absolute;
  filter: blur(120px);
}
.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: var(--splash-inner-glow-core);
  animation: glowPulse 6.2s ease-in-out infinite;
  z-index: var(--app-z-floating);
}
.inner-glow-2 {
  height: 65%;
  width: 65%;
  background-color: var(--splash-inner-glow-mid);
  animation: glowPulse 5.4s ease-in-out infinite;
  z-index: var(--app-z-floating-subtle);
}
.inner-glow-3 {
  height: 100%;
  width: 100%;
  background-color: var(--splash-inner-glow-outer);
  animation: glowPulse 6.8s ease-in-out infinite;
}
@keyframes glowPulse {
  0%, 100% {
    opacity: 0.76;
    scale: 0.97;
  }
  20%, 78% {
    opacity: 0.9;
    scale: 1;
  }
  42% {
    opacity: 1;
    scale: 1.035;
  }
  58% {
    opacity: 0.84;
    scale: 1.02;
  }
}
#canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: var(--app-z-fab);
}
.splash-brand {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -60%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  z-index: var(--app-z-splash-brand);
}
.splash-logo {
  width: 10rem;
  height: auto;
  filter: drop-shadow(0 0 1px color-mix(in srgb, var(--app-color-always-white) 85%, transparent)) drop-shadow(0 0 1px color-mix(in srgb, var(--app-color-always-white) 25%, transparent)) drop-shadow(0 0 4px color-mix(in srgb, var(--app-color-warning) 15%, transparent));
}
.splash-tagline {
  margin-top: 1rem;
  font-size: 1rem;
  font-family: var(--app-font-family);
  font-style: italic;
  color: var(--splash-tagline-color);
  position: relative;
  display: inline-block;
  white-space: nowrap;
  text-align: center;
  opacity: 0;
}
.splash-tagline.is-font-ready {
  opacity: 1;
}
.splash-tagline::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  font-family: inherit;
  font-style: inherit;
  font-weight: inherit;
  pointer-events: none;
  background-image:
    linear-gradient(
      90deg,
      var(--splash-tagline-gloss-clear) 0%,
      var(--splash-tagline-gloss-clear) 46.4%,
      var(--splash-tagline-gloss-mid) 48.2%,
      var(--splash-tagline-gloss-peak) 50%,
      var(--splash-tagline-gloss-mid) 51.8%,
      var(--splash-tagline-gloss-clear) 53.6%,
      var(--splash-tagline-gloss-clear) 100%);
  background-size: 200% 100%;
  background-position: 100% 0;
  background-repeat: no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 8px var(--splash-tagline-shadow);
  opacity: 0;
}
.splash-tagline.is-font-ready::after {
  opacity: 1;
  animation: thinkingGloss 1.8s ease-out 1 forwards;
}
@keyframes thinkingGloss {
  0% {
    background-position: 100% 0;
    opacity: 1;
  }
  85% {
    background-position: -20% 0;
    opacity: 1;
  }
  100% {
    background-position: -24% 0;
    opacity: 0;
  }
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 400;
  src: url("./media/open-sans-v40-latin-regular-6CPMF22W.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 400;
  src: url("./media/open-sans-v40-latin-italic-GR66RQS2.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 700;
  src: url("./media/open-sans-v40-latin-700-3CXQMHVO.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 700;
  src: url("./media/open-sans-v40-latin-700italic-CXXIA32R.woff2") format("woff2");
}

/* angular:styles/global:styles */
