/*
MIT License

Copyright (c) 2024 Luigi De Rosa, Thierry Michel, Xavier Foucrier

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

 */
@charset "UTF-8";

@import url("https://fonts.googleapis.com/css2?family=Rubik:wght@400;700&family=Source+Code+Pro:wght@400;700&family=Space+Mono:wght@400;700&display=swap");
.header__infos__version {
  font-family: "Space Mono", monospace; }

.menu__footer__download {
  font-weight: 700; }

.menu__footer__download, .menu-extra__credits, .docs__nav__lateral__link,
[class*='docs__nav__lateral__link--'] {
  text-transform: uppercase; }

.menu-trigger__github, .menu__pages__item__title,
.menu__pages__item__link, .menu-subpages__item__link, .menu-extra__twitter, .menu-extra__credits {
  text-decoration: none; }

.menu__pages__list, .menu-subpages__list {
  margin: 0;
  padding: 0;
  list-style-type: none; }

.docs__nav__lateral__button {
  display: inline-block;
  margin: 0;
  padding: 0;
  background: none;
  border: 0 none;
  -webkit-appearance: none;
  border-radius: 0;
  outline: none;
  appearance: none;
  cursor: pointer; }

/*
 * Colors
 */
/*html*/
.lock-scroll,
.lock-scroll body {
  overflow-x: hidden; }

.h-pull-left {
  float: left !important; }

.h-pull-right {
  float: right !important; }

.h-text-left {
  text-align: left !important; }

.h-text-right {
  text-align: right !important; }

.h-text-center {
  text-align: center !important; }

.h-text-justify {
  text-align: justify !important; }

.h-text-uppercase {
  text-transform: uppercase; }

.h-text-notransform {
  text-transform: none; }

.h-text-nodecoration {
  text-decoration: none; }

/*
 * Hide visually and from screen readers:
 * http://juicystudio.com/article/screen-readers-display-none.php
 */
.h-hidden {
  display: none !important;
  visibility: hidden; }

/*
 * Hide only visually, but have it available for screen readers:
 * http://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 */
.h-visually-hidden {
  position: absolute;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  /*
   * Extends the .visuallyhidden class to allow the element
   * to be focusable when navigated to via the keyboard:
   * https://www.drupal.org/node/897638
   */ }
  .h-visually-hidden.is-focusable:active, .h-visually-hidden.is-focusable:focus {
    position: static;
    overflow: visible;
    width: auto;
    height: auto;
    margin: 0;
    clip: auto; }

/*
 * Clearfix: contain floats
 * http://cssmojo.com/latest_new_clearfix_so_far/
 */
.h-clearfix::after {
  content: '';
  display: table;
  clear: both; }

.h-inline-block {
  display: inline-block !important; }

.h-table {
  display: table !important; }

.h-cell {
  display: table-cell !important; }

.h-va-middle {
  vertical-align: middle !important; }

/**
 * Text hyphenation
 *
 * Break strings when their length exceeds the width of their container
 * and hyphenate words at the end of lines using the `hyphens` property.
 * Browser support for hyphenation: http://caniuse.com/#search=hyphenation
 */
.h-text-hyphenate {
  word-wrap: break-word;
  hyphens: auto; }

/**
 * Prevent line breaks
 */
.h-nobr {
  white-space: nowrap; }

/*
 * Vendor
 */
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/**
 * Remove default margin.
 */
body {
  margin: 0; }

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block; }

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */ }

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none; }

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent; }

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0; }

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted; }

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold; }

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic; }

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000; }

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0; }

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px; }

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0; }

/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto; }

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em; }

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */ }

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible; }

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none; }

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */ }

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default; }

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal; }

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box; }

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  padding: .35em .625em .75em;
  border: 0;
  margin: 0 2px; }

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto; }

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold; }

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

td,
th {
  padding: 0; }

/*
 * Base
 */
html.js {
  opacity: 0; }
  html.js.wf-active, html.js.wf-inactive, html.js.ready {
    opacity: 1; }

body {
  overflow-x: hidden; }
  @media (prefers-color-scheme: dark) {
    body {
      background: #020300;
      color: #7d889b; } }
  body ::selection {
    color: #f2f;
    background: #348230; }
    @media (prefers-color-scheme: dark) {
      body ::selection {
        color: #21252b; } }
  body [data-feature-order='0'] ::selection {
    background: #38d1f1; }
  body [data-feature-order='1'] ::selection {
    background: #04bf0c; }
  body [data-feature-order='2'] ::selection {
    background: #ffa543; }
  body [data-feature-order='3'] ::selection {
    background: #ec4343; }
  body [data-feature-order='4'] ::selection {
    background: #8c44d9; }
  body.prevent-scroll {
    overflow: hidden;
    height: 100vh;
    margin-left: calc(100vw - 100%); }

body > svg {
  display: none; }

img {
  max-width: 100%;
  height: auto; }

a,
a:hover,
a:active,
a:visited {
  text-decoration: none; }

html.is-transitioning,
html.is-transitioning * {
  pointer-events: none;
  cursor: progress; }

.site-content {
  display: flex;
  flex-direction: column;
  flex: 1; }

.site-content-inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-grow: 1; }
  .site-content-inner > :first-child {
    margin-top: 0; }
  .site-content-inner > :last-child {
    margin-bottom: 0; }
  .site-content-inner[data-barba-namespace='docs'] {
    display: block;
    padding: 0; }

code {
  padding: 2px 4px;
  font-family: "Source Code Pro", monaco, menlo, consolas, monospace;
  background: #f5f7fc;
  border-radius: 4px; }
  @media (prefers-color-scheme: dark) {
    code {
      background: #3e4451; } }

blockquote {
  margin: 2rem 0;
  padding: 0 2.5rem;
  color: #a0a0a0;
  border-left: 3px solid currentcolor;
  overflow: hidden; }
  @media (prefers-color-scheme: dark) {
    blockquote {
      color: #575c67; }
      blockquote code {
        color: #7d889b; } }

hr {
  display: inline-flex;
  background: #348230;
  width: 5rem;
  height: 0.2rem;
  margin: 2rem 0;
  border: none; }

/**
 * Global settings
 */
html {
  box-sizing: border-box; }

*,
*::before,
*::after {
  box-sizing: inherit; }

* {
  -webkit-tap-highlight-color: transparent; }

/**
 * Media
 */
img {
  height: auto; }

/**
 * Forms
 */
input:focus,
select:focus,
textarea:focus,
button:focus {
  outline: none; }

html {
  font-size: calc(1em * 0.625); }

body {
  /* sass-lint:disable-block no-vendor-prefixes */
  font: 300 1.3rem/1.65 "Rubik", sans-serif;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased; }
  @media only screen and (min-width: 48em) {
    body {
      font: 300 1.6rem/1.65 "Rubik", sans-serif; } }
  @media only screen and (min-width: 64em) {
    body {
      font: 300 1.8rem/1.65 "Rubik", sans-serif; } }

[class*='footer--'],
.footer {
  position: fixed;
  z-index: 10;
  bottom: 0;
  left: 0;
  padding: 2rem;
  color: currentcolor;
  font-size: 1.1rem;
  letter-spacing: 0.15em;
  pointer-events: none; }
  @media only screen and (min-width: 64em) {
    [class*='footer--'],
    .footer {
      padding: 4.5rem; } }
  @media only screen and (max-width: 47.99em) {
    [class*='footer--'],
    .footer {
      display: none; } }
  [data-barba="container"]:not([data-barba-namespace="docs"]) [class*='footer--'], [data-barba="container"]:not([data-barba-namespace="docs"])
  .footer {
    display: none; }

.header,
[class*='header--'] {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  background: #020300;
  pointer-events: none; }
  @media (prefers-color-scheme: dark) {
    .header,
    [class*='header--'] {
      background: #020300; } }
  @media only screen and (min-width: 48em) {
    .header,
    [class*='header--'] {
      background: transparent; } }

.header__wrapper {
  display: flex;
  justify-content: space-between;
  overflow: hidden;
  width: 100vw;
  padding: 20px; }
  @media only screen and (min-width: 48em) {
    .header__wrapper {
      padding: 40px; } }

.header__infos {
  display: flex;
  align-items: center;
  pointer-events: auto; }
  @media only screen and (min-width: 48em) {
    .header__infos {
      position: fixed; } }

.header__infos__logo {
  margin-right: 10px; }

.header__infos__version {
  color: #348230;
  font-size: 1.1rem; }
  [data-feature-order='0'] .header__infos__version {
    color: #38d1f1; }
  [data-feature-order='1'] .header__infos__version {
    color: #04bf0c; }
  [data-feature-order='2'] .header__infos__version {
    color: #ffa543; }
  [data-feature-order='3'] .header__infos__version {
    color: #ec4343; }
  [data-feature-order='4'] .header__infos__version {
    color: #8c44d9; }

.header__infos__docs {
  margin-left: 1rem;
  color: #348230;
  font-size: 2rem; }

.header__external-links {
  z-index: 1000;
  display: flex;
  pointer-events: auto;
  user-select: none; }
  @media only screen and (min-width: 48em) {
    .header__external-links {
      position: fixed;
      right: 4rem; } }

.header__external-links__github {
  position: relative; }
  .is-open .header__external-links__github {
    transform: translateX(calc(-100vw + 170px)); }
    @media only screen and (min-width: 48em) {
      .is-open .header__external-links__github {
        transform: translateX(-300px); } }

.header__nav {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%; }
  @media only screen and (min-width: 48em) {
    .header__nav {
      width: auto; } }

.menu-trigger {
  position: relative;
  z-index: 999;
  overflow: hidden;
  width: 50px;
  height: 50px;
  margin: 0 1rem;
  background-color: #16191d;
  border-radius: 50%;
  cursor: pointer; }
  [data-feature-order='0'] .menu-trigger {
    background-color: rgba(56, 209, 241, 0.2); }
  [data-feature-order='1'] .menu-trigger {
    background-color: rgba(4, 191, 12, 0.2); }
  [data-feature-order='2'] .menu-trigger {
    background-color: rgba(255, 165, 67, 0.2); }
  [data-feature-order='3'] .menu-trigger {
    background-color: rgba(236, 67, 67, 0.2); }
  [data-feature-order='4'] .menu-trigger {
    background-color: rgba(140, 68, 217, 0.2); }

.menu-trigger__shape {
  position: absolute;
  top: 0;
  left: 0;
  fill: transparent;
  stroke: #348230;
  stroke-width: 4px;
  stroke-dasharray: 160px;
  stroke-dashoffset: 160px;
  transition: stroke-dashoffset 0.6s cubic-bezier(0.165, 0.84, 0.44, 1); }
  @media (prefers-color-scheme: dark) {
    .menu-trigger__shape {
      stroke: #348230; } }
  [data-feature-order='0'] .menu-trigger__shape {
    stroke: #38d1f1; }
  [data-feature-order='1'] .menu-trigger__shape {
    stroke: #04bf0c; }
  [data-feature-order='2'] .menu-trigger__shape {
    stroke: #ffa543; }
  [data-feature-order='3'] .menu-trigger__shape {
    stroke: #ec4343; }
  [data-feature-order='4'] .menu-trigger__shape {
    stroke: #8c44d9; }
  .is-open .menu-trigger__shape,
  .menu-trigger:hover .menu-trigger__shape {
    stroke-dashoffset: 0; }

.menu-trigger__github {
  position: absolute;
  z-index: 999;
  top: 50px;
  right: 110px; }
  .menu-trigger__github .circle {
    fill: #333;
    transition: fill 0.2s ease-out; }
  .menu-trigger__github:hover .circle {
    fill: #348230; }
  .menu-trigger__github .shape {
    fill: white; }

.menu-trigger__github,
.menu-trigger__github__icon {
  display: block;
  width: 50px;
  height: 50px; }

.menu-trigger__bar {
  position: absolute;
  left: 50%;
  display: block;
  overflow: hidden;
  width: 45%;
  height: 0.3rem;
  background: #348230;
  transform: translate(-50%, -50%);
  transform-origin: center center;
  transition: top 0.4s, transform 0.4s, opacity 0.4s ease-in-out;
  /* stylelint-disable no-descending-specificity */
  /* stylelint-enable no-descending-specificity */ }
  @media (prefers-color-scheme: dark) {
    .menu-trigger__bar {
      background: #348230; } }
  [data-feature-order='0'] .menu-trigger__bar {
    background-color: #38d1f1; }
  [data-feature-order='1'] .menu-trigger__bar {
    background-color: #04bf0c; }
  [data-feature-order='2'] .menu-trigger__bar {
    background-color: #ffa543; }
  [data-feature-order='3'] .menu-trigger__bar {
    background-color: #ec4343; }
  [data-feature-order='4'] .menu-trigger__bar {
    background-color: #8c44d9; }
  .modal.is-open .menu-trigger__bar:nth-child(1) {
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg); }
  .menu-trigger__bar:nth-child(2) {
    top: 35%; }
    .is-open .menu-trigger__bar:nth-child(2) {
      top: 50%;
      transform: translate(-50%, -50%) rotate(45deg); }
  .menu-trigger__bar:nth-child(3) {
    top: 50%; }
    .is-open .menu-trigger__bar:nth-child(3) {
      opacity: 0;
      transform: translate(200%, -50%); }
    .modal.is-open .menu-trigger__bar:nth-child(3) {
      opacity: 1;
      transform: translate(-50%, -50%) rotate(45deg); }
  .menu-trigger__bar:nth-child(4) {
    top: 64%; }
    .is-open .menu-trigger__bar:nth-child(4) {
      top: 50%;
      transform: translate(-50%, -50%) rotate(-45deg); }

.menu {
  position: absolute;
  z-index: 99;
  top: 0;
  right: 0;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  height: 100vh;
  padding: 180px 50px 50px;
  font-family: "Space Mono", monospace;
  user-select: none;
  pointer-events: none; }
  @media only screen and (min-width: 48em) {
    .menu {
      width: 500px; } }
  .menu.is-open {
    display: flex;
    pointer-events: initial; }
  .menu > div {
    width: 100%; }

.menu__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: rgba(245, 247, 252, 0.9);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease-in-out;
  cursor: pointer; }
  @media (prefers-color-scheme: dark) {
    .menu__overlay {
      background: rgba(40, 44, 52, 0.9); } }
  .is-open .menu__overlay {
    opacity: 1;
    pointer-events: initial; }

.menu__panel {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  overflow-y: scroll;
  width: 100%;
  height: 100vh;
  padding: 100px 50px 50px;
  background-color: white;
  box-shadow: 10px 10px 10px 10px #d3defc;
  transform: translateX(110%); }
  @media (prefers-color-scheme: dark) {
    .menu__panel {
      background: rgba(33, 37, 43, 0.9);
      box-shadow: 10px 10px 10px 10px #21252b; } }
  @media only screen and (min-width: 48em) {
    .menu__panel {
      padding: 180px 50px 50px; } }
  @media only screen and (min-width: 48em) and (max-height: 850px) {
    .menu__panel {
      padding-top: 140px; } }
  .menu__panel::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 10rem; }
    @media only screen and (min-width: 48em) {
      .menu__panel::before {
        height: 18rem; } }

.menu__pages {
  position: relative;
  flex-grow: 1; }

.menu__pages__item + .menu__pages__item {
  margin-top: 20px; }
  @media screen and (max-height: 850px) {
    .menu__pages__item + .menu__pages__item {
      margin-top: 15px; } }

.menu__pages__item__title,
.menu__pages__item__link {
  color: #348230;
  font-size: 4rem;
  line-height: 1.2em;
  transition: color 0.2s ease-out; }
  @media (prefers-color-scheme: dark) {
    .menu__pages__item__title,
    .menu__pages__item__link {
      color: #348230; } }
  .menu__pages__item__title.is-active,
  .menu__pages__item__link.is-active {
    color: black;
    pointer-events: none; }
    @media (prefers-color-scheme: dark) {
      .menu__pages__item__title.is-active,
      .menu__pages__item__link.is-active {
        color: currentcolor; } }
  @media screen and (max-height: 850px) {
    .menu__pages__item__title,
    .menu__pages__item__link {
      font-size: 3rem;
      line-height: 1.2; } }

[data-feature-order='0'] .menu__pages__item__link:not(.is-active) {
  color: #38d1f1; }

[data-feature-order='1'] .menu__pages__item__link:not(.is-active) {
  color: #04bf0c; }

[data-feature-order='2'] .menu__pages__item__link:not(.is-active) {
  color: #ffa543; }

[data-feature-order='3'] .menu__pages__item__link:not(.is-active) {
  color: #ec4343; }

[data-feature-order='4'] .menu__pages__item__link:not(.is-active) {
  color: #8c44d9; }

[data-feature-order='5'] .menu__pages__item__link:not(.is-active) {
  color: #348230; }

.menu__pages__item__link:not(.is-active):hover, .menu__pages__item__link:not(.is-active).is-active {
  color: black; }
  @media (prefers-color-scheme: dark) {
    .menu__pages__item__link:not(.is-active):hover, .menu__pages__item__link:not(.is-active).is-active {
      color: currentcolor; } }

.menu-subpages__list {
  padding-left: 20px; }

.menu__pages__item__subpages {
  margin-top: 15px; }

.menu-subpages__item {
  font-size: 1.6rem;
  line-height: 1.2em; }
  .menu-subpages__item + .menu-subpages__item {
    margin-top: 15px; }

.menu-subpages__item__link {
  display: flex;
  align-items: center; }

.menu-subpages__item__link__line {
  width: 0;
  height: 2px;
  margin-right: 10px;
  transition: width 0.2s ease-out; }
  .menu-subpages__item:nth-child(1) .menu-subpages__item__link__line {
    background-color: #38d1f1; }
  .menu-subpages__item:nth-child(2) .menu-subpages__item__link__line {
    background-color: #04bf0c; }
  .menu-subpages__item:nth-child(3) .menu-subpages__item__link__line {
    background-color: #ffa543; }
  .menu-subpages__item:nth-child(4) .menu-subpages__item__link__line {
    background-color: #ec4343; }
  .menu-subpages__item:nth-child(5) .menu-subpages__item__link__line {
    background-color: #8c44d9; }
  .menu-subpages__item:nth-child(6) .menu-subpages__item__link__line {
    background-color: #348230; }
  .menu-subpages__item.is-active .menu-subpages__item__link__line {
    width: 30px; }

.menu-subpages__item__link__label {
  color: #858585;
  transition: color 0.2s ease-out; }
  @media (prefers-color-scheme: dark) {
    .menu-subpages__item__link__label {
      color: #7d889b; } }
  .menu-subpages__item:nth-child(1):hover .menu-subpages__item__link__label,
  .menu-subpages__item:nth-child(1).is-active .menu-subpages__item__link__label {
    color: #38d1f1; }
  .menu-subpages__item:nth-child(2):hover .menu-subpages__item__link__label,
  .menu-subpages__item:nth-child(2).is-active .menu-subpages__item__link__label {
    color: #04bf0c; }
  .menu-subpages__item:nth-child(3):hover .menu-subpages__item__link__label,
  .menu-subpages__item:nth-child(3).is-active .menu-subpages__item__link__label {
    color: #ffa543; }
  .menu-subpages__item:nth-child(4):hover .menu-subpages__item__link__label,
  .menu-subpages__item:nth-child(4).is-active .menu-subpages__item__link__label {
    color: #ec4343; }
  .menu-subpages__item:nth-child(5):hover .menu-subpages__item__link__label,
  .menu-subpages__item:nth-child(5).is-active .menu-subpages__item__link__label {
    color: #8c44d9; }
  .menu-subpages__item:nth-child(6):hover .menu-subpages__item__link__label,
  .menu-subpages__item:nth-child(6).is-active .menu-subpages__item__link__label {
    color: #348230; }

.menu__footer {
  position: relative;
  margin-top: 80px; }
  @media screen and (max-height: 850px) {
    .menu__footer {
      margin-top: 50px; } }

.menu__footer__download {
  display: block;
  width: 100%;
  padding: 10px;
  color: white;
  font-size: 1.3rem;
  text-align: center;
  letter-spacing: 0.15em;
  background: transparent;
  border: 0;
  border-radius: 5px;
  outline: 0;
  transition: background 0.2s ease-out; }
  @media (prefers-color-scheme: dark) {
    .menu__footer__download {
      color: #16191d; } }
  .menu__footer__download:hover {
    background: #000; }
  [data-feature-order='0'] .menu__footer__download {
    background-color: #38d1f1; }
  [data-feature-order='1'] .menu__footer__download {
    background-color: #04bf0c; }
  [data-feature-order='2'] .menu__footer__download {
    background-color: #ffa543; }
  [data-feature-order='3'] .menu__footer__download {
    background-color: #ec4343; }
  [data-feature-order='4'] .menu__footer__download {
    background-color: #8c44d9; }
  [data-feature-order='5'] .menu__footer__download {
    background-color: #348230; }

.menu__footer__extra {
  margin-top: 50px; }

.menu-extra {
  display: flex;
  justify-content: space-between;
  align-items: center; }

.menu-extra__twitter {
  display: flex;
  align-items: center;
  height: 14px;
  margin-right: 40px;
  color: currentcolor; }

.menu-extra__twitter__icon {
  display: block;
  width: 16px;
  height: 13px;
  margin-right: 10px;
  fill: currentcolor; }

.menu-extra__twitter__label {
  font-size: 1.1rem;
  white-space: nowrap;
  letter-spacing: 0.15em; }

.menu-extra__credits {
  color: black;
  font-size: 1.1rem;
  letter-spacing: 0.1em; }
  .menu-extra__credits a {
    display: flex; }
    @media (prefers-color-scheme: dark) {
      .menu-extra__credits a {
        opacity: 0.8; } }
  .menu-extra__credits a img {
    border-radius: 4px; }

.big-title,
[class*='big-title--'] {
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: hidden;
  min-height: 100vh;
  opacity: 0.07;
  pointer-events: none;
  user-select: none; }

.big-title__title {
  position: absolute;
  top: -25vh;
  left: 70%;
  display: block;
  margin: 0;
  color: #348230;
  font-size: 45rem;
  font-weight: 400;
  transform: rotate(90deg);
  transform-origin: left center; }
  @media (prefers-color-scheme: dark) {
    .big-title__title {
      color: black; } }
  [class*='big-title--'][class*='--black'] .big-title__title {
    color: white; }

.button,
[class*='button--'] {
  display: block;
  padding: 1rem 3.8rem;
  color: #348230;
  font-family: "Space Mono", monospace;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1rem;
  border: 0.2rem solid #348230;
  fill: #348230;
  border-radius: 0.4rem;
  transition: background-color 0.4s, color 0.4s, border-color 0.4s; }
  .button:hover,
  [class*='button--']:hover {
    color: white;
    background: #348230; }
  [data-feature-order='0'] .button, [data-feature-order='0']
  [class*='button--'] {
    color: #38d1f1;
    border-color: #38d1f1; }
  [data-feature-order='1'] .button, [data-feature-order='1']
  [class*='button--'] {
    color: #04bf0c;
    border-color: #04bf0c; }
  [data-feature-order='2'] .button, [data-feature-order='2']
  [class*='button--'] {
    color: #ffa543;
    border-color: #ffa543; }
  [data-feature-order='3'] .button, [data-feature-order='3']
  [class*='button--'] {
    color: #ec4343;
    border-color: #ec4343; }
  [data-feature-order='4'] .button, [data-feature-order='4']
  [class*='button--'] {
    color: #8c44d9;
    border-color: #8c44d9; }

[class*='button--'][class*='--fill'] {
  color: white;
  background: #348230;
  fill: white; }
  [data-feature-order='0'] [class*='button--'][class*='--fill']:not([class*='--black']) {
    background-color: #38d1f1;
    border-color: #38d1f1; }
  [data-feature-order='1'] [class*='button--'][class*='--fill']:not([class*='--black']) {
    background-color: #04bf0c;
    border-color: #04bf0c; }
  [data-feature-order='2'] [class*='button--'][class*='--fill']:not([class*='--black']) {
    background-color: #ffa543;
    border-color: #ffa543; }
  [data-feature-order='3'] [class*='button--'][class*='--fill']:not([class*='--black']) {
    background-color: #ec4343;
    border-color: #ec4343; }
  [data-feature-order='4'] [class*='button--'][class*='--fill']:not([class*='--black']) {
    background-color: #8c44d9;
    border-color: #8c44d9; }
  [class*='button--'][class*='--fill']:not([class*='--black']):hover {
    background: #348230;
    border-color: #348230; }
    [data-feature-order='0'] [class*='button--'][class*='--fill']:not([class*='--black']):hover {
      background-color: #10c1e6;
      border-color: #10c1e6; }
    [data-feature-order='1'] [class*='button--'][class*='--fill']:not([class*='--black']):hover {
      background-color: #038d09;
      border-color: #038d09; }
    [data-feature-order='2'] [class*='button--'][class*='--fill']:not([class*='--black']):hover {
      background-color: #ff8d10;
      border-color: #ff8d10; }
    [data-feature-order='3'] [class*='button--'][class*='--fill']:not([class*='--black']):hover {
      background-color: #e51717;
      border-color: #e51717; }
    [data-feature-order='4'] [class*='button--'][class*='--fill']:not([class*='--black']):hover {
      background-color: #7228c2;
      border-color: #7228c2; }

[class*='button--'][class*='--fill'][class*='--black'] {
  background: currentcolor;
  border-color: transparent; }
  @media (prefers-color-scheme: dark) {
    .is-open [class*='button--'][class*='--fill'][class*='--black'] {
      background: #0b0c0e;
      border-color: #0b0c0e; } }

[class*='button--'][class*='--github'] {
  color: currentcolor;
  font-size: 11px;
  font-weight: 300;
  transition: background-color 0.4s, color 0.4s, border-color 0.4s, transform 0.4s; }
  @media (prefers-color-scheme: dark) {
    [class*='button--'][class*='--github'] {
      color: #21252b; } }
  [class*='button--'][class*='--github'] span {
    pointer-events: none;
    position: absolute;
    top: 50%;
    left: 100%;
    width: 160%;
    margin-left: 1rem;
    opacity: 0;
    transform: translateY(-50%);
    transition: opacity 0.4s ease-in-out; }
    .is-open [class*='button--'][class*='--github'] span {
      pointer-events: auto;
      opacity: 1; }
      @media (prefers-color-scheme: dark) {
        .is-open [class*='button--'][class*='--github'] span {
          color: #7d889b; } }

[class*='button--'][class*='--rounded'] {
  width: 5rem;
  height: 5rem;
  padding: 0.7rem;
  border-radius: 50%; }

.cta {
  display: flex;
  align-items: center;
  margin-right: 4rem;
  padding: 0;
  background: transparent;
  border: 0; }
  .cta .icon--barba {
    width: 4rem;
    height: 4rem; }
  .cta [class*='__caption'] {
    display: flex;
    flex-direction: column;
    margin: 0 1rem;
    color: #348230;
    font-family: "Space Mono", monospace;
    font-weight: 300;
    text-align: left;
    letter-spacing: 0.2rem; }
  .cta [class*='__subtitle'] {
    font-size: 1.2rem;
    line-height: 1.2rem;
    text-transform: uppercase; }
  .cta [class*='__title'] {
    font-size: 3rem;
    line-height: 3rem; }

.grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: 30rem;
  grid-gap: 3rem;
  margin: 0;
  padding: 5rem 0;
  list-style: none; }
  @media only screen and (min-width: 48em) {
    .grid {
      grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
      grid-auto-rows: minmax(200px, 250px); } }

.grid__item__link {
  display: flex;
  align-items: center;
  color: #348230;
  font-family: "Space Mono", monospace;
  font-size: 1.1rem;
  line-height: 1.2rem;
  letter-spacing: 0.2rem; }
  .grid__item__link .icon--barba {
    width: 1.5rem;
    height: 1.5rem;
    margin: 0 0.5rem;
    fill: #348230; }

.icon,
[class*='icon--'] {
  width: 3.2rem;
  height: 3.2rem;
  fill: inherit; }

[class*='icon--'][class*='--barba'] {
  fill: transparent;
  stroke: white;
  stroke-width: 0.1rem; }

.partial-image {
  width: 100%;
  height: 100%;
  object-fit: cover; }

.link {
  position: relative;
  color: #348230; }
  [data-feature-order='0'] .link {
    color: #38d1f1; }
  [data-feature-order='1'] .link {
    color: #04bf0c; }
  [data-feature-order='2'] .link {
    color: #ffa543; }
  [data-feature-order='3'] .link {
    color: #ec4343; }
  [data-feature-order='4'] .link {
    color: #8c44d9; }
  [data-feature-order='5'] .link {
    color: #348230; }
  .link::before {
    content: '';
    position: absolute;
    bottom: -0.5rem;
    left: 0;
    display: block;
    width: 100%;
    height: 0.2rem;
    background-color: #348230;
    transform-origin: center left;
    transition: transform 0.3s ease-out; }
    [data-feature-order='0'] .link::before {
      background-color: #38d1f1; }
    [data-feature-order='1'] .link::before {
      background-color: #04bf0c; }
    [data-feature-order='2'] .link::before {
      background-color: #ffa543; }
    [data-feature-order='3'] .link::before {
      background-color: #ec4343; }
    [data-feature-order='4'] .link::before {
      background-color: #8c44d9; }
    [data-feature-order='5'] .link::before {
      background-color: #348230; }
  .link:hover::before {
    transform-origin: center right;
    transform: scaleX(0); }

/* stylelint-disable selector-max-combinators, selector-max-compound-selectors, no-descending-specificity */
.logo {
  width: 100%;
  font-size: 0; }
  .logo svg {
    overflow: visible;
    width: 100%; }
  .logo .links a {
    outline: none; }
  .logo .base,
  .logo .js__letter {
    transition: stroke 0.4s, fill 0.4s; }
  @media (prefers-color-scheme: dark) {
    .logo .base {
      fill: rgba(40, 44, 52, 0.7); } }
  .logo .base .js__rect {
    opacity: 0; }
  .logo .base .js__rect__alternate {
    display: none; }
  .logo svg.gray .base,
  .logo svg.fillgray .base {
    stroke: #e0e0e0; }
  .logo svg.gray .js__letter,
  .logo svg.fillgray .js__letter {
    fill: #e0e0e0; }
  .logo svg.holed .hover rect,
  .logo svg.holed .hover circle,
  .logo svg.holed .hover path {
    fill: white; }
  .logo .js.front .js__rect_alternate {
    display: block; }
  .logo .hover .item {
    opacity: 0; }

.featured svg .base {
  stroke: #e0e0e0; }

.featured svg .js__letter {
  fill: #e0e0e0; }

.featured .hover rect,
.featured .hover circle,
.featured .hover path {
  fill: white; }

.featured .hover .c6 .js path {
  fill: #348230; }

.item .can-grow,
.detail-feature .item {
  transition: transform 1.4s cubic-bezier(0.77, 0, 0.175, 1);
  will-change: transform; }

.item.grow.b1,
.detail-feature .item.b1 {
  z-index: 9; }
  .item.grow.b1 rect,
  .detail-feature .item.b1 rect {
    transform: scale(6) translate(-3vw, -4vh) rotate(20deg); }
  .item.grow.b1 circle,
  .detail-feature .item.b1 circle {
    transform: scale(6) translate(8vw, -3vh) rotate(20deg); }

.item.grow.a2,
.detail-feature .item.a2 {
  z-index: 9; }
  .item.grow.a2 circle,
  .detail-feature .item.a2 circle {
    transform: scale(6) translate(1vw, -1vh) rotate(64deg); }
  .item.grow.a2 rect,
  .detail-feature .item.a2 rect {
    transform: scale(8) translate(7vw, -14vh) rotate(30deg); }

.item.grow.r3,
.detail-feature .item.r3 {
  z-index: 9; }
  .item.grow.r3 path,
  .detail-feature .item.r3 path {
    transform: scale(7) translate(10vw, -2vh) rotate(-147deg); }
  .item.grow.r3 rect,
  .detail-feature .item.r3 rect {
    transform: scale(7.3) translate(-5vw, -5vh) rotate(11deg); }

.item.grow.b4,
.detail-feature .item.b4 {
  z-index: 9; }
  .item.grow.b4 rect,
  .detail-feature .item.b4 rect {
    transform: scale(7) translate(4vw, -4vh) rotate(-27deg); }
  .item.grow.b4 circle,
  .detail-feature .item.b4 circle {
    transform: scale(7.3) translate(-5vw, -5vh) rotate(11deg); }

.item.grow.a5,
.detail-feature .item.a5 {
  z-index: 9; }
  .item.grow.a5 rect,
  .detail-feature .item.a5 rect {
    transform: scale(7) translate(-15vw, -5vh) rotate(-24deg); }
  .item.grow.a5 circle,
  .detail-feature .item.a5 circle {
    transform: scale(7.3) translate(2vw, -5vh) rotate(-9deg); }

.item.grow.c6,
.detail-feature .item.c6 {
  z-index: 9; }
  .item.grow.c6 .togrow,
  .detail-feature .item.c6 .togrow {
    transform: scale(5) rotate(-35deg); }

.can-move .move.move1 {
  animation: move1 20s infinite ease-in-out; }

.can-move .move.move2 {
  animation: move2 29s infinite ease-in-out; }

.can-move .move.move3 {
  animation: move3 24s infinite ease-in-out; }

.can-move .move.move4 {
  animation: move4 39s infinite ease-in-out; }

.can-move .move.move5 {
  animation: move5 18s infinite ease-in-out; }

@keyframes move1 {
  0% {
    transform: translate(0, 0); }
  50% {
    transform: translate(10vw, 10vh); }
  100% {
    transform: translate(0, 0); } }

@keyframes move2 {
  0% {
    transform: translate(0, 0); }
  50% {
    transform: translate(14vw, -10vh); }
  100% {
    transform: translate(0, 0); } }

@keyframes move3 {
  0% {
    transform: translate(0, 0); }
  50% {
    transform: translate(4vw, -20vh); }
  100% {
    transform: translate(0, 0); } }

@keyframes move4 {
  0% {
    transform: translate(0, 0); }
  50% {
    transform: translate(30vw, 8vh); }
  100% {
    transform: translate(0, 0); } }

@keyframes move5 {
  0% {
    transform: translate(0, 0); }
  50% {
    transform: translate(-7vw, 8vh); }
  100% {
    transform: translate(0, 0); } }

.featured--0 .hover .b1 {
  opacity: 1; }

.featured--1 .hover .a2 {
  opacity: 1; }

.featured--2 .hover .r3 {
  opacity: 1; }

.featured--3 .hover .b4 {
  opacity: 1; }

.featured--4 .hover .a5 {
  opacity: 1; }

.featured--5 .hover .c6 {
  opacity: 1; }

.featured--5 svg .js__letter {
  display: none;
  fill: #348230;
  opacity: 0.1; }
  @media only screen and (min-width: 48em) {
    .featured--5 svg .js__letter {
      display: block; } }
  .featured--5 svg .js__letter.to-animate {
    transform: scale(18) translate(-10%, 10%) rotate(-30deg); }

.docs__markdown {
  overflow: hidden;
  width: 100%;
  padding: 12rem 3rem; }
  @media only screen and (min-width: 48em) {
    .docs__markdown {
      max-width: 60vw;
      left: calc(28vw + ((100% - 28vw) / 2) - (60vw / 2));
      position: relative; } }
  @media only screen and (min-width: 64em) {
    .docs__markdown {
      max-width: 55vw;
      left: calc(380px + ((100% - 380px) / 2) - (55vw / 2));
      position: relative;
      padding: 12rem 4rem 6rem 4rem; } }
  .docs__markdown h1 {
    display: flex;
    margin: 0;
    padding-bottom: 2rem;
    color: #255d22;
    font-family: "Space Mono", monospace;
    font-size: 3rem;
    font-weight: 400; }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown h1 {
        font-size: 4rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown h1 {
        font-size: 5rem; } }
    .docs__markdown h1 small {
      font-size: 1.5rem; }
      @media only screen and (min-width: 37.5em) {
        .docs__markdown h1 small {
          font-size: 2rem; } }
  .docs__markdown h2,
  .docs__markdown h3,
  .docs__markdown h4,
  .docs__markdown h5,
  .docs__markdown h6,
  .docs__markdown p {
    margin: 0;
    font-family: "Rubik", sans-serif; }
  .docs__markdown h2 {
    padding-top: 2.8rem;
    font-size: 2.2rem;
    font-weight: 100; }
    @media only screen and (max-width: 767px) {
      .docs__markdown h2 {
       display: none; } }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown h2 {
        padding-top: 3.2rem;
        font-size: 2.8rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown h2 {
        padding-top: 4rem;
        font-size: 3.5rem; } }
  .docs__markdown h3 {
    padding-top: 1.2rem;
    font-size: 1.8rem;
    font-weight: 700; }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown h3 {
        padding-top: 1.6rem;
        font-size: 2.2rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown h3 {
        padding-top: 2rem;
        font-size: 2.8rem; } }
  .docs__markdown h4 {
    padding-top: 1.2rem;
    font-size: 1.6rem;
    font-weight: 700; }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown h4 {
        padding-top: 1.4rem;
        font-size: 1.8rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown h4 {
        padding-top: 1.8rem;
        font-size: 2.4rem; } }
  .docs__markdown h5 {
    padding-top: 0.8rem;
    font-size: 1.5rem;
    font-weight: 700; }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown h5 {
        padding-top: 1rem;
        font-size: 1.7rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown h5 {
        padding-top: 1.3rem;
        font-size: 2.2rem; } }
  .docs__markdown h6 {
    padding-top: 0.8rem;
    font-size: 1.3rem;
    font-weight: 700; }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown h6 {
        padding-top: 1rem;
        font-size: 1.5rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown h6 {
        padding-top: 1.2rem;
        font-size: 2rem; } }
  .docs__markdown p {
    padding-top: 0.5rem;
    font-size: 1.2rem; }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown p {
        padding-top: 0.7rem;
        font-size: 1.4rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown p {
        padding-top: 0.9rem;
        font-size: 1.6rem; } }
  .docs__markdown table {
    display: block;
    overflow: auto;
    width: 100%;
    margin: 2rem 0; }
    .docs__markdown table th,
    .docs__markdown table td,
    .docs__markdown table tr {
      padding: 0.5rem;
      font-size: 1.2rem;
      border: 1px solid #ebebeb; }
      @media (prefers-color-scheme: dark) {
        .docs__markdown table th,
        .docs__markdown table td,
        .docs__markdown table tr {
          border: 1px solid #181a1f; } }
      @media only screen and (min-width: 37.5em) {
        .docs__markdown table th,
        .docs__markdown table td,
        .docs__markdown table tr {
          padding: 0.7rem;
          font-size: 1.2rem; } }
      @media only screen and (min-width: 64em) {
        .docs__markdown table th,
        .docs__markdown table td,
        .docs__markdown table tr {
          padding: 1rem;
          font-size: 1.5rem; } }
  .docs__markdown ul {
    padding-left: 2rem;
    font-size: 1.2rem;
    list-style: none; }
    @media only screen and (min-width: 37.5em) {
      .docs__markdown ul {
        padding-left: 4rem;
        font-size: 1.4rem; } }
    @media only screen and (min-width: 64em) {
      .docs__markdown ul {
        padding-left: 6rem;
        font-size: 1.8rem; } }
    .docs__markdown ul li {
      padding-left: 0.5rem; }
    .docs__markdown ul li::before {
      content: '';
      position: relative;
      top: 1em;
      left: -1em;
      display: block;
      width: 0;
      height: 0;
      border-width: 0.35em 0 0.35em 0.45em;
      border-style: solid;
      border-color: transparent #348230; }
  .docs__markdown a:not([title='Badge']):not(.headerlink) {
    position: relative;
    color: #348230;
    white-space: nowrap; }
    @media (prefers-color-scheme: dark) {
      .docs__markdown a:not([title='Badge']):not(.headerlink) {
        color: #348230; }
        .docs__markdown a:not([title='Badge']):not(.headerlink):has(code) {
          color: #7d889b; }
          .docs__markdown a:not([title='Badge']):not(.headerlink):has(code)::before {
            color: rgba(255, 255, 255, 0.7); } }
    .docs__markdown a:not([title='Badge']):not(.headerlink)::before {
      content: '';
      position: absolute;
      bottom: -2px;
      left: 0;
      width: 100%;
      height: 1px;
      background: currentColor;
      opacity: 0.2;
      transition: opacity 350ms ease;
      pointer-events: none; }
    .docs__markdown a:not([title='Badge']):not(.headerlink):hover::before {
      opacity: 1; }
    .docs__markdown a:not([title='Badge']):not(.headerlink) code {
      border-radius: 4px 4px 0 0; }
  .docs__markdown .headerlink {
    position: absolute;
    left: -30px;
    width: 30px;
    opacity: 0;
    transition: opacity 250ms ease; }
    .docs__markdown .headerlink::before {
      content: '#';
      color: #348230; }
  .docs__markdown h2,
  .docs__markdown h3,
  .docs__markdown h4,
  .docs__markdown h5,
  .docs__markdown h6 {
    position: relative; }

.docs__markdown h2 {
  font-size: 26px;
}

    .docs__markdown h2:hover .headerlink,
    .docs__markdown h3:hover .headerlink,
    .docs__markdown h4:hover .headerlink,
    .docs__markdown h5:hover .headerlink,
    .docs__markdown h6:hover .headerlink {
      opacity: 1; }
  .docs__markdown h1 a.headerlink {
    display: none; }
  .docs__markdown .info {
    border-radius: 10px;
    padding: 20px;
    width: 100%;
    margin: 25px 0;
    background: #f5f7fc; }
    @media (prefers-color-scheme: dark) {
      .docs__markdown .info {
        background: #21252b; } }

.docs__nav__lateral {
  position: static;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  width: 100%; }
  @media only screen and (min-width: 48em) {
    .docs__nav__lateral {
      margin-bottom: 6rem; } }
  @media only screen and (min-width: 48em) {
    .docs__nav__lateral {
      max-width: 60vw;
      left: calc(28vw + ((100% - 28vw) / 2) - (60vw / 2));
      position: relative; } }
  @media only screen and (min-width: 64em) {
    .docs__nav__lateral {
      max-width: 55vw;
      left: calc(380px + ((100% - 380px) / 2) - (55vw / 2));
      position: relative;
      padding: 0 4rem; } }
  .docs__nav__lateral .icon--barba {
    width: 15px;
    height: 15px;
    margin-left: 1rem;
    stroke: #348230;
    fill: #348230; }

.docs__nav__lateral__button {
  display: flex;
  width: 100%;
  margin: 2rem;
  color: #348230;
  font-family: "Space Mono", monospace;
  font-size: 1.3rem;
  font-weight: 700; }
  @media only screen and (min-width: 48em) {
    .docs__nav__lateral__button {
      display: none; } }
  @media only screen and (min-width: 48em) {
    .header__external-links__github {
      display: none; } }  
.docs__nav__lateral__label {
  margin: 1rem; }

.docs__nav__lateral__link,
[class*='docs__nav__lateral__link--'] {
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-width: 20%;
  margin: 2rem;
  padding: 1rem 2rem;
  color: #348230;
  font-family: "Space Mono", monospace;
  font-size: 1.3rem;
  font-weight: 700;
  background-color: transparent;
  border-radius: 5px;
  transition: 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition-property: color, background-color; }
  @media (prefers-color-scheme: dark) {
    .docs__nav__lateral__link,
    [class*='docs__nav__lateral__link--'] {
      color: #348230; } }
  @media only screen and (min-width: 37.5em) {
    .docs__nav__lateral__link:hover,
    [class*='docs__nav__lateral__link--']:hover {
      color: white;
      background: #348230; }
      .docs__nav__lateral__link:hover svg,
      [class*='docs__nav__lateral__link--']:hover svg {
        fill: white;
        stroke: white; } }
  @media only screen and (min-width: 64em) {
    .docs__nav__lateral__link,
    [class*='docs__nav__lateral__link--'] {
      margin: 0; } }

.docs__nav {
  position: fixed;
  z-index: 10;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow-y: auto;
  padding: 14rem 0;
  background: #f5f7fc;
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
  @media (prefers-color-scheme: dark) {
    .docs__nav {
      background: #21252b; } }
  @media only screen and (min-width: 48em) {
    .docs__nav {
      right: unset;
      width: 28vw; } }
  @media only screen and (min-width: 64em) {
    .docs__nav {
      width: 380px; } }
  @media only screen and (max-width: 47.99em) {
    .docs__nav {
      transform: translateX(-100%); }
      .docs__nav.is-open {
        transform: translateX(0); } }
  .docs__nav::before {
    content: '';
    position: fixed;
    z-index: 1;
    top: 0;
    left: 0;
    width: inherit;
    max-width: inherit;
    height: 14rem;
    background: inherit; }

.docs__nav__list {
  display: block;
  overflow: auto;
  padding: 0;
  list-style: none;
  padding-left: 3rem;
  padding-right: 3rem; }
  @media only screen and (min-width: 48em) {
    .docs__nav__list {
      padding-left: 5rem;
      padding-right: 3rem; } }
  @media only screen and (min-width: 64em) {
    .docs__nav__list {
      padding-right: 5rem; } }
  .docs__nav__list > li {
    border-bottom: 1px solid rgba(0, 0, 0, 0.1); }
    .docs__nav__list > li a {
      color: #404040; }
      @media (prefers-color-scheme: dark) {
        .docs__nav__list > li a {
          color: #7d889b; } }
    .docs__nav__list > li:last-child {
      border-bottom: none; }

.docs__nav__title {
  color: #316e30;
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 2rem;
  text-transform: uppercase;
  opacity: 0.3;
  transition: opacity 450ms ease; }
  @media only screen and (min-width: 64em) {
    .docs__nav__title {
      font-size: 1.5rem; } }
  .docs__nav__title.is-open {
    opacity: 0.7; }
  .docs__nav__title:hover:not(.is-open) {
    opacity: 0.5;
    transition-duration: 250ms; }

.docs__nav__sublist {
  overflow: hidden;
  height: 0;
  margin: 0;
  padding-left: 1rem;
  list-style: none; }
  @media only screen and (min-width: 37.5em) {
    .docs__nav__sublist {
      padding-left: 2rem; } }
  @media only screen and (min-width: 64em) {
    .docs__nav__sublist {
      padding-left: 3rem; } }
  .docs__nav__sublist li {
    position: relative; }
    .docs__nav__sublist li::before {
      content: '';
      position: absolute;
      top: 0.5em;
      left: -1em;
      width: 0;
      height: 0;
      border-width: 0.35em 0 0.35em 0.45em;
      border-style: solid;
      border-color: transparent #348230;
      opacity: 0;
      transition: opacity 450ms ease; }
      @media only screen and (min-width: 64em) {
        .docs__nav__sublist li::before {
          top: calc(50% - 0.35em); } }
    .docs__nav__sublist li.is-open::before {
      opacity: 1; }
  .docs__nav__sublist.is-open {
    height: auto;
    margin-bottom: 2rem; }

.docs__nav__subtitle {
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 2rem;
  transition: color 450ms ease; }
  @media only screen and (min-width: 64em) {
    .docs__nav__subtitle {
      font-size: 1.5rem; } }
  .docs__nav__subtitle.is-open {
    color: #348230; }
  .docs__nav__subtitle:hover:not(.is-open) {
    color: #348230;
    transition-duration: 250ms; }

.docs {
  width: 100%; }
  .docs a[title="Badge"] {
    display: inline-flex;
    margin-right: 4px; }
    @media (prefers-color-scheme: dark) {
      .docs a[title="Badge"] {
        opacity: 0.8;
        transition: opacity 250ms ease; }
        .docs a[title="Badge"]:hover {
          opacity: 1; } }
    .docs a[title="Badge"] img {
      border-radius: 4px; }
  .docs img[title="Badge"] {
    border-radius: 4px;
    margin-right: 4px; }
    @media (prefers-color-scheme: dark) {
      .docs img[title="Badge"] {
        opacity: 0.8; } }
  .docs .highlight {
    overflow: auto;
    margin: 2rem 0;
    background: #f5f7fc;
    border-radius: 4px;
    /* stylelint-disable selector-max-combinators, selector-max-compound-selectors, selector-max-class, no-descending-specificity */ }
    @media (prefers-color-scheme: dark) {
      .docs .highlight {
        background: #21252b; } }
    .docs .highlight .gutter {
      display: none; }
    .docs .highlight table {
      margin: 0;
      overflow: hidden; }
    .docs .highlight tbody {
      display: flex; }
    .docs .highlight th,
    .docs .highlight td,
    .docs .highlight tr {
      padding: 1rem;
      border: 0; }
    .docs .highlight pre {
      margin: 0;
      color: #333;
      font-family: "Source Code Pro", monaco, menlo, consolas, monospace;
      font-weight: 400;
      line-height: 1.6rem; }
      @media (prefers-color-scheme: dark) {
        .docs .highlight pre {
          color: #777d88; } }
      @media only screen and (min-width: 37.5em) {
        .docs .highlight pre {
          line-height: 2rem; } }
      @media only screen and (min-width: 64em) {
        .docs .highlight pre {
          line-height: 2.5rem; } }
      .docs .highlight pre .comment,
      .docs .highlight pre .title {
        color: #858585; }
        @media (prefers-color-scheme: dark) {
          .docs .highlight pre .comment,
          .docs .highlight pre .title {
            color: #434a59; } }
      .docs .highlight pre .variable,
      .docs .highlight pre .attribute,
      .docs .highlight pre .tag,
      .docs .highlight pre .regexp,
      .docs .highlight pre .ruby .constant,
      .docs .highlight pre .xml .tag .title,
      .docs .highlight pre .xml .pi,
      .docs .highlight pre .xml .doctype,
      .docs .highlight pre .html .doctype,
      .docs .highlight pre .css .id,
      .docs .highlight pre .css .class,
      .docs .highlight pre .css .pseudo {
        color: #ec4343; }
        @media (prefers-color-scheme: dark) {
          .docs .highlight pre .variable,
          .docs .highlight pre .attribute,
          .docs .highlight pre .tag,
          .docs .highlight pre .regexp,
          .docs .highlight pre .ruby .constant,
          .docs .highlight pre .xml .tag .title,
          .docs .highlight pre .xml .pi,
          .docs .highlight pre .xml .doctype,
          .docs .highlight pre .html .doctype,
          .docs .highlight pre .css .id,
          .docs .highlight pre .css .class,
          .docs .highlight pre .css .pseudo {
            color: #d19a66; } }
      .docs .highlight pre .number,
      .docs .highlight pre .rocessor,
      .docs .highlight pre .built_in,
      .docs .highlight pre .literal,
      .docs .highlight pre .params,
      .docs .highlight pre .constant {
        color: #ffa543; }
        @media (prefers-color-scheme: dark) {
          .docs .highlight pre .number,
          .docs .highlight pre .rocessor,
          .docs .highlight pre .built_in,
          .docs .highlight pre .literal,
          .docs .highlight pre .params,
          .docs .highlight pre .constant {
            color: #d19a66; } }
      .docs .highlight pre .class,
      .docs .highlight pre .css .rules .attribute {
        color: #718c00; }
        @media (prefers-color-scheme: dark) {
          .docs .highlight pre .class,
          .docs .highlight pre .css .rules .attribute {
            color: #98c379; } }
      .docs .highlight pre .string,
      .docs .highlight pre .value,
      .docs .highlight pre .inheritance,
      .docs .highlight pre .header,
      .docs .highlight pre .ruby .symbol,
      .docs .highlight pre .xml .cdata {
        color: #718c00; }
        @media (prefers-color-scheme: dark) {
          .docs .highlight pre .string,
          .docs .highlight pre .value,
          .docs .highlight pre .inheritance,
          .docs .highlight pre .header,
          .docs .highlight pre .ruby .symbol,
          .docs .highlight pre .xml .cdata {
            color: #98c379; } }
      .docs .highlight pre .css .hexcolor {
        color: #3e999f; }
      .docs .highlight pre .function,
      .docs .highlight pre .javascript .title {
        color: #4271ae; }
        @media (prefers-color-scheme: dark) {
          .docs .highlight pre .function,
          .docs .highlight pre .javascript .title {
            color: #61afef; } }
      .docs .highlight pre .keyword,
      .docs .highlight pre .javascript .function {
        color: #8c44d9; }
        @media (prefers-color-scheme: dark) {
          .docs .highlight pre .keyword,
          .docs .highlight pre .javascript .function {
            color: #c678dd; } }
    .docs .highlight figcaption {
      margin: -5px 0 5px;
      color: #858585;
      font-size: 1.2em;
      zoom: 1; }
    .docs .highlight figcaption::before,
    .docs .highlight figcaption::after {
      content: '';
      display: table;
      clear: both; }
    .docs .highlight figcaption a {
      float: right; }
  .docs .lifecycle-diagram {
    transition: opacity 250ms ease; }
    .docs .lifecycle-diagram::before {
      display: none; }
    .docs .lifecycle-diagram:hover {
      opacity: 0.8; }
    .docs .lifecycle-diagram.dark {
      display: none; }
    @media (prefers-color-scheme: dark) {
      .docs .lifecycle-diagram.light {
        display: none; }
      .docs .lifecycle-diagram.dark {
        display: flex; } }

.docs__page-transition {
  position: fixed;
  z-index: 10;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
  height: 100vh;
  background-color: #348230; }
  @media (prefers-color-scheme: dark) {
    .docs__page-transition {
      background-color: #21252b; } }
  @media only screen and (min-width: 48em) {
    .docs__page-transition {
      left: 28vw;
      width: calc(100vw - 28vw); } }
  @media only screen and (min-width: 64em) {
    .docs__page-transition {
      left: 380px;
      width: calc(100vw - 380px); } }

.example__card__title {
  color: black;
  font-family: "Space Mono", monospace;
  font-size: 1.8rem;
  font-weight: 300;
  line-height: 2rem;
  letter-spacing: 0.1rem; }
  @media (prefers-color-scheme: dark) {
    .example__card__title {
      color: #7d889b; } }

.example__card__picture {
  width: 100;
  height: 70%; }

.example__card__links {
  display: flex;
  justify-content: space-between;
  margin-top: 1rem; }
  .example__card__links .link--zip {
    margin-left: auto; }

.feature__action,
[class*='feature__action--'] {
  display: flex;
  align-items: center;
  padding: 1rem 1.4rem;
  border-radius: 5rem; }
  .feature__action svg,
  [class*='feature__action--'] svg {
    width: 15px;
    height: 15px;
    margin-left: 1rem;
    stroke: none;
    fill: white; }
  [data-feature-order='0'] .feature__action, [data-feature-order='0']
  [class*='feature__action--'] {
    background-color: rgba(212, 246, 254, 0.1); }
    [data-feature-order='0'] .feature__action svg, [data-feature-order='0']
    [class*='feature__action--'] svg {
      fill: #38d1f1;
      stroke: #38d1f1; }
  [data-feature-order='1'] .feature__action, [data-feature-order='1']
  [class*='feature__action--'] {
    background-color: rgba(228, 255, 204, 0.05); }
    [data-feature-order='1'] .feature__action svg, [data-feature-order='1']
    [class*='feature__action--'] svg {
      fill: #04bf0c;
      stroke: #04bf0c; }
  [data-feature-order='2'] .feature__action, [data-feature-order='2']
  [class*='feature__action--'] {
    background-color: rgba(254, 240, 213, 0.05); }
    [data-feature-order='2'] .feature__action svg, [data-feature-order='2']
    [class*='feature__action--'] svg {
      fill: #ffa543;
      stroke: #ffa543; }
  [data-feature-order='3'] .feature__action, [data-feature-order='3']
  [class*='feature__action--'] {
    background-color: rgba(252, 220, 221, 0.05); }
    [data-feature-order='3'] .feature__action svg, [data-feature-order='3']
    [class*='feature__action--'] svg {
      fill: #ec4343;
      stroke: #ec4343; }
  [data-feature-order='4'] .feature__action, [data-feature-order='4']
  [class*='feature__action--'] {
    background-color: rgba(248, 230, 255, 0.05); }
    [data-feature-order='4'] .feature__action svg, [data-feature-order='4']
    [class*='feature__action--'] svg {
      fill: #8c44d9;
      stroke: #8c44d9; }
  [data-feature-order='5'] .feature__action, [data-feature-order='5']
  [class*='feature__action--'] {
    background-color: rgba(143, 173, 255, 0.05); }
    [data-feature-order='5'] .feature__action svg, [data-feature-order='5']
    [class*='feature__action--'] svg {
      fill: #348230;
      stroke: #348230; }

.feature__action__title {
  margin: 0;
  font-family: "Space Mono", monospace;
  font-size: 3rem;
  font-weight: 900;
  text-transform: uppercase; }

.feature__nav {
  position: fixed;
  z-index: 10;
  top: 50%;
  left: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100vw;
  margin: 0;
  padding: 0 1rem;
  list-style: none;
  transform: translateY(-50%);
  pointer-events: none; }
  @media only screen and (min-width: 48em) {
    .feature__nav {
      padding: 0 5rem; } }
  .feature__nav li {
    pointer-events: all; }
  .feature__nav a {
    position: relative;
    display: flex;
    align-items: center;
    color: #0c0c0c;
    font-family: "Space Mono", monospace;
    font-size: 1.1rem;
    text-transform: uppercase;
    letter-spacing: 0.212rem; }
    @media (prefers-color-scheme: dark) {
      .feature__nav a {
        color: #7d889b; }
        [data-feature-order='0'] .feature__nav a {
          color: #38d1f1; }
        [data-feature-order='1'] .feature__nav a {
          color: #04bf0c; }
        [data-feature-order='2'] .feature__nav a {
          color: #ffa543; }
        [data-feature-order='3'] .feature__nav a {
          color: #ec4343; }
        [data-feature-order='4'] .feature__nav a {
          color: #8c44d9; } }
    .feature__nav a .icon--barba {
      width: 2.1rem;
      height: 1.5rem;
      fill: currentcolor;
      stroke: currentcolor; }
    .feature__nav a span {
      position: absolute;
      top: 50%;
      white-space: nowrap;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.3s, transform 0.3s ease-out; }

@media only screen and (min-width: 48em) {
  .feature__nav__el a:hover span {
    opacity: 1;
    pointer-events: initial;
    transform: translate3d(0, -50%, 0); } }

.feature__nav__el:first-child a .icon--barba {
  margin-right: 1rem; }

.feature__nav__el:first-child a span {
  left: 3.1rem;
  transform: translate(10%, -50%); }

.feature__nav__el:last-child a .icon--barba {
  margin-left: 1rem; }

.feature__nav__el:last-child a span {
  right: 3.1rem;
  transform: translate(-10%, -50%); }

/* stylelint-disable selector-max-combinators, selector-max-compound-selectors, max-nesting-depth, no-descending-specificity */
.feature {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  margin-top: 20rem !important;
  margin-bottom: 10rem !important;
  padding: 0 2rem;
  perspective: 1000px; }
  @media only screen and (min-width: 48em) {
    .feature {
      margin-top: 0 !important;
      margin-bottom: 0 !important;
      padding: 4rem; } }
  @media only screen and (min-width: 64em) {
    .is-transitioning .feature {
      overflow: hidden; } }

.big-shape-outer {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
  right: 0;
  left: 0;
  opacity: 0.8; }
  @media (prefers-color-scheme: dark) {
    .big-shape-outer {
      opacity: 0.9; } }
  .big-shape-outer svg {
    display: block;
    max-width: 56.8rem;
    margin: 0 auto; }
    .big-shape-outer svg .base,
    .big-shape-outer svg .links {
      display: none; }
  .big-shape-outer * {
    pointer-events: none; }

[data-feature-order='0'] .colored {
  color: #38d1f1; }

[data-feature-order='1'] .colored {
  color: #04bf0c; }

[data-feature-order='2'] .colored {
  color: #ffa543; }

[data-feature-order='3'] .colored {
  color: #ec4343; }

[data-feature-order='4'] .colored {
  color: #8c44d9; }

[data-feature-order='5'] .colored {
  color: #348230; }

.feature-outer {
  position: relative;
  display: flex;
  flex-direction: column;
  max-width: 80rem;
  height: 100%;
  margin: 0 auto; }
  @media only screen and (min-width: 48em) {
    .feature-outer {
      padding-top: 6rem; } }
  .feature-outer p {
    font-size: 1.4rem;
    line-height: 1.8rem; }
    @media only screen and (min-width: 48em) {
      .feature-outer p {
        font-size: 2.4rem;
        line-height: 3.6rem; } }
    .feature-outer p a {
      position: relative;
      color: #348230; }
      [data-feature-order='0'] .feature-outer p a {
        color: #38d1f1; }
      [data-feature-order='1'] .feature-outer p a {
        color: #04bf0c; }
      [data-feature-order='2'] .feature-outer p a {
        color: #ffa543; }
      [data-feature-order='3'] .feature-outer p a {
        color: #ec4343; }
      [data-feature-order='4'] .feature-outer p a {
        color: #8c44d9; }
      [data-feature-order='5'] .feature-outer p a {
        color: #348230; }
      .feature-outer p a::before {
        content: '';
        position: absolute;
        bottom: -0.15em;
        left: 0;
        display: block;
        width: 100%;
        height: 0.2rem;
        background-color: #348230;
        transform-origin: center left;
        transition: transform 0.3s ease-out; }
        [data-feature-order='0'] .feature-outer p a::before {
          background-color: #38d1f1; }
        [data-feature-order='1'] .feature-outer p a::before {
          background-color: #04bf0c; }
        [data-feature-order='2'] .feature-outer p a::before {
          background-color: #ffa543; }
        [data-feature-order='3'] .feature-outer p a::before {
          background-color: #ec4343; }
        [data-feature-order='4'] .feature-outer p a::before {
          background-color: #8c44d9; }
        [data-feature-order='5'] .feature-outer p a::before {
          background-color: #348230; }
      .feature-outer p a:hover::before {
        transform-origin: center right;
        transform: scaleX(0); }
  .feature-outer .feature__action__title {
    font-size: 1.6rem;
    line-height: 2.2rem; }

.feature__title {
  margin: 0;
  font-family: "Space Mono", monospace;
  font-size: 3.2rem;
  font-weight: 400;
  text-align: center; }
  @media only screen and (min-width: 48em) {
    .feature__title {
      top: -5rem;
      font-size: 5rem; } }
  @media only screen and (min-width: 100em) {
    .feature__title {
      font-size: 7rem; } }

.feature__bodymovin {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
  width: 100vw; }
  @media only screen and (max-width: 47.99em) {
    .feature__bodymovin {
      display: none; } }
  @media (prefers-color-scheme: dark) {
    .feature__bodymovin path[fill='rgb(255,255,255)'] {
      fill: #0b0c0e; } }

.feature .logo.featured {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  top: -10rem;
  width: 23.5rem; }
  @media only screen and (min-width: 48em) {
    .feature .logo.featured {
      top: 4rem; } }
  .feature .logo.featured .base {
    position: relative;
    z-index: 50; }
  .feature .logo.featured .big {
    display: block; }

.credits-table tr {
  display: inline; }

.credits-table td,
.credits-table th {
  position: relative;
  float: left;
  width: 31%;
  margin: 2rem 0.5%;
  padding: 0; }
  @media only screen and (min-width: 48em) {
    .credits-table td,
    .credits-table th {
      width: 23%; } }

.credits-table td > sup {
  display: none; }

.credits-table a {
  color: #348230; }
  @media (prefers-color-scheme: dark) {
    .credits-table a {
      color: #7d889b; } }
  .credits-table a img {
    width: 85%;
    border-radius: 100%; }

/* stylelint-disable selector-max-combinators, selector-max-compound-selectors, max-nesting-depth, no-descending-specificity */
.feature-box {
  position: absolute;
  z-index: 99;
  top: 0;
  left: 50%;
  width: 100%;
  max-width: 85vw;
  margin-top: 10rem;
  background: rgba(255, 255, 255, 0.7);
  border-radius: 10px;
  box-shadow: 0 1.4rem 3rem rgba(160, 160, 160, 0.3);
  transform: translateX(-50%);
  backdrop-filter: blur(4px); }
  @media (prefers-color-scheme: dark) {
    .feature-box {
      background: rgba(33, 37, 43, 0.7);
      box-shadow: 0 1.4rem 3rem rgba(33, 37, 43, 0.3);
      color: rgba(255, 255, 255, 0.8); } }
  @media only screen and (min-width: 48em) {
    .feature-box {
      top: initial;
      bottom: 5rem;
      width: 80rem;
      margin-top: 0; } }
  @media only screen and (min-width: 100em) {
    .feature-box {
      bottom: 8rem; } }

.feature-box__body {
  display: grid;
  grid-template-columns: 1fr;
  padding: 3rem; }
  @media only screen and (min-width: 64em) {
    .feature-box__body {
      grid-template-columns: repeat(6, 1fr);
      grid-gap: 3rem;
      padding: 4rem; } }

@media only screen and (max-width: 63.99em) {
  .feature-box__column + .feature-box__column,
  [class*='feature-box__column--'] + .feature-box__column, .feature-box__column +
  [class*='feature-box__column--'],
  [class*='feature-box__column--'] +
  [class*='feature-box__column--'] {
    margin-top: 2rem; } }

.feature-box__column[class*='two'],
[class*='feature-box__column--'][class*='two'] {
  grid-column: span 2; }
  @media only screen and (max-width: 63.99em) {
    .feature-box__column[class*='two'],
    [class*='feature-box__column--'][class*='two'] {
      display: flex;
      flex-wrap: wrap;
      grid-column: span 4; } }

.feature-box__column[class*='three'],
[class*='feature-box__column--'][class*='three'] {
  grid-column: span 3; }

.feature-box__column[class*='four'],
[class*='feature-box__column--'][class*='four'] {
  grid-column: span 4; }

.feature-box__column__icon,
[class*='feature-box__column__icon--'] {
  display: block;
  width: 3rem;
  height: 3rem;
  margin: 0 1rem 1rem 0; }
  @media only screen and (min-width: 64em) {
    .feature-box__column__icon,
    [class*='feature-box__column__icon--'] {
      width: 4rem;
      height: 4rem; } }
  .feature-box__column__icon[class*='big'],
  [class*='feature-box__column__icon--'][class*='big'] {
    width: 18rem;
    height: 13rem;
    margin: 0 auto; }
    @media only screen and (min-width: 64em) {
      .feature-box__column__icon[class*='big'],
      [class*='feature-box__column__icon--'][class*='big'] {
        display: block;
        width: 18rem;
        height: 13rem; } }
  .feature-box__column__icon .partial-image,
  [class*='feature-box__column__icon--'] .partial-image {
    object-fit: contain; }

.feature-box__body__title {
  margin: 0;
  font-family: "Space Mono", monospace;
  font-size: 2rem;
  font-weight: 900;
  text-transform: uppercase; }

.feature-box__body__text {
  margin: 1rem 0;
  font-size: 1.4rem !important;
  line-height: 1.5 !important; }
  @media only screen and (min-width: 64em) {
    .feature-box__body__text {
      margin: 0;
      font-size: 1.6rem !important; } }

.feature-box__footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem;
  border-top: 1px solid rgba(0, 0, 0, 0.05); }

[data-barba='container'] {
  position: relative;
  min-height: 100vh; }
  .is-transitioning [data-barba='container'] {
    position: absolute;
    width: 100%;
    overflow: hidden; }

.homepage {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  align-items: center;
  padding: 4rem;
  text-align: center; }
  .homepage .logo {
    max-width: 57rem;
    margin: 0 auto; }

.homepage__logo-outer {
  position: relative;
  width: 100%; }
  @media only screen and (max-width: 47.99em) {
    .homepage__logo-outer .logo.only-big {
      padding: 2rem 0; } }

.homepage__logo {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0; }
  @media only screen and (max-width: 47.99em) {
    .homepage__logo {
      padding: 2rem 0; } }
  .to-feature .homepage__logo {
    z-index: -1; }

.homepage .logo.only-big {
  position: relative;
  z-index: 2;
  pointer-events: none; }
  .homepage .logo.only-big .base,
  .homepage .logo.only-big .links {
    display: none; }
  .to-feature .homepage .logo.only-big {
    position: static; }

.homepage__title {
  max-width: 65rem;
  margin: 0;
  margin-bottom: 2rem;
  font-family: "Space Mono", monospace;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1.2; }
  @media only screen and (min-width: 37.5em) {
    .homepage__title {
      width: 80%;
      font-size: 2.5rem; } }
  .homepage__title .line {
    overflow: hidden; }
  .homepage__title span {
    display: inline-block; }

.homepage__list {
  position: relative;
  z-index: -1;
  width: 100%;
  margin: 3rem 0;
  padding: 0; }
  .homepage__list div {
    position: absolute;
    top: 100%;
    right: 0;
    left: 0; }

.homepage__list__item,
[class*='homepage__list__item--'] {
  display: block;
  width: 100%;
  font-family: "Space Mono", monospace;
  font-size: 2.2rem;
  font-weight: 400;
  text-align: center;
  opacity: 0;
  transform: scale(0.9); }
  @media only screen and (min-width: 37.5em) {
    .homepage__list__item,
    [class*='homepage__list__item--'] {
      font-size: 3rem; } }
  @media only screen and (min-width: 48em) {
    .homepage__list__item,
    [class*='homepage__list__item--'] {
      font-size: 4rem; } }
  .homepage__list__item[class*='--0'],
  [class*='homepage__list__item--'][class*='--0'] {
    color: #38d1f1; }
  .homepage__list__item[class*='--1'],
  [class*='homepage__list__item--'][class*='--1'] {
    color: #04bf0c; }
  .homepage__list__item[class*='--2'],
  [class*='homepage__list__item--'][class*='--2'] {
    color: #ffa543; }
  .homepage__list__item[class*='--3'],
  [class*='homepage__list__item--'][class*='--3'] {
    color: #ec4343; }
  .homepage__list__item[class*='--4'],
  [class*='homepage__list__item--'][class*='--4'] {
    color: #8c44d9; }
  .homepage__list__item[class*='--5'],
  [class*='homepage__list__item--'][class*='--5'] {
    color: #348230; }
  .homepage__list__item:first-child,
  [class*='homepage__list__item--']:first-child {
    position: relative; }

.homepage__buttons {
  display: flex;
  flex-direction: column; }
  @media only screen and (min-width: 48em) {
    .homepage__buttons {
      flex-direction: row; }
      .homepage__buttons .button + .button {
        margin-left: 2rem; } }
  .homepage__buttons .button {
    margin-top: 1rem;
    border-radius: 10rem; }

.page {
  width: 100%;
  max-width: 1440px;
  height: 100%;
  margin: 0 auto;
  padding: 16rem 4rem 6rem; }
  @media only screen and (min-width: 48em) {
    .page {
      padding: 16rem 11.19% 0; } }
  .page .icon--barba {
    stroke-width: 0; }

[data-barba-namespace*='page--'][data-barba-namespace*='--black']::before {
  content: '';
  position: fixed;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: #0c0c0c; }

.page-wrapper {
  width: 100%;
  height: 100%; }

@media only screen and (min-width: 64em) {
  .page-inner {
    padding: 0 10rem; } }

.page__header {
  max-width: 60rem; }
  .page__header h1 {
    margin: 0;
    color: #348230;
    font-family: "Space Mono", monospace;
    font-size: 2.8rem;
    font-weight: 400;
    line-height: 3.2rem; }
    @media only screen and (min-width: 48em) {
      .page__header h1 {
        font-size: 3.6rem;
        line-height: 4.2rem; } }
    @media only screen and (min-width: 64em) {
      .page__header h1 {
        font-size: 6.5rem;
        line-height: 6.5rem; } }
    [data-barba-namespace*='--black'] .page__header h1 {
      color: white; }
  .page__header p {
    margin: 2rem 0;
    font-size: 1.6rem;
    line-height: 2.4rem; }
    [data-barba-namespace*='--black'] .page__header p {
      color: white; }
    .page__header p a {
      position: relative;
      color: #348230;
      white-space: nowrap; }
      .page__header p a::before {
        content: '';
        position: absolute;
        bottom: -2px;
        left: 0;
        width: 100%;
        height: 1px;
        background: currentColor;
        opacity: 0.2;
        transition: opacity 350ms ease;
        pointer-events: none; }
      .page__header p a:hover::before {
        opacity: 1; }
  .page__header ul a {
    color: #348230; }
  @media only screen and (min-width: 48em) {
    .page__header h1 + p {
      font-size: 2.4rem;
      line-height: 3.2rem; } }
  @media only screen and (min-width: 64em) {
    .page__header h1 + p {
      margin-top: 5.4rem;
      font-size: 3.5rem;
      line-height: 4.8rem; } }
  .page__header blockquote {
    margin: 5rem 0; }

.page__separator {
  width: 5rem;
  height: 0.2rem;
  margin: 5rem 0;
  background: #348230; }

.form {
  display: none; }
  @media only screen and (min-width: 48em) {
    .form {
      display: block; } }

.form__title {
  margin: 3rem;
  color: white;
  font-family: "Space Mono", monospace;
  font-size: 4rem;
  font-weight: 300;
  text-align: center;
  text-transform: capitalize; }

.form__wrapper {
  visibility: visible; }
  .form__wrapper.is-hidden {
    visibility: hidden; }

.drop-area {
  margin: 1.5rem 3rem;
  background: #2448b0;
  border: 1rem solid #1c398c;
  user-select: none; }
  .drop-area.highlight {
    border: 1rem solid white; }

.form__picture {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 4rem;
  color: #112356;
  font-family: "Space Mono", monospace;
  border-radius: 7px; }
  .form__picture .icon--barba {
    width: 6rem;
    height: 6rem;
    stroke: #112356; }
    .highlight .form__picture .icon--barba {
      stroke: white; }

.form__picture__size {
  margin: 0;
  font-size: 4rem;
  line-height: 4rem; }

.form__picture__infos,
[class*='form__picture__infos--'] {
  margin: 1rem 0;
  font-size: 1.4rem; }
  .form__picture__infos[class*='--white'],
  [class*='form__picture__infos--'][class*='--white'] {
    color: white; }

.form__picture__input {
  display: none; }

.form__section {
  display: flex;
  flex-direction: column;
  margin: 1.5rem 3rem;
  background: #1c398c;
  border-radius: 7px; }
  @media only screen and (min-width: 48em) {
    .form__section {
      flex-direction: row; } }

.form__field {
  display: flex;
  flex-direction: column;
  padding: 1.5rem; }

.form__label {
  margin: 0;
  color: white;
  font-size: 1.2rem;
  text-transform: uppercase; }

.form__input--text {
  padding: 1rem;
  color: white;
  font-family: "Space Mono", monospace;
  background: #2448b0;
  border: 0;
  border-radius: 3px; }
  @media only screen and (min-width: 48em) {
    .form__input--text {
      width: 22rem; } }
  .form__input--text::placeholder {
    color: black; }
  .form__input--text:focus {
    outline: 1px solid white; }
    .form__input--text:focus::placeholder {
      color: white; }

.form__submit {
  margin: 1.5rem 3rem 3rem; }

.form__input--submit {
  width: 100%;
  padding: 1.5rem;
  color: #348230;
  font-family: "Space Mono", monospace;
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.2rem;
  background: white;
  border: 0;
  border-radius: 7px; }
  .is-invalid .form__input--submit {
    opacity: 0.5; }

.modal,
[class*='modal--'] {
  position: fixed;
  z-index: 999;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: none;
  justify-content: center;
  align-items: center;
  overflow: auto; }
  .modal.is-open,
  [class*='modal--'].is-open {
    display: flex; }

.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(245, 247, 252, 0.9);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease-in-out; }
  @media (prefers-color-scheme: dark) {
    .modal__overlay {
      background-color: #21252b; } }
  .is-open .modal__overlay {
    opacity: 1;
    pointer-events: initial; }

.modal__box__close {
  position: absolute;
  bottom: -7rem;
  display: flex;
  justify-content: center;
  width: 100%; }
  @media only screen and (min-width: 48em) {
    .modal__box__close {
      top: 0;
      right: -8rem;
      justify-content: flex-end;
      width: max-content;
      height: max-content; } }

.modal__box {
  position: relative;
  z-index: 1000;
  display: none;
  flex-direction: column;
  align-items: center;
  width: max-content;
  min-width: 30rem;
  height: max-content;
  min-height: 30rem;
  margin: auto;
  background: #348230;
  box-shadow: 0 1px 20px rgba(28, 57, 140, 0.4);
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
  border-radius: 7px; }
  .is-open .modal__box {
    display: flex;
    opacity: 1; }

.showcase-cta {
  display: none; }
  @media only screen and (min-width: 48em) {
    .showcase-cta {
      display: flex; } }

.showcase-cta__button-inner {
  position: relative;
  margin-right: 2rem; }
  .showcase-cta__button-inner::before, .showcase-cta__button-inner::after {
    content: '';
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    display: block;
    width: 4rem;
    height: 4rem;
    background-color: #348230;
    border-radius: 4rem;
    opacity: 0.4; }
  .showcase-cta__button-inner::before {
    animation: pulse 1.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) infinite both; }
  .showcase-cta__button-inner::after {
    animation: pulse 1.3s 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) infinite both; }

.showcase-cta__button__pulse {
  position: relative;
  width: 4rem;
  height: 4rem;
  background-color: #348230;
  border-radius: 4rem;
  cursor: pointer;
  transition: 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition-property: transform, background-color; }
  .showcase-cta__button__pulse::before, .showcase-cta__button__pulse::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 2px;
    height: 30%;
    background-color: white; }
  .showcase-cta__button__pulse::after {
    width: 30%;
    height: 2px; }

.showcase-cta__button:hover .showcase-cta__button__pulse {
  background-color: #1f46b8; }

@keyframes pulse {
  0% {
    opacity: 0.5;
    transform: scale(1); }
  100% {
    opacity: 0;
    transform: scale(1.75); } }

.form__feedback,
[class*='form__feedback--'] {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  justify-content: center;
  align-items: center;
  font-family: "Space Mono", monospace;
  font-size: 4rem;
  text-align: center;
  transition: opacity 0.4s ease-in-out; }

.form__feedback--succeed {
  display: none;
  color: #04bf0c;
  opacity: 0; }
  .form__feedback--succeed.is-active {
    display: flex;
    opacity: 1; }

.form__feedback--failed {
  display: none;
  color: #d90b0b;
  opacity: 0; }
  .form__feedback--failed.is-active {
    display: flex;
    opacity: 1; }

.showcase__card__picture {
  width: 100%;
  height: 80%; }

.showcase__card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1rem; }
  .showcase__card__footer :first-child {
    display: flex;
    flex-direction: column;
    margin-right: 1em; }

.showcase__card__footer__title {
  margin: 0;
  color: #348230;
  font-size: 1.8rem;
  font-weight: 300;
  line-height: 2.2rem;
  letter-spacing: 0.25rem; }
  @media (prefers-color-scheme: dark) {
    .showcase__card__footer__title {
      color: #7d889b; } }

.showcase__card__footer__author {
  margin: 0;
  font-family: "Space Mono", monospace;
  font-size: 1.1rem;
  line-height: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.2rem;
  opacity: 0.3; }
  @media (prefers-color-scheme: dark) {
    .showcase__card__footer__author {
      color: #7d889b; } }

.link--view {
  text-transform: uppercase; }

.loader--spinner {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: none;
  justify-content: center;
  align-items: center;
  opacity: 0;
  transition: opacity 0.4s ease-in-out; }
  .loader--spinner.is-active {
    display: flex;
    opacity: 1; }

@keyframes spinner-line-fade-more {
  0%,
  100% {
    opacity: 0;
    /* minimum opacity */ }
  1% {
    opacity: 1; } }

@keyframes spinner-line-fade-quick {
  0%,
  39%,
  100% {
    opacity: 0;
    /* minimum opacity */ }
  40% {
    opacity: 1; } }

@keyframes spinner-line-fade-default {
  0%,
  100% {
    opacity: 0;
    /* minimum opacity */ }
  1% {
    opacity: 1; } }

.transition {
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100vw;
  height: 100vh;
  pointer-events: none; }
  .transition .transition__background {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #348230;
    transform: translateX(-100%); }
    [data-feature-order='0'] ~ .transition .transition__background {
      background-color: #38d1f1; }
    [data-feature-order='1'] ~ .transition .transition__background {
      background-color: #04bf0c; }
    [data-feature-order='2'] ~ .transition .transition__background {
      background-color: #ffa543; }
    [data-feature-order='3'] ~ .transition .transition__background {
      background-color: #ec4343; }
    [data-feature-order='4'] ~ .transition .transition__background {
      background-color: #8c44d9; }
    @media (prefers-color-scheme: dark) {
      .transition .transition__background {
        background: #21252b !important; } }

.transition__title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 500px;
  margin: 0 auto;
  color: white;
  font-family: "Space Mono", monospace;
  font-size: 2.4rem !important;
  font-weight: 400;
  text-transform: capitalize;
  letter-spacing: 0.5px !important;
  opacity: 0;
  will-change: opacity, transform; }
  @media only screen and (min-width: 48em) {
    .transition__title {
      font-size: 3.6rem !important; } }
  @media only screen and (min-width: 80em) {
    .transition__title {
      font-size: 4.8rem !important; } }

/*
 * Dev related stuff or crappy hotfixes…
 */
