@keyframes heart {
  0%,40%,80%,100% {
    transform: scale(1);
  }
  20%,60% {
    transform: scale(1.15);
  }
}
.md-typeset h2 {
  font-weight: 700;
  margin-top: 0.175em;
}
.md-typeset .twitter {
  color: #00acee;
}
.md-typeset .mastodon {
  color: #897ff8;
}
.md-typeset .mdx-video {
  width: auto;
}
.md-typeset .mdx-video__inner {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.138%;
}
.md-typeset .mdx-video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border: none;
}
.md-typeset .mdx-heart {
  animation: heart 1000ms infinite;
}
.md-typeset .mdx-insiders {
  color: #e91e63;
}
.md-typeset .mdx-badge {
  font-size: 0.85em;
}
.md-typeset .mdx-badge--heart {
  --md-typeset-a-color: hsla(340, 82%, 52%, 1);
  --md-accent-fg-color: hsla(340, 100%, 63%, 1);
  --md-accent-fg-color--transparent: hsla(340, 82%, 52%, 0.1);
}
.md-typeset .mdx-badge--heart .twemoji {
  animation: heart 1000ms infinite;
}
.md-typeset .mdx-badge--right {
  float: right;
  margin-left: 0.35em;
}
[dir="ltr"] .md-typeset .mdx-badge__icon {
  border-top-left-radius: 0.1rem;
}
[dir="rtl"] .md-typeset .mdx-badge__icon {
  border-top-right-radius: 0.1rem;
}
[dir="ltr"] .md-typeset .mdx-badge__icon {
  border-bottom-left-radius: 0.1rem;
}
[dir="rtl"] .md-typeset .mdx-badge__icon {
  border-bottom-right-radius: 0.1rem;
}
.md-typeset .mdx-badge__icon {
  padding: 0.2rem;
  background: var(--md-accent-fg-color--transparent);
}
.md-typeset .mdx-badge__icon:last-child {
  border-radius: 0.1rem;
}
[dir="ltr"] .md-typeset .mdx-badge__text {
  border-top-right-radius: 0.1rem;
}
[dir="rtl"] .md-typeset .mdx-badge__text {
  border-top-left-radius: 0.1rem;
}
[dir="ltr"] .md-typeset .mdx-badge__text {
  border-bottom-right-radius: 0.1rem;
}
[dir="rtl"] .md-typeset .mdx-badge__text {
  border-bottom-left-radius: 0.1rem;
}
.md-typeset .mdx-badge__text {
  padding: 0.2rem 0.3rem;
  box-shadow: 0 0 0 1px inset var(--md-accent-fg-color--transparent);
}
.md-typeset .mdx-switch button {
  cursor: pointer;
  transition: opacity 250ms;
}
.md-typeset .mdx-switch button:focus,.md-typeset .mdx-switch button:hover {
  opacity: 0.75;
}
.md-typeset .mdx-switch button>code {
  display: block;
  color: var(--md-primary-bg-color);
  background-color: var(--md-primary-fg-color);
}
.md-typeset .mdx-columns ol,.md-typeset .mdx-columns ul {
  -moz-columns: 2;
       columns: 2;
}
@media screen and (max-width: 29.984375em) {
  .md-typeset .mdx-columns ol,.md-typeset .mdx-columns ul {
    -moz-columns: initial;
         columns: initial;
  }
}
.md-typeset .mdx-columns li {
  -moz-column-break-inside: avoid;
       break-inside: avoid;
}
.md-typeset .mdx-flags {
  margin: 2em auto;
}
.md-typeset .mdx-flags ol {
  list-style: none;
}
.md-typeset .mdx-flags ol li {
  margin-bottom: 1em;
}
.md-typeset .mdx-flags__item {
  display: flex;
  gap: 0.6rem;
}
.md-typeset .mdx-flags__content {
  display: flex;
  flex: 1;
  flex-direction: column;
}
.md-typeset .mdx-flags__content span {
  display: inline-flex;
  align-items: baseline;
  justify-content: space-between;
}
.md-typeset .mdx-flags__content>span:nth-child(2) {
  font-size: 80%;
}
.md-typeset .mdx-flags__content code {
  float: right;
}
.md-typeset .mdx-social {
  position: relative;
  height: min(27rem, 80vw);
}
.md-typeset .mdx-social:hover .mdx-social__image {
  background-color: rgba(228, 228, 228, 0.05);
}
.md-typeset .mdx-social__layer {
  position: absolute;
  margin-top: 4rem;
  transition: 250ms cubic-bezier(0.7, 0, 0.3, 1);
  transform-style: preserve-3d;
}
.md-typeset .mdx-social__layer:hover .mdx-social__label {
  opacity: 1;
}
.md-typeset .mdx-social__layer:hover .mdx-social__image {
  background-color: rgba(127, 127, 127, 0.99);
}
.md-typeset .mdx-social__layer:hover~.mdx-social__layer {
  opacity: 0;
}
.md-typeset .mdx-social__image {
  box-shadow: -0.25rem 0.25rem 0.5rem rgba(0, 0, 0, 0.05);
  transition: all 250ms;
  transform: rotate(-40deg) skew(15deg, 15deg) scale(0.7);
}
.md-typeset .mdx-social__image img {
  display: block;
}
.md-typeset .mdx-social__label {
  position: absolute;
  display: block;
  padding: 0.2rem 0.4rem;
  color: var(--md-default-bg-color);
  background-color: var(--md-default-fg-color--light);
  opacity: 0;
  transition: all 250ms;
}
.md-typeset .mdx-social:hover .mdx-social__layer:nth-child(6) {
  transform: translateY(-30px);
}
.md-typeset .mdx-social:hover .mdx-social__layer:nth-child(5) {
  transform: translateY(-20px);
}
.md-typeset .mdx-social:hover .mdx-social__layer:nth-child(4) {
  transform: translateY(-10px);
}
.md-typeset .mdx-social:hover .mdx-social__layer:nth-child(3) {
  transform: translateY(0px);
}
.md-typeset .mdx-social:hover .mdx-social__layer:nth-child(2) {
  transform: translateY(10px);
}
.md-typeset .mdx-social:hover .mdx-social__layer:nth-child(1) {
  transform: translateY(20px);
}
.md-typeset .mdx-social:hover .mdx-social__layer:nth-child(0) {
  transform: translateY(30px);
}

.md-banner {
  color: var(--md-footer-fg-color--lighter);
}
.md-banner strong {
  color: var(--md-footer-fg-color);
  white-space: nowrap;
}
.md-banner a {
  color: var(--md-footer-fg-color);
}
.md-banner a:focus,.md-banner a:hover {
  color: currentcolor;
}
.md-banner a:focus .twemoji,.md-banner a:hover .twemoji {
  background-color: var(--md-footer-fg-color);
  box-shadow: none;
}
.md-banner .twemoji {
  display: inline-block;
  width: 1.2rem;
  height: 1.2rem;
  padding: 0.25rem;
  vertical-align: bottom;
  border-radius: 100%;
  box-shadow: 0 0 0 0.05rem currentcolor inset;
  transition: all 250ms;
}
.md-banner .twemoji svg {
  display: block;
  max-height: initial;
}

.mdx-container {
  padding-top: 1rem;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1123 258'><path d='M1124,2c0,0 0,256 0,256l-1125,0l0,-48c0,0 16,5 55,5c116,0 197,-92 325,-92c121,0 114,46 254,46c140,0 214,-167 572,-166Z' style='fill: hsla(230, 15%, 14%, 1)' /></svg>") no-repeat bottom, linear-gradient(to bottom, var(--md-primary-fg-color), var(--md-primary-fg-color--dark) 99%);
}
[data-md-color-scheme=slate] .mdx-container {
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1123 258'><path d='M1124,2c0,0 0,256 0,256l-1125,0l0,-48c0,0 16,5 55,5c116,0 197,-92 325,-92c121,0 114,46 254,46c140,0 214,-167 572,-166Z' style='fill: hsla(230, 15%, 14%, 1)' /></svg>") no-repeat bottom, linear-gradient(to bottom, var(--md-primary-fg-color), hsl(230, 15%, 25%) 99%, var(--md-default-bg-color) 99%);
}

.mdx-hero {
  margin: 0 0.8rem;
  color: var(--md-primary-bg-color);
}
.mdx-hero h1 {
  margin-bottom: 1rem;
  font-weight: 700;
  color: currentcolor;
}
@media screen and (max-width: 29.984375em) {
  .mdx-hero h1 {
    font-size: 1.4rem;
  }
}
.mdx-hero a .youtube-play {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEUAAABFBAMAAADuozYaAAAAMFBMVEUzerczerczerczerczerczerczerczerczerczerczerczerczerczerczerczerewtGpRAAAAEHRSTlMADBgkMDxIVF9rd4OPm6ez+/4a3QAAAphJREFUeF6NlTtvE0EQx9dnOwmCKK5AoiBXUSHkTwCHZIUyLulwgUSJjSJFIgpJEFJKEijo4nQUCGERuisMEr0LhASViXikJDxtfI/Btzu7sw+f8L+53bnf7czOzO4xQ8WbT8Mw3L7CcuXdAdT7eg5yugdK6aOJyJlvoOslczUrENKBg5R6YKtlMw/AUVI1kQswQQMzLxiMpR2duQQT9VcPWFk/rNRqS2tq2nGXiW+LeXnPWcjDaEaBtBTWEdqUllO4ir7XDWH7beWmadRX5DT1jYjfMkMnjKjnhacKM3WLm//orl+PR2v3NGZGOOOfFviukvF4DtKWHjZFOcuHn8ajxTFatyM6zIbn+LAxHi0DQOQrptDHwuKSEUMGhhi7nKfZiNM/lA2+kjPpoUhdsGw1qcen+9lmMvkaA7sSamezYyzWiOlMKqtyGUu2KLNJDMSBVoEhvjg2GRj5TKUuwq13LAaOtGpjXE2bgXfcgvvpZo+6w8CLzMKbKBCPKjL2MX0uFkCXLpP4GGwzn4GdKZjOFMzm/5m4Ihmx98Bl0gZj+DI3P1uUn7w8H1CeK8LlK2SsUpS5U3zx3WIGoqnnsO4LTv/Q4ZjHg3ESWY1JAv1g/JJHMCBGtSpu/SNjnnMuHkqEXvX4gsS8QQLDgLq8Q2LFHDGl6zw4Ou9NZPAo04UywOZHZwsAUZVZrg4JT6sZnTQYqQ1Upg11AV1tORdiUsGrFxcy1dYv3yJwfTGRs8K6b97XWzpS6pMr2oARsCc8wU+ViB5BJgL02UW0pPfF/HwXDcNJv8Fo+0Zt9Rkdw+n/gxSRq4adDVefmam7LhJVLMbrWgS1LKnct5hd5mqGIOpqW6U9IuIWy9E1TEH6xGf5WloNw8crFvEPBcXB14/oPOoAAAAASUVORK5CYII=);
  background-repeat: no-repeat;
  background-position: center center;
}
.mdx-hero a:hover .youtube-play {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEUAAABFBAMAAADuozYaAAAAMFBMVEUzerczerczerczerczerczerczerczerczerczerczerczerczerczerczerczerewtGpRAAAAD3RSTlMAESIzRFVmd4iZqrvM3e5GKvWZAAACmElEQVR4Xo2VO28TQRDH12c7CYIorkCiIFdRIeRPAIdkhTIu6XCBRImNIkUiCkkQUkoSKOjidBQIYRG6KwwSvQuEBJWJeKQkPG18j8G3O7uzD5/wv7ndud/tzM7M7jFDxZtPwzDcvsJy5d0B1Pt6DnK6B0rpo4nImW+g6yVzNSsQ0oGDlHpgq2UzD8BRUjWRCzBBAzMvGIylHZ25BBP1Vw9YWT+s1GpLa2racZeJb4t5ec9ZyMNoRoG0FNYR2pSWU7iKvtcNYftt5aZp1FfkNPWNiN8yQyeMqOeFpwozdYub/+iuX49Ha/c0ZkY4458W+K6S8XgO0pYeNkU5y4efxqPFMVq3IzrMhuf4sDEeLQNA5Cum0MfC4pIRQwaGGLucp9mI0z+UDb6SM+mhSF2wbDWpx6f72WYy+RoDuxJqZ7NjLNaI6Uwqq3IZS7Yos0kMxIFWgSG+ODYZGPlMpS7CrXcsBo60amNcTZuBd9yC++lmj7rDwIvMwpsoEI8qMvYxfS4WQJcuk/gYbDOfgZ0pmM4UzOb/mbgiGbH3wGXSBmP4Mjc/W5SfvDwfUJ4rwuUrZKxSlLlTfPHdYgaiqeew7gtO/9DhmMeDcRJZjUkC/WD8kkcwIEa1Km79I2Oecy4eSoRe9fiCxLxBAsOAurxDYsUcMaXrPDg6701k8CjThTLA5kdnCwBRlVmuDglPqxmdNBipDVSmDXUBXW05F2JSwasXFzLV1i/fInB9MZGzwrpv3tdbOlLqkyvagBGwJzzBT5WIHkEmAvTZRbSk98X8fBcNw0m/wWj7Rm31GR3D6f+DFJGrhp0NV5+ZqbsuElUsxutaBLUsqdy3mF3maoYg6mpbpT0i4hbL0TVMQfrEZ/laWg3DxysW8Q8FxcHXj+g86gAAAABJRU5ErkJggg==);
}
.mdx-hero__image {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.mdx-hero__content {
  padding-bottom: 6rem;
}
@media screen and (min-width: 60em) {
  .mdx-hero {
    display: flex;
    align-items: stretch;
  }
  .mdx-hero__content {
    max-width: 19rem;
    padding-bottom: 14vw;
    margin-top: 3.5rem;
  }
  .mdx-hero__image {
    order: 1;
    width: 38rem;
    transform: translateX(4rem);
  }
}
@media screen and (min-width: 76.25em) {
  .mdx-hero__image {
    transform: translateX(8rem);
  }
}
.mdx-hero .md-button {
  margin-top: 0.5rem;
  margin-right: 0.5rem;
  color: var(--md-primary-bg-color);
}
.mdx-hero .md-button:focus,.mdx-hero .md-button:hover {
  color: var(--md-accent-bg-color);
  background-color: var(--md-accent-fg-color);
  border-color: var(--md-accent-fg-color);
}
.mdx-hero .md-button--primary {
  color: hsl(280, 37%, 48%);
  background-color: var(--md-primary-bg-color);
  border-color: var(--md-primary-bg-color);
}

.md-typeset .mdx-iconsearch {
  position: relative;
  background-color: var(--md-default-bg-color);
  border-radius: 0.1rem;
  box-shadow: var(--md-shadow-z1);
  transition: box-shadow 125ms;
}
.md-typeset .mdx-iconsearch:focus-within,.md-typeset .mdx-iconsearch:hover {
  box-shadow: var(--md-shadow-z2);
}
.md-typeset .mdx-iconsearch .md-input {
  background: var(--md-default-bg-color);
  box-shadow: none;
}
[data-md-color-scheme=slate] .md-typeset .mdx-iconsearch .md-input {
  background: var(--md-code-bg-color);
}
.md-typeset .mdx-iconsearch-result {
  max-height: 50vh;
  overflow-y: auto;
  backface-visibility: hidden;
  touch-action: pan-y;
  scrollbar-width: thin;
  scrollbar-color: var(--md-default-fg-color--lighter) transparent;
}
.md-tooltip .md-typeset .mdx-iconsearch-result {
  max-height: 10.25rem;
}
.md-typeset .mdx-iconsearch-result::-webkit-scrollbar {
  width: 0.2rem;
  height: 0.2rem;
}
.md-typeset .mdx-iconsearch-result::-webkit-scrollbar-thumb {
  background-color: var(--md-default-fg-color--lighter);
}
.md-typeset .mdx-iconsearch-result::-webkit-scrollbar-thumb:hover {
  background-color: var(--md-accent-fg-color);
}
.md-typeset .mdx-iconsearch-result__meta {
  position: absolute;
  top: 0.4rem;
  right: 0.6rem;
  font-size: 0.64rem;
  color: var(--md-default-fg-color--lighter);
}
[dir="ltr"] .md-typeset .mdx-iconsearch-result__list {
  margin-left: 0;
}
[dir="rtl"] .md-typeset .mdx-iconsearch-result__list {
  margin-right: 0;
}
.md-typeset .mdx-iconsearch-result__list {
  padding: 0;
  margin: 0;
  list-style: none;
}
[dir="ltr"] .md-typeset .mdx-iconsearch-result__item {
  margin-left: 0;
}
[dir="rtl"] .md-typeset .mdx-iconsearch-result__item {
  margin-right: 0;
}
.md-typeset .mdx-iconsearch-result__item {
  padding: 0.2rem 0.6rem;
  margin: 0;
  border-bottom: 0.05rem solid var(--md-default-fg-color--lightest);
}
.md-typeset .mdx-iconsearch-result__item:last-child {
  border-bottom: none;
}
.md-typeset .mdx-iconsearch-result__item>* {
  margin-right: 0.6rem;
}
.md-typeset .mdx-iconsearch-result__item img {
  width: 0.9rem;
  height: 0.9rem;
}
[data-md-color-scheme=slate] .md-typeset .mdx-iconsearch-result__item img[src*=squidfunk] {
  filter: invert(1); /* stylelint-disable-line */
}

.md-typeset .mdx-premium p {
  margin: 2em 0;
  text-align: center;
}
.md-typeset .mdx-premium img {
  height: 3.25rem;
}
.md-typeset .mdx-premium p:last-child {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.md-typeset .mdx-premium p:last-child>a {
  display: block;
  flex-shrink: 0;
}
.md-typeset .mdx-sponsorship__list {
  margin: 2em 0;
}
.md-typeset .mdx-sponsorship__list::after {
  display: block;
  clear: both;
  content: "";
}
[dir="ltr"] .md-typeset .mdx-sponsorship__item {
  float: left;
}
[dir="rtl"] .md-typeset .mdx-sponsorship__item {
  float: right;
}
.md-typeset .mdx-sponsorship__item {
  display: block;
  width: 1.6rem;
  height: 1.6rem;
  margin: 0.2rem;
  overflow: hidden;
  border-radius: 100%;
  transition: color 125ms, transform 125ms;
  transform: scale(1);
}
.md-typeset .mdx-sponsorship__item:focus,.md-typeset .mdx-sponsorship__item:hover {
  transform: scale(1.1);
}
.md-typeset .mdx-sponsorship__item:focus img,.md-typeset .mdx-sponsorship__item:hover img {
  filter: grayscale(0%);
}
.md-typeset .mdx-sponsorship__item--private {
  font-size: 0.6rem;
  font-weight: 700;
  line-height: 1.6rem;
  color: var(--md-default-fg-color--lighter);
  text-align: center;
  background: var(--md-default-fg-color--lightest);
}
.md-typeset .mdx-sponsorship__item img {
  display: block;
  width: 100%;
  height: auto;
  filter: grayscale(100%) opacity(75%);
  transition: filter 125ms;
}
.md-typeset .mdx-sponsorship-button {
  font-weight: 400;
}
.md-typeset .mdx-sponsorship-count,.md-typeset .mdx-sponsorship-total {
  font-weight: 700;
}

.mdx-spotlight {
  margin: 2em 0;
}
.mdx-spotlight__feature {
  display: flex;
  flex: 1 0 48%;
  flex-flow: row nowrap;
  gap: 3.2rem;
  margin: 0 0 3.2rem;
}
.mdx-spotlight__feature a {
  display: block;
  flex-shrink: 0;
  transition: transform 0.5s cubic-bezier(0.075, 0.85, 0.175, 1);
}
.mdx-spotlight__feature a:hover {
  transform: scale(1.025);
}
.mdx-spotlight__feature a.img {
  border-radius: 0.2rem;
  box-shadow: var(--md-shadow-z2);
  display: block;
  height: auto;
  max-width: 100%;
  width: 25rem;
}
.mdx-spotlight__feature a.img,.mdx-spotlight__feature figcaption {
  transition: transform 0.75s cubic-bezier(0.075, 0.85, 0.175, 1) 125ms, opacity 0.75s 125ms;
}
@media screen and (max-width: 60em) {
  .mdx-spotlight__feature {
    flex-direction: column;
    gap: 0;
  }
}
@media screen and (min-width: 60em) {
  .mdx-spotlight__feature:nth-child(odd) {
    flex-direction: row-reverse;
  }
}

.md-content header {
  display: block;
  transition: opacity 0.75s;
}
.md-content__inner {
  margin-bottom: 0;
  padding: 5.2rem 0;
}
.md-content__inner:before {
  display: none;
}
.md-content__inner>:last-child {
  margin-bottom: 0;
}

@media screen and (min-width: 60em) {
  .mdx-content__inner {
    display: flex;
    flex-wrap: nowrap;
    gap: 6.4rem;
  }
  .mdx-content__column {
    margin-top: 0;
  }
  .mdx-content__column:first-child {
    flex: 2 0;
  }
  .mdx-content__column:last-child {
    flex: 1 0;
    margin-top: 0;
  }
}

.mdx-connect {
  display: block;
  transition: transform 0.75s cubic-bezier(0.075, 0.85, 0.175, 1) 125ms, opacity 0.75s 125ms;
}
.mdx-connect .mdx-connect__link {
  color: var(--md-default-fg-color);
  display: block;
}

.md-main {
  margin: 0;
}
.md-main__inner {
  margin: 0;
}
.md-main__inner>.md-content,.md-main__inner>.md-sidebar--secondary {
  display: none;
}
.md-main .md-sidebar {
  padding: 0;
}

.md-typeset .md-button {
  background-color: #337ab7;
  border-width: 0;
  color: var(--md-primary-bg-color);
  margin-right: 0.5rem;
  margin-top: 0.5rem;
}

.mdx-parallax__group {
  background-color: var(--md-default-bg-color);
  color: var(--md-typeset-color);
  display: block;
  position: relative;
  transform-style: preserve-3d;
}
.mdx-parallax__image {
  display: block;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: var(--md-image-position, 50%);
     object-position: var(--md-image-position, 50%);
  position: absolute;
  width: 100%;
  z-index: -1;
}

.mdx-expect {
  margin: 2.4rem 0;
}
.mdx-expect__list {
  display: flex;
  flex-flow: row wrap;
  gap: 1.6rem;
  padding: 0;
}
.mdx-expect__item {
  display: flex;
  flex: 1 0 48%;
  gap: 0.6rem;
  margin: 0;
  transition: transform 0.75s cubic-bezier(0.075, 0.85, 0.175, 1), opacity 0.75s;
}
.mdx-expect__item:first-child {
  transition-delay: 0.2s;
}
.mdx-expect__icon {
  fill: currentcolor;
  background-color: var(--md-default-fg-color--lightest);
  border-radius: 100%;
  flex-shrink: 0;
  height: 2.2rem;
  padding: 0.4rem;
  width: 2.2rem;
}