@charset "UTF-8";
/* You can add global styles to this file, and also import other style files */
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,400;0,600;1,400&display=swap");
body {
  margin: 0;
  padding: 0;
}

:root {
  --brand-color: #1ba94c;
  --brand-rgb: 27, 169, 76;
  --brand-hover: rgb(34.0255102041, 212.9744897959, 95.7755102041);
  --brand-dark: rgb(19.9744897959, 125.0255102041, 56.2244897959);
  --brand-disabled: rgb(204.1275510204, 246.8724489796, 218.8775510204);
  --brand-box-shadow: rgba(27, 169, 76, 0.5);
  --brand-box-shadow-hover: rgba(27, 169, 76, 0.4);
  --primary-color: #1ba94c;
  --primary-rgb: 27, 169, 76;
  --primary-hover: rgb(34.0255102041, 212.9744897959, 95.7755102041);
  --primary-dark: rgb(19.9744897959, 125.0255102041, 56.2244897959);
  --primary-disabled: rgb(204.1275510204, 246.8724489796, 218.8775510204);
  --primary-box-shadow: rgba(27, 169, 76, 0.5);
  --primary-box-shadow-hover: rgba(27, 169, 76, 0.4);
  --secondary-color: #097bbf;
  --secondary-rgb: 9, 123, 191;
  --secondary-hover: rgb(11.295, 154.365, 239.705);
  --secondary-dark: rgb(6.705, 91.635, 142.295);
  --secondary-disabled: rgb(202.475, 233.825, 252.525);
  --secondary-box-shadow: rgba(9, 123, 191, 0.5);
  --secondary-box-shadow-hover: rgba(9, 123, 191, 0.4);
  --error-color: #a93c32;
  --error-rgb: 169, 60, 50;
  --error-hover: rgb(200.2054794521, 80.7534246575, 69.7945205479);
  --error-dark: rgb(129.6438356164, 46.0273972603, 38.3561643836);
  --error-disabled: rgb(246.7808219178, 228.8630136986, 227.2191780822);
  --error-box-shadow: rgba(169, 60, 50, 0.5);
  --error-box-shadow-hover: rgba(169, 60, 50, 0.4);
  --success-color: #22a97a;
  --success-rgb: 34, 169, 122;
  --success-hover: rgb(42.5418719212, 211.4581280788, 152.6502463054);
  --success-dark: rgb(25.4581280788, 126.5418719212, 91.3497536946);
  --success-disabled: rgb(211.7093596059, 246.2906403941, 234.2512315271);
  --success-box-shadow: rgba(34, 169, 122, 0.5);
  --success-box-shadow-hover: rgba(34, 169, 122, 0.4);
  --disabled-color: #6EA989;
  --app-background: linear-gradient(to bottom, #fff 0%, #f3f7f7 100%);
  --font-family-sans-serif: "Open Sans", sans-serif;
  --heading-color: #3a424e;
  --link-color: #5fa6ff;
  --link-color-hover: #447dbd;
  --disabled-text-color: #b7c9cc;
  --toolbar-background-color: #39424e;
  --toolbar-box-shadow-color: rgba(115, 143, 147, 0.3);
  --toolbar-border-color: #28313d;
  --card-shadow-color: rgba(99, 118, 129, 0.3);
  --card-hover-shadow-color: rgba(99, 118, 129, 0.5);
  --card-margin-gutter: 0px;
  --font-family-sans-serif: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-family-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --brand-color: #1ba94c;
  --brand-color-hover: #158f3f;
  --brand-color-light: #6ed69a;
  --brand-color-hover-transparent: rgba(27, 169, 76, 0.1);
  --brand-box-shadow: rgba(27, 169, 76, 0.2);
  --brand-box-shadow-hover: rgba(27, 169, 76, 0.3);
  --brand-disabled: rgba(27, 169, 76, 0.5);
  --primary-color: #1ba94c;
  --primary-color-hover: #158f3f;
  --primary-color-light: #6ed69a;
  --primary-color-hover-transparent: rgba(27, 169, 76, 0.1);
  --primary-box-shadow: rgba(27, 169, 76, 0.2);
  --primary-box-shadow-hover: rgba(27, 169, 76, 0.3);
  --primary-disabled: rgba(27, 169, 76, 0.5);
  --secondary-color: #097bbf;
  --secondary-color-hover: #0768a2;
  --secondary-color-light: #65b5e6;
  --secondary-color-hover-transparent: rgba(9, 123, 191, 0.1);
  --secondary-box-shadow: rgba(9, 123, 191, 0.2);
  --secondary-box-shadow-hover: rgba(9, 123, 191, 0.3);
  --secondary-disabled: rgba(9, 123, 191, 0.5);
  --error-color: #a93c32;
  --error-color-hover: #8f322a;
  --error-color-light: #e48d85;
  --error-color-hover-transparent: rgba(169, 60, 50, 0.1);
  --error-box-shadow: rgba(169, 60, 50, 0.2);
  --error-box-shadow-hover: rgba(169, 60, 50, 0.3);
  --error-disabled: rgba(169, 60, 50, 0.5);
  --success-color: #22a97a;
  --success-color-hover: #1c8f67;
  --success-color-light: #75d7b2;
  --success-color-hover-transparent: rgba(34, 169, 122, 0.1);
  --success-box-shadow: rgba(34, 169, 122, 0.2);
  --success-box-shadow-hover: rgba(34, 169, 122, 0.3);
  --success-disabled: rgba(34, 169, 122, 0.5);
  --info-color: #097bbf;
  --info-color-hover: #0768a2;
  --info-color-light: #65b5e6;
  --info-color-hover-transparent: rgba(9, 123, 191, 0.1);
  --info-box-shadow: rgba(9, 123, 191, 0.2);
  --info-box-shadow-hover: rgba(9, 123, 191, 0.3);
  --text-color: #1f2937;
  --text-color-light: #6b7280;
  --disabled-text-color: #9ca3af;
  --disabled-color: #6EA989;
  --link-color: #097bbf;
  --link-color-hover: #0768a2;
  --bg-color: #ffffff;
  --bg-color-light: #f9fafb;
  --bg-color-dark: #f3f4f6;
  --border-color: #e5e7eb;
  --border-color-focus: #6ed69a;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --rounded-sm: 0.125rem;
  --rounded: 0.25rem;
  --rounded-md: 0.375rem;
  --rounded-lg: 0.5rem;
  --rounded-full: 9999px;
  --transition-fast: 150ms;
  --transition-normal: 300ms;
  --transition-slow: 500ms;
}

body {
  font-family: var(--font-family-sans-serif) !important;
}

/* Flexbox
// ================================================== */
.flex {
  display: flex;
}

.inline-flex {
  display: block;
}

.none {
  display: none;
}

.inline-flex {
  display: inline-flex;
}

/* Flex direction */
.layout-row {
  display: flex;
  flex-direction: row;
}

@media screen and (max-width: 767px) {
  .layout-xs-column {
    flex-direction: column;
    display: flex;
    gap: 2.5rem;
  }
}

/* Default */
.layout-row-reverse {
  display: flex;
  flex-direction: row-reverse;
}

.layout-column {
  display: flex;
  flex-direction: column;
}

.layout-column-reverse {
  display: flex;
  flex-direction: column-reverse;
}

/* Flex wrap */
.nowrap {
  flex-wrap: nowrap;
}

/* Default */
.wrap {
  flex-wrap: wrap;
}

.wrap-reverse {
  flex-wrap: wrap-reverse;
}

/* Justify content */
.justify-content-end {
  justify-content: flex-end;
}

.justify-content-start {
  justify-content: flex-start;
}

/* Default */
.justify-content-center {
  justify-content: center;
}

.justify-content-around {
  justify-content: space-around;
}

.justify-content-between {
  justify-content: space-between;
}

.justify-content-stretch {
  justify-content: stretch;
}

/* Align items */
.align-items-start {
  align-items: flex-start;
}

.align-items-center {
  align-items: center;
}

.align-items-end {
  align-items: flex-end;
}

.align-items-stretch {
  align-items: stretch;
}

/* Default */
.align-items-baseline {
  align-items: baseline;
}

.fill-height {
  min-height: 100vh;
}

/* Flex grow */
.flex-grow-none {
  flex-grow: 0;
}

/* Default */
.flex-grow {
  flex-grow: 1;
}

/* Flex shrink */
.flex-shrink-none {
  flex-shrink: 0;
}

.flex-shrink {
  flex-shrink: 1;
}

/* Default */
/* Flex basis */
.flex-basis-auto {
  flex-basis: auto;
}

/* Default */
.flex-basis-none {
  flex-basis: 0;
}

/* Align self */
.align-self-auto {
  align-self: auto;
}

/* Default */
.align-self-start {
  align-self: flex-start;
}

.align-self-center {
  align-self: center;
}

.align-self-end {
  align-self: flex-end;
}

.align-self-stretch {
  align-self: stretch;
}

.align-self-baseline {
  align-self: baseline;
}

.mt-0 {
  margin-top: 0px !important;
}

.pt-0 {
  padding-top: 0px !important;
}

.mb-0 {
  margin-bottom: 0px !important;
}

.pb-0 {
  padding-bottom: 0px !important;
}

.ml-0 {
  margin-left: 0px !important;
}

.pl-0 {
  padding-left: 0px !important;
}

.mr-0 {
  margin-right: 0px !important;
}

.pr-0 {
  padding-right: 0px !important;
}

.w-0 {
  width: 0% !important;
}

.h-0 {
  height: 0% !important;
}

.mx-0 {
  margin-left: 0px !important;
  margin-right: 0px !important;
}

.my-0 {
  margin-top: 0px !important;
  margin-bottom: 0px !important;
}

.ma-0 {
  margin: 0px !important;
}

.px-0 {
  padding-left: 0px !important;
  padding-right: 0px !important;
}

.py-0 {
  padding-top: 0px !important;
  padding-bottom: 0px !important;
}

.pa-0 {
  padding: 0px !important;
}

.mt-1 {
  margin-top: 1px !important;
}

.pt-1 {
  padding-top: 1px !important;
}

.mb-1 {
  margin-bottom: 1px !important;
}

.pb-1 {
  padding-bottom: 1px !important;
}

.ml-1 {
  margin-left: 1px !important;
}

.pl-1 {
  padding-left: 1px !important;
}

.mr-1 {
  margin-right: 1px !important;
}

.pr-1 {
  padding-right: 1px !important;
}

.w-1 {
  width: 1% !important;
}

.h-1 {
  height: 1% !important;
}

.mx-1 {
  margin-left: 1px !important;
  margin-right: 1px !important;
}

.my-1 {
  margin-top: 1px !important;
  margin-bottom: 1px !important;
}

.ma-1 {
  margin: 1px !important;
}

.px-1 {
  padding-left: 1px !important;
  padding-right: 1px !important;
}

.py-1 {
  padding-top: 1px !important;
  padding-bottom: 1px !important;
}

.pa-1 {
  padding: 1px !important;
}

.mt-2 {
  margin-top: 2px !important;
}

.pt-2 {
  padding-top: 2px !important;
}

.mb-2 {
  margin-bottom: 2px !important;
}

.pb-2 {
  padding-bottom: 2px !important;
}

.ml-2 {
  margin-left: 2px !important;
}

.pl-2 {
  padding-left: 2px !important;
}

.mr-2 {
  margin-right: 2px !important;
}

.pr-2 {
  padding-right: 2px !important;
}

.w-2 {
  width: 2% !important;
}

.h-2 {
  height: 2% !important;
}

.mx-2 {
  margin-left: 2px !important;
  margin-right: 2px !important;
}

.my-2 {
  margin-top: 2px !important;
  margin-bottom: 2px !important;
}

.ma-2 {
  margin: 2px !important;
}

.px-2 {
  padding-left: 2px !important;
  padding-right: 2px !important;
}

.py-2 {
  padding-top: 2px !important;
  padding-bottom: 2px !important;
}

.pa-2 {
  padding: 2px !important;
}

.mt-3 {
  margin-top: 3px !important;
}

.pt-3 {
  padding-top: 3px !important;
}

.mb-3 {
  margin-bottom: 3px !important;
}

.pb-3 {
  padding-bottom: 3px !important;
}

.ml-3 {
  margin-left: 3px !important;
}

.pl-3 {
  padding-left: 3px !important;
}

.mr-3 {
  margin-right: 3px !important;
}

.pr-3 {
  padding-right: 3px !important;
}

.w-3 {
  width: 3% !important;
}

.h-3 {
  height: 3% !important;
}

.mx-3 {
  margin-left: 3px !important;
  margin-right: 3px !important;
}

.my-3 {
  margin-top: 3px !important;
  margin-bottom: 3px !important;
}

.ma-3 {
  margin: 3px !important;
}

.px-3 {
  padding-left: 3px !important;
  padding-right: 3px !important;
}

.py-3 {
  padding-top: 3px !important;
  padding-bottom: 3px !important;
}

.pa-3 {
  padding: 3px !important;
}

.mt-4 {
  margin-top: 4px !important;
}

.pt-4 {
  padding-top: 4px !important;
}

.mb-4 {
  margin-bottom: 4px !important;
}

.pb-4 {
  padding-bottom: 4px !important;
}

.ml-4 {
  margin-left: 4px !important;
}

.pl-4 {
  padding-left: 4px !important;
}

.mr-4 {
  margin-right: 4px !important;
}

.pr-4 {
  padding-right: 4px !important;
}

.w-4 {
  width: 4% !important;
}

.h-4 {
  height: 4% !important;
}

.mx-4 {
  margin-left: 4px !important;
  margin-right: 4px !important;
}

.my-4 {
  margin-top: 4px !important;
  margin-bottom: 4px !important;
}

.ma-4 {
  margin: 4px !important;
}

.px-4 {
  padding-left: 4px !important;
  padding-right: 4px !important;
}

.py-4 {
  padding-top: 4px !important;
  padding-bottom: 4px !important;
}

.pa-4 {
  padding: 4px !important;
}

.mt-5 {
  margin-top: 5px !important;
}

.pt-5 {
  padding-top: 5px !important;
}

.mb-5 {
  margin-bottom: 5px !important;
}

.pb-5 {
  padding-bottom: 5px !important;
}

.ml-5 {
  margin-left: 5px !important;
}

.pl-5 {
  padding-left: 5px !important;
}

.mr-5 {
  margin-right: 5px !important;
}

.pr-5 {
  padding-right: 5px !important;
}

.w-5 {
  width: 5% !important;
}

.h-5 {
  height: 5% !important;
}

.mx-5 {
  margin-left: 5px !important;
  margin-right: 5px !important;
}

.my-5 {
  margin-top: 5px !important;
  margin-bottom: 5px !important;
}

.ma-5 {
  margin: 5px !important;
}

.px-5 {
  padding-left: 5px !important;
  padding-right: 5px !important;
}

.py-5 {
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}

.pa-5 {
  padding: 5px !important;
}

.mt-6 {
  margin-top: 6px !important;
}

.pt-6 {
  padding-top: 6px !important;
}

.mb-6 {
  margin-bottom: 6px !important;
}

.pb-6 {
  padding-bottom: 6px !important;
}

.ml-6 {
  margin-left: 6px !important;
}

.pl-6 {
  padding-left: 6px !important;
}

.mr-6 {
  margin-right: 6px !important;
}

.pr-6 {
  padding-right: 6px !important;
}

.w-6 {
  width: 6% !important;
}

.h-6 {
  height: 6% !important;
}

.mx-6 {
  margin-left: 6px !important;
  margin-right: 6px !important;
}

.my-6 {
  margin-top: 6px !important;
  margin-bottom: 6px !important;
}

.ma-6 {
  margin: 6px !important;
}

.px-6 {
  padding-left: 6px !important;
  padding-right: 6px !important;
}

.py-6 {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

.pa-6 {
  padding: 6px !important;
}

.mt-7 {
  margin-top: 7px !important;
}

.pt-7 {
  padding-top: 7px !important;
}

.mb-7 {
  margin-bottom: 7px !important;
}

.pb-7 {
  padding-bottom: 7px !important;
}

.ml-7 {
  margin-left: 7px !important;
}

.pl-7 {
  padding-left: 7px !important;
}

.mr-7 {
  margin-right: 7px !important;
}

.pr-7 {
  padding-right: 7px !important;
}

.w-7 {
  width: 7% !important;
}

.h-7 {
  height: 7% !important;
}

.mx-7 {
  margin-left: 7px !important;
  margin-right: 7px !important;
}

.my-7 {
  margin-top: 7px !important;
  margin-bottom: 7px !important;
}

.ma-7 {
  margin: 7px !important;
}

.px-7 {
  padding-left: 7px !important;
  padding-right: 7px !important;
}

.py-7 {
  padding-top: 7px !important;
  padding-bottom: 7px !important;
}

.pa-7 {
  padding: 7px !important;
}

.mt-8 {
  margin-top: 8px !important;
}

.pt-8 {
  padding-top: 8px !important;
}

.mb-8 {
  margin-bottom: 8px !important;
}

.pb-8 {
  padding-bottom: 8px !important;
}

.ml-8 {
  margin-left: 8px !important;
}

.pl-8 {
  padding-left: 8px !important;
}

.mr-8 {
  margin-right: 8px !important;
}

.pr-8 {
  padding-right: 8px !important;
}

.w-8 {
  width: 8% !important;
}

.h-8 {
  height: 8% !important;
}

.mx-8 {
  margin-left: 8px !important;
  margin-right: 8px !important;
}

.my-8 {
  margin-top: 8px !important;
  margin-bottom: 8px !important;
}

.ma-8 {
  margin: 8px !important;
}

.px-8 {
  padding-left: 8px !important;
  padding-right: 8px !important;
}

.py-8 {
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}

.pa-8 {
  padding: 8px !important;
}

.mt-9 {
  margin-top: 9px !important;
}

.pt-9 {
  padding-top: 9px !important;
}

.mb-9 {
  margin-bottom: 9px !important;
}

.pb-9 {
  padding-bottom: 9px !important;
}

.ml-9 {
  margin-left: 9px !important;
}

.pl-9 {
  padding-left: 9px !important;
}

.mr-9 {
  margin-right: 9px !important;
}

.pr-9 {
  padding-right: 9px !important;
}

.w-9 {
  width: 9% !important;
}

.h-9 {
  height: 9% !important;
}

.mx-9 {
  margin-left: 9px !important;
  margin-right: 9px !important;
}

.my-9 {
  margin-top: 9px !important;
  margin-bottom: 9px !important;
}

.ma-9 {
  margin: 9px !important;
}

.px-9 {
  padding-left: 9px !important;
  padding-right: 9px !important;
}

.py-9 {
  padding-top: 9px !important;
  padding-bottom: 9px !important;
}

.pa-9 {
  padding: 9px !important;
}

.mt-10 {
  margin-top: 10px !important;
}

.pt-10 {
  padding-top: 10px !important;
}

.mb-10 {
  margin-bottom: 10px !important;
}

.pb-10 {
  padding-bottom: 10px !important;
}

.ml-10 {
  margin-left: 10px !important;
}

.pl-10 {
  padding-left: 10px !important;
}

.mr-10 {
  margin-right: 10px !important;
}

.pr-10 {
  padding-right: 10px !important;
}

.w-10 {
  width: 10% !important;
}

.h-10 {
  height: 10% !important;
}

.mx-10 {
  margin-left: 10px !important;
  margin-right: 10px !important;
}

.my-10 {
  margin-top: 10px !important;
  margin-bottom: 10px !important;
}

.ma-10 {
  margin: 10px !important;
}

.px-10 {
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.py-10 {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.pa-10 {
  padding: 10px !important;
}

.mt-11 {
  margin-top: 11px !important;
}

.pt-11 {
  padding-top: 11px !important;
}

.mb-11 {
  margin-bottom: 11px !important;
}

.pb-11 {
  padding-bottom: 11px !important;
}

.ml-11 {
  margin-left: 11px !important;
}

.pl-11 {
  padding-left: 11px !important;
}

.mr-11 {
  margin-right: 11px !important;
}

.pr-11 {
  padding-right: 11px !important;
}

.w-11 {
  width: 11% !important;
}

.h-11 {
  height: 11% !important;
}

.mx-11 {
  margin-left: 11px !important;
  margin-right: 11px !important;
}

.my-11 {
  margin-top: 11px !important;
  margin-bottom: 11px !important;
}

.ma-11 {
  margin: 11px !important;
}

.px-11 {
  padding-left: 11px !important;
  padding-right: 11px !important;
}

.py-11 {
  padding-top: 11px !important;
  padding-bottom: 11px !important;
}

.pa-11 {
  padding: 11px !important;
}

.mt-12 {
  margin-top: 12px !important;
}

.pt-12 {
  padding-top: 12px !important;
}

.mb-12 {
  margin-bottom: 12px !important;
}

.pb-12 {
  padding-bottom: 12px !important;
}

.ml-12 {
  margin-left: 12px !important;
}

.pl-12 {
  padding-left: 12px !important;
}

.mr-12 {
  margin-right: 12px !important;
}

.pr-12 {
  padding-right: 12px !important;
}

.w-12 {
  width: 12% !important;
}

.h-12 {
  height: 12% !important;
}

.mx-12 {
  margin-left: 12px !important;
  margin-right: 12px !important;
}

.my-12 {
  margin-top: 12px !important;
  margin-bottom: 12px !important;
}

.ma-12 {
  margin: 12px !important;
}

.px-12 {
  padding-left: 12px !important;
  padding-right: 12px !important;
}

.py-12 {
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}

.pa-12 {
  padding: 12px !important;
}

.mt-13 {
  margin-top: 13px !important;
}

.pt-13 {
  padding-top: 13px !important;
}

.mb-13 {
  margin-bottom: 13px !important;
}

.pb-13 {
  padding-bottom: 13px !important;
}

.ml-13 {
  margin-left: 13px !important;
}

.pl-13 {
  padding-left: 13px !important;
}

.mr-13 {
  margin-right: 13px !important;
}

.pr-13 {
  padding-right: 13px !important;
}

.w-13 {
  width: 13% !important;
}

.h-13 {
  height: 13% !important;
}

.mx-13 {
  margin-left: 13px !important;
  margin-right: 13px !important;
}

.my-13 {
  margin-top: 13px !important;
  margin-bottom: 13px !important;
}

.ma-13 {
  margin: 13px !important;
}

.px-13 {
  padding-left: 13px !important;
  padding-right: 13px !important;
}

.py-13 {
  padding-top: 13px !important;
  padding-bottom: 13px !important;
}

.pa-13 {
  padding: 13px !important;
}

.mt-14 {
  margin-top: 14px !important;
}

.pt-14 {
  padding-top: 14px !important;
}

.mb-14 {
  margin-bottom: 14px !important;
}

.pb-14 {
  padding-bottom: 14px !important;
}

.ml-14 {
  margin-left: 14px !important;
}

.pl-14 {
  padding-left: 14px !important;
}

.mr-14 {
  margin-right: 14px !important;
}

.pr-14 {
  padding-right: 14px !important;
}

.w-14 {
  width: 14% !important;
}

.h-14 {
  height: 14% !important;
}

.mx-14 {
  margin-left: 14px !important;
  margin-right: 14px !important;
}

.my-14 {
  margin-top: 14px !important;
  margin-bottom: 14px !important;
}

.ma-14 {
  margin: 14px !important;
}

.px-14 {
  padding-left: 14px !important;
  padding-right: 14px !important;
}

.py-14 {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.pa-14 {
  padding: 14px !important;
}

.mt-15 {
  margin-top: 15px !important;
}

.pt-15 {
  padding-top: 15px !important;
}

.mb-15 {
  margin-bottom: 15px !important;
}

.pb-15 {
  padding-bottom: 15px !important;
}

.ml-15 {
  margin-left: 15px !important;
}

.pl-15 {
  padding-left: 15px !important;
}

.mr-15 {
  margin-right: 15px !important;
}

.pr-15 {
  padding-right: 15px !important;
}

.w-15 {
  width: 15% !important;
}

.h-15 {
  height: 15% !important;
}

.mx-15 {
  margin-left: 15px !important;
  margin-right: 15px !important;
}

.my-15 {
  margin-top: 15px !important;
  margin-bottom: 15px !important;
}

.ma-15 {
  margin: 15px !important;
}

.px-15 {
  padding-left: 15px !important;
  padding-right: 15px !important;
}

.py-15 {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}

.pa-15 {
  padding: 15px !important;
}

.mt-16 {
  margin-top: 16px !important;
}

.pt-16 {
  padding-top: 16px !important;
}

.mb-16 {
  margin-bottom: 16px !important;
}

.pb-16 {
  padding-bottom: 16px !important;
}

.ml-16 {
  margin-left: 16px !important;
}

.pl-16 {
  padding-left: 16px !important;
}

.mr-16 {
  margin-right: 16px !important;
}

.pr-16 {
  padding-right: 16px !important;
}

.w-16 {
  width: 16% !important;
}

.h-16 {
  height: 16% !important;
}

.mx-16 {
  margin-left: 16px !important;
  margin-right: 16px !important;
}

.my-16 {
  margin-top: 16px !important;
  margin-bottom: 16px !important;
}

.ma-16 {
  margin: 16px !important;
}

.px-16 {
  padding-left: 16px !important;
  padding-right: 16px !important;
}

.py-16 {
  padding-top: 16px !important;
  padding-bottom: 16px !important;
}

.pa-16 {
  padding: 16px !important;
}

.mt-20 {
  margin-top: 20px !important;
}

.pt-20 {
  padding-top: 20px !important;
}

.mb-20 {
  margin-bottom: 20px !important;
}

.pb-20 {
  padding-bottom: 20px !important;
}

.ml-20 {
  margin-left: 20px !important;
}

.pl-20 {
  padding-left: 20px !important;
}

.mr-20 {
  margin-right: 20px !important;
}

.pr-20 {
  padding-right: 20px !important;
}

.w-20 {
  width: 20% !important;
}

.h-20 {
  height: 20% !important;
}

.mx-20 {
  margin-left: 20px !important;
  margin-right: 20px !important;
}

.my-20 {
  margin-top: 20px !important;
  margin-bottom: 20px !important;
}

.ma-20 {
  margin: 20px !important;
}

.px-20 {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

.py-20 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

.pa-20 {
  padding: 20px !important;
}

.mt-25 {
  margin-top: 25px !important;
}

.pt-25 {
  padding-top: 25px !important;
}

.mb-25 {
  margin-bottom: 25px !important;
}

.pb-25 {
  padding-bottom: 25px !important;
}

.ml-25 {
  margin-left: 25px !important;
}

.pl-25 {
  padding-left: 25px !important;
}

.mr-25 {
  margin-right: 25px !important;
}

.pr-25 {
  padding-right: 25px !important;
}

.w-25 {
  width: 25% !important;
}

.h-25 {
  height: 25% !important;
}

.mx-25 {
  margin-left: 25px !important;
  margin-right: 25px !important;
}

.my-25 {
  margin-top: 25px !important;
  margin-bottom: 25px !important;
}

.ma-25 {
  margin: 25px !important;
}

.px-25 {
  padding-left: 25px !important;
  padding-right: 25px !important;
}

.py-25 {
  padding-top: 25px !important;
  padding-bottom: 25px !important;
}

.pa-25 {
  padding: 25px !important;
}

.mt-30 {
  margin-top: 30px !important;
}

.pt-30 {
  padding-top: 30px !important;
}

.mb-30 {
  margin-bottom: 30px !important;
}

.pb-30 {
  padding-bottom: 30px !important;
}

.ml-30 {
  margin-left: 30px !important;
}

.pl-30 {
  padding-left: 30px !important;
}

.mr-30 {
  margin-right: 30px !important;
}

.pr-30 {
  padding-right: 30px !important;
}

.w-30 {
  width: 30% !important;
}

.h-30 {
  height: 30% !important;
}

.mx-30 {
  margin-left: 30px !important;
  margin-right: 30px !important;
}

.my-30 {
  margin-top: 30px !important;
  margin-bottom: 30px !important;
}

.ma-30 {
  margin: 30px !important;
}

.px-30 {
  padding-left: 30px !important;
  padding-right: 30px !important;
}

.py-30 {
  padding-top: 30px !important;
  padding-bottom: 30px !important;
}

.pa-30 {
  padding: 30px !important;
}

.mt-35 {
  margin-top: 35px !important;
}

.pt-35 {
  padding-top: 35px !important;
}

.mb-35 {
  margin-bottom: 35px !important;
}

.pb-35 {
  padding-bottom: 35px !important;
}

.ml-35 {
  margin-left: 35px !important;
}

.pl-35 {
  padding-left: 35px !important;
}

.mr-35 {
  margin-right: 35px !important;
}

.pr-35 {
  padding-right: 35px !important;
}

.w-35 {
  width: 35% !important;
}

.h-35 {
  height: 35% !important;
}

.mx-35 {
  margin-left: 35px !important;
  margin-right: 35px !important;
}

.my-35 {
  margin-top: 35px !important;
  margin-bottom: 35px !important;
}

.ma-35 {
  margin: 35px !important;
}

.px-35 {
  padding-left: 35px !important;
  padding-right: 35px !important;
}

.py-35 {
  padding-top: 35px !important;
  padding-bottom: 35px !important;
}

.pa-35 {
  padding: 35px !important;
}

.mt-40 {
  margin-top: 40px !important;
}

.pt-40 {
  padding-top: 40px !important;
}

.mb-40 {
  margin-bottom: 40px !important;
}

.pb-40 {
  padding-bottom: 40px !important;
}

.ml-40 {
  margin-left: 40px !important;
}

.pl-40 {
  padding-left: 40px !important;
}

.mr-40 {
  margin-right: 40px !important;
}

.pr-40 {
  padding-right: 40px !important;
}

.w-40 {
  width: 40% !important;
}

.h-40 {
  height: 40% !important;
}

.mx-40 {
  margin-left: 40px !important;
  margin-right: 40px !important;
}

.my-40 {
  margin-top: 40px !important;
  margin-bottom: 40px !important;
}

.ma-40 {
  margin: 40px !important;
}

.px-40 {
  padding-left: 40px !important;
  padding-right: 40px !important;
}

.py-40 {
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}

.pa-40 {
  padding: 40px !important;
}

.mt-45 {
  margin-top: 45px !important;
}

.pt-45 {
  padding-top: 45px !important;
}

.mb-45 {
  margin-bottom: 45px !important;
}

.pb-45 {
  padding-bottom: 45px !important;
}

.ml-45 {
  margin-left: 45px !important;
}

.pl-45 {
  padding-left: 45px !important;
}

.mr-45 {
  margin-right: 45px !important;
}

.pr-45 {
  padding-right: 45px !important;
}

.w-45 {
  width: 45% !important;
}

.h-45 {
  height: 45% !important;
}

.mx-45 {
  margin-left: 45px !important;
  margin-right: 45px !important;
}

.my-45 {
  margin-top: 45px !important;
  margin-bottom: 45px !important;
}

.ma-45 {
  margin: 45px !important;
}

.px-45 {
  padding-left: 45px !important;
  padding-right: 45px !important;
}

.py-45 {
  padding-top: 45px !important;
  padding-bottom: 45px !important;
}

.pa-45 {
  padding: 45px !important;
}

.mt-50 {
  margin-top: 50px !important;
}

.pt-50 {
  padding-top: 50px !important;
}

.mb-50 {
  margin-bottom: 50px !important;
}

.pb-50 {
  padding-bottom: 50px !important;
}

.ml-50 {
  margin-left: 50px !important;
}

.pl-50 {
  padding-left: 50px !important;
}

.mr-50 {
  margin-right: 50px !important;
}

.pr-50 {
  padding-right: 50px !important;
}

.w-50 {
  width: 50% !important;
}

.h-50 {
  height: 50% !important;
}

.mx-50 {
  margin-left: 50px !important;
  margin-right: 50px !important;
}

.my-50 {
  margin-top: 50px !important;
  margin-bottom: 50px !important;
}

.ma-50 {
  margin: 50px !important;
}

.px-50 {
  padding-left: 50px !important;
  padding-right: 50px !important;
}

.py-50 {
  padding-top: 50px !important;
  padding-bottom: 50px !important;
}

.pa-50 {
  padding: 50px !important;
}

.mt-75 {
  margin-top: 75px !important;
}

.pt-75 {
  padding-top: 75px !important;
}

.mb-75 {
  margin-bottom: 75px !important;
}

.pb-75 {
  padding-bottom: 75px !important;
}

.ml-75 {
  margin-left: 75px !important;
}

.pl-75 {
  padding-left: 75px !important;
}

.mr-75 {
  margin-right: 75px !important;
}

.pr-75 {
  padding-right: 75px !important;
}

.w-75 {
  width: 75% !important;
}

.h-75 {
  height: 75% !important;
}

.mx-75 {
  margin-left: 75px !important;
  margin-right: 75px !important;
}

.my-75 {
  margin-top: 75px !important;
  margin-bottom: 75px !important;
}

.ma-75 {
  margin: 75px !important;
}

.px-75 {
  padding-left: 75px !important;
  padding-right: 75px !important;
}

.py-75 {
  padding-top: 75px !important;
  padding-bottom: 75px !important;
}

.pa-75 {
  padding: 75px !important;
}

.mt-100 {
  margin-top: 100px !important;
}

.pt-100 {
  padding-top: 100px !important;
}

.mb-100 {
  margin-bottom: 100px !important;
}

.pb-100 {
  padding-bottom: 100px !important;
}

.ml-100 {
  margin-left: 100px !important;
}

.pl-100 {
  padding-left: 100px !important;
}

.mr-100 {
  margin-right: 100px !important;
}

.pr-100 {
  padding-right: 100px !important;
}

.w-100 {
  width: 100% !important;
}

.h-100 {
  height: 100% !important;
}

.mx-100 {
  margin-left: 100px !important;
  margin-right: 100px !important;
}

.my-100 {
  margin-top: 100px !important;
  margin-bottom: 100px !important;
}

.ma-100 {
  margin: 100px !important;
}

.px-100 {
  padding-left: 100px !important;
  padding-right: 100px !important;
}

.py-100 {
  padding-top: 100px !important;
  padding-bottom: 100px !important;
}

.pa-100 {
  padding: 100px !important;
}

.mt-auto {
  margin-top: auto !important;
}

.mb-auto {
  margin-bottom: auto !important;
}

.ml-auto {
  margin-left: auto !important;
}

.mr-auto {
  margin-right: auto !important;
}

.w-auto {
  width: auto !important;
}

.h-auto {
  height: auto !important;
}

.mx-auto {
  margin-left: auto !important;
  margin-right: auto !important;
}

.my-auto {
  margin-top: auto !important;
  margin-bottom: auto !important;
}

.ma-auto {
  margin: auto !important;
}

.text-center {
  text-align: center;
}

.text-start {
  text-align: start;
}

.text-end {
  text-align: end;
}

.text-capitalize {
  text-transform: capitalize;
}

.text-uppercase {
  text-transform: uppercase;
}

.text-justify {
  text-align: justify;
}

.font-weight-bold {
  font-weight: bold;
}

.font-weight-light {
  font-weight: lighter;
}

.font-weight-medium {
  font-weight: normal;
}

h6 {
  color: var(--heading-color);
  font-size: 0.4em;
}

h5 {
  color: var(--heading-color);
  font-size: 0.8em;
}

h4 {
  color: var(--heading-color);
  font-size: 1.2em;
}

h3 {
  color: var(--heading-color);
  font-size: 1.6em;
}

h2 {
  color: var(--heading-color);
  font-size: 2em;
}

h1 {
  color: var(--heading-color);
  font-size: 2.4em;
}

.caption {
  font-size: 14px;
}

body {
  background: var(--app-background);
  min-height: 100vh;
}

.app-title {
  color: var(--primary-color);
}

/* h8k-navbar.scss */
.navbar {
  background-color: #ffffff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  width: 100%;
  transition: all 0.3s ease;
}
.navbar.fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
}

.navbar-content {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  gap: 1rem;
  max-width: 1200px;
  margin: 0 auto;
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

.h8k-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
}
.h8k-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 0.25rem;
}

.title {
  font-size: 1.25rem;
  font-weight: 600;
  margin: 0;
  color: #333333;
}

@media (max-width: 768px) {
  .navbar-content {
    align-items: flex-start;
  }
  .title {
    margin-top: 0.5rem;
    font-size: 1.1rem;
  }
  .h8k-logo {
    width: 35px;
    height: 35px;
  }
}
.form-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin-bottom: 1rem;
}
@media screen and (min-width: 769px) {
  .form-container.horizontal {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem;
  }
  .form-container.horizontal .form-group {
    flex: 1;
    min-width: 0;
  }
  .form-container.horizontal .button-container {
    margin-top: 1.5rem;
    flex-shrink: 0;
  }
}
@media screen and (min-width: 769px) {
  .form-container.inline .form-group {
    display: flex;
    align-items: center;
  }
  .form-container.inline .form-group label {
    flex: 0 0 auto;
    margin-right: 1rem;
    margin-bottom: 0;
    min-width: 8rem;
  }
  .form-container.inline .form-group .input-wrapper {
    flex: 1;
    min-width: 0;
  }
}

.form-group {
  margin-bottom: 1rem;
  width: 100%;
  position: relative;
}

.input-wrapper {
  position: relative;
  width: 100%;
}

label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 500;
  color: #0e141e;
}
@media screen and (max-width: 768px) {
  label {
    font-size: clamp(0.675rem, 2vw, 0.875rem);
  }
}
label.required:after {
  content: "*";
  color: var(--error-color, #a93c32);
  margin-left: 0.25rem;
}

input:not([type=radio]):not([type=checkbox]) {
  box-shadow: inset 0 0.0625rem 0.25rem rgba(0, 0, 0, 0.1), 0 0 0 transparent;
  border: 0;
  border-radius: 0;
  background-color: #f3f7f7;
  color: #0e141e;
  height: clamp(2rem, 4vh, 2.25rem);
  outline: none;
  font-size: clamp(0.675rem, 2vw, 0.875rem);
  padding: 0 clamp(0.75rem, 2vw, 0.75rem);
  border-bottom: 0.125rem solid transparent;
  transition: all 0.2s ease-in-out;
  display: block;
  width: 100%;
  box-sizing: border-box;
}
input:not([type=radio]):not([type=checkbox]):hover {
  background-color: rgb(236.88, 242.92, 242.92);
}
@media screen and (max-width: 768px) {
  input:not([type=radio]):not([type=checkbox]) {
    font-size: clamp(0.675rem, 2vw, 1rem);
    height: clamp(2rem, 4vh, 2.5rem);
  }
  input:not([type=radio]):not([type=checkbox]).constrained-width {
    width: clamp(6rem, 18vw, 7rem);
  }
}
input:not([type=radio]):not([type=checkbox]).success, input:not([type=radio]):not([type=checkbox]).error {
  border-width: 0.0625rem;
  border-style: solid;
}
input:not([type=radio]):not([type=checkbox]).outlined {
  border: 0.125rem solid #8b98af;
  border-radius: 0.125rem;
}
input:not([type=radio]):not([type=checkbox]).success {
  border-color: var(--success-color);
}
input:not([type=radio]):not([type=checkbox]).error {
  border-color: var(--error-color);
}
input:not([type=radio]):not([type=checkbox]).large {
  height: clamp(1.8rem, 6vw, 2.5rem);
  font-size: clamp(0.675rem, 2vw, 1rem);
}
input:not([type=radio]):not([type=checkbox]).white {
  background: white;
}
input:not([type=radio]):not([type=checkbox]).rounded {
  border-radius: 0.25rem;
}
input:not([type=radio]):not([type=checkbox]):focus {
  border-bottom: 0.125rem solid #2e4163;
}
input:not([type=radio]):not([type=checkbox]):disabled {
  opacity: 0.7;
  cursor: not-allowed;
  background-color: #eaeaea;
}
input:not([type=radio]):not([type=checkbox])[type=radio], input:not([type=radio]):not([type=checkbox])[type=checkbox] {
  height: auto;
}
input:not([type=radio]):not([type=checkbox])::placeholder {
  color: rgba(14, 20, 30, 0.4);
  font-style: normal;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  height: clamp(1.75rem, 4vw, 2rem);
  min-width: clamp(6rem, 18vw, 7rem);
  padding: 0.5rem 2.5rem 0.5rem 0.75rem;
  font-size: clamp(0.675rem, 2vw, 0.875rem);
  line-height: 1.25;
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #8b98af;
  border-radius: 0.25rem;
  background-color: #f3f7f7;
  color: #0e141e;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3E%3Cpath d='M0 2l4 4 4-4z' fill='%230e141e'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
}
select:hover {
  border-color: var(--secondary-color);
}
select:focus {
  outline: none;
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.2);
}
select::-moz-focus-inner {
  border: 0;
}
select:disabled {
  background-color: #eaeaea;
  color: #6b7280;
  cursor: not-allowed;
}

.custom-select {
  position: relative;
  width: 100%;
}
.custom-select::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0.75rem;
  transform: translateY(-50%);
  width: 0.5rem;
  height: 0.5rem;
  border-right: 2px solid #0e141e;
  border-bottom: 2px solid #0e141e;
  pointer-events: none;
}

.form-hint {
  margin-bottom: clamp(0.25rem, 2vw, 0.5rem);
  line-height: clamp(0.45rem, 2vw, 0.75rem);
  word-break: break-word;
  overflow-wrap: break-word;
  word-wrap: break-word;
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  hyphens: auto;
  font-size: clamp(0.45rem, 2vw, 0.75rem);
  color: rgba(0, 0, 0, 0.6);
  margin-left: clamp(0.15rem, 1vw, 0.25rem);
  display: block;
}

.persistent-hint {
  display: block;
  margin-top: 0.375rem;
  font-size: clamp(0.45rem, 2vw, 0.75rem);
  color: rgba(0, 0, 0, 0.6);
  line-height: clamp(0.45rem, 2vw, 0.75rem);
}

.success-text {
  color: var(--success-color);
  display: flex;
  align-items: center;
  font-size: clamp(0.45rem, 2vw, 0.75rem);
  margin-top: 0.375rem;
}
.success-text:before {
  content: "✓";
  margin-right: 0.375rem;
  font-weight: bold;
}

.error-text {
  color: var(--error-color);
  display: flex;
  align-items: center;
  font-size: clamp(0.45rem, 2vw, 0.75rem);
  margin-top: 0.375rem;
}
.error-text:before {
  content: "✖";
  margin-right: 0.375rem;
  font-weight: bold;
}

.button-container {
  display: flex;
  justify-content: flex-end;
}
@media screen and (max-width: 768px) {
  .button-container {
    justify-content: stretch;
  }
  .button-container button,
  .button-container .btn {
    flex: 1;
  }
}
.button-container button + button,
.button-container .btn + .btn {
  margin-left: 0.5rem;
}
@media screen and (max-width: 768px) {
  .button-container button + button,
  .button-container .btn + .btn {
    margin-left: 0.25rem;
  }
}

.input-with-icon {
  position: relative;
}
.input-with-icon input {
  padding-right: 2.5rem;
}
.input-with-icon .input-icon {
  position: absolute;
  top: 50%;
  right: 0.75rem;
  transform: translateY(-50%);
  pointer-events: none;
  color: rgba(14, 20, 30, 0.5);
}
.input-with-icon .input-action {
  position: absolute;
  top: 50%;
  right: 0.75rem;
  transform: translateY(-50%);
  cursor: pointer;
}
.input-with-icon .input-action:hover {
  color: #2e4163;
}

.input-group {
  display: flex;
  align-items: stretch;
  width: 100%;
}
.input-group .input-prefix,
.input-group .input-suffix {
  display: flex;
  align-items: center;
  padding: 0 0.75rem;
  background-color: #e8eef0;
  color: #0e141e;
  font-size: clamp(0.675rem, 2vw, 0.875rem);
  border-bottom: 0.125rem solid transparent;
}
.input-group .input-prefix {
  border-right: 1px solid rgba(0, 0, 0, 0.1);
}
.input-group .input-suffix {
  border-left: 1px solid rgba(0, 0, 0, 0.1);
}
.input-group input {
  flex: 1;
  min-width: 0;
  border-radius: 0;
}

.vertical-align-baseline {
  display: flex;
  align-items: baseline;
}
@media screen and (max-width: 768px) {
  .vertical-align-baseline {
    flex-direction: column;
    align-items: stretch;
  }
}

button,
a.button {
  outline: none;
  padding: 0 1.5rem;
  min-height: clamp(2.25rem, 4vw, 2.75rem);
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  border: none;
  margin: 0.5rem 0.75rem;
  transition: all 0.15s ease;
  cursor: pointer;
  font-size: clamp(0.575rem, 1.5vw, 1em);
  font-weight: 600;
  font-family: var(--font-family-sans-serif);
  -webkit-border-radius: 0.25rem;
  -moz-border-radius: 0.25rem;
  border-radius: 0.25rem;
}
button:active,
a.button:active {
  transform: translateY(1px);
}
button:focus,
a.button:focus {
  outline: none;
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--brand-color-light);
}
button.outlined,
a.button.outlined {
  background: transparent;
  border: 1px solid currentColor;
  box-shadow: none;
}
button.text,
a.button.text {
  background: transparent;
  border: none;
  box-shadow: none;
  margin: 0.5rem 0;
}
button.icon-only,
a.button.icon-only {
  width: 2.25rem;
  height: 2.25rem;
  min-height: 2.25rem;
  padding: 0;
  margin: 0.5rem 0.75rem;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 9999px;
}
button.icon-only:disabled,
a.button.icon-only:disabled {
  background: transparent;
}
button.icon-only i,
a.button.icon-only i {
  font-size: 1.5rem;
  width: 1.5rem;
  height: 1.5rem;
}
@media screen and (max-width: 768px) {
  button.icon-only i,
  a.button.icon-only i {
    font-size: 1.25rem;
    width: 1.25rem;
    height: 1.25rem;
  }
}
button.small,
a.button.small {
  min-height: 2.25rem;
  font-size: clamp(0.575rem, 1.5vw, 0.75em);
}
button.small.icon-only,
a.button.small.icon-only {
  width: 2rem;
  min-height: 2rem;
  height: 2rem;
}
button.small.icon-only i,
a.button.small.icon-only i {
  font-size: 1.25rem;
  width: 1.25rem;
  height: 1.25rem;
}
@media screen and (max-width: 768px) {
  button.small.icon-only i,
  a.button.small.icon-only i {
    font-size: 1rem;
    width: 1rem;
    height: 1rem;
  }
}
button.x-small,
a.button.x-small {
  min-height: 1.75rem;
  padding: 0.25rem 0.75rem;
  font-size: 0.7em;
}
@media screen and (max-width: 768px) {
  button.x-small,
  a.button.x-small {
    font-size: 0.6em;
    width: 3.75rem;
  }
}
button.x-small.icon-only,
a.button.x-small.icon-only {
  width: 1.5rem;
  min-height: 1.5rem;
  height: 1.5rem;
}
button.x-small.icon-only i,
a.button.x-small.icon-only i {
  font-size: 1rem;
  width: 1rem;
  height: 1rem;
}
button.large,
a.button.large {
  min-height: clamp(2.75rem, 4vw, 3.25rem);
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
}
button.large.icon-only,
a.button.large.icon-only {
  width: clamp(2.25rem, 4vw, 2.75rem);
  min-height: clamp(2.25rem, 4vw, 2.75rem);
  height: clamp(2.25rem, 4vw, 2.75rem);
}
button.large.icon-only i,
a.button.large.icon-only i {
  font-size: clamp(1.5rem, 4vw, 2.25rem);
  width: clamp(1.5rem, 4vw, 2.25rem);
  height: clamp(1.5rem, 4vw, 2.25rem);
}
@media screen and (max-width: 768px) {
  button.large.icon-only i,
  a.button.large.icon-only i {
    font-size: clamp(1.25rem, 4vw, 2rem);
    width: clamp(1.25rem, 4vw, 2rem);
    height: clamp(1.25rem, 4vw, 2rem);
  }
}
@media screen and (max-width: 768px) {
  button.large,
  a.button.large {
    min-height: clamp(2.5rem, 4vw, 3rem);
    width: clamp(4.5rem, 4vw, 5rem);
  }
}
button.disabled, button:disabled,
a.button.disabled,
a.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
  border: none;
  background-color: var(--disabled-color, #6EA989);
  color: var(--disabled-text-color) !important;
}
button.disabled:active, button:disabled:active,
a.button.disabled:active,
a.button:disabled:active {
  transform: none;
}
button.flat,
a.button.flat {
  box-shadow: none;
}
button.tile,
a.button.tile {
  border-radius: 0;
}

button {
  color: #ffffff;
  background: var(--brand-color);
  box-shadow: 0 0.15rem 0.5rem var(--brand-box-shadow, rgba(0, 0, 0, 0.15));
}
button:hover {
  background: var(--brand-color-hover);
  box-shadow: 0 0.1875rem 0.375rem var(--brand-box-shadow-hover, rgba(0, 0, 0, 0.2));
}
button:focus {
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--brand-color-light, rgba(255, 255, 255, 0.5));
}
button.outlined {
  background: transparent;
  color: var(--brand-color);
  border: 0.0625rem solid var(--brand-color);
  box-shadow: none;
}
button.outlined:hover {
  background: var(--brand-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.text {
  color: var(--brand-color);
  background: transparent;
  box-shadow: none;
}
button.text:hover {
  background: var(--brand-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.icon-only i {
  color: var(--brand-color);
}
button.icon-only:hover {
  background: var(--brand-color-hover-transparent, rgba(0, 0, 0, 0.05)) !important;
  box-shadow: none;
}
button.disabled, button:disabled {
  background: var(--brand-disabled, var(--disabled-color, #6EA989));
  box-shadow: none;
}
button.disabled i, button:disabled i {
  color: var(--disabled-text-color) !important;
}
button.primary {
  color: #ffffff;
  background: var(--primary-color);
  box-shadow: 0 0.15rem 0.5rem var(--primary-box-shadow, rgba(0, 0, 0, 0.15));
}
button.primary:hover {
  background: var(--primary-color-hover);
  box-shadow: 0 0.1875rem 0.375rem var(--primary-box-shadow-hover, rgba(0, 0, 0, 0.2));
}
button.primary:focus {
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--primary-color-light, rgba(255, 255, 255, 0.5));
}
button.primary.outlined {
  background: transparent;
  color: var(--primary-color);
  border: 0.0625rem solid var(--primary-color);
  box-shadow: none;
}
button.primary.outlined:hover {
  background: var(--primary-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.primary.text {
  color: var(--primary-color);
  background: transparent;
  box-shadow: none;
}
button.primary.text:hover {
  background: var(--primary-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.primary.icon-only i {
  color: var(--primary-color);
}
button.primary.icon-only:hover {
  background: var(--primary-color-hover-transparent, rgba(0, 0, 0, 0.05)) !important;
  box-shadow: none;
}
button.primary.disabled, button.primary:disabled {
  background: var(--primary-disabled, var(--disabled-color, #6EA989));
  box-shadow: none;
}
button.primary.disabled i, button.primary:disabled i {
  color: var(--disabled-text-color) !important;
}
button.secondary {
  color: #fff;
  background: var(--secondary-color);
  box-shadow: 0 0.15rem 0.5rem var(--secondary-box-shadow, rgba(0, 0, 0, 0.15));
}
button.secondary:hover {
  background: var(--secondary-color-hover);
  box-shadow: 0 0.1875rem 0.375rem var(--secondary-box-shadow-hover, rgba(0, 0, 0, 0.2));
}
button.secondary:focus {
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--secondary-color-light, rgba(255, 255, 255, 0.5));
}
button.secondary.outlined {
  background: transparent;
  color: var(--secondary-color);
  border: 0.0625rem solid var(--secondary-color);
  box-shadow: none;
}
button.secondary.outlined:hover {
  background: var(--secondary-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.secondary.text {
  color: var(--secondary-color);
  background: transparent;
  box-shadow: none;
}
button.secondary.text:hover {
  background: var(--secondary-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.secondary.icon-only i {
  color: var(--secondary-color);
}
button.secondary.icon-only:hover {
  background: var(--secondary-color-hover-transparent, rgba(0, 0, 0, 0.05)) !important;
  box-shadow: none;
}
button.secondary.disabled, button.secondary:disabled {
  background: var(--secondary-disabled, var(--disabled-color, #6EA989));
  box-shadow: none;
}
button.secondary.disabled i, button.secondary:disabled i {
  color: var(--disabled-text-color) !important;
}
button.danger {
  color: #ffffff;
  background: var(--error-color);
  box-shadow: 0 0.15rem 0.5rem var(--error-box-shadow, rgba(0, 0, 0, 0.15));
}
button.danger:hover {
  background: var(--error-color-hover);
  box-shadow: 0 0.1875rem 0.375rem var(--error-box-shadow-hover, rgba(0, 0, 0, 0.2));
}
button.danger:focus {
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--error-color-light, rgba(255, 255, 255, 0.5));
}
button.danger.outlined {
  background: transparent;
  color: var(--error-color);
  border: 0.0625rem solid var(--error-color);
  box-shadow: none;
}
button.danger.outlined:hover {
  background: var(--error-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.danger.text {
  color: var(--error-color);
  background: transparent;
  box-shadow: none;
}
button.danger.text:hover {
  background: var(--error-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.danger.icon-only i {
  color: var(--error-color);
}
button.danger.icon-only:hover {
  background: var(--error-color-hover-transparent, rgba(0, 0, 0, 0.05)) !important;
  box-shadow: none;
}
button.danger.disabled, button.danger:disabled {
  background: var(--error-disabled, var(--disabled-color, #6EA989));
  box-shadow: none;
}
button.danger.disabled i, button.danger:disabled i {
  color: var(--disabled-text-color) !important;
}
button.success {
  color: #ffffff;
  background: var(--success-color);
  box-shadow: 0 0.15rem 0.5rem var(--success-box-shadow, rgba(0, 0, 0, 0.15));
}
button.success:hover {
  background: var(--success-color-hover);
  box-shadow: 0 0.1875rem 0.375rem var(--success-box-shadow-hover, rgba(0, 0, 0, 0.2));
}
button.success:focus {
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--success-color-light, rgba(255, 255, 255, 0.5));
}
button.success.outlined {
  background: transparent;
  color: var(--success-color);
  border: 0.0625rem solid var(--success-color);
  box-shadow: none;
}
button.success.outlined:hover {
  background: var(--success-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.success.text {
  color: var(--success-color);
  background: transparent;
  box-shadow: none;
}
button.success.text:hover {
  background: var(--success-color-hover-transparent, rgba(0, 0, 0, 0.05));
}
button.success.icon-only i {
  color: var(--success-color);
}
button.success.icon-only:hover {
  background: var(--success-color-hover-transparent, rgba(0, 0, 0, 0.05)) !important;
  box-shadow: none;
}
button.success.disabled, button.success:disabled {
  background: var(--success-disabled, var(--disabled-color, #6EA989));
  box-shadow: none;
}
button.success.disabled i, button.success:disabled i {
  color: var(--disabled-text-color) !important;
}

a {
  color: var(--link-color);
  text-decoration: none;
  transition: color 0.3s ease-in-out;
}
a:hover {
  text-decoration: underline;
  color: var(--link-color-hover);
}

.card {
  background-color: var(--bg-color, #fff);
  box-shadow: var(--shadow, 0 0.1875rem 0.625rem 0 rgba(0, 0, 0, 0.1));
  border-radius: var(--rounded, 0.25rem);
  transition: box-shadow 0.25s cubic-bezier(0.32, 0.01, 0, 1), transform 0.2s ease;
  margin: var(--card-margin-gutter, 1rem);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  overflow: auto;
  position: relative;
  width: 100%;
}
.card.hoverable:hover {
  box-shadow: var(--shadow-lg, 0 1rem 2rem rgba(0, 0, 0, 0.1));
  transform: translateY(-0.125rem);
}
.card.flat {
  box-shadow: none;
  background: var(--bg-color, white);
}
.card.outlined {
  background: var(--bg-color, white);
  border: 1px solid var(--border-color, rgba(0, 0, 0, 0.1));
  box-shadow: none;
}
.card.primary {
  border-top: 3px solid var(--primary-color, #1ba94c);
}
.card.secondary {
  border-top: 3px solid var(--secondary-color, #097bbf);
}
.card.danger {
  border-top: 3px solid var(--error-color, #a93c32);
}
.card.success {
  border-top: 3px solid var(--success-color, #22a97a);
}
.card .card-text {
  padding: clamp(0.75rem, 2vw, 1.25rem);
  font-size: clamp(0.75rem, 1.5vw, 1rem);
  color: var(--text-color, #1f2937);
  flex: 1 1 auto;
}
.card .card-actions {
  padding: clamp(0.5rem, 1.5vw, 1rem) clamp(0.4rem, 1vw, 0.8rem);
  font-size: clamp(0.75rem, 1.5vw, 1rem);
  display: flex;
  flex-direction: row;
  align-items: center;
  border-top: 1px solid var(--border-color, rgba(0, 0, 0, 0.1));
}
.card .card-actions.justify-content-between {
  justify-content: space-between;
}
.card .card-actions.justify-content-end {
  justify-content: flex-end;
}
.card .card-actions button, .card .card-actions a {
  margin: 0.25rem;
}
.card .card-actions button:first-child, .card .card-actions a:first-child {
  margin-left: 0;
}
.card .card-actions button:last-child, .card .card-actions a:last-child {
  margin-right: 0;
}
.card .card-image {
  position: relative;
  padding-top: 56.25%;
  overflow: hidden;
}
.card .card-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card .card-header {
  padding: clamp(0.5rem, 1.5vw, 1rem) clamp(0.75rem, 2vw, 1.25rem);
  font-size: clamp(0.875rem, 1.5vw, 1.125rem);
  font-weight: 600;
  border-bottom: 1px solid var(--border-color, rgba(0, 0, 0, 0.1));
}
.card .card-header h1, .card .card-header h2, .card .card-header h3, .card .card-header h4, .card .card-header h5, .card .card-header h6 {
  margin: 0;
}
.card.loading {
  position: relative;
  overflow: hidden;
}
.card.loading::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  transform: translateX(-100%);
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0.2) 20%, rgba(255, 255, 255, 0.5) 60%, rgba(255, 255, 255, 0));
  animation: shimmer 2s infinite;
}
.card.small {
  max-width: 300px;
}
.card.small .card-text {
  padding: clamp(0.5rem, 1vw, 0.75rem);
}
.card.small .card-actions {
  padding: clamp(0.25rem, 0.75vw, 0.5rem) clamp(0.25rem, 0.5vw, 0.5rem);
}
.card.large {
  max-width: 800px;
}

@keyframes shimmer {
  100% {
    transform: translateX(100%);
  }
}
@-webkit-keyframes slide-up-fade-in {
  0% {
    opacity: 0;
    transform: translate(0px, 25px);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-moz-keyframes slide-up-fade-in {
  0% {
    opacity: 0;
    transform: translate(0px, 25px);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-ms-keyframes slide-up-fade-in {
  0% {
    opacity: 0;
    transform: translate(0px, 25px);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@keyframes slide-up-fade-in {
  0% {
    opacity: 0;
    transform: translate(0px, 25px);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-webkit-keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-moz-keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-ms-keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-webkit-keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-moz-keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@-ms-keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
@keyframes slide-in-fade-in {
  0% {
    opacity: 0;
    transform: translate(25px, 0);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
.slide-up-fade-in {
  -webkit-animation-delay: 0;
  -webkit-animation-duration: 0.2s;
  -webkit-animation-name: slide-up-fade-in;
  -webkit-animation-fill-mode: fowards;
  -webkit-animation-direction: cubic-bezier(0.35, 0, 0.25, 1);
  -moz-animation-delay: 0;
  -moz-animation-duration: 0.2s;
  -moz-animation-name: slide-up-fade-in;
  -moz-animation-fill-mode: fowards;
  -moz-animation-direction: cubic-bezier(0.35, 0, 0.25, 1);
  animation-delay: 0;
  animation-duration: 0.2s;
  animation-name: slide-up-fade-in;
  animation-fill-mode: fowards;
  animation-direction: cubic-bezier(0.35, 0, 0.25, 1);
}

ul,
ol {
  margin: 0 0 0 1.5rem;
}
ul li,
ol li {
  padding-top: 0.375rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}
@media (min-width: 640px) {
  ul li,
  ol li {
    font-size: 0.9375rem;
  }
}
@media (min-width: 768px) {
  ul li,
  ol li {
    font-size: 1rem;
    line-height: 1.5rem;
  }
}
ul.styled,
ol.styled {
  margin: 0;
  padding: 0;
}
ul.styled li,
ol.styled li {
  background: #ffffff;
  min-width: 8rem;
  margin: 0.75rem 0;
  border-radius: 0.375rem;
  padding: 0.5rem 0.75rem 0.5rem 1.25rem;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  position: relative;
  transition: transform 150ms ease, box-shadow 150ms ease;
}
@media (min-width: 640px) {
  ul.styled li,
  ol.styled li {
    min-width: 10rem;
    padding: 0.5rem 0.75rem 0.5rem 1.5rem;
  }
}
@media (min-width: 768px) {
  ul.styled li,
  ol.styled li {
    min-width: 12rem;
    padding: 0.625rem 1rem 0.625rem 1.75rem;
  }
}
ul.styled li:hover,
ol.styled li:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}
ul.bordered li,
ol.bordered li {
  border-bottom: 1px solid #e5e7eb;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  transition: background-color 150ms ease;
}
ul.bordered li:hover,
ol.bordered li:hover {
  background-color: #f9fafb;
}
ul.bordered li:last-child,
ol.bordered li:last-child {
  border-bottom: none;
}
ul.inset li,
ol.inset li {
  padding: 0.5rem 0.75rem;
  margin-bottom: 0.25rem;
  background-color: #f9fafb;
  border-left: 3px solid #e5e7eb;
  border-radius: 0 0.25rem 0.25rem 0;
  transition: border-color 150ms ease, background-color 150ms ease;
}
@media (min-width: 640px) {
  ul.inset li,
  ol.inset li {
    padding: 0.625rem 1rem;
  }
}
ul.inset li:hover,
ol.inset li:hover {
  border-left-color: #9ca3af;
  background-color: #f3f4f6;
}
ul.interactive li,
ol.interactive li {
  cursor: pointer;
  position: relative;
  padding-right: 1.5rem;
}
ul.interactive li::after,
ol.interactive li::after {
  content: "→";
  position: absolute;
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0;
  transition: opacity 150ms ease, transform 150ms ease;
}
ul.interactive li:hover::after,
ol.interactive li:hover::after {
  opacity: 1;
  transform: translateY(-50%) translateX(2px);
}

ul.styled {
  list-style-type: none;
}
ul.styled li::before {
  content: "•";
  color: #6b7280;
  font-weight: bold;
  position: absolute;
  left: 0.5rem;
}
@media (min-width: 768px) {
  ul.styled li::before {
    left: 0.75rem;
  }
}
ul.checklist {
  list-style-type: none;
}
ul.checklist li {
  padding-left: 1.75rem;
  position: relative;
}
ul.checklist li::before {
  content: "✓";
  color: #10b981;
  position: absolute;
  left: 0;
  font-weight: bold;
}

ol.styled {
  list-style-type: none;
  counter-reset: list-counter;
}
ol.styled li {
  counter-increment: list-counter;
}
ol.styled li::before {
  content: counter(list-counter) ".";
  color: #6b7280;
  font-weight: 500;
  position: absolute;
  left: 0.5rem;
}
@media (min-width: 768px) {
  ol.styled li::before {
    left: 0.75rem;
  }
}

table {
  width: 100%;
  max-width: 100%;
  margin-bottom: 2rem;
  border-collapse: collapse;
  padding-bottom: 2rem;
  font-size: clamp(0.575rem, 2vw, 1rem);
}
table thead tr {
  webkit-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
  font-size: clamp(0.575rem, 2vw, 1rem);
}
table thead tr th {
  color: #738f93;
  letter-spacing: 0.0875rem;
  font-size: clamp(0.575rem, 2vw, 0.875rem);
  border-bottom: 0.0625rem solid rgba(0, 0, 0, 0.12);
  height: 3rem;
  padding: 0 1.6rem;
  vertical-align: middle;
  font-weight: 400;
}
table thead tr th:first-child {
  padding-left: 1.875rem;
}
table thead tr th:last-child {
  padding-right: 1.875rem;
}
table thead tr th.sortable {
  outline: none;
}
table th,
table td {
  text-align: left;
  padding: 1.6rem;
  border-top: 0;
  -webkit-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
table th.numeric,
table td.numeric {
  text-align: right;
}
table tbody tr {
  padding: 0 1.875rem;
}
table tbody tr td {
  font-size: clamp(0.575rem, 2vw, 0.8rem);
  border-bottom: 0.0625rem solid rgba(0, 0, 0, 0.12);
  height: 3rem;
  padding: 0 1rem;
  vertical-align: center !important;
}
table tbody tr td:first-child {
  padding-left: 1.875rem;
}
table tbody tr td:last-child {
  padding-right: 1.875rem;
}
table tbody tr:hover {
  background: #eeeeee;
}
table tbody tr:last-child {
  margin-bottom: 1.875rem;
}

.alert {
  display: flex;
  align-items: center;
  position: relative;
  padding: 0.75rem 1rem 0.75rem 3rem;
  margin-bottom: 0.75rem;
  border-radius: 0.375rem;
  border-style: solid;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  font-size: 0.875rem;
  line-height: 1.25rem;
  transition: all 150ms ease;
  border-color: var(--primary-color);
  border-width: 1px;
  color: var(--primary-color);
  font-weight: 500;
  background: rgba(var(--primary-rgb), 0.1);
}
.alert:before {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Material Icons;
  speak: none;
  font-style: normal;
  font-weight: normal;
  text-transform: none;
  line-height: 1;
  content: "notifications";
}
@media (max-width: 768px) {
  .alert:before {
    left: 0.75rem;
    font-size: 0.875rem;
  }
}
@media (max-width: 480px) {
  .alert:before {
    left: 0.5rem;
    font-size: 0.75rem;
  }
}
.alert.filled {
  background: var(--primary-color);
  color: #ffffff;
}
.alert.info {
  border-color: var(--secondary-color);
  border-width: 1px;
  color: var(--secondary-color);
  font-weight: 500;
  background: rgba(var(--secondary-rgb), 0.1);
}
.alert.info:before {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  content: "ℹ";
}
@media (max-width: 768px) {
  .alert.info:before {
    left: 0.75rem;
    font-size: 0.875rem;
  }
}
@media (max-width: 480px) {
  .alert.info:before {
    left: 0.5rem;
    font-size: 0.75rem;
  }
}
.alert.info.filled {
  background: var(--secondary-color);
  color: #ffffff;
}
.alert.success {
  border-color: var(--success-color);
  border-width: 1px;
  color: var(--success-color);
  font-weight: 500;
  background: rgba(var(--success-rgb), 0.1);
}
.alert.success:before {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  content: "✓";
}
@media (max-width: 768px) {
  .alert.success:before {
    left: 0.75rem;
    font-size: 0.875rem;
  }
}
@media (max-width: 480px) {
  .alert.success:before {
    left: 0.5rem;
    font-size: 0.75rem;
  }
}
.alert.success.filled {
  background: var(--success-color);
  color: #ffffff;
}
.alert.error {
  border-color: var(--error-color);
  border-width: 1px;
  color: var(--error-color);
  font-weight: 500;
  background: rgba(var(--error-rgb), 0.1);
}
.alert.error:before {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  content: "⚠";
}
@media (max-width: 768px) {
  .alert.error:before {
    left: 0.75rem;
    font-size: 0.875rem;
  }
}
@media (max-width: 480px) {
  .alert.error:before {
    left: 0.5rem;
    font-size: 0.75rem;
  }
}
.alert.error.filled {
  background: var(--error-color);
  color: #ffffff;
}
.alert.warning {
  border-color: var(--warning-color);
  border-width: 1px;
  color: var(--warning-color);
  font-weight: 500;
  background: rgba(var(--warning-rgb), 0.1);
}
.alert.warning:before {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  content: "⚠";
}
@media (max-width: 768px) {
  .alert.warning:before {
    left: 0.75rem;
    font-size: 0.875rem;
  }
}
@media (max-width: 480px) {
  .alert.warning:before {
    left: 0.5rem;
    font-size: 0.75rem;
  }
}
.alert.warning.filled {
  background: var(--warning-color);
  color: #ffffff;
}
@media (max-width: 768px) {
  .alert {
    padding: 0.625rem 0.75rem 0.625rem 2.5rem;
    font-size: 0.875rem;
  }
}
@media (max-width: 480px) {
  .alert {
    padding: 0.5rem 0.5rem 0.5rem 2rem;
    font-size: 0.75rem;
  }
}
.alert:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.3);
}
.alert.dismissible {
  padding-right: 1rem;
}
.alert.dismissible > span {
  flex: 1;
}
.alert.dismissible button.icon-only {
  position: static;
  margin-left: 1rem;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  opacity: 1;
  color: inherit;
  transition: opacity 150ms ease;
}
.alert.dismissible button.icon-only:hover {
  opacity: 0.85;
}
.alert.dismissible button.icon-only i.material-icons {
  font-size: 1.25rem;
  line-height: 1;
  color: inherit !important;
}

.alert.filled.dismissible > button.icon-only,
.alert.filled.dismissible > button.icon-only > i.material-icons {
  color: #ffffff !important;
}

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