@import url("https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,100..900;1,100..900&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;
}

a {
  color: var(--color-primary-bg);
}

button {
  border: none;
}

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

video {
  max-width: 100%;
  max-height: 100%;
  height: auto;
}

:root {
  --color-primary: #90FF69;
  --color-primary-rgb: 144, 255, 105;
  --color-primary-bg: #90FF69;
  --color-primary-bg-rgb: 144, 255, 105;
  --color-primary-fg: #121212;
  --color-primary-fg-rgb: 18, 18, 18;
  --color-primary-inverted-bg: #6f0096;
  --color-primary-inverted-bg-rgb: 111, 0, 150;
  --color-primary-inverted-fg: #ededed;
  --color-primary-inverted-fg-rgb: 237, 237, 237;
  --color-secondary: #D869FF;
  --color-secondary-rgb: 216, 105, 255;
  --color-secondary-bg: #D869FF;
  --color-secondary-bg-rgb: 216, 105, 255;
  --color-secondary-fg: #121212;
  --color-secondary-fg-rgb: 18, 18, 18;
  --color-secondary-inverted-bg: #279600;
  --color-secondary-inverted-bg-rgb: 39, 150, 0;
  --color-secondary-inverted-fg: #ededed;
  --color-secondary-inverted-fg-rgb: 237, 237, 237;
  --color-danger: #FF5C5D;
  --color-danger-rgb: 255, 92, 93;
  --color-danger-bg: #FF5C5D;
  --color-danger-bg-rgb: 255, 92, 93;
  --color-danger-fg: #121212;
  --color-danger-fg-rgb: 18, 18, 18;
  --color-danger-inverted-bg: #00a3a2;
  --color-danger-inverted-bg-rgb: 0, 163, 162;
  --color-danger-inverted-fg: #ededed;
  --color-danger-inverted-fg-rgb: 237, 237, 237;
  --color-warning: #FF9E5C;
  --color-warning-rgb: 255, 158, 92;
  --color-warning-bg: #FF9E5C;
  --color-warning-bg-rgb: 255, 158, 92;
  --color-warning-fg: #121212;
  --color-warning-fg-rgb: 18, 18, 18;
  --color-warning-inverted-bg: #0061a3;
  --color-warning-inverted-bg-rgb: 0, 97, 163;
  --color-warning-inverted-fg: #ededed;
  --color-warning-inverted-fg-rgb: 237, 237, 237;
  --color-success: #90FF69;
  --color-success-rgb: 144, 255, 105;
  --color-success-bg: #90FF69;
  --color-success-bg-rgb: 144, 255, 105;
  --color-success-fg: #121212;
  --color-success-fg-rgb: 18, 18, 18;
  --color-success-inverted-bg: #6f0096;
  --color-success-inverted-bg-rgb: 111, 0, 150;
  --color-success-inverted-fg: #ededed;
  --color-success-inverted-fg-rgb: 237, 237, 237;
  --color-info: #66B4FF;
  --color-info-rgb: 102, 180, 255;
  --color-info-bg: #66B4FF;
  --color-info-bg-rgb: 102, 180, 255;
  --color-info-fg: #121212;
  --color-info-fg-rgb: 18, 18, 18;
  --color-info-inverted-bg: #994b00;
  --color-info-inverted-bg-rgb: 153, 75, 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: #F8F8F8;
  --color-dark-fg-rgb: 248, 248, 248;
  --color-dark-inverted-bg: #ededed;
  --color-dark-inverted-bg-rgb: 237, 237, 237;
  --color-dark-inverted-fg: #070707;
  --color-dark-inverted-fg-rgb: 7, 7, 7;
  --color-medium: #B4B4B4;
  --color-medium-rgb: 180, 180, 180;
  --color-medium-bg: #B4B4B4;
  --color-medium-bg-rgb: 180, 180, 180;
  --color-medium-fg: #121212;
  --color-medium-fg-rgb: 18, 18, 18;
  --color-medium-inverted-bg: #4b4b4b;
  --color-medium-inverted-bg-rgb: 75, 75, 75;
  --color-medium-inverted-fg: #ededed;
  --color-medium-inverted-fg-rgb: 237, 237, 237;
  --color-light: #F8F8F8;
  --color-light-rgb: 248, 248, 248;
  --color-light-bg: #F8F8F8;
  --color-light-bg-rgb: 248, 248, 248;
  --color-light-fg: #121212;
  --color-light-fg-rgb: 18, 18, 18;
  --color-light-inverted-bg: #070707;
  --color-light-inverted-bg-rgb: 7, 7, 7;
  --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: #F8F8F8;
  --color-body-fg-rgb: 248, 248, 248;
  --color-body-inverted-bg: #ededed;
  --color-body-inverted-bg-rgb: 237, 237, 237;
  --color-body-inverted-fg: #070707;
  --color-body-inverted-fg-rgb: 7, 7, 7;
  --color-element: #222222;
  --color-element-rgb: 34, 34, 34;
  --color-element-bg: #222222;
  --color-element-bg-rgb: 34, 34, 34;
  --color-element-fg: #F8F8F8;
  --color-element-fg-rgb: 248, 248, 248;
  --color-element-inverted-bg: #dddddd;
  --color-element-inverted-bg-rgb: 221, 221, 221;
  --color-element-inverted-fg: #070707;
  --color-element-inverted-fg-rgb: 7, 7, 7;
  --color-scale: 255, 255, 255;
  --color-scale-inverted: 0, 0, 0;
}

:root {
  --font-base: 'Noto Sans', sans-serif;
  --font-headers: 'Noto Sans', sans-serif;
  --font-legible: 'Noto Sans', sans-serif;
  --font-monospace: monospace;
  --font-size-base: 16px;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
}

: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.2s ease-in-out, translate 0.2s 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: %2390FF69; 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.16s;
}

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