@charset "UTF-8";

/* node_modules/@ionic/angular/css/core.css */
: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, .08);
}
[dir=rtl].ios .menu-content-reveal {
  box-shadow: 8px 0 42px rgba(0, 0, 0, .08);
}
.md .menu-content-reveal {
  box-shadow: 4px 0px 16px rgba(0, 0, 0, .18);
}
.md .menu-content-push {
  box-shadow: 4px 0px 16px rgba(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;
  }
}

/* node_modules/@ionic/angular/css/normalize.css */
audio,
canvas,
progress,
video {
  vertical-align: baseline;
}
audio:not([controls]) {
  display: none;
  height: 0;
}
b,
strong {
  font-weight: bold;
}
img {
  max-width: 100%;
}
hr {
  height: 1px;
  border-width: 0;
  box-sizing: content-box;
}
pre {
  overflow: auto;
}
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
label,
input,
select,
textarea {
  font-family: inherit;
  line-height: normal;
}
textarea {
  overflow: auto;
  height: auto;
  font: inherit;
  color: inherit;
}
textarea::placeholder {
  padding-left: 2px;
}
form,
input,
optgroup,
select {
  margin: 0;
  font: inherit;
  color: inherit;
}
html input[type=button],
input[type=reset],
input[type=submit] {
  cursor: pointer;
  -webkit-appearance: button;
}
a,
a div,
a span,
a ion-icon,
a ion-label,
button,
button div,
button span,
button ion-icon,
button ion-label,
.ion-tappable,
[tappable],
[tappable] div,
[tappable] span,
[tappable] ion-icon,
[tappable] ion-label,
input,
textarea {
  touch-action: manipulation;
}
a ion-label,
button ion-label {
  pointer-events: none;
}
button {
  padding: 0;
  border: 0;
  border-radius: 0;
  font-family: inherit;
  font-style: inherit;
  font-variant: inherit;
  line-height: 1;
  text-transform: none;
  cursor: pointer;
  -webkit-appearance: button;
}
[tappable] {
  cursor: pointer;
}
a[disabled],
button[disabled],
html input[disabled] {
  cursor: default;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  height: auto;
}
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}

/* node_modules/@ionic/angular/css/structure.css */
* {
  box-sizing: border-box;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}
html {
  width: 100%;
  height: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
html.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;
}

/* node_modules/@ionic/angular/css/typography.css */
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;
}

/* node_modules/@ionic/angular/css/display.css */
.ion-hide {
  display: none !important;
}
.ion-hide-up {
  display: none !important;
}
.ion-hide-down {
  display: none !important;
}
@media (min-width: 576px) {
  .ion-hide-sm-up {
    display: none !important;
  }
}
@media (max-width: 575.98px) {
  .ion-hide-sm-down {
    display: none !important;
  }
}
@media (min-width: 768px) {
  .ion-hide-md-up {
    display: none !important;
  }
}
@media (max-width: 767.98px) {
  .ion-hide-md-down {
    display: none !important;
  }
}
@media (min-width: 992px) {
  .ion-hide-lg-up {
    display: none !important;
  }
}
@media (max-width: 991.98px) {
  .ion-hide-lg-down {
    display: none !important;
  }
}
@media (min-width: 1200px) {
  .ion-hide-xl-up {
    display: none !important;
  }
}
@media (max-width: 1199.98px) {
  .ion-hide-xl-down {
    display: none !important;
  }
}
.ion-display-none {
  display: none !important;
}
@media (min-width: 576px) {
  .ion-display-sm-none {
    display: none !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-none {
    display: none !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-none {
    display: none !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-none {
    display: none !important;
  }
}
.ion-display-inline {
  display: inline !important;
}
@media (min-width: 576px) {
  .ion-display-sm-inline {
    display: inline !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-inline {
    display: inline !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-inline {
    display: inline !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-inline {
    display: inline !important;
  }
}
.ion-display-inline-block {
  display: inline-block !important;
}
@media (min-width: 576px) {
  .ion-display-sm-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-inline-block {
    display: inline-block !important;
  }
}
.ion-display-block {
  display: block !important;
}
@media (min-width: 576px) {
  .ion-display-sm-block {
    display: block !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-block {
    display: block !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-block {
    display: block !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-block {
    display: block !important;
  }
}
.ion-display-flex {
  display: flex !important;
}
@media (min-width: 576px) {
  .ion-display-sm-flex {
    display: flex !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-flex {
    display: flex !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-flex {
    display: flex !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-flex {
    display: flex !important;
  }
}
.ion-display-inline-flex {
  display: inline-flex !important;
}
@media (min-width: 576px) {
  .ion-display-sm-inline-flex {
    display: inline-flex !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-inline-flex {
    display: inline-flex !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-inline-flex {
    display: inline-flex !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-inline-flex {
    display: inline-flex !important;
  }
}
.ion-display-grid {
  display: grid !important;
}
@media (min-width: 576px) {
  .ion-display-sm-grid {
    display: grid !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-grid {
    display: grid !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-grid {
    display: grid !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-grid {
    display: grid !important;
  }
}
.ion-display-inline-grid {
  display: inline-grid !important;
}
@media (min-width: 576px) {
  .ion-display-sm-inline-grid {
    display: inline-grid !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-inline-grid {
    display: inline-grid !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-inline-grid {
    display: inline-grid !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-inline-grid {
    display: inline-grid !important;
  }
}
.ion-display-table {
  display: table !important;
}
@media (min-width: 576px) {
  .ion-display-sm-table {
    display: table !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-table {
    display: table !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-table {
    display: table !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-table {
    display: table !important;
  }
}
.ion-display-table-cell {
  display: table-cell !important;
}
@media (min-width: 576px) {
  .ion-display-sm-table-cell {
    display: table-cell !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-table-cell {
    display: table-cell !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-table-cell {
    display: table-cell !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-table-cell {
    display: table-cell !important;
  }
}
.ion-display-table-row {
  display: table-row !important;
}
@media (min-width: 576px) {
  .ion-display-sm-table-row {
    display: table-row !important;
  }
}
@media (min-width: 768px) {
  .ion-display-md-table-row {
    display: table-row !important;
  }
}
@media (min-width: 992px) {
  .ion-display-lg-table-row {
    display: table-row !important;
  }
}
@media (min-width: 1200px) {
  .ion-display-xl-table-row {
    display: table-row !important;
  }
}

/* node_modules/@ionic/angular/css/padding.css */
.ion-no-padding {
  --padding-start: 0;
  --padding-end: 0;
  --padding-top: 0;
  --padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  padding-top: 0;
  padding-bottom: 0;
}
.ion-padding {
  --padding-start: var(--ion-padding, 16px);
  --padding-end: var(--ion-padding, 16px);
  --padding-top: var(--ion-padding, 16px);
  --padding-bottom: var(--ion-padding, 16px);
  -webkit-padding-start: var(--ion-padding, 16px);
  padding-inline-start: var(--ion-padding, 16px);
  -webkit-padding-end: var(--ion-padding, 16px);
  padding-inline-end: var(--ion-padding, 16px);
  padding-top: var(--ion-padding, 16px);
  padding-bottom: var(--ion-padding, 16px);
}
.ion-padding-top {
  --padding-top: var(--ion-padding, 16px);
  padding-top: var(--ion-padding, 16px);
}
.ion-padding-start {
  --padding-start: var(--ion-padding, 16px);
  -webkit-padding-start: var(--ion-padding, 16px);
  padding-inline-start: var(--ion-padding, 16px);
}
.ion-padding-end {
  --padding-end: var(--ion-padding, 16px);
  -webkit-padding-end: var(--ion-padding, 16px);
  padding-inline-end: var(--ion-padding, 16px);
}
.ion-padding-bottom {
  --padding-bottom: var(--ion-padding, 16px);
  padding-bottom: var(--ion-padding, 16px);
}
.ion-padding-vertical {
  --padding-top: var(--ion-padding, 16px);
  --padding-bottom: var(--ion-padding, 16px);
  padding-top: var(--ion-padding, 16px);
  padding-bottom: var(--ion-padding, 16px);
}
.ion-padding-horizontal {
  --padding-start: var(--ion-padding, 16px);
  --padding-end: var(--ion-padding, 16px);
  -webkit-padding-start: var(--ion-padding, 16px);
  padding-inline-start: var(--ion-padding, 16px);
  -webkit-padding-end: var(--ion-padding, 16px);
  padding-inline-end: var(--ion-padding, 16px);
}
.ion-no-margin {
  --margin-start: 0;
  --margin-end: 0;
  --margin-top: 0;
  --margin-bottom: 0;
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
  margin-bottom: 0;
}
.ion-margin {
  --margin-start: var(--ion-margin, 16px);
  --margin-end: var(--ion-margin, 16px);
  --margin-top: var(--ion-margin, 16px);
  --margin-bottom: var(--ion-margin, 16px);
  -webkit-margin-start: var(--ion-margin, 16px);
  margin-inline-start: var(--ion-margin, 16px);
  -webkit-margin-end: var(--ion-margin, 16px);
  margin-inline-end: var(--ion-margin, 16px);
  margin-top: var(--ion-margin, 16px);
  margin-bottom: var(--ion-margin, 16px);
}
.ion-margin-top {
  --margin-top: var(--ion-margin, 16px);
  margin-top: var(--ion-margin, 16px);
}
.ion-margin-start {
  --margin-start: var(--ion-margin, 16px);
  -webkit-margin-start: var(--ion-margin, 16px);
  margin-inline-start: var(--ion-margin, 16px);
}
.ion-margin-end {
  --margin-end: var(--ion-margin, 16px);
  -webkit-margin-end: var(--ion-margin, 16px);
  margin-inline-end: var(--ion-margin, 16px);
}
.ion-margin-bottom {
  --margin-bottom: var(--ion-margin, 16px);
  margin-bottom: var(--ion-margin, 16px);
}
.ion-margin-vertical {
  --margin-top: var(--ion-margin, 16px);
  --margin-bottom: var(--ion-margin, 16px);
  margin-top: var(--ion-margin, 16px);
  margin-bottom: var(--ion-margin, 16px);
}
.ion-margin-horizontal {
  --margin-start: var(--ion-margin, 16px);
  --margin-end: var(--ion-margin, 16px);
  -webkit-margin-start: var(--ion-margin, 16px);
  margin-inline-start: var(--ion-margin, 16px);
  -webkit-margin-end: var(--ion-margin, 16px);
  margin-inline-end: var(--ion-margin, 16px);
}

/* node_modules/@ionic/angular/css/float-elements.css */
.ion-float-left {
  float: left !important;
}
.ion-float-right {
  float: right !important;
}
.ion-float-start {
  float: left !important;
}
:host-context([dir=rtl]) .ion-float-start {
  float: right !important;
}
[dir=rtl] .ion-float-start {
  float: right !important;
}
@supports selector(:dir(rtl)) {
  .ion-float-start:dir(rtl) {
    float: right !important;
  }
}
.ion-float-end {
  float: right !important;
}
:host-context([dir=rtl]) .ion-float-end {
  float: left !important;
}
[dir=rtl] .ion-float-end {
  float: left !important;
}
@supports selector(:dir(rtl)) {
  .ion-float-end:dir(rtl) {
    float: left !important;
  }
}
@media (min-width: 576px) {
  .ion-float-sm-left {
    float: left !important;
  }
  .ion-float-sm-right {
    float: right !important;
  }
  .ion-float-sm-start {
    float: left !important;
  }
  :host-context([dir=rtl]) .ion-float-sm-start {
    float: right !important;
  }
  [dir=rtl] .ion-float-sm-start {
    float: right !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-sm-start:dir(rtl) {
      float: right !important;
    }
  }
  .ion-float-sm-end {
    float: right !important;
  }
  :host-context([dir=rtl]) .ion-float-sm-end {
    float: left !important;
  }
  [dir=rtl] .ion-float-sm-end {
    float: left !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-sm-end:dir(rtl) {
      float: left !important;
    }
  }
}
@media (min-width: 768px) {
  .ion-float-md-left {
    float: left !important;
  }
  .ion-float-md-right {
    float: right !important;
  }
  .ion-float-md-start {
    float: left !important;
  }
  :host-context([dir=rtl]) .ion-float-md-start {
    float: right !important;
  }
  [dir=rtl] .ion-float-md-start {
    float: right !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-md-start:dir(rtl) {
      float: right !important;
    }
  }
  .ion-float-md-end {
    float: right !important;
  }
  :host-context([dir=rtl]) .ion-float-md-end {
    float: left !important;
  }
  [dir=rtl] .ion-float-md-end {
    float: left !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-md-end:dir(rtl) {
      float: left !important;
    }
  }
}
@media (min-width: 992px) {
  .ion-float-lg-left {
    float: left !important;
  }
  .ion-float-lg-right {
    float: right !important;
  }
  .ion-float-lg-start {
    float: left !important;
  }
  :host-context([dir=rtl]) .ion-float-lg-start {
    float: right !important;
  }
  [dir=rtl] .ion-float-lg-start {
    float: right !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-lg-start:dir(rtl) {
      float: right !important;
    }
  }
  .ion-float-lg-end {
    float: right !important;
  }
  :host-context([dir=rtl]) .ion-float-lg-end {
    float: left !important;
  }
  [dir=rtl] .ion-float-lg-end {
    float: left !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-lg-end:dir(rtl) {
      float: left !important;
    }
  }
}
@media (min-width: 1200px) {
  .ion-float-xl-left {
    float: left !important;
  }
  .ion-float-xl-right {
    float: right !important;
  }
  .ion-float-xl-start {
    float: left !important;
  }
  :host-context([dir=rtl]) .ion-float-xl-start {
    float: right !important;
  }
  [dir=rtl] .ion-float-xl-start {
    float: right !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-xl-start:dir(rtl) {
      float: right !important;
    }
  }
  .ion-float-xl-end {
    float: right !important;
  }
  :host-context([dir=rtl]) .ion-float-xl-end {
    float: left !important;
  }
  [dir=rtl] .ion-float-xl-end {
    float: left !important;
  }
  @supports selector(:dir(rtl)) {
    .ion-float-xl-end:dir(rtl) {
      float: left !important;
    }
  }
}

/* node_modules/@ionic/angular/css/text-alignment.css */
.ion-text-center {
  text-align: center !important;
}
.ion-text-justify {
  text-align: justify !important;
}
.ion-text-start {
  text-align: start !important;
}
.ion-text-end {
  text-align: end !important;
}
.ion-text-left {
  text-align: left !important;
}
.ion-text-right {
  text-align: right !important;
}
.ion-text-nowrap {
  white-space: nowrap !important;
}
.ion-text-wrap {
  white-space: normal !important;
}
@media (min-width: 576px) {
  .ion-text-sm-center {
    text-align: center !important;
  }
  .ion-text-sm-justify {
    text-align: justify !important;
  }
  .ion-text-sm-start {
    text-align: start !important;
  }
  .ion-text-sm-end {
    text-align: end !important;
  }
  .ion-text-sm-left {
    text-align: left !important;
  }
  .ion-text-sm-right {
    text-align: right !important;
  }
  .ion-text-sm-nowrap {
    white-space: nowrap !important;
  }
  .ion-text-sm-wrap {
    white-space: normal !important;
  }
}
@media (min-width: 768px) {
  .ion-text-md-center {
    text-align: center !important;
  }
  .ion-text-md-justify {
    text-align: justify !important;
  }
  .ion-text-md-start {
    text-align: start !important;
  }
  .ion-text-md-end {
    text-align: end !important;
  }
  .ion-text-md-left {
    text-align: left !important;
  }
  .ion-text-md-right {
    text-align: right !important;
  }
  .ion-text-md-nowrap {
    white-space: nowrap !important;
  }
  .ion-text-md-wrap {
    white-space: normal !important;
  }
}
@media (min-width: 992px) {
  .ion-text-lg-center {
    text-align: center !important;
  }
  .ion-text-lg-justify {
    text-align: justify !important;
  }
  .ion-text-lg-start {
    text-align: start !important;
  }
  .ion-text-lg-end {
    text-align: end !important;
  }
  .ion-text-lg-left {
    text-align: left !important;
  }
  .ion-text-lg-right {
    text-align: right !important;
  }
  .ion-text-lg-nowrap {
    white-space: nowrap !important;
  }
  .ion-text-lg-wrap {
    white-space: normal !important;
  }
}
@media (min-width: 1200px) {
  .ion-text-xl-center {
    text-align: center !important;
  }
  .ion-text-xl-justify {
    text-align: justify !important;
  }
  .ion-text-xl-start {
    text-align: start !important;
  }
  .ion-text-xl-end {
    text-align: end !important;
  }
  .ion-text-xl-left {
    text-align: left !important;
  }
  .ion-text-xl-right {
    text-align: right !important;
  }
  .ion-text-xl-nowrap {
    white-space: nowrap !important;
  }
  .ion-text-xl-wrap {
    white-space: normal !important;
  }
}

/* node_modules/@ionic/angular/css/text-transformation.css */
.ion-text-uppercase {
  text-transform: uppercase !important;
}
.ion-text-lowercase {
  text-transform: lowercase !important;
}
.ion-text-capitalize {
  text-transform: capitalize !important;
}
@media (min-width: 576px) {
  .ion-text-sm-uppercase {
    text-transform: uppercase !important;
  }
  .ion-text-sm-lowercase {
    text-transform: lowercase !important;
  }
  .ion-text-sm-capitalize {
    text-transform: capitalize !important;
  }
}
@media (min-width: 768px) {
  .ion-text-md-uppercase {
    text-transform: uppercase !important;
  }
  .ion-text-md-lowercase {
    text-transform: lowercase !important;
  }
  .ion-text-md-capitalize {
    text-transform: capitalize !important;
  }
}
@media (min-width: 992px) {
  .ion-text-lg-uppercase {
    text-transform: uppercase !important;
  }
  .ion-text-lg-lowercase {
    text-transform: lowercase !important;
  }
  .ion-text-lg-capitalize {
    text-transform: capitalize !important;
  }
}
@media (min-width: 1200px) {
  .ion-text-xl-uppercase {
    text-transform: uppercase !important;
  }
  .ion-text-xl-lowercase {
    text-transform: lowercase !important;
  }
  .ion-text-xl-capitalize {
    text-transform: capitalize !important;
  }
}

/* node_modules/@ionic/angular/css/flex-utils.css */
.ion-align-content-start {
  align-content: flex-start !important;
}
.ion-align-content-end {
  align-content: flex-end !important;
}
.ion-align-content-center {
  align-content: center !important;
}
.ion-align-content-between {
  align-content: space-between !important;
}
.ion-align-content-around {
  align-content: space-around !important;
}
.ion-align-content-stretch {
  align-content: stretch !important;
}
@media (min-width: 576px) {
  .ion-align-content-sm-start {
    align-content: flex-start !important;
  }
  .ion-align-content-sm-end {
    align-content: flex-end !important;
  }
  .ion-align-content-sm-center {
    align-content: center !important;
  }
  .ion-align-content-sm-between {
    align-content: space-between !important;
  }
  .ion-align-content-sm-around {
    align-content: space-around !important;
  }
  .ion-align-content-sm-stretch {
    align-content: stretch !important;
  }
}
@media (min-width: 768px) {
  .ion-align-content-md-start {
    align-content: flex-start !important;
  }
  .ion-align-content-md-end {
    align-content: flex-end !important;
  }
  .ion-align-content-md-center {
    align-content: center !important;
  }
  .ion-align-content-md-between {
    align-content: space-between !important;
  }
  .ion-align-content-md-around {
    align-content: space-around !important;
  }
  .ion-align-content-md-stretch {
    align-content: stretch !important;
  }
}
@media (min-width: 992px) {
  .ion-align-content-lg-start {
    align-content: flex-start !important;
  }
  .ion-align-content-lg-end {
    align-content: flex-end !important;
  }
  .ion-align-content-lg-center {
    align-content: center !important;
  }
  .ion-align-content-lg-between {
    align-content: space-between !important;
  }
  .ion-align-content-lg-around {
    align-content: space-around !important;
  }
  .ion-align-content-lg-stretch {
    align-content: stretch !important;
  }
}
@media (min-width: 1200px) {
  .ion-align-content-xl-start {
    align-content: flex-start !important;
  }
  .ion-align-content-xl-end {
    align-content: flex-end !important;
  }
  .ion-align-content-xl-center {
    align-content: center !important;
  }
  .ion-align-content-xl-between {
    align-content: space-between !important;
  }
  .ion-align-content-xl-around {
    align-content: space-around !important;
  }
  .ion-align-content-xl-stretch {
    align-content: stretch !important;
  }
}
.ion-align-items-start {
  align-items: start !important;
}
.ion-align-items-end {
  align-items: end !important;
}
.ion-align-items-center {
  align-items: center !important;
}
.ion-align-items-stretch {
  align-items: stretch !important;
}
.ion-align-items-baseline {
  align-items: baseline !important;
}
@media (min-width: 576px) {
  .ion-align-items-sm-start {
    align-items: start !important;
  }
  .ion-align-items-sm-end {
    align-items: end !important;
  }
  .ion-align-items-sm-center {
    align-items: center !important;
  }
  .ion-align-items-sm-stretch {
    align-items: stretch !important;
  }
  .ion-align-items-sm-baseline {
    align-items: baseline !important;
  }
}
@media (min-width: 768px) {
  .ion-align-items-md-start {
    align-items: start !important;
  }
  .ion-align-items-md-end {
    align-items: end !important;
  }
  .ion-align-items-md-center {
    align-items: center !important;
  }
  .ion-align-items-md-stretch {
    align-items: stretch !important;
  }
  .ion-align-items-md-baseline {
    align-items: baseline !important;
  }
}
@media (min-width: 992px) {
  .ion-align-items-lg-start {
    align-items: start !important;
  }
  .ion-align-items-lg-end {
    align-items: end !important;
  }
  .ion-align-items-lg-center {
    align-items: center !important;
  }
  .ion-align-items-lg-stretch {
    align-items: stretch !important;
  }
  .ion-align-items-lg-baseline {
    align-items: baseline !important;
  }
}
@media (min-width: 1200px) {
  .ion-align-items-xl-start {
    align-items: start !important;
  }
  .ion-align-items-xl-end {
    align-items: end !important;
  }
  .ion-align-items-xl-center {
    align-items: center !important;
  }
  .ion-align-items-xl-stretch {
    align-items: stretch !important;
  }
  .ion-align-items-xl-baseline {
    align-items: baseline !important;
  }
}
.ion-align-self-start {
  align-self: start !important;
}
.ion-align-self-end {
  align-self: end !important;
}
.ion-align-self-center {
  align-self: center !important;
}
.ion-align-self-stretch {
  align-self: stretch !important;
}
.ion-align-self-baseline {
  align-self: baseline !important;
}
.ion-align-self-auto {
  align-self: auto !important;
}
@media (min-width: 576px) {
  .ion-align-self-sm-start {
    align-self: start !important;
  }
  .ion-align-self-sm-end {
    align-self: end !important;
  }
  .ion-align-self-sm-center {
    align-self: center !important;
  }
  .ion-align-self-sm-stretch {
    align-self: stretch !important;
  }
  .ion-align-self-sm-baseline {
    align-self: baseline !important;
  }
  .ion-align-self-sm-auto {
    align-self: auto !important;
  }
}
@media (min-width: 768px) {
  .ion-align-self-md-start {
    align-self: start !important;
  }
  .ion-align-self-md-end {
    align-self: end !important;
  }
  .ion-align-self-md-center {
    align-self: center !important;
  }
  .ion-align-self-md-stretch {
    align-self: stretch !important;
  }
  .ion-align-self-md-baseline {
    align-self: baseline !important;
  }
  .ion-align-self-md-auto {
    align-self: auto !important;
  }
}
@media (min-width: 992px) {
  .ion-align-self-lg-start {
    align-self: start !important;
  }
  .ion-align-self-lg-end {
    align-self: end !important;
  }
  .ion-align-self-lg-center {
    align-self: center !important;
  }
  .ion-align-self-lg-stretch {
    align-self: stretch !important;
  }
  .ion-align-self-lg-baseline {
    align-self: baseline !important;
  }
  .ion-align-self-lg-auto {
    align-self: auto !important;
  }
}
@media (min-width: 1200px) {
  .ion-align-self-xl-start {
    align-self: start !important;
  }
  .ion-align-self-xl-end {
    align-self: end !important;
  }
  .ion-align-self-xl-center {
    align-self: center !important;
  }
  .ion-align-self-xl-stretch {
    align-self: stretch !important;
  }
  .ion-align-self-xl-baseline {
    align-self: baseline !important;
  }
  .ion-align-self-xl-auto {
    align-self: auto !important;
  }
}
.ion-justify-content-start {
  justify-content: flex-start !important;
}
.ion-justify-content-end {
  justify-content: flex-end !important;
}
.ion-justify-content-center {
  justify-content: center !important;
}
.ion-justify-content-between {
  justify-content: space-between !important;
}
.ion-justify-content-around {
  justify-content: space-around !important;
}
.ion-justify-content-evenly {
  justify-content: space-evenly !important;
}
@media (min-width: 576px) {
  .ion-justify-content-sm-start {
    justify-content: flex-start !important;
  }
  .ion-justify-content-sm-end {
    justify-content: flex-end !important;
  }
  .ion-justify-content-sm-center {
    justify-content: center !important;
  }
  .ion-justify-content-sm-between {
    justify-content: space-between !important;
  }
  .ion-justify-content-sm-around {
    justify-content: space-around !important;
  }
  .ion-justify-content-sm-evenly {
    justify-content: space-evenly !important;
  }
}
@media (min-width: 768px) {
  .ion-justify-content-md-start {
    justify-content: flex-start !important;
  }
  .ion-justify-content-md-end {
    justify-content: flex-end !important;
  }
  .ion-justify-content-md-center {
    justify-content: center !important;
  }
  .ion-justify-content-md-between {
    justify-content: space-between !important;
  }
  .ion-justify-content-md-around {
    justify-content: space-around !important;
  }
  .ion-justify-content-md-evenly {
    justify-content: space-evenly !important;
  }
}
@media (min-width: 992px) {
  .ion-justify-content-lg-start {
    justify-content: flex-start !important;
  }
  .ion-justify-content-lg-end {
    justify-content: flex-end !important;
  }
  .ion-justify-content-lg-center {
    justify-content: center !important;
  }
  .ion-justify-content-lg-between {
    justify-content: space-between !important;
  }
  .ion-justify-content-lg-around {
    justify-content: space-around !important;
  }
  .ion-justify-content-lg-evenly {
    justify-content: space-evenly !important;
  }
}
@media (min-width: 1200px) {
  .ion-justify-content-xl-start {
    justify-content: flex-start !important;
  }
  .ion-justify-content-xl-end {
    justify-content: flex-end !important;
  }
  .ion-justify-content-xl-center {
    justify-content: center !important;
  }
  .ion-justify-content-xl-between {
    justify-content: space-between !important;
  }
  .ion-justify-content-xl-around {
    justify-content: space-around !important;
  }
  .ion-justify-content-xl-evenly {
    justify-content: space-evenly !important;
  }
}
.ion-flex-row {
  flex-direction: row !important;
}
.ion-flex-row-reverse {
  flex-direction: row-reverse !important;
}
.ion-flex-column {
  flex-direction: column !important;
}
.ion-flex-column-reverse {
  flex-direction: column-reverse !important;
}
@media (min-width: 576px) {
  .ion-flex-sm-row {
    flex-direction: row !important;
  }
  .ion-flex-sm-row-reverse {
    flex-direction: row-reverse !important;
  }
  .ion-flex-sm-column {
    flex-direction: column !important;
  }
  .ion-flex-sm-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 768px) {
  .ion-flex-md-row {
    flex-direction: row !important;
  }
  .ion-flex-md-row-reverse {
    flex-direction: row-reverse !important;
  }
  .ion-flex-md-column {
    flex-direction: column !important;
  }
  .ion-flex-md-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 992px) {
  .ion-flex-lg-row {
    flex-direction: row !important;
  }
  .ion-flex-lg-row-reverse {
    flex-direction: row-reverse !important;
  }
  .ion-flex-lg-column {
    flex-direction: column !important;
  }
  .ion-flex-lg-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 1200px) {
  .ion-flex-xl-row {
    flex-direction: row !important;
  }
  .ion-flex-xl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .ion-flex-xl-column {
    flex-direction: column !important;
  }
  .ion-flex-xl-column-reverse {
    flex-direction: column-reverse !important;
  }
}
.ion-wrap {
  flex-wrap: wrap !important;
}
.ion-nowrap {
  flex-wrap: nowrap !important;
}
.ion-wrap-reverse {
  flex-wrap: wrap-reverse !important;
}
.ion-flex-wrap {
  flex-wrap: wrap !important;
}
.ion-flex-nowrap {
  flex-wrap: nowrap !important;
}
.ion-flex-wrap-reverse {
  flex-wrap: wrap-reverse !important;
}
@media (min-width: 576px) {
  .ion-flex-sm-wrap {
    flex-wrap: wrap !important;
  }
  .ion-flex-sm-nowrap {
    flex-wrap: nowrap !important;
  }
  .ion-flex-sm-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
}
@media (min-width: 768px) {
  .ion-flex-md-wrap {
    flex-wrap: wrap !important;
  }
  .ion-flex-md-nowrap {
    flex-wrap: nowrap !important;
  }
  .ion-flex-md-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
}
@media (min-width: 992px) {
  .ion-flex-lg-wrap {
    flex-wrap: wrap !important;
  }
  .ion-flex-lg-nowrap {
    flex-wrap: nowrap !important;
  }
  .ion-flex-lg-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
}
@media (min-width: 1200px) {
  .ion-flex-xl-wrap {
    flex-wrap: wrap !important;
  }
  .ion-flex-xl-nowrap {
    flex-wrap: nowrap !important;
  }
  .ion-flex-xl-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
}
.ion-flex-1 {
  flex: 1 !important;
}
.ion-flex-auto {
  flex: auto !important;
}
.ion-flex-initial {
  flex: initial !important;
}
.ion-flex-none {
  flex: none !important;
}
@media (min-width: 576px) {
  .ion-flex-sm-1 {
    flex: 1 !important;
  }
  .ion-flex-sm-auto {
    flex: auto !important;
  }
  .ion-flex-sm-initial {
    flex: initial !important;
  }
  .ion-flex-sm-none {
    flex: none !important;
  }
}
@media (min-width: 768px) {
  .ion-flex-md-1 {
    flex: 1 !important;
  }
  .ion-flex-md-auto {
    flex: auto !important;
  }
  .ion-flex-md-initial {
    flex: initial !important;
  }
  .ion-flex-md-none {
    flex: none !important;
  }
}
@media (min-width: 992px) {
  .ion-flex-lg-1 {
    flex: 1 !important;
  }
  .ion-flex-lg-auto {
    flex: auto !important;
  }
  .ion-flex-lg-initial {
    flex: initial !important;
  }
  .ion-flex-lg-none {
    flex: none !important;
  }
}
@media (min-width: 1200px) {
  .ion-flex-xl-1 {
    flex: 1 !important;
  }
  .ion-flex-xl-auto {
    flex: auto !important;
  }
  .ion-flex-xl-initial {
    flex: initial !important;
  }
  .ion-flex-xl-none {
    flex: none !important;
  }
}
.ion-flex-grow-0 {
  flex-grow: 0 !important;
}
.ion-flex-grow-1 {
  flex-grow: 1 !important;
}
.ion-flex-shrink-0 {
  flex-shrink: 0 !important;
}
.ion-flex-shrink-1 {
  flex-shrink: 1 !important;
}
@media (min-width: 576px) {
  .ion-flex-sm-grow-0 {
    flex-grow: 0 !important;
  }
  .ion-flex-sm-grow-1 {
    flex-grow: 1 !important;
  }
  .ion-flex-sm-shrink-0 {
    flex-shrink: 0 !important;
  }
  .ion-flex-sm-shrink-1 {
    flex-shrink: 1 !important;
  }
}
@media (min-width: 768px) {
  .ion-flex-md-grow-0 {
    flex-grow: 0 !important;
  }
  .ion-flex-md-grow-1 {
    flex-grow: 1 !important;
  }
  .ion-flex-md-shrink-0 {
    flex-shrink: 0 !important;
  }
  .ion-flex-md-shrink-1 {
    flex-shrink: 1 !important;
  }
}
@media (min-width: 992px) {
  .ion-flex-lg-grow-0 {
    flex-grow: 0 !important;
  }
  .ion-flex-lg-grow-1 {
    flex-grow: 1 !important;
  }
  .ion-flex-lg-shrink-0 {
    flex-shrink: 0 !important;
  }
  .ion-flex-lg-shrink-1 {
    flex-shrink: 1 !important;
  }
}
@media (min-width: 1200px) {
  .ion-flex-xl-grow-0 {
    flex-grow: 0 !important;
  }
  .ion-flex-xl-grow-1 {
    flex-grow: 1 !important;
  }
  .ion-flex-xl-shrink-0 {
    flex-shrink: 0 !important;
  }
  .ion-flex-xl-shrink-1 {
    flex-shrink: 1 !important;
  }
}
.ion-order-first {
  order: -1 !important;
}
.ion-order-0 {
  order: 0 !important;
}
.ion-order-1 {
  order: 1 !important;
}
.ion-order-2 {
  order: 2 !important;
}
.ion-order-3 {
  order: 3 !important;
}
.ion-order-4 {
  order: 4 !important;
}
.ion-order-5 {
  order: 5 !important;
}
.ion-order-6 {
  order: 6 !important;
}
.ion-order-7 {
  order: 7 !important;
}
.ion-order-8 {
  order: 8 !important;
}
.ion-order-9 {
  order: 9 !important;
}
.ion-order-10 {
  order: 10 !important;
}
.ion-order-11 {
  order: 11 !important;
}
.ion-order-12 {
  order: 12 !important;
}
.ion-order-last {
  order: 13 !important;
}
@media (min-width: 576px) {
  .ion-order-sm-first {
    order: -1 !important;
  }
  .ion-order-sm-0 {
    order: 0 !important;
  }
  .ion-order-sm-1 {
    order: 1 !important;
  }
  .ion-order-sm-2 {
    order: 2 !important;
  }
  .ion-order-sm-3 {
    order: 3 !important;
  }
  .ion-order-sm-4 {
    order: 4 !important;
  }
  .ion-order-sm-5 {
    order: 5 !important;
  }
  .ion-order-sm-6 {
    order: 6 !important;
  }
  .ion-order-sm-7 {
    order: 7 !important;
  }
  .ion-order-sm-8 {
    order: 8 !important;
  }
  .ion-order-sm-9 {
    order: 9 !important;
  }
  .ion-order-sm-10 {
    order: 10 !important;
  }
  .ion-order-sm-11 {
    order: 11 !important;
  }
  .ion-order-sm-12 {
    order: 12 !important;
  }
  .ion-order-sm-last {
    order: 13 !important;
  }
}
@media (min-width: 768px) {
  .ion-order-md-first {
    order: -1 !important;
  }
  .ion-order-md-0 {
    order: 0 !important;
  }
  .ion-order-md-1 {
    order: 1 !important;
  }
  .ion-order-md-2 {
    order: 2 !important;
  }
  .ion-order-md-3 {
    order: 3 !important;
  }
  .ion-order-md-4 {
    order: 4 !important;
  }
  .ion-order-md-5 {
    order: 5 !important;
  }
  .ion-order-md-6 {
    order: 6 !important;
  }
  .ion-order-md-7 {
    order: 7 !important;
  }
  .ion-order-md-8 {
    order: 8 !important;
  }
  .ion-order-md-9 {
    order: 9 !important;
  }
  .ion-order-md-10 {
    order: 10 !important;
  }
  .ion-order-md-11 {
    order: 11 !important;
  }
  .ion-order-md-12 {
    order: 12 !important;
  }
  .ion-order-md-last {
    order: 13 !important;
  }
}
@media (min-width: 992px) {
  .ion-order-lg-first {
    order: -1 !important;
  }
  .ion-order-lg-0 {
    order: 0 !important;
  }
  .ion-order-lg-1 {
    order: 1 !important;
  }
  .ion-order-lg-2 {
    order: 2 !important;
  }
  .ion-order-lg-3 {
    order: 3 !important;
  }
  .ion-order-lg-4 {
    order: 4 !important;
  }
  .ion-order-lg-5 {
    order: 5 !important;
  }
  .ion-order-lg-6 {
    order: 6 !important;
  }
  .ion-order-lg-7 {
    order: 7 !important;
  }
  .ion-order-lg-8 {
    order: 8 !important;
  }
  .ion-order-lg-9 {
    order: 9 !important;
  }
  .ion-order-lg-10 {
    order: 10 !important;
  }
  .ion-order-lg-11 {
    order: 11 !important;
  }
  .ion-order-lg-12 {
    order: 12 !important;
  }
  .ion-order-lg-last {
    order: 13 !important;
  }
}
@media (min-width: 1200px) {
  .ion-order-xl-first {
    order: -1 !important;
  }
  .ion-order-xl-0 {
    order: 0 !important;
  }
  .ion-order-xl-1 {
    order: 1 !important;
  }
  .ion-order-xl-2 {
    order: 2 !important;
  }
  .ion-order-xl-3 {
    order: 3 !important;
  }
  .ion-order-xl-4 {
    order: 4 !important;
  }
  .ion-order-xl-5 {
    order: 5 !important;
  }
  .ion-order-xl-6 {
    order: 6 !important;
  }
  .ion-order-xl-7 {
    order: 7 !important;
  }
  .ion-order-xl-8 {
    order: 8 !important;
  }
  .ion-order-xl-9 {
    order: 9 !important;
  }
  .ion-order-xl-10 {
    order: 10 !important;
  }
  .ion-order-xl-11 {
    order: 11 !important;
  }
  .ion-order-xl-12 {
    order: 12 !important;
  }
  .ion-order-xl-last {
    order: 13 !important;
  }
}

/* src/styles.scss */
:root {
  --font-sans:
    "Inter",
    "Instrument Sans",
    system-ui,
    -apple-system,
    "Segoe UI",
    sans-serif;
  --bg-base: #f6f7fb;
  --bg-surface: #ffffff;
  --bg-elevated: #eef2f7;
  --bg-inverse: #0f172a;
  --text-primary: #0b1220;
  --text-secondary: #3e4c66;
  --text-muted: #7b8794;
  --text-inverse: #f8fafc;
  --text-placeholder: #9aa5b5;
  --border-default: #e2e8f0;
  --border-subtle: #f1f5f9;
  --border-strong: #cbd5e1;
  --sovereign-blue: #0b1220;
  --sovereign-indigo: #2f3a8f;
  --sovereign-gradient:
    linear-gradient(
      135deg,
      #0b1220 0%,
      #1b2540 100%);
  --color-success: #1f7a63;
  --color-success-bg: #e7f3ef;
  --color-success-text: #155e4e;
  --color-warning: #b7791f;
  --color-warning-bg: #fff7e6;
  --color-warning-text: #7c4a12;
  --color-danger: #b23a3a;
  --color-danger-bg: #fceaea;
  --color-danger-text: #7a2424;
  --color-info: #2f3a8f;
  --color-info-bg: #eef0ff;
  --color-info-text: #222c6a;
  --color-info-border: color-mix(in srgb, var(--color-info) 35%, var(--border-default));
  --ws-operations: #0f5d5e;
  --ws-operations-bg: #ecf8f6;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 24px rgba(0, 0, 0, 0.08);
  --shadow-card: var(--shadow-sm);
  --shadow-elevated: 0 4px 14px rgba(11, 18, 32, 0.1), 0 2px 6px rgba(11, 18, 32, 0.06);
  --shadow-login-card: var(--shadow-lg);
  --shadow-fab: 0 4px 16px color-mix(in srgb, var(--color-info) 40%, transparent);
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-chip: var(--radius-md);
  --radius-input: var(--radius-lg);
  --radius-btn: var(--radius-xl);
  --radius-card: var(--radius-xl);
  --radius-pill: 999px;
  --bg-app: var(--bg-base);
  --bg-card: var(--bg-elevated);
  --bg-inset: var(--bg-elevated);
  --border-divider: var(--border-default);
  --border-input: var(--border-default);
  --brand-primary: var(--color-info);
  --brand-primary-soft: var(--color-info-bg);
  --brand-primary-text: var(--color-info-text);
  --brand-primary-dark: #222c6a;
  --brand-primary-border: var(--color-info-border);
  --color-success-soft: var(--color-success-bg);
  --color-warning-soft: var(--color-warning-bg);
  --color-danger-soft: var(--color-danger-bg);
  --persona-occupant: var(--ws-operations);
  --persona-occupant-soft: var(--ws-operations-bg);
  --persona-services-navy: var(--sovereign-blue);
  --persona-services-green: #1f7a63;
  --persona-services-green-soft: var(--color-success-bg);
  --persona-access-active: var(--ws-operations);
  --ring-primary: var(--color-info);
  --ring-ok: var(--color-success);
  --ring-delay: var(--color-warning);
  --ring-alert: var(--color-danger);
  --badge-fcfs: var(--color-warning);
  --badge-fcfs-soft: var(--color-warning-bg);
  --badge-assigned: var(--color-info);
  --badge-assigned-soft: var(--color-info-bg);
  --badge-paid: var(--color-success);
  --badge-paid-soft: var(--color-success-bg);
  --badge-valid: #b7791f;
  --badge-valid-soft: var(--color-warning-bg);
  --action-access: var(--color-info);
  --action-parking: var(--color-success);
  --action-visitors: color-mix(in srgb, var(--color-info) 70%, #38bdf8);
  --action-valet: var(--color-warning);
  --action-amenities: var(--color-warning-text);
  --occupant-primary: var(--brand-primary);
  --occupant-primary-soft: var(--brand-primary-soft);
  --occupant-access: var(--persona-access-active);
  --occupant-access-soft: var(--persona-occupant-soft);
  --services-primary: var(--persona-services-green);
  --services-primary-soft: var(--persona-services-green-soft);
  --services-brand: var(--persona-services-navy);
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 12px;
  --space-lg: 16px;
  --space-xl: 24px;
  --space-2xl: 32px;
  --space-3xl: 48px;
  --mobile-width: 390px;
  --touch-min: 48px;
  --feature-btn-size: 60px;
  --header-height: 56px;
  --tab-bar-height: 50px;
  --tab-icon-size: 20px;
  --tab-label-size: 11px;
  --tab-bar-padding-top: var(--space-md);
  --login-card-max: 358px;
  --text-header: 20px;
  --lh-header: 28px;
  --text-header-lg: 24px;
  --lh-header-lg: 32px;
  --text-subheader: 17px;
  --lh-subheader: 26px;
  --text-body: 15px;
  --lh-body: 22px;
  --text-body-sm: 14px;
  --lh-body-sm: 20px;
  --text-caption: 13px;
  --lh-caption: 18px;
  --text-caption-sm: 12px;
  --lh-caption-sm: 16px;
  --text-chip: 13px;
  --lh-chip: 18px;
  --text-button: 15px;
  --lh-button: 22px;
  --text-timer: 32px;
  --lh-timer: 40px;
  --overlay-scrim: rgba(11, 18, 32, 0.4);
  --ion-color-primary: var(--color-info);
  --ion-color-primary-rgb:
    47,
    58,
    143;
  --ion-color-primary-contrast: #ffffff;
  --ion-color-primary-shade: #29347e;
  --ion-color-primary-tint: #444e9a;
  --ion-background-color: var(--bg-base);
  --ion-text-color: var(--text-primary);
  --ion-font-family: var(--font-sans);
  color-scheme: light;
}
html[data-theme=dark],
html.dark {
  color-scheme: dark;
  --bg-base: #0b1121;
  --bg-surface: #151f32;
  --bg-elevated: #1e293b;
  --bg-inverse: #f1f5f9;
  --text-primary: #f1f5f9;
  --text-secondary: #94a3b8;
  --text-muted: #64748b;
  --text-inverse: #0b1220;
  --text-placeholder: #64748b;
  --border-default: #2b364d;
  --border-subtle: #223049;
  --border-strong: #3a4967;
  --sovereign-blue: #070b14;
  --sovereign-indigo: #a5b4fc;
  --sovereign-gradient:
    linear-gradient(
      135deg,
      #070b14 0%,
      #151f32 100%);
  --color-success: #6ee7b7;
  --color-success-bg: #0f2d26;
  --color-success-text: #cff8ea;
  --color-warning: #fcd34d;
  --color-warning-bg: #2b1f0b;
  --color-warning-text: #ffe9a6;
  --color-danger: #fca5a5;
  --color-danger-bg: #2b1212;
  --color-danger-text: #ffd0d0;
  --color-info: #a5b4fc;
  --color-info-bg: #151a3b;
  --color-info-text: #dce1ff;
  --color-info-border: color-mix(in srgb, var(--color-info) 35%, var(--border-default));
  --ws-operations: #5eead4;
  --ws-operations-bg: #0f2d2a;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.35);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.45);
  --shadow-lg: 0 10px 24px rgba(0, 0, 0, 0.55);
  --shadow-card: var(--shadow-sm);
  --shadow-elevated: 0 6px 20px rgba(0, 0, 0, 0.45), 0 2px 6px rgba(0, 0, 0, 0.35);
  --shadow-login-card: var(--shadow-lg);
  --shadow-fab: 0 4px 16px color-mix(in srgb, var(--color-info) 35%, transparent);
  --brand-primary-dark: #c7d2fe;
  --persona-services-green: var(--color-success);
  --persona-services-green-soft: var(--color-success-bg);
  --overlay-scrim: rgba(0, 0, 0, 0.65);
  --ion-color-primary: var(--color-info);
  --ion-color-primary-rgb:
    165,
    180,
    252;
  --ion-color-primary-contrast: #0b1121;
  --ion-color-primary-shade: #919fde;
  --ion-color-primary-tint: #aebdfc;
}
.ion-palette-services {
  --ion-color-primary: var(--persona-services-green);
  --ion-color-primary-rgb:
    31,
    122,
    99;
  --ion-color-primary-shade: #1b6c57;
  --ion-color-primary-tint: #358873;
}
html[data-theme=dark].ion-palette-services,
html.dark.ion-palette-services {
  --ion-color-primary: var(--ws-operations);
  --ion-color-primary-rgb:
    94,
    234,
    212;
  --ion-color-primary-contrast: #0b1121;
}
html.theme-transition,
html.theme-transition * {
  transition:
    background-color 0.28s ease,
    color 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease !important;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
button,
input {
  font-family: inherit;
  -webkit-tap-highlight-color: transparent;
}
.m-safe-top {
  padding-top: env(safe-area-inset-top, 0);
}
.m-safe-bottom {
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.m-page {
  --padding-start: var(--space-lg);
  --padding-end: var(--space-lg);
  --padding-top: var(--space-lg);
  --padding-bottom: calc(var(--space-2xl) + env(safe-area-inset-bottom, 0));
  max-width: var(--mobile-width);
  margin-inline: auto;
}
.m-page--flush {
  --padding-start: 0;
  --padding-end: 0;
}
.m-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.m-stack--lg {
  gap: var(--space-lg);
}
.m-text-header,
.m-section-title {
  margin: 0;
  font-size: var(--text-header);
  line-height: var(--lh-header);
  font-weight: 700;
  color: var(--text-primary);
}
.m-text-header-lg {
  margin: 0;
  font-size: var(--text-header-lg);
  line-height: var(--lh-header-lg);
  font-weight: 700;
  color: var(--text-primary);
}
.m-section-title {
  font-size: var(--text-subheader);
  line-height: var(--lh-subheader);
  font-weight: 600;
}
.m-section-subtitle {
  margin: var(--space-xs) 0 0;
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
  font-weight: 400;
  color: var(--text-muted);
}
.m-caption {
  font-size: var(--text-caption-sm);
  line-height: var(--lh-caption-sm);
  color: var(--text-muted);
}
.m-brand-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 88px;
  padding: var(--space-xl) var(--space-lg);
  background: var(--sovereign-gradient);
}
.m-brand-bar--services {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-divider);
}
.m-brand-bar__logo {
  display: block;
  height: 32px;
  width: auto;
  max-width: 140px;
  object-fit: contain;
}
.m-brand-bar--services .m-brand-bar__logo {
  filter: brightness(0) saturate(100%);
  opacity: 0.88;
}
.m-card {
  background: var(--bg-surface);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: var(--space-lg);
}
.m-card--muted {
  background: var(--bg-card);
}
.m-card--bordered {
  border: 1px solid var(--border-divider);
  box-shadow: none;
}
.m-card--elevated {
  box-shadow: var(--shadow-login-card);
}
.m-card--accent-left,
.m-card--occupant {
  border-left: 4px solid var(--color-info);
}
.m-card--accent-services,
.m-card--services {
  border-left: 4px solid var(--persona-services-green);
}
.m-login-page {
  --background: var(--bg-surface);
  min-height: 100%;
}
.m-login-body {
  padding: var(--space-xl) var(--space-lg) var(--space-2xl);
}
.m-login-card {
  max-width: var(--login-card-max);
  margin: 0 auto;
  padding: var(--space-2xl) var(--space-xl);
  background: var(--bg-surface);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-login-card);
  text-align: center;
}
.m-login-card__avatar {
  width: 72px;
  height: 72px;
  margin: 0 auto var(--space-lg);
  border-radius: 50%;
  object-fit: cover;
  background: var(--bg-card);
}
.m-login-card__avatar--placeholder {
  display: grid;
  place-items: center;
  font-size: 28px;
  color: var(--text-muted);
}
.m-login-card__welcome {
  margin: 0 0 var(--space-xl);
  font-size: var(--text-subheader);
  line-height: var(--lh-subheader);
  font-weight: 700;
  color: var(--text-primary);
}
.m-login-card__link {
  display: inline-block;
  margin-top: var(--space-lg);
  font-size: var(--text-body);
  line-height: var(--lh-body);
  font-weight: 500;
  color: var(--color-info);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
}
.m-login-services {
  max-width: var(--login-card-max);
  margin: 0 auto;
}
.m-login-services__icon {
  width: 64px;
  height: 64px;
  margin: var(--space-lg) auto;
  border-radius: 50%;
  background: var(--color-success);
  color: var(--text-inverse);
  display: grid;
  place-items: center;
  font-size: 28px;
}
.m-login-services__title {
  margin: 0 0 var(--space-xl);
  text-align: center;
  font-size: var(--text-subheader);
  font-weight: 700;
}
.m-login-services__forgot {
  display: block;
  width: 100%;
  margin-top: var(--space-md);
  text-align: center;
  font-size: var(--text-body-sm);
  font-weight: 500;
  color: var(--color-success);
  background: none;
  border: none;
  cursor: pointer;
}
.m-helpline-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  margin: var(--space-3xl) auto 0;
  padding: 10px var(--space-xl);
  border: 1px solid var(--border-divider);
  border-radius: var(--radius-pill);
  background: var(--bg-surface);
  font-size: var(--text-body-sm);
  font-weight: 500;
  color: var(--text-secondary);
  cursor: pointer;
}
.m-helpline-btn__shield {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--color-danger);
  color: white;
  font-size: 10px;
  display: grid;
  place-items: center;
}
.m-field {
  text-align: left;
  margin-bottom: var(--space-lg);
}
.m-field__label {
  display: block;
  margin-bottom: var(--space-sm);
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
  font-weight: 400;
  color: var(--text-muted);
}
.m-field__control {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-height: var(--touch-min);
  padding: var(--space-md);
  border: 1px solid var(--border-input);
  border-radius: var(--radius-input);
  background: var(--bg-surface);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.m-field__control:focus-within {
  border-color: var(--color-info);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-info) 22%, transparent);
}
.m-field__control ion-icon {
  flex-shrink: 0;
  font-size: 22px;
  color: var(--text-muted);
}
.m-field__control ion-input {
  flex: 1;
  --padding-start: 0;
  --padding-end: 0;
  --padding-top: 0;
  --padding-bottom: 0;
  --background: transparent;
  font-size: var(--text-body-sm);
  line-height: var(--lh-body-sm);
  color: var(--text-primary);
}
.m-field__helper {
  margin-top: var(--space-xs);
  font-size: var(--text-caption-sm);
  line-height: var(--lh-caption-sm);
  color: var(--text-muted);
}
.m-field--error .m-field__control {
  border-color: var(--color-danger);
}
.m-field--error .m-field__helper {
  color: var(--color-danger);
}
.m-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--touch-min);
  padding: 0 var(--space-xl);
  border: none;
  border-radius: var(--radius-btn);
  font-size: var(--text-button);
  line-height: var(--lh-button);
  font-weight: 500;
  cursor: pointer;
  width: 100%;
  transition: transform 0.1s ease, opacity 0.15s ease;
}
.m-btn:active:not(:disabled) {
  transform: scale(0.98);
  opacity: 0.92;
}
.m-btn--primary,
.m-btn--occupant {
  background: var(--color-info);
  color: var(--text-inverse);
}
.m-btn--primary:disabled,
.m-btn--occupant:disabled {
  background: var(--border-subtle);
  color: var(--text-muted);
  cursor: not-allowed;
}
.m-btn--ghost,
.m-btn--outline {
  background: transparent;
  color: var(--color-info);
  border: 1px solid var(--color-info-border);
}
.m-btn--services {
  background: var(--color-success);
  color: var(--text-inverse);
}
.m-btn--success {
  background: var(--color-success);
  color: var(--text-inverse);
}
.m-btn--danger {
  background: var(--color-danger);
  color: var(--text-inverse);
}
.m-btn--sm {
  min-height: 40px;
  font-size: var(--text-body-sm);
  padding: 0 var(--space-md);
  width: auto;
}
.m-btn-row {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}
.m-theme-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  min-height: 40px;
  padding: 0 var(--space-md);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-pill);
  background: var(--bg-surface);
  color: var(--text-secondary);
  font-size: var(--text-body-sm);
  font-weight: 500;
  cursor: pointer;
}
.m-theme-toggle:active {
  transform: scale(0.98);
}
.m-theme-toggle ion-icon {
  font-size: 18px;
  color: var(--color-info);
}
.m-otp-status {
  width: 40px;
  height: 40px;
  margin: 0 auto var(--space-lg);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 20px;
}
.m-otp-status--error {
  background: var(--color-danger);
  color: var(--text-inverse);
}
.m-otp-status--success {
  background: var(--color-info);
  color: var(--text-inverse);
}
.m-otp-row {
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
}
.m-otp-cell {
  width: 44px;
  height: 48px;
  border: 1px solid var(--border-input);
  border-radius: var(--radius-chip);
  text-align: center;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 600;
  color: var(--text-primary);
  background: var(--bg-surface);
  outline: none;
  padding: 0;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
  touch-action: manipulation;
}
.m-otp-cell:focus {
  border-color: var(--color-info);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-info) 22%, transparent);
}
.m-otp-cell--filled {
  border-color: var(--color-info);
}
.m-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 4px 10px;
  border-radius: var(--radius-chip);
  font-size: var(--text-chip);
  line-height: var(--lh-chip);
  font-weight: 600;
}
.m-chip::before {
  content: none;
}
.m-chip--dot::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.m-chip--success {
  background: var(--color-success-bg);
  color: var(--color-success-text);
}
.m-chip--warn {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
}
.m-chip--danger {
  background: var(--color-danger-bg);
  color: var(--color-danger-text);
}
.m-chip--neutral {
  background: var(--bg-card);
  color: var(--text-secondary);
}
.m-chip--primary,
.m-chip--occupant {
  background: var(--color-info-bg);
  color: var(--color-info-text);
  border: 1px solid var(--color-info-border);
}
.m-chip--fcfs {
  background: var(--badge-fcfs-soft);
  color: var(--badge-fcfs);
}
.m-chip--assigned {
  background: var(--badge-assigned-soft);
  color: var(--badge-assigned);
}
.m-chip--paid {
  background: var(--badge-paid-soft);
  color: var(--badge-paid);
}
.m-chip--valid {
  background: var(--badge-valid-soft);
  color: var(--badge-valid);
}
.m-chip--services {
  background: var(--persona-services-green-soft);
  color: var(--persona-services-green);
}
.m-app-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-divider);
}
.m-app-header__logo {
  width: 28px;
  height: 22px;
  flex-shrink: 0;
  object-fit: contain;
}
.m-app-header__user {
  flex: 1;
  min-width: 0;
  text-align: right;
}
.m-app-header__name {
  margin: 0;
  font-size: var(--text-body-sm);
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.m-app-header__meta {
  margin: 2px 0 0;
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.m-app-header__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--bg-card);
}
.m-app-header__logout {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 1px solid var(--border-divider);
  border-radius: 50%;
  background: var(--bg-surface);
  color: var(--text-secondary);
  cursor: pointer;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}
.m-app-header__logout ion-icon {
  font-size: 18px;
}
.m-app-header__logout:active {
  background: var(--bg-card);
}
.m-quick-actions {
  display: flex;
  gap: var(--space-2xl);
  overflow-x: auto;
  padding: var(--space-sm) var(--space-lg);
  margin: 0 calc(var(--space-lg) * -1);
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.m-quick-actions::-webkit-scrollbar {
  display: none;
}
.m-quick-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  min-width: var(--feature-btn-size);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  text-decoration: none;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
}
.m-quick-action:active .m-quick-action__ring {
  transform: scale(0.95);
}
.m-quick-action__ring {
  width: var(--feature-btn-size);
  height: var(--feature-btn-size);
  border-radius: 50%;
  border: 2px solid currentColor;
  display: grid;
  place-items: center;
  font-size: 26px;
  background: var(--bg-surface);
  transition: transform 0.1s ease;
}
.m-quick-action__ring:has(.m-quick-action__image) {
  overflow: hidden;
}
.m-quick-action__image {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  pointer-events: none;
  -webkit-user-select: none;
  user-select: none;
}
.m-quick-action__label {
  font-size: var(--text-caption-sm);
  font-weight: 600;
  color: currentColor;
  text-align: center;
}
.m-quick-action--primary {
  color: var(--ring-primary);
}
.m-quick-action--ok {
  color: var(--ring-ok);
}
.m-quick-action--delay {
  color: var(--ring-delay);
}
.m-quick-action--alert {
  color: var(--ring-alert);
}
.m-quick-action--access {
  color: var(--ring-primary);
}
.m-quick-action--parking {
  color: var(--ring-ok);
}
.m-quick-action--visitors {
  color: #38bdf8;
}
.m-quick-action--valet {
  color: var(--ring-delay);
}
.m-quick-action--amenities {
  color: #a16207;
}
.m-dashboard-section {
  padding: 0 var(--space-lg) var(--space-md);
}
.m-dashboard-section:has(.m-horizontal-scroll) {
  overflow: visible;
}
.m-dashboard-section .m-quick-actions {
  margin-top: var(--space-lg);
  padding-top: var(--space-sm);
}
.m-accordion__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-md) 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
}
.m-accordion__chevron {
  font-size: 18px;
  color: var(--text-muted);
  transition: transform 0.2s ease;
}
.m-accordion__chevron--open {
  transform: rotate(180deg);
}
.m-horizontal-scroll {
  display: flex;
  gap: var(--space-md);
  width: 100%;
  max-width: 100%;
  overflow-x: scroll;
  overflow-y: hidden;
  padding-bottom: var(--space-sm);
  margin: 0 calc(var(--space-lg) * -1);
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
  scroll-padding-inline: var(--space-lg);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-x;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
}
.m-horizontal-scroll::after {
  content: "";
  flex: 0 0 1px;
}
.m-horizontal-scroll::-webkit-scrollbar {
  display: none;
}
.m-notice-card {
  flex: 0 0 260px;
  padding: var(--space-md);
  border-radius: var(--radius-card);
  border: 1px solid var(--border-divider);
  background: var(--bg-surface);
}
.m-notice-card--alert {
  border-color: var(--color-danger-soft);
  background: var(--color-danger-soft);
}
.m-notice-card__title {
  margin: 0;
  font-size: var(--text-body-sm);
  font-weight: 600;
}
.m-notice-card__meta {
  margin: var(--space-xs) 0;
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
}
.m-active-card {
  flex: 0 0 220px;
  scroll-snap-align: start;
  padding: var(--space-md);
  border-radius: var(--radius-card);
  background: var(--bg-surface);
  border: none;
  box-shadow: var(--shadow-elevated);
}
.m-active-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-sm);
}
.m-active-card__icon {
  font-size: 22px;
  color: var(--text-secondary);
}
.m-active-card__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
.m-active-card__dot--ok {
  background: var(--color-success);
}
.m-active-card__dot--delay {
  background: var(--color-warning);
}
.m-active-card__dot--alert {
  background: var(--color-danger);
}
.m-active-card__title {
  margin: 0;
  font-size: var(--text-body-sm);
  font-weight: 600;
  color: var(--text-primary);
}
.m-active-card__meta {
  margin: var(--space-xs) 0 0;
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
}
.m-active-card__detail {
  margin: var(--space-xs) 0 0;
  font-size: var(--text-caption-sm);
  line-height: var(--lh-caption-sm);
  color: var(--text-secondary);
}
.m-highlight-card {
  flex: 0 0 280px;
  height: 140px;
  border-radius: var(--radius-card);
  background:
    linear-gradient(
      180deg,
      transparent 40%,
      rgba(0, 0, 0, 0.65) 100%),
    var(--bg-card);
  display: flex;
  align-items: flex-end;
  padding: var(--space-md);
  color: white;
  font-size: var(--text-body-sm);
  font-weight: 600;
}
.m-fab {
  position: fixed;
  right: var(--space-lg);
  bottom: calc(var(--tab-bar-height) + var(--space-lg) + env(safe-area-inset-bottom, 0));
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: none;
  background: var(--color-info);
  color: var(--text-inverse);
  font-size: 24px;
  box-shadow: var(--shadow-fab);
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 10;
}
.m-tab-bar-preview {
  display: flex;
  border-top: 1px solid var(--border-divider);
  background: var(--bg-surface);
  padding-top: var(--tab-bar-padding-top);
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.m-tab-bar-preview__item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: var(--space-xs) 0;
  font-size: var(--tab-label-size);
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
}
.m-tab-bar-preview__item ion-icon {
  font-size: var(--tab-icon-size);
}
.m-tab-bar-preview__item--active {
  color: var(--color-info);
}
.m-tab-bar-preview__item--access {
  color: var(--persona-access-active);
}
.m-segment {
  display: flex;
  padding: 4px;
  background: var(--bg-card);
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-lg);
}
.m-segment__btn {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  border: none;
  border-radius: var(--radius-pill);
  background: transparent;
  font-size: var(--text-body-sm);
  font-weight: 500;
  color: var(--text-secondary);
  cursor: pointer;
}
.m-segment__btn--active {
  background: var(--color-info);
  color: var(--text-inverse);
}
.m-access-card {
  padding: var(--space-lg) 0;
  text-align: center;
}
.m-access-qr-card {
  padding: var(--space-lg);
  border-radius: var(--radius-card);
  background: var(--bg-surface);
  box-shadow: var(--shadow-elevated);
  text-align: center;
}
.m-access-qr-card__hint {
  margin: 0 0 var(--space-md);
  font-size: var(--text-body-sm);
  color: var(--text-muted);
}
.m-access-qr-card__code {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-md);
}
.m-access-qr-card__image {
  width: 200px;
  height: 200px;
  border-radius: var(--radius-chip);
  background: #fff;
}
.m-access-qr-card__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
}
.m-access-refresh-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-info);
  background: var(--bg-surface);
  color: var(--color-info);
  font-size: var(--text-body-sm);
  font-weight: 600;
  cursor: pointer;
}
.m-access-refresh-btn:disabled {
  opacity: 0.6;
  cursor: default;
}
.m-access-qr-card__timer {
  font-size: var(--text-body-sm);
  font-weight: 600;
  color: var(--text-muted);
}
.m-access-or {
  margin: var(--space-lg) 0;
  text-align: center;
  font-size: var(--text-body-sm);
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.08em;
}
.m-access-card__title {
  margin: 0 0 var(--space-lg);
  font-size: var(--text-subheader);
  font-weight: 600;
}
.m-qr-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-lg);
  border-radius: var(--radius-card);
  background: var(--bg-card);
}
.m-qr-block__placeholder {
  width: 180px;
  height: 180px;
  border-radius: var(--radius-chip);
  background:
    repeating-linear-gradient(
      45deg,
      #1a1a1a,
      #1a1a1a 4px,
      #ffffff 4px,
      #ffffff 8px);
}
.m-access-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-md);
  font-size: var(--text-body-sm);
}
.m-access-status__ready {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  color: var(--color-success);
  font-weight: 500;
}
.m-access-status__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}
.m-access-status__refresh {
  color: var(--color-info);
  font-weight: 500;
}
.m-numeric-code {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-md);
}
.m-numeric-code--boxed {
  gap: var(--space-sm);
}
.m-numeric-code__box {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-chip);
  background: var(--bg-surface);
  box-shadow: var(--shadow-elevated);
  font-size: var(--text-header-lg);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
}
.m-numeric-code__refresh {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  margin-left: var(--space-sm);
  border-radius: var(--radius-chip);
  border: 1px solid var(--color-info);
  background: var(--bg-surface);
  color: var(--color-info);
  cursor: pointer;
}
.m-numeric-code__refresh:disabled {
  opacity: 0.6;
  cursor: default;
}
.m-numeric-code__digit {
  font-size: var(--text-header-lg);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
}
.m-access-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
  border-top: 1px solid var(--border-divider);
  background: var(--bg-surface);
}
.m-access-footer__granted {
  color: var(--color-success);
  font-weight: 600;
}
.m-nfc-ripple {
  position: relative;
  width: 100px;
  height: 100px;
  margin: var(--space-lg) auto;
  display: grid;
  place-items: center;
}
.m-nfc-ripple::before,
.m-nfc-ripple::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  border: 2px solid var(--brand-primary-soft);
}
.m-nfc-ripple::before {
  width: 100%;
  height: 100%;
  opacity: 0.5;
}
.m-nfc-ripple::after {
  width: 75%;
  height: 75%;
  opacity: 0.7;
}
.m-nfc-ripple__core {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-info);
  color: white;
  display: grid;
  place-items: center;
  font-size: 24px;
  z-index: 1;
}
.m-parking-card__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin: var(--space-md) 0;
  text-align: center;
}
.m-parking-card__grid-label {
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
}
.m-parking-card__grid-value {
  margin-top: 2px;
  font-size: var(--text-body-sm);
  font-weight: 600;
}
.m-parking-timer {
  text-align: center;
  margin: var(--space-lg) 0;
}
.m-parking-timer__label {
  font-size: var(--text-body-sm);
  color: var(--text-muted);
}
.m-parking-timer__value {
  font-size: var(--text-timer);
  line-height: var(--lh-timer);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.m-entry-methods {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.m-entry-method {
  flex: 1;
  min-height: 36px;
  border: 1px solid var(--border-divider);
  border-radius: var(--radius-chip);
  background: var(--bg-surface);
  font-size: var(--text-caption-sm);
  font-weight: 500;
  color: var(--text-secondary);
  cursor: pointer;
}
.m-entry-method--active {
  border-color: var(--color-info-border);
  color: var(--color-info-text);
  background: var(--color-info-bg);
}
.m-scan-hero {
  text-align: center;
  padding: var(--space-2xl) var(--space-lg);
}
.m-scan-hero__icon {
  width: 96px;
  height: 96px;
  margin: 0 auto var(--space-xl);
  border-radius: 50%;
  background: var(--color-info-bg);
  color: var(--color-info);
  display: grid;
  place-items: center;
  font-size: 40px;
}
.m-scan-hero__icon-btn {
  border: none;
  padding: 0;
  cursor: pointer;
  transition: transform 0.15s ease, opacity 0.15s ease;
}
.m-scan-hero__icon-btn:active:not(:disabled) {
  transform: scale(0.96);
}
.m-scan-hero__icon-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.m-scan-viewport {
  overflow: hidden;
  padding: 0;
}
.m-scan-viewport__header {
  padding: var(--space-lg);
  border-bottom: 1px solid var(--border-divider);
}
.m-scan-viewport__reader {
  width: 100%;
  min-height: 300px;
  background: #000;
}
.m-scan-viewport__reader video {
  object-fit: cover !important;
}
.m-scan-viewport__actions {
  display: flex;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg) var(--space-lg);
}
.m-turnstyle {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}
.m-turnstyle__heading {
  margin: 0;
  font-size: var(--text-header);
  font-weight: 700;
  color: var(--text-primary);
}
.m-turnstyle__methods {
  display: flex;
  gap: var(--space-sm);
}
.m-turnstyle__method {
  flex: 1;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  border: 1px solid var(--border-divider);
  border-radius: var(--radius-chip);
  background: var(--bg-surface);
  font-size: var(--text-body-sm);
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
}
.m-turnstyle__method ion-icon {
  font-size: 18px;
}
.m-turnstyle__method--active {
  border-color: var(--color-info);
  background: var(--color-info);
  color: var(--text-inverse);
}
.m-turnstyle-scanner {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-card);
  background: #0f172a;
  min-height: 280px;
}
.m-turnstyle-scanner__reader {
  width: 100%;
  min-height: 280px;
}
.m-turnstyle-scanner__reader video {
  object-fit: cover !important;
}
.m-turnstyle-scanner__overlay {
  pointer-events: none;
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--space-md);
}
.m-turnstyle-scanner__frame-wrap {
  flex: 1;
  display: grid;
  place-items: center;
}
.m-turnstyle-scanner__frame {
  width: min(220px, 70%);
  aspect-ratio: 1;
  border: 2px dashed var(--color-danger);
  border-radius: var(--radius-card);
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.45);
  position: relative;
}
.m-turnstyle-scanner__frame::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 50%;
  height: 2px;
  background: var(--color-danger);
}
.m-turnstyle-scanner__hint {
  align-self: center;
  margin: 0;
  padding: var(--space-xs) var(--space-md);
  border-radius: var(--radius-pill);
  background: rgba(0, 0, 0, 0.55);
  color: var(--text-inverse);
  font-size: var(--text-caption-sm);
}
.m-system-ready {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-body-sm);
  color: var(--color-success);
  font-weight: 600;
}
.m-system-ready__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-success);
}
.m-turnstyle-nfc {
  text-align: center;
  padding: var(--space-2xl) var(--space-lg);
}
.m-turnstyle-nfc__hint {
  margin: var(--space-lg) 0 0;
  font-size: var(--text-body-sm);
  color: var(--text-muted);
}
.m-sos-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  margin: var(--space-xl) auto 0;
  padding: var(--space-sm) var(--space-lg);
  border: 1px solid var(--border-divider);
  border-radius: var(--radius-pill);
  background: var(--bg-surface);
  color: var(--color-info);
  font-size: var(--text-body-sm);
  font-weight: 600;
  cursor: pointer;
}
.m-verification-hero {
  text-align: center;
  padding: var(--space-xl) var(--space-lg) var(--space-lg);
}
.m-verification-hero__icon {
  width: 72px;
  height: 72px;
  margin: 0 auto var(--space-md);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 36px;
}
.m-verification-hero__icon--granted {
  background: var(--color-success-bg);
  color: var(--color-success);
}
.m-verification-hero__icon--denied {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}
.m-verification-hero__title {
  margin: 0;
  font-size: var(--text-header-lg);
  font-weight: 700;
}
.m-verification-hero__title--granted {
  color: var(--color-success);
}
.m-verification-hero__title--denied {
  color: var(--color-danger);
}
.m-verification-hero__subtitle {
  margin: var(--space-xs) 0 0;
  font-size: var(--text-body-sm);
  color: var(--text-muted);
}
.m-verification-card {
  position: relative;
  padding: var(--space-lg);
}
.m-verification-card__profile {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
}
.m-verification-card__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--bg-card);
  display: grid;
  place-items: center;
  font-weight: 700;
  color: var(--text-secondary);
  flex-shrink: 0;
}
.m-verification-card__name {
  margin: 0;
  font-size: var(--text-subheader);
  font-weight: 700;
}
.m-verification-card__meta {
  margin: 2px 0 0;
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
}
.m-verification-card__badge {
  position: absolute;
  top: var(--space-lg);
  right: var(--space-lg);
}
.m-verification-details {
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-divider);
}
.m-verification-details__title {
  margin: 0 0 var(--space-md);
  font-size: var(--text-body-sm);
  font-weight: 700;
}
.m-verification-detail-row {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
  margin-bottom: var(--space-md);
}
.m-verification-detail-row__icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-chip);
  display: grid;
  place-items: center;
  font-size: 16px;
  flex-shrink: 0;
}
.m-verification-detail-row__icon--time {
  background: var(--color-info-bg);
  color: var(--color-info);
}
.m-verification-detail-row__icon--gate {
  background: #f3e8ff;
  color: #7c3aed;
}
.m-verification-detail-row__icon--type {
  background: var(--color-success-bg);
  color: var(--color-success);
}
.m-verification-detail-row__label {
  margin: 0;
  font-size: var(--text-body-sm);
  font-weight: 700;
}
.m-verification-detail-row__value {
  margin: 2px 0 0;
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
}
.m-verification-alert {
  text-align: center;
  padding: var(--space-lg);
  border-radius: var(--radius-card);
  background: var(--color-warning-bg, #fffbeb);
  border: 1px solid color-mix(in srgb, var(--color-warning) 35%, transparent);
  color: #92400e;
}
.m-verification-alert__title {
  margin: var(--space-sm) 0 var(--space-xs);
  font-size: var(--text-body-sm);
  font-weight: 700;
}
.m-verification-alert__text {
  margin: 0;
  font-size: var(--text-caption-sm);
}
.m-verification-denied-card {
  text-align: center;
  padding: var(--space-2xl) var(--space-lg);
}
.m-stat-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  text-align: center;
}
.m-stat__value {
  font-size: var(--text-header-lg);
  font-weight: 700;
}
.m-stat__label {
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
  margin-top: var(--space-xs);
}
.m-stat--green .m-stat__value {
  color: var(--color-success);
}
.m-stat--blue .m-stat__value {
  color: var(--color-info);
}
.m-stat--orange .m-stat__value {
  color: var(--color-warning);
}
.m-kv-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.m-kv-row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-md);
  font-size: var(--text-body-sm);
}
.m-kv-row__label {
  color: var(--text-muted);
}
.m-kv-row__value {
  font-weight: 600;
  text-align: right;
}
.m-kv-row__value--accent {
  color: var(--color-warning);
  font-weight: 700;
}
.m-visitor-card__row {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
}
.m-visitor-card__photo {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-chip);
  background: var(--bg-card);
  flex-shrink: 0;
  display: grid;
  place-items: center;
  color: var(--text-muted);
  font-size: 24px;
}
.m-visitor-card__actions {
  display: flex;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}
.m-visitor-form__photo-slot {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-card);
  background: var(--bg-card);
  display: grid;
  place-items: center;
  color: var(--text-muted);
  font-size: 32px;
}
.m-qr-pass {
  text-align: center;
  padding: var(--space-lg);
}
.m-qr-pass__code {
  margin-top: var(--space-md);
  font-size: var(--text-header-lg);
  font-weight: 700;
  letter-spacing: 0.2em;
  font-variant-numeric: tabular-nums;
}
.m-host-card {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  border-radius: var(--radius-card);
  background: var(--bg-card);
}
.m-valet-price {
  text-align: center;
  font-size: var(--text-header-lg);
  font-weight: 700;
  color: var(--color-info);
  margin: var(--space-lg) 0;
}
.m-countdown {
  width: 72px;
  height: 72px;
  margin: var(--space-lg) auto;
  border-radius: 50%;
  border: 3px solid var(--color-danger);
  color: var(--color-danger);
  font-size: var(--text-subheader);
  font-weight: 700;
  display: grid;
  place-items: center;
  font-variant-numeric: tabular-nums;
}
.m-payment-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-sm);
}
.m-payment-tile {
  aspect-ratio: 1;
  border: 1px solid var(--border-divider);
  border-radius: var(--radius-chip);
  display: grid;
  place-items: center;
  font-size: var(--text-caption-sm);
  font-weight: 500;
  color: var(--text-secondary);
  background: var(--bg-surface);
}
.m-list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  min-height: var(--touch-min);
  padding: var(--space-md) var(--space-lg);
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-divider);
}
.m-list-item:first-child {
  border-top-left-radius: var(--radius-card);
  border-top-right-radius: var(--radius-card);
}
.m-list-item:last-child {
  border-bottom: none;
}
.m-list-item__title {
  font-size: var(--text-body);
  font-weight: 600;
}
.m-list-item__meta {
  font-size: var(--text-body-sm);
  color: var(--text-muted);
}
.m-log-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--border-divider);
}
.m-log-row:last-child {
  border-bottom: none;
}
.m-toast {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-card);
  font-size: var(--text-body-sm);
  font-weight: 500;
}
.m-toast--success {
  background: var(--color-success-bg);
  color: var(--color-success-text);
  border: 1px solid color-mix(in srgb, var(--color-success) 35%, transparent);
}
.m-toast--error {
  background: var(--color-danger-bg);
  color: var(--color-danger-text);
  border: 1px solid color-mix(in srgb, var(--color-danger) 35%, transparent);
}
.m-empty-state {
  text-align: center;
  padding: var(--space-2xl) var(--space-lg);
  color: var(--text-muted);
}
.m-empty-state__icon {
  font-size: 48px;
  margin-bottom: var(--space-md);
  opacity: 0.4;
}
.m-skeleton {
  border-radius: var(--radius-chip);
  background:
    linear-gradient(
      90deg,
      var(--bg-card) 25%,
      #eceef1 50%,
      var(--bg-card) 75%);
  background-size: 200% 100%;
  animation: m-skeleton-shimmer 1.2s ease-in-out infinite;
}
@keyframes m-skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
.m-skeleton--line {
  height: 14px;
  margin-bottom: var(--space-sm);
}
.m-skeleton--block {
  height: 80px;
}
.m-persona-grid {
  display: grid;
  gap: var(--space-md);
}
.m-persona-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-radius: var(--radius-card);
  border: 1px solid var(--border-divider);
  background: var(--bg-surface);
  text-align: left;
  width: 100%;
  min-height: var(--touch-min);
  cursor: pointer;
  box-shadow: var(--shadow-card);
}
.m-persona-card:active {
  transform: scale(0.99);
}
.m-persona-card__icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-input);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 20px;
}
.m-persona-card__icon--occupant {
  background: var(--color-info-bg);
  color: var(--color-info);
}
.m-persona-card__icon--services {
  background: var(--persona-services-green-soft);
  color: var(--persona-services-green);
}
.m-persona-card__title {
  margin: 0;
  font-size: var(--text-body);
  font-weight: 600;
}
.m-persona-card__desc {
  margin: var(--space-xs) 0 0;
  font-size: var(--text-body-sm);
  color: var(--text-muted);
}
.m-ui-kit-swatch {
  height: 48px;
  border-radius: var(--radius-chip);
  border: 1px solid var(--border-divider);
}
.m-ui-kit-swatch__label {
  margin-top: var(--space-xs);
  font-size: var(--text-caption-sm);
  color: var(--text-muted);
}
.m-pin {
  font-family:
    ui-monospace,
    SFMono-Regular,
    Menlo,
    monospace;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.2em;
}
.m-tab-bar-custom {
  --background: var(--bg-surface);
  border-top: 1px solid var(--border-divider);
  padding-top: var(--tab-bar-padding-top);
  padding-bottom: env(safe-area-inset-bottom, 0);
  min-height: var(--tab-bar-height);
}
.m-tab-bar-custom ion-tab-button {
  --padding-top: var(--space-xs);
  --padding-bottom: var(--space-xs);
}
.m-tab-bar-custom ion-tab-button ion-icon {
  font-size: var(--tab-icon-size);
}
.m-tab-bar-custom ion-tab-button ion-label {
  font-size: var(--tab-label-size);
  font-weight: 500;
  margin-top: 2px;
}
.m-hero {
  padding: var(--space-xl) var(--space-lg);
  border-radius: var(--radius-card);
  color: var(--text-inverse);
}
.m-hero--primary,
.m-hero--occupant {
  background: var(--sovereign-gradient);
}
.m-hero--services {
  background:
    linear-gradient(
      145deg,
      var(--persona-services-navy) 0%,
      var(--persona-services-green) 100%);
}
.m-hero__title {
  margin: 0;
  font-size: var(--text-header-lg);
  font-weight: 700;
}
.m-hero__subtitle {
  margin: var(--space-sm) 0 0;
  font-size: var(--text-body-sm);
  opacity: 0.9;
}
.m-card--flat {
  box-shadow: none;
}
html[data-theme=dark] .m-brand-bar,
html.dark .m-brand-bar {
  background: var(--sovereign-gradient);
}
html[data-theme=dark] .m-brand-bar--services,
html.dark .m-brand-bar--services {
  background: var(--bg-surface);
  border-bottom-color: var(--border-default);
}
html[data-theme=dark] .m-brand-bar--services .m-brand-bar__logo,
html.dark .m-brand-bar--services .m-brand-bar__logo {
  filter: brightness(0) invert(1);
  opacity: 0.92;
}
html[data-theme=dark] .m-login-card,
html[data-theme=dark] .m-card--elevated,
html.dark .m-login-card,
html.dark .m-card--elevated {
  box-shadow: var(--shadow-md);
}
html[data-theme=dark] .m-btn--primary:disabled,
html.dark .m-btn--primary:disabled {
  background: var(--bg-elevated);
  color: var(--text-muted);
}
html[data-theme=dark] .m-btn--ghost,
html.dark .m-btn--ghost {
  border-color: var(--color-info-border);
  color: var(--color-info);
}
html[data-theme=dark] .m-field__control,
html.dark .m-field__control {
  background: var(--bg-elevated);
}
html[data-theme=dark] .m-field__control:focus-within,
html.dark .m-field__control:focus-within {
  border-color: var(--color-info);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-info) 22%, transparent);
}
html[data-theme=dark] .m-otp-cell,
html.dark .m-otp-cell {
  background: var(--bg-elevated);
  border-color: var(--border-default);
}
html[data-theme=dark] .m-otp-cell:focus,
html.dark .m-otp-cell:focus {
  border-color: var(--color-info);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-info) 22%, transparent);
}
html[data-theme=dark] .m-quick-action__ring,
html.dark .m-quick-action__ring {
  background: var(--bg-surface);
}
html[data-theme=dark] .m-segment,
html.dark .m-segment {
  background: var(--bg-elevated);
}
html[data-theme=dark] .m-qr-block__placeholder,
html.dark .m-qr-block__placeholder {
  background:
    repeating-linear-gradient(
      45deg,
      #f1f5f9,
      #f1f5f9 4px,
      var(--bg-elevated) 4px,
      var(--bg-elevated) 8px);
}
html[data-theme=dark] .m-highlight-card,
html.dark .m-highlight-card {
  background:
    linear-gradient(
      180deg,
      transparent 35%,
      rgba(0, 0, 0, 0.75) 100%),
    var(--bg-elevated);
}
html[data-theme=dark] .m-skeleton,
html.dark .m-skeleton {
  background:
    linear-gradient(
      90deg,
      var(--bg-elevated) 25%,
      color-mix(in srgb, var(--bg-elevated) 60%, var(--text-muted)) 50%,
      var(--bg-elevated) 75%);
  background-size: 200% 100%;
}
html[data-theme=dark] .m-notice-card--alert,
html.dark .m-notice-card--alert {
  border-color: color-mix(in srgb, var(--color-danger) 40%, var(--border-default));
}
html[data-theme=dark] .m-payment-tile,
html.dark .m-payment-tile {
  background: var(--bg-elevated);
}
html[data-theme=dark] .m-entry-method,
html.dark .m-entry-method {
  background: var(--bg-elevated);
}
html[data-theme=dark] .m-entry-method--active,
html.dark .m-entry-method--active {
  background: var(--color-info-bg);
  border-color: var(--color-info-border);
  color: var(--color-info-text);
}
html[data-theme=dark] .m-helpline-btn,
html.dark .m-helpline-btn {
  background: var(--bg-elevated);
  border-color: var(--border-default);
}
html[data-theme=dark] .m-nfc-ripple::before,
html[data-theme=dark] .m-nfc-ripple::after,
html.dark .m-nfc-ripple::before,
html.dark .m-nfc-ripple::after {
  border-color: color-mix(in srgb, var(--color-info) 30%, transparent);
}
html[data-theme=dark] .m-toast--success,
html.dark .m-toast--success {
  background: var(--color-success-bg);
  color: var(--color-success-text);
  border: 1px solid color-mix(in srgb, var(--color-success) 40%, transparent);
}
html[data-theme=dark] .m-toast--error,
html.dark .m-toast--error {
  background: var(--color-danger-bg);
  color: var(--color-danger-text);
  border: 1px solid color-mix(in srgb, var(--color-danger) 40%, transparent);
}
html[data-theme=dark] .ui-kit-device,
html.dark .ui-kit-device {
  border-color: var(--border-default);
  background: var(--bg-base);
}
html,
body,
ion-app {
  height: 100%;
}
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-body);
  line-height: var(--lh-body);
  background: var(--bg-app);
  color: var(--text-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
.occupant-shell ion-router-outlet {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  display: block;
  contain: none;
}
.occupant-shell ion-router-outlet > .ion-page {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  contain: none;
  animation: occupant-tab-appear 180ms ease-out;
}
@keyframes occupant-tab-appear {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@media (prefers-reduced-motion: reduce) {
  .occupant-shell ion-router-outlet > .ion-page {
    animation: none;
  }
}
.occupant-shell ion-router-outlet > .ion-page > ion-content {
  flex: 1 1 auto;
  min-height: 0;
}
ion-content {
  --background: var(--bg-app);
}
ion-content.m-login-page {
  --background: var(--bg-surface);
}
ion-toolbar {
  --background: var(--bg-surface);
  --border-color: var(--border-divider);
  --color: var(--text-primary);
  --min-height: var(--header-height);
}
.app-header-user__backdrop {
  position: fixed;
  inset: 0;
  z-index: 200000;
  background: transparent;
}
.app-header-user__menu {
  position: fixed;
  z-index: 200001;
}
.app-header-user__logout {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 var(--space-md);
  border: 1px solid var(--border-divider);
  border-radius: var(--radius-btn);
  background: var(--bg-surface);
  color: var(--color-danger);
  font-size: var(--text-body-sm);
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  -webkit-tap-highlight-color: transparent;
  font-family: var(--font-sans);
}
.app-header-user__logout:active {
  opacity: 0.9;
}
ion-button {
  --border-radius: var(--radius-btn);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}

/* angular:styles/global:styles */
/*# sourceMappingURL=styles.css.map */
