@import "https://fonts.googleapis.com/css2?family=Public+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap";
pre code.hljs {
  padding: 1em;
  display: block;
  overflow-x: auto;
}

code.hljs {
  padding: 3px 5px;
}

.hljs {
  color: #d6deeb;
  background: #011627;
}

.hljs-keyword {
  color: #c792ea;
  font-style: italic;
}

.hljs-built_in {
  color: #addb67;
  font-style: italic;
}

.hljs-type {
  color: #82aaff;
}

.hljs-literal {
  color: #ff5874;
}

.hljs-number {
  color: #f78c6c;
}

.hljs-regexp {
  color: #5ca7e4;
}

.hljs-string {
  color: #ecc48d;
}

.hljs-subst {
  color: #d3423e;
}

.hljs-symbol {
  color: #82aaff;
}

.hljs-class {
  color: #ffcb8b;
}

.hljs-function {
  color: #82aaff;
}

.hljs-title {
  color: #dcdcaa;
  font-style: italic;
}

.hljs-params {
  color: #7fdbca;
}

.hljs-comment {
  color: #637777;
  font-style: italic;
}

.hljs-doctag {
  color: #7fdbca;
}

.hljs-meta, .hljs-meta .hljs-keyword {
  color: #82aaff;
}

.hljs-meta .hljs-string {
  color: #ecc48d;
}

.hljs-section {
  color: #82b1ff;
}

.hljs-attr, .hljs-name, .hljs-tag {
  color: #7fdbca;
}

.hljs-attribute {
  color: #80cbc4;
}

.hljs-variable {
  color: #addb67;
}

.hljs-bullet {
  color: #d9f5dd;
}

.hljs-code {
  color: #80cbc4;
}

.hljs-emphasis {
  color: #c792ea;
  font-style: italic;
}

.hljs-strong {
  color: #addb67;
  font-weight: 700;
}

.hljs-formula {
  color: #c792ea;
}

.hljs-link {
  color: #ff869a;
}

.hljs-quote {
  color: #697098;
  font-style: italic;
}

.hljs-selector-tag {
  color: #ff6363;
}

.hljs-selector-id {
  color: #fad430;
}

.hljs-selector-class {
  color: #addb67;
  font-style: italic;
}

.hljs-selector-attr, .hljs-selector-pseudo {
  color: #c792ea;
  font-style: italic;
}

.hljs-template-tag {
  color: #c792ea;
}

.hljs-template-variable {
  color: #addb67;
}

.hljs-addition {
  color: #addb67;
  font-style: italic;
}

.hljs-deletion {
  color: #ef535090;
  font-style: italic;
}

*, :before, :after {
  box-sizing: border-box;
}

* {
  margin: 0;
}

html, body {
  height: 100%;
}

body {
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}

img, picture, video, canvas, svg {
  max-width: 100%;
  display: block;
}

input, button, textarea, select {
  font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

#root, #__next {
  isolation: isolate;
}

li {
  margin-bottom: 1em;
}

ul {
  margin-bottom: 2em;
}

.mt-1 {
  margin-top: 1rem;
}

.mt-2 {
  margin-top: 2rem;
}

.mt-3 {
  margin-top: 3rem;
}

.mt-4 {
  margin-top: 4rem;
}

:root {
  --font-fallback: BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-sans;
  --font-body: Public Sans, var(--font-fallback);
  --font-heading: Public Sans, var(--font-fallback);
  --font-code: Menlo, Consolas, Monaco, Liberation Mono, Lucida Console, monospace;
}

body {
  font-family: var(--font-body);
  line-height: calc(1em + .725rem);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  margin-top: 1em;
  margin-bottom: .5em;
  line-height: 1;
}

h1 {
  color: var(--primary-color);
  font-size: 4rem;
  font-weight: 700;
}

h2 {
  color: var(--primary-color-light);
  font-size: 2rem;
  font-weight: 600;
}

h3 {
  font-size: 1.5rem;
}

code, pre {
  font-family: var(--font-code);
}

p {
  margin-bottom: 1em;
}

a {
  color: var(--highlight-color);
}

a:hover, a:active {
  color: var(--highlight-color-400);
}

a.simple, a.simple:hover, a.simple:active {
  color: inherit;
}

em {
  font-style: normal;
  font-weight: 700;
}

strong {
  isolation: isolate;
  font-weight: 800;
  position: relative;
}

strong:after {
  content: "";
  width: 105.5%;
  height: .5em;
  z-index: -1;
  background-image: url("data:image/svg+xml,%3Csvg preserveAspectRatio='none' viewBox='0 0 100 10' version='1.1' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2,8 Q30,5 98,4' fill='none' stroke='hsl(354deg, 100%, 67%)' stroke-width='2' /%3E%3C/svg%3E");
  position: absolute;
  top: 80%;
  left: -5%;
}

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

.error {
  color: var(--error-color);
}

.success {
  color: var(--success-color);
}

.admonition {
  background-color: var(--background-color-strong);
  border-radius: .5rem;
  margin: 2rem -1rem;
  padding: 1rem;
}

.admonition .admonition-title {
  background-color: var(--primary-color);
  color: var(--background-color);
  border-radius: .5rem .5rem 0 0;
  margin: -1rem -1rem 1rem;
  padding: 1rem;
  font-weight: bold;
}

.admonition p:last-child {
  margin-bottom: 0;
}

:root {
  --primary-color: #112f4b;
  --primary-color-100: #112f4b;
  --primary-color-200: #1a4975;
  --primary-color-300: #23639f;
  --primary-color-400: #2c7dc9;
  --primary-color-500: #4f96d8;
  --primary-color-light: #2e87ad;
  --primary-color-light-100: #19485d;
  --primary-color-light-200: #236885;
  --primary-color-light-300: #2e87ad;
  --primary-color-light-400: #42a3cd;
  --primary-color-light-500: #6ab7d7;
  --highlight-color: #ff5768;
  --highlight-color-100: #f00018;
  --highlight-color-200: #ff243a;
  --highlight-color-300: #ff5768;
  --highlight-color-400: #ff8a95;
  --highlight-color-500: #ffbdc3;
  --background-color-strong: #dadcf1;
  --background-color: #f0f2ff;
  --gray-100: #17171c;
  --gray-200: #454654;
  --gray-300: #73758c;
  --gray-400: #abacba;
  --gray-500: #e3e3e8;
  --gray-600: #fff;
  --error-color: #f00018;
  --success-color: #00b31e;
  --color-neutral-background: #abacba;
  --color-success-background: #82e392;
  --color-partial-background: #e0e382;
  --color-fail-background: #e38282;
}

body {
  background-color: var(--background-color);
}

.breadcrumbs {
  align-items: center;
  padding: 0;
  display: flex;
}

.breadcrumbs .breadcrumb {
  list-style: none;
}

.breadcrumbs .breadcrumb:before {
  content: "/";
  color: var(--gray-300);
  margin: 0 .2em;
}

.breadcrumbs .breadcrumb a {
  color: var(--gray-300);
  text-decoration: none;
}

.breadcrumbs .breadcrumb a:hover {
  color: var(--gray-400);
}

.breadcrumbs .breadcrumb:last-child a {
  cursor: default;
  color: var(--primary-color-400);
}

.breadcrumbs .breadcrumb:last-child a:hover {
  color: var(--primary-color-400);
}

form {
  width: 100%;
  max-width: 100%;
}

form.small-form {
  width: 30rem;
}

label.strong {
  font-weight: bold;
}

input[type="checkbox"] {
  margin-right: .5rem;
}

.form-field {
  flex-direction: column;
  margin-bottom: 1rem;
  display: flex;
}

.form-file-field {
  margin-bottom: 1rem;
  overflow-x: hidden;
}

.form-file-field a {
  text-overflow: ellipsis;
}

.form-file-field label {
  display: block;
}

.form-file-field input[type="checkbox"] + label {
  display: inline;
}

.checkbox-field {
  align-items: center;
  margin-bottom: 1rem;
  display: flex;
}

input[type="text"], input[type="password"], input[type="email"], select, textarea {
  border: 1px solid #ccc;
  border-radius: .5rem;
  padding: .5rem 1rem;
}

input[type="file"]::-webkit-file-upload-button, input[type="file"]::-ms-browse, input[type="file"]::file-selector-button {
  border: 1px solid #ccc;
  border-radius: .5rem;
  padding: .5rem 1rem;
}

.errorlist {
  color: var(--error-color);
  padding: 0;
  list-style: none;
}

.mermaid {
  justify-content: center;
  display: flex;
}

.header {
  padding-top: .5rem;
  padding-bottom: .5rem;
}

.header ul, .header li {
  margin-bottom: 0;
}

.header .navbar {
  width: 100%;
  justify-content: space-between;
  display: flex;
}

.header .navbar-start, .header .navbar-end {
  gap: 1rem;
  display: flex;
}

.header .navbar-navigation {
  gap: 1rem;
  list-style: none;
  display: flex;
}

.header .navbar-navigation-item a {
  color: var(--primary-color);
  text-decoration: none;
}

.header .navbar-navigation-item a:hover {
  color: var(--primary-color-200);
}

.header .navbar-brand {
  color: var(--primary-color);
  font-weight: bold;
}

.header .navbar-brand a {
  color: inherit;
  text-decoration: none;
}

.footer .copyright {
  color: var(--gray-400);
}

.slide-container {
  height: min(80vh, 20rem);
  margin: 2rem 0;
}

.slide-container:after {
  content: "Press F to go fullscreen :)";
  color: var(--gray-400);
}

.slide-container .quote {
  background-color: #45465499;
  padding: 1rem 2rem;
}

.slide-container .quote p {
  color: var(--gray-600);
  font-style: italic;
}

.slide-container .quote p.author {
  color: var(--gray-400);
  text-align: end;
  font-style: normal;
}

.slide-container .quote p.author:before {
  content: "-- ";
}

.slide-container .reveal img {
  max-height: min(60vh, 30rem);
  margin-inline: auto;
}

.slide-large {
  height: min(80vh, 40rem);
  width: min(80vw, 60rem);
}

table {
  min-width: 100%;
  border-spacing: inherit;
  border-bottom: .5rem solid var(--primary-color);
  border-radius: .5rem;
  margin: 1rem auto 2rem;
}

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

table.left-aligned-text {
  text-align: left;
}

table.invisible {
  border-bottom: none;
}

table.invisible thead, table.invisible tbody tr {
  background-color: #0000;
}

table.invisible td, table.invisible th {
  border: none;
}

thead {
  background-color: var(--primary-color);
  color: var(--background-color);
}

thead tr:first-child th:first-child {
  border-top-left-radius: .5rem;
}

thead tr:first-child th:last-child {
  border-top-right-radius: .5rem;
}

th, td {
  padding: .5rem 1rem;
}

th:first-child, td:first-child {
  border-left: none;
}

td {
  border-left: 1px solid #e3e3e8;
}

th {
  border-left: 1px solid #174169;
}

tbody tr:nth-child(2n+1) {
  background-color: var(--background-color-strong);
}

tbody tr:hover {
  color: var(--primary-color-light);
}

.neutral-cell {
  background-color: var(--color-neutral-background);
}

.success-cell {
  background-color: var(--color-success-background);
}

.partial-success-cell {
  background-color: var(--color-partial-background);
}

.fail-cell {
  background-color: var(--color-fail-background);
}

.text-vertical {
  writing-mode: vertical-lr;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.text-vertical.vertical-normal {
  text-orientation: upright;
}

.tab-group {
  margin-top: 4rem;
  display: flex;
}

.tab-group:after {
  content: "";
  border-bottom: 1px solid #ccc;
  flex-grow: 1;
}

.tab-group .tab-btn {
  cursor: pointer;
  background: none;
  border: 1px solid #ccc;
  border-top-left-radius: .5rem;
  border-top-right-radius: .5rem;
  padding: .5rem 1rem;
}

.tab-group .tab-btn.selected {
  cursor: default;
  color: var(--highlight-color);
  border-bottom: none;
}

.btn {
  cursor: pointer;
  border: none;
  border-radius: .5rem;
  padding: .5rem 1rem;
  text-decoration: none;
}

.btn.primary {
  background-color: var(--highlight-color);
  color: var(--gray-600);
}

.btn.primary:hover {
  background-color: var(--highlight-color-200);
}

.btn.secondary {
  background-color: var(--primary-color);
  color: var(--gray-600);
}

.btn.secondary:hover {
  background-color: var(--primary-color-200);
}

.btn.border {
  border: 1px solid var(--primary-color);
  color: var(--gray-100);
  background: none;
}

.btn.border:hover {
  color: var(--gray-200);
}

.btn.hidden {
  background-color: #0000;
}

.btn.full {
  width: 100%;
}

.checklist {
  padding: 0;
  list-style: none;
}

.checklist li:before {
  content: "✘";
  margin-right: .5em;
}

.checklist li.checked:before {
  content: "✔";
}

.content-group {
  margin: 1rem 0 2rem;
  padding-bottom: 1rem;
}

.content-group.with-border {
  border-bottom: 1px solid var(--gray-500);
}

.content-group.isolated {
  margin-top: 2rem;
  margin-bottom: 4rem;
}

img {
  max-width: 100%;
}

img.thumbnail {
  width: 10rem;
}

img.responsive {
  width: 100%;
}

img.pretty {
  border-radius: .5rem;
}

.loader-container {
  align-items: center;
  display: flex;
}

.wavy-text {
  color: var(--primary-color-light);
  animation: wavy-text 1s ease-in-out infinite;
}

@keyframes wavy-text {
  0% {
    transform: translateY(0);
  }

  25% {
    transform: translateY(-.2em);
  }

  50% {
    transform: translateY(0);
  }

  75% {
    transform: translateY(.2em);
  }

  100% {
    transform: translateY(0);
  }
}

.animated-loader {
  width: 80px;
  height: 80px;
  display: inline-block;
  position: relative;
}

.animated-loader div {
  border: 4px solid var(--primary-color-light);
  opacity: 1;
  border-radius: 50%;
  animation: animated-loader 1s cubic-bezier(0, .2, .8, 1) infinite;
  position: absolute;
}

.animated-loader div:nth-child(2) {
  animation-delay: -.5s;
}

@keyframes animated-loader {
  0% {
    width: 0;
    height: 0;
    opacity: 0;
    top: 36px;
    left: 36px;
  }

  4.9% {
    width: 0;
    height: 0;
    opacity: 0;
    top: 36px;
    left: 36px;
  }

  5% {
    width: 0;
    height: 0;
    opacity: 1;
    top: 36px;
    left: 36px;
  }

  100% {
    width: 72px;
    height: 72px;
    opacity: 0;
    top: 0;
    left: 0;
  }
}

body {
  min-height: 100vh;
  flex-direction: column;
  display: flex;
}

.header, .content, .footer {
  padding-left: 1rem;
  padding-right: 1rem;
}

.content {
  flex-grow: 1;
  margin: 1rem auto;
}

.content.text-content {
  max-width: 80ch;
}

.footer {
  display: flex;
}

.footer .copyright {
  margin-left: auto;
}

code {
  border-radius: .5rem;
}

dl {
  margin-bottom: 1rem;
}

dl dt {
  font-weight: 600;
}

dl dd {
  margin-left: 1rem;
}

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