@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:ital@0;1&display=swap");
*,
*::before,
*::after {
  box-sizing: border-box;
}

:focus {
  outline: 1px solid var(--color-primary);
}

:root {
  font-family: var(--font-base);
  font-size: var(--font-size-base);
  -webkit-text-size-adjust: none;
}

html,
body {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
}

body {
  min-width: 100%;
  background-color: var(--color-body-bg);
  color: var(--color-body-fg);
}

section,
header,
main,
footer {
  display: block;
}

button,
a[href] {
  cursor: pointer;
}

menu,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
}

ul,
ul li {
  margin: 0;
  padding: 0;
  list-style: none;
}

pre {
  white-space: pre-wrap;
  margin: 0;
}

img {
  max-width: 100%;
  max-height: 100%;
  height: auto;
  vertical-align: middle;
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 1em;
}

:root {
  --color-primary: #6777FF;
  --color-primary-rgb: 103, 119, 255;
  --color-primary-bg: #6777FF;
  --color-primary-bg-rgb: 103, 119, 255;
  --color-primary-fg: #F7F7F7;
  --color-primary-fg-rgb: 247, 247, 247;
  --color-primary-inverted-bg: #988800;
  --color-primary-inverted-bg-rgb: 152, 136, 0;
  --color-primary-inverted-fg: #080808;
  --color-primary-inverted-fg-rgb: 8, 8, 8;
  --color-secondary: #FFEF67;
  --color-secondary-rgb: 255, 239, 103;
  --color-secondary-bg: #FFEF67;
  --color-secondary-bg-rgb: 255, 239, 103;
  --color-secondary-fg: #121212;
  --color-secondary-fg-rgb: 18, 18, 18;
  --color-secondary-inverted-bg: #001098;
  --color-secondary-inverted-bg-rgb: 0, 16, 152;
  --color-secondary-inverted-fg: #ededed;
  --color-secondary-inverted-fg-rgb: 237, 237, 237;
  --color-danger: #FF3D41;
  --color-danger-rgb: 255, 61, 65;
  --color-danger-bg: #FF3D41;
  --color-danger-bg-rgb: 255, 61, 65;
  --color-danger-fg: #F7F7F7;
  --color-danger-fg-rgb: 247, 247, 247;
  --color-danger-inverted-bg: #00c2be;
  --color-danger-inverted-bg-rgb: 0, 194, 190;
  --color-danger-inverted-fg: #080808;
  --color-danger-inverted-fg-rgb: 8, 8, 8;
  --color-warning: #FF8A3D;
  --color-warning-rgb: 255, 138, 61;
  --color-warning-bg: #FF8A3D;
  --color-warning-bg-rgb: 255, 138, 61;
  --color-warning-fg: #121212;
  --color-warning-fg-rgb: 18, 18, 18;
  --color-warning-inverted-bg: #0075c2;
  --color-warning-inverted-bg-rgb: 0, 117, 194;
  --color-warning-inverted-fg: #ededed;
  --color-warning-inverted-fg-rgb: 237, 237, 237;
  --color-success: #72FF3D;
  --color-success-rgb: 114, 255, 61;
  --color-success-bg: #72FF3D;
  --color-success-bg-rgb: 114, 255, 61;
  --color-success-fg: #121212;
  --color-success-fg-rgb: 18, 18, 18;
  --color-success-inverted-bg: #8d00c2;
  --color-success-inverted-bg-rgb: 141, 0, 194;
  --color-success-inverted-fg: #ededed;
  --color-success-inverted-fg-rgb: 237, 237, 237;
  --color-info: #3DA2FF;
  --color-info-rgb: 61, 162, 255;
  --color-info-bg: #3DA2FF;
  --color-info-bg-rgb: 61, 162, 255;
  --color-info-fg: #121212;
  --color-info-fg-rgb: 18, 18, 18;
  --color-info-inverted-bg: #c25d00;
  --color-info-inverted-bg-rgb: 194, 93, 0;
  --color-info-inverted-fg: #ededed;
  --color-info-inverted-fg-rgb: 237, 237, 237;
  --color-dark: #121212;
  --color-dark-rgb: 18, 18, 18;
  --color-dark-bg: #121212;
  --color-dark-bg-rgb: 18, 18, 18;
  --color-dark-fg: #F7F7F7;
  --color-dark-fg-rgb: 247, 247, 247;
  --color-dark-inverted-bg: #ededed;
  --color-dark-inverted-bg-rgb: 237, 237, 237;
  --color-dark-inverted-fg: #080808;
  --color-dark-inverted-fg-rgb: 8, 8, 8;
  --color-medium: #B3B3B3;
  --color-medium-rgb: 179, 179, 179;
  --color-medium-bg: #B3B3B3;
  --color-medium-bg-rgb: 179, 179, 179;
  --color-medium-fg: #121212;
  --color-medium-fg-rgb: 18, 18, 18;
  --color-medium-inverted-bg: #4c4c4c;
  --color-medium-inverted-bg-rgb: 76, 76, 76;
  --color-medium-inverted-fg: #ededed;
  --color-medium-inverted-fg-rgb: 237, 237, 237;
  --color-light: #F7F7F7;
  --color-light-rgb: 247, 247, 247;
  --color-light-bg: #F7F7F7;
  --color-light-bg-rgb: 247, 247, 247;
  --color-light-fg: #121212;
  --color-light-fg-rgb: 18, 18, 18;
  --color-light-inverted-bg: #080808;
  --color-light-inverted-bg-rgb: 8, 8, 8;
  --color-light-inverted-fg: #ededed;
  --color-light-inverted-fg-rgb: 237, 237, 237;
  --color-body: #121212;
  --color-body-rgb: 18, 18, 18;
  --color-body-bg: #121212;
  --color-body-bg-rgb: 18, 18, 18;
  --color-body-fg: #F7F7F7;
  --color-body-fg-rgb: 247, 247, 247;
  --color-body-inverted-bg: #ededed;
  --color-body-inverted-bg-rgb: 237, 237, 237;
  --color-body-inverted-fg: #080808;
  --color-body-inverted-fg-rgb: 8, 8, 8;
  --color-element: #181818;
  --color-element-rgb: 24, 24, 24;
  --color-element-bg: #181818;
  --color-element-bg-rgb: 24, 24, 24;
  --color-element-fg: #F7F7F7;
  --color-element-fg-rgb: 247, 247, 247;
  --color-element-inverted-bg: #e7e7e7;
  --color-element-inverted-bg-rgb: 231, 231, 231;
  --color-element-inverted-fg: #080808;
  --color-element-inverted-fg-rgb: 8, 8, 8;
  --color-scale: 255, 255, 255;
  --color-scale-inverted: 0, 0, 0;
}

:root {
  --font-base: "IBM Plex Sans", sans-serif;
  --font-headers: "IBM Plex Sans", sans-serif;
  --font-legible: "IBM Plex Sans", sans-serif;
  --font-monospace: "IBM Plex Mono", monospace;
  --font-size-base: 16px;
}

:root::before {
  content: "";
  display: block;
  position: fixed;
  inset: 0 0 0 0;
  background-color: var(--color-body-bg);
  transition: opacity 0.4s ease-in-out;
  z-index: 9999;
}
:root::after {
  display: block;
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: 9999;
  line-height: 1;
  translate: -50% -50%;
  transform-origin: 50% 50%;
  transition: opacity 0.4s ease-in-out, translate 0.4s ease-in-out;
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 128 128'%3E%3Cstyle%3E path %7B fill: none; stroke: %236777FF; stroke-width: 8; animation: spin 2s linear infinite; transform-origin: center; %7D @keyframes spin %7B 0%25 %7B rotate: 0deg; %7D 100%25 %7B rotate: 360deg; %7D %7D %3C/style%3E%3Cpath d='M 4 64 A 60 60 0 1 0 64 4' /%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 6rem;
  height: 6rem;
  backface-visibility: visible;
}
:root.loading::before, :root.loading::after {
  opacity: 1;
}
:root:not(.loading)::before, :root:not(.loading)::after {
  pointer-events: none;
  opacity: 0;
}
:root:not(.loading)::after {
  transition-delay: 0.32s;
}

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