@import url("https://fonts.googleapis.com/css?family=Raleway:400,500,700|Roboto+Slab:400,700");
*, *::after, *::before {
  box-sizing: inherit;
}

* {
  font: inherit;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video, hr {
  margin: 0;
  padding: 0;
  border: 0;
}

html {
  box-sizing: border-box;
}

body {
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg, white);
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, main, form legend {
  display: block;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

button, input, textarea, select {
  margin: 0;
}

.btn, .form-control, .link, .reset {
  background-color: transparent;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: inherit;
  line-height: inherit;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

select.form-control::-ms-expand {
  display: none;
}

textarea {
  resize: vertical;
  overflow: auto;
  vertical-align: top;
}

input::-ms-clear {
  display: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

img, video, svg {
  max-width: 100%;
}

:root, [data-theme="default"] {
  --color-primary-darker: hsl(199, 92%, 54%);
  --color-primary-darker-h: 199;
  --color-primary-darker-s: 92%;
  --color-primary-darker-l: 54%;
  --color-primary-dark: hsl(199, 92%, 64%);
  --color-primary-dark-h: 199;
  --color-primary-dark-s: 92%;
  --color-primary-dark-l: 64%;
  --color-primary: hsl(199, 92%, 74%);
  --color-primary-h: 199;
  --color-primary-s: 92%;
  --color-primary-l: 74%;
  --color-primary-light: hsl(199, 92%, 84%);
  --color-primary-light-h: 199;
  --color-primary-light-s: 92%;
  --color-primary-light-l: 84%;
  --color-primary-lighter: hsl(199, 92%, 94%);
  --color-primary-lighter-h: 199;
  --color-primary-lighter-s: 92%;
  --color-primary-lighter-l: 94%;
  --color-accent-darker: hsl(201, 98%, 21%);
  --color-accent-darker-h: 201;
  --color-accent-darker-s: 98%;
  --color-accent-darker-l: 21%;
  --color-accent-dark: hsl(201, 98%, 31%);
  --color-accent-dark-h: 201;
  --color-accent-dark-s: 98%;
  --color-accent-dark-l: 31%;
  --color-accent: hsl(201, 98%, 41%);
  --color-accent-h: 201;
  --color-accent-s: 98%;
  --color-accent-l: 41%;
  --color-accent-light: hsl(201, 98%, 51%);
  --color-accent-light-h: 201;
  --color-accent-light-s: 98%;
  --color-accent-light-l: 51%;
  --color-accent-lighter: hsl(201, 98%, 61%);
  --color-accent-lighter-h: 201;
  --color-accent-lighter-s: 98%;
  --color-accent-lighter-l: 61%;
  --color-black: hsl(0, 0%, 0%);
  --color-black-h: 0;
  --color-black-s: 0%;
  --color-black-l: 0%;
  --color-white: hsl(0, 0%, 100%);
  --color-white-h: 0;
  --color-white-s: 0%;
  --color-white-l: 100%;
  --color-warning-darker: hsl(46, 100%, 41%);
  --color-warning-darker-h: 46;
  --color-warning-darker-s: 100%;
  --color-warning-darker-l: 41%;
  --color-warning-dark: hsl(46, 100%, 51%);
  --color-warning-dark-h: 46;
  --color-warning-dark-s: 100%;
  --color-warning-dark-l: 51%;
  --color-warning: hsl(46, 100%, 61%);
  --color-warning-h: 46;
  --color-warning-s: 100%;
  --color-warning-l: 61%;
  --color-warning-light: hsl(46, 100%, 71%);
  --color-warning-light-h: 46;
  --color-warning-light-s: 100%;
  --color-warning-light-l: 71%;
  --color-warning-lighter: hsl(46, 100%, 81%);
  --color-warning-lighter-h: 46;
  --color-warning-lighter-s: 100%;
  --color-warning-lighter-l: 81%;
  --color-success-darker: hsl(94, 48%, 36%);
  --color-success-darker-h: 94;
  --color-success-darker-s: 48%;
  --color-success-darker-l: 36%;
  --color-success-dark: hsl(94, 48%, 46%);
  --color-success-dark-h: 94;
  --color-success-dark-s: 48%;
  --color-success-dark-l: 46%;
  --color-success: hsl(94, 48%, 56%);
  --color-success-h: 94;
  --color-success-s: 48%;
  --color-success-l: 56%;
  --color-success-light: hsl(94, 48%, 66%);
  --color-success-light-h: 94;
  --color-success-light-s: 48%;
  --color-success-light-l: 66%;
  --color-success-lighter: hsl(94, 48%, 76%);
  --color-success-lighter-h: 94;
  --color-success-lighter-s: 48%;
  --color-success-lighter-l: 76%;
  --color-error-darker: hsl(355, 90%, 41%);
  --color-error-darker-h: 355;
  --color-error-darker-s: 90%;
  --color-error-darker-l: 41%;
  --color-error-dark: hsl(355, 90%, 51%);
  --color-error-dark-h: 355;
  --color-error-dark-s: 90%;
  --color-error-dark-l: 51%;
  --color-error: hsl(355, 90%, 61%);
  --color-error-h: 355;
  --color-error-s: 90%;
  --color-error-l: 61%;
  --color-error-light: hsl(355, 90%, 71%);
  --color-error-light-h: 355;
  --color-error-light-s: 90%;
  --color-error-light-l: 71%;
  --color-error-lighter: hsl(355, 90%, 81%);
  --color-error-lighter-h: 355;
  --color-error-lighter-s: 90%;
  --color-error-lighter-l: 81%;
  --color-bg: hsl(0, 0%, 7%);
  --color-bg-h: 0;
  --color-bg-s: 0%;
  --color-bg-l: 7%;
  --color-contrast-lower: hsl(0, 0%, 11%);
  --color-contrast-lower-h: 0;
  --color-contrast-lower-s: 0%;
  --color-contrast-lower-l: 11%;
  --color-contrast-low: hsl(0, 0%, 20%);
  --color-contrast-low-h: 0;
  --color-contrast-low-s: 0%;
  --color-contrast-low-l: 20%;
  --color-contrast-medium: hsl(0, 0%, 54%);
  --color-contrast-medium-h: 0;
  --color-contrast-medium-s: 0%;
  --color-contrast-medium-l: 54%;
  --color-contrast-high: hsl(0, 0%, 88%);
  --color-contrast-high-h: 0;
  --color-contrast-high-s: 0%;
  --color-contrast-high-l: 88%;
  --color-contrast-higher: hsl(0, 0%, 100%);
  --color-contrast-higher-h: 0;
  --color-contrast-higher-s: 0%;
  --color-contrast-higher-l: 100%;
}

[data-theme] {
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
  color: hsl(0, 0%, 88%);
  color: var(--color-contrast-high);
}

:root {
  --space-unit:  1em;
  --space-xxxxs: calc(0.125*var(--space-unit));
  --space-xxxs:  calc(0.25*var(--space-unit));
  --space-xxs:   calc(0.375*var(--space-unit));
  --space-xs:    calc(0.5*var(--space-unit));
  --space-sm:    calc(0.75*var(--space-unit));
  --space-md:    calc(1.25*var(--space-unit));
  --space-lg:    calc(2*var(--space-unit));
  --space-xl:    calc(3.25*var(--space-unit));
  --space-xxl:   calc(5.25*var(--space-unit));
  --space-xxxl:  calc(8.5*var(--space-unit));
  --space-xxxxl: calc(13.75*var(--space-unit));
  --component-padding: var(--space-md);
}

@supports (--css: variables) {
  @media (min-width: 64rem) {
    :root {
      --space-unit:  1.25em;
    }
  }
}

.margin-top, .margin-top--md {
  margin-top: 1.25em;
  margin-top: var(--space-md);
}

.margin-top--xxxxs {
  margin-top: 0.125em;
  margin-top: var(--space-xxxxs);
}

.margin-top--xxxs {
  margin-top: 0.25em;
  margin-top: var(--space-xxxs);
}

.margin-top--xxs {
  margin-top: 0.375em;
  margin-top: var(--space-xxs);
}

.margin-top--xs {
  margin-top: 0.5em;
  margin-top: var(--space-xs);
}

.margin-top--sm {
  margin-top: 0.75em;
  margin-top: var(--space-sm);
}

.margin-top--lg {
  margin-top: 2em;
  margin-top: var(--space-lg);
}

.margin-top--xl {
  margin-top: 3.25em;
  margin-top: var(--space-xl);
}

.margin-top--xxl {
  margin-top: 5.25em;
  margin-top: var(--space-xxl);
}

.margin-top--xxxl {
  margin-top: 8.5em;
  margin-top: var(--space-xxxl);
}

.margin-top--xxxxl {
  margin-top: 13.75em;
  margin-top: var(--space-xxxxl);
}

.margin-bottom, .margin-bottom--md {
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

.margin-bottom--xxxxs {
  margin-bottom: 0.125em;
  margin-bottom: var(--space-xxxxs);
}

.margin-bottom--xxxs {
  margin-bottom: 0.25em;
  margin-bottom: var(--space-xxxs);
}

.margin-bottom--xxs {
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

.margin-bottom--xs {
  margin-bottom: 0.5em;
  margin-bottom: var(--space-xs);
}

.margin-bottom--sm {
  margin-bottom: 0.75em;
  margin-bottom: var(--space-sm);
}

.margin-bottom--lg {
  margin-bottom: 2em;
  margin-bottom: var(--space-lg);
}

.margin-bottom--xl {
  margin-bottom: 3.25em;
  margin-bottom: var(--space-xl);
}

.margin-bottom--xxl {
  margin-bottom: 5.25em;
  margin-bottom: var(--space-xxl);
}

.margin-bottom--xxxl {
  margin-bottom: 8.5em;
  margin-bottom: var(--space-xxxl);
}

.margin-bottom--xxxxl {
  margin-bottom: 13.75em;
  margin-bottom: var(--space-xxxxl);
}

:root {
  --container-width-xs: 37.5rem;
  --container-width-sm: 45rem;
  --container-width-md: 64rem;
  --container-width-lg: 80rem;
  --container-width-xl: 90rem;
}

.container {
  width: calc(100% - 1.25em);
  width: calc(100% - 2*var(--component-padding));
  margin-left: auto;
  margin-right: auto;
}

.container--full-width {
  width: 100%;
}

.container--xs {
  max-width: 37.5rem;
  max-width: var(--container-width-xs);
}

.container--sm {
  max-width: 45rem;
  max-width: var(--container-width-sm);
}

.container--md {
  max-width: 64rem;
  max-width: var(--container-width-md);
}

.container--lg {
  max-width: 80rem;
  max-width: var(--container-width-lg);
}

.container--xl {
  max-width: 90rem;
  max-width: var(--container-width-xl);
}

.container--adaptive, .container--adaptive-lg {
  max-width: 37.5rem;
  max-width: var(--container-width-xs);
}

@media (min-width: 64rem) {
  .container--adaptive, .container--adaptive-lg {
    max-width: 64rem;
    max-width: var(--container-width-md);
  }
}

@media (min-width: 90rem) {
  .container--adaptive, .container--adaptive-lg {
    max-width: 80rem;
    max-width: var(--container-width-lg);
  }
}

.container--adaptive-sm {
  max-width: 37.5rem;
  max-width: var(--container-width-xs);
}

@media (min-width: 64rem) {
  .container--adaptive-sm {
    max-width: 45rem;
    max-width: var(--container-width-sm);
  }
}

.container--adaptive-md {
  max-width: 37.5rem;
  max-width: var(--container-width-xs);
}

@media (min-width: 64rem) {
  .container--adaptive-md {
    max-width: 64rem;
    max-width: var(--container-width-md);
  }
}

.container--adaptive-xl {
  max-width: 37.5rem;
  max-width: var(--container-width-xs);
}

@media (min-width: 64rem) {
  .container--adaptive-xl {
    max-width: 64rem;
    max-width: var(--container-width-md);
  }
}

@media (min-width: 90rem) {
  .container--adaptive-xl {
    max-width: 90rem;
    max-width: var(--container-width-xl);
  }
}

.grid {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.grid > * {
  background-clip: content-box;
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
}

.grid--gap-xs, .grid-gap--xs {
  margin: -0.5em 0 0 -0.5em;
  margin: calc(var(--space-xs)*-1) 0 0 calc(var(--space-xs)*-1);
}

.grid--gap-xs > *, .grid-gap--xs > * {
  padding: 0.5em 0 0 0.5em;
  padding: var(--space-xs) 0 0 var(--space-xs);
}

.grid--gap-sm, .grid-gap--sm {
  margin: -0.75em 0 0 -0.75em;
  margin: calc(var(--space-sm)*-1) 0 0 calc(var(--space-sm)*-1);
}

.grid--gap-sm > *, .grid-gap--sm > * {
  padding: 0.75em 0 0 0.75em;
  padding: var(--space-sm) 0 0 var(--space-sm);
}

.grid--gap-md, .grid-gap--md {
  margin: -1.25em 0 0 -1.25em;
  margin: calc(var(--space-md)*-1) 0 0 calc(var(--space-md)*-1);
}

.grid--gap-md > *, .grid-gap--md > * {
  padding: 1.25em 0 0 1.25em;
  padding: var(--space-md) 0 0 var(--space-md);
}

.grid--gap-lg, .grid-gap--lg {
  margin: -2em 0 0 -2em;
  margin: calc(var(--space-lg)*-1) 0 0 calc(var(--space-lg)*-1);
}

.grid--gap-lg > *, .grid-gap--lg > * {
  padding: 2em 0 0 2em;
  padding: var(--space-lg) 0 0 var(--space-lg);
}

.grid--gap-xl, .grid-gap--xl {
  margin: -3.25em 0 0 -3.25em;
  margin: calc(var(--space-xl)*-1) 0 0 calc(var(--space-xl)*-1);
}

.grid--gap-xl > *, .grid-gap--xl > * {
  padding: 3.25em 0 0 3.25em;
  padding: var(--space-xl) 0 0 var(--space-xl);
}

.col {
  -ms-flex-positive: 1;
      flex-grow: 1;
  -ms-flex-preferred-size: 0;
      flex-basis: 0;
  max-width: 100%;
}

.col--1 {
  -ms-flex-preferred-size: 8.33%;
      flex-basis: 8.33%;
  max-width: 8.33%;
}

.col--2 {
  -ms-flex-preferred-size: 16.66%;
      flex-basis: 16.66%;
  max-width: 16.66%;
}

.col--3 {
  -ms-flex-preferred-size: 25%;
      flex-basis: 25%;
  max-width: 25%;
}

.col--4 {
  -ms-flex-preferred-size: 33.33%;
      flex-basis: 33.33%;
  max-width: 33.33%;
}

.col--5 {
  -ms-flex-preferred-size: 41.66%;
      flex-basis: 41.66%;
  max-width: 41.66%;
}

.col--6 {
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  max-width: 50%;
}

.col--7 {
  -ms-flex-preferred-size: 58.33%;
      flex-basis: 58.33%;
  max-width: 58.33%;
}

.col--8 {
  -ms-flex-preferred-size: 66.66%;
      flex-basis: 66.66%;
  max-width: 66.66%;
}

.col--9 {
  -ms-flex-preferred-size: 75%;
      flex-basis: 75%;
  max-width: 75%;
}

.col--10 {
  -ms-flex-preferred-size: 83.33%;
      flex-basis: 83.33%;
  max-width: 83.33%;
}

.col--11 {
  -ms-flex-preferred-size: 91.66%;
      flex-basis: 91.66%;
  max-width: 91.66%;
}

.col--12 {
  -ms-flex-preferred-size: 100%;
      flex-basis: 100%;
  max-width: 100%;
}

@media (min-width: 30rem) {
  .col--xs {
    -ms-flex-positive: 1;
        flex-grow: 1;
    -ms-flex-preferred-size: 0;
        flex-basis: 0;
    max-width: 100%;
  }
  .col--xs-1 {
    -ms-flex-preferred-size: 8.33%;
        flex-basis: 8.33%;
    max-width: 8.33%;
  }
  .col--xs-2 {
    -ms-flex-preferred-size: 16.66%;
        flex-basis: 16.66%;
    max-width: 16.66%;
  }
  .col--xs-3 {
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
    max-width: 25%;
  }
  .col--xs-4 {
    -ms-flex-preferred-size: 33.33%;
        flex-basis: 33.33%;
    max-width: 33.33%;
  }
  .col--xs-5 {
    -ms-flex-preferred-size: 41.66%;
        flex-basis: 41.66%;
    max-width: 41.66%;
  }
  .col--xs-6 {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .col--xs-7 {
    -ms-flex-preferred-size: 58.33%;
        flex-basis: 58.33%;
    max-width: 58.33%;
  }
  .col--xs-8 {
    -ms-flex-preferred-size: 66.66%;
        flex-basis: 66.66%;
    max-width: 66.66%;
  }
  .col--xs-9 {
    -ms-flex-preferred-size: 75%;
        flex-basis: 75%;
    max-width: 75%;
  }
  .col--xs-10 {
    -ms-flex-preferred-size: 83.33%;
        flex-basis: 83.33%;
    max-width: 83.33%;
  }
  .col--xs-11 {
    -ms-flex-preferred-size: 91.66%;
        flex-basis: 91.66%;
    max-width: 91.66%;
  }
  .col--xs-12 {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
  }
}

@media (min-width: 37.5rem) {
  .col--sm {
    -ms-flex-positive: 1;
        flex-grow: 1;
    -ms-flex-preferred-size: 0;
        flex-basis: 0;
    max-width: 100%;
  }
  .col--sm-1 {
    -ms-flex-preferred-size: 8.33%;
        flex-basis: 8.33%;
    max-width: 8.33%;
  }
  .col--sm-2 {
    -ms-flex-preferred-size: 16.66%;
        flex-basis: 16.66%;
    max-width: 16.66%;
  }
  .col--sm-3 {
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
    max-width: 25%;
  }
  .col--sm-4 {
    -ms-flex-preferred-size: 33.33%;
        flex-basis: 33.33%;
    max-width: 33.33%;
  }
  .col--sm-5 {
    -ms-flex-preferred-size: 41.66%;
        flex-basis: 41.66%;
    max-width: 41.66%;
  }
  .col--sm-6 {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .col--sm-7 {
    -ms-flex-preferred-size: 58.33%;
        flex-basis: 58.33%;
    max-width: 58.33%;
  }
  .col--sm-8 {
    -ms-flex-preferred-size: 66.66%;
        flex-basis: 66.66%;
    max-width: 66.66%;
  }
  .col--sm-9 {
    -ms-flex-preferred-size: 75%;
        flex-basis: 75%;
    max-width: 75%;
  }
  .col--sm-10 {
    -ms-flex-preferred-size: 83.33%;
        flex-basis: 83.33%;
    max-width: 83.33%;
  }
  .col--sm-11 {
    -ms-flex-preferred-size: 91.66%;
        flex-basis: 91.66%;
    max-width: 91.66%;
  }
  .col--sm-12 {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
  }
}

@media (min-width: 64rem) {
  .col--md {
    -ms-flex-positive: 1;
        flex-grow: 1;
    -ms-flex-preferred-size: 0;
        flex-basis: 0;
    max-width: 100%;
  }
  .col--md-1 {
    -ms-flex-preferred-size: 8.33%;
        flex-basis: 8.33%;
    max-width: 8.33%;
  }
  .col--md-2 {
    -ms-flex-preferred-size: 16.66%;
        flex-basis: 16.66%;
    max-width: 16.66%;
  }
  .col--md-3 {
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
    max-width: 25%;
  }
  .col--md-4 {
    -ms-flex-preferred-size: 33.33%;
        flex-basis: 33.33%;
    max-width: 33.33%;
  }
  .col--md-5 {
    -ms-flex-preferred-size: 41.66%;
        flex-basis: 41.66%;
    max-width: 41.66%;
  }
  .col--md-6 {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .col--md-7 {
    -ms-flex-preferred-size: 58.33%;
        flex-basis: 58.33%;
    max-width: 58.33%;
  }
  .col--md-8 {
    -ms-flex-preferred-size: 66.66%;
        flex-basis: 66.66%;
    max-width: 66.66%;
  }
  .col--md-9 {
    -ms-flex-preferred-size: 75%;
        flex-basis: 75%;
    max-width: 75%;
  }
  .col--md-10 {
    -ms-flex-preferred-size: 83.33%;
        flex-basis: 83.33%;
    max-width: 83.33%;
  }
  .col--md-11 {
    -ms-flex-preferred-size: 91.66%;
        flex-basis: 91.66%;
    max-width: 91.66%;
  }
  .col--md-12 {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
  }
}

@media (min-width: 80rem) {
  .col--lg {
    -ms-flex-positive: 1;
        flex-grow: 1;
    -ms-flex-preferred-size: 0;
        flex-basis: 0;
    max-width: 100%;
  }
  .col--lg-1 {
    -ms-flex-preferred-size: 8.33%;
        flex-basis: 8.33%;
    max-width: 8.33%;
  }
  .col--lg-2 {
    -ms-flex-preferred-size: 16.66%;
        flex-basis: 16.66%;
    max-width: 16.66%;
  }
  .col--lg-3 {
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
    max-width: 25%;
  }
  .col--lg-4 {
    -ms-flex-preferred-size: 33.33%;
        flex-basis: 33.33%;
    max-width: 33.33%;
  }
  .col--lg-5 {
    -ms-flex-preferred-size: 41.66%;
        flex-basis: 41.66%;
    max-width: 41.66%;
  }
  .col--lg-6 {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .col--lg-7 {
    -ms-flex-preferred-size: 58.33%;
        flex-basis: 58.33%;
    max-width: 58.33%;
  }
  .col--lg-8 {
    -ms-flex-preferred-size: 66.66%;
        flex-basis: 66.66%;
    max-width: 66.66%;
  }
  .col--lg-9 {
    -ms-flex-preferred-size: 75%;
        flex-basis: 75%;
    max-width: 75%;
  }
  .col--lg-10 {
    -ms-flex-preferred-size: 83.33%;
        flex-basis: 83.33%;
    max-width: 83.33%;
  }
  .col--lg-11 {
    -ms-flex-preferred-size: 91.66%;
        flex-basis: 91.66%;
    max-width: 91.66%;
  }
  .col--lg-12 {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
  }
}

@media (min-width: 90rem) {
  .col--xl {
    -ms-flex-positive: 1;
        flex-grow: 1;
    -ms-flex-preferred-size: 0;
        flex-basis: 0;
    max-width: 100%;
  }
  .col--xl-1 {
    -ms-flex-preferred-size: 8.33%;
        flex-basis: 8.33%;
    max-width: 8.33%;
  }
  .col--xl-2 {
    -ms-flex-preferred-size: 16.66%;
        flex-basis: 16.66%;
    max-width: 16.66%;
  }
  .col--xl-3 {
    -ms-flex-preferred-size: 25%;
        flex-basis: 25%;
    max-width: 25%;
  }
  .col--xl-4 {
    -ms-flex-preferred-size: 33.33%;
        flex-basis: 33.33%;
    max-width: 33.33%;
  }
  .col--xl-5 {
    -ms-flex-preferred-size: 41.66%;
        flex-basis: 41.66%;
    max-width: 41.66%;
  }
  .col--xl-6 {
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 50%;
  }
  .col--xl-7 {
    -ms-flex-preferred-size: 58.33%;
        flex-basis: 58.33%;
    max-width: 58.33%;
  }
  .col--xl-8 {
    -ms-flex-preferred-size: 66.66%;
        flex-basis: 66.66%;
    max-width: 66.66%;
  }
  .col--xl-9 {
    -ms-flex-preferred-size: 75%;
        flex-basis: 75%;
    max-width: 75%;
  }
  .col--xl-10 {
    -ms-flex-preferred-size: 83.33%;
        flex-basis: 83.33%;
    max-width: 83.33%;
  }
  .col--xl-11 {
    -ms-flex-preferred-size: 91.66%;
        flex-basis: 91.66%;
    max-width: 91.66%;
  }
  .col--xl-12 {
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    max-width: 100%;
  }
}

.flex {
  display: -ms-flexbox;
  display: flex;
}

.flex > * {
  display: inline-block;
}

.flex--wrap {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.flex--column {
  -ms-flex-direction: column;
      flex-direction: column;
}

.flex--end {
  -ms-flex-pack: end;
      justify-content: flex-end;
}

.flex--center {
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}

.flex--center-x {
  -ms-flex-pack: center;
      justify-content: center;
}

.flex--center-y {
  -ms-flex-align: center;
      align-items: center;
}

.flex--space-between {
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.flex--space-around {
  -ms-flex-pack: distribute;
      justify-content: space-around;
}

.flex--space-evenly {
  -ms-flex-pack: space-evenly;
      justify-content: space-evenly;
}

.flex--grow > * {
  -ms-flex-positive: 1;
      flex-grow: 1;
}

.flex--shrink-none > * {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.flex--gap > *, .flex--gap-md > *, .flex-gap > *, .flex-gap--md > * {
  margin-right: 1.25em;
  margin-right: var(--space-md);
}

.flex--gap > *:last-child, .flex--gap-md > *:last-child, .flex-gap > *:last-child, .flex-gap--md > *:last-child {
  margin-right: 0;
}

.flex--wrap.flex--gap, .flex--wrap.flex--gap-md, .flex--wrap.flex-gap, .flex--wrap.flex-gap--md {
  margin-bottom: -1.25em;
  margin-bottom: calc(-1*var(--space-md));
}

.flex--wrap.flex--gap > *, .flex--wrap.flex--gap-md > *, .flex--wrap.flex-gap > *, .flex--wrap.flex-gap--md > * {
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

.flex--gap-xxs > *, .flex-gap--xxs > * {
  margin-right: 0.375em;
  margin-right: var(--space-xxs);
}

.flex--gap-xxs > *:last-child, .flex-gap--xxs > *:last-child {
  margin-right: 0;
}

.flex--wrap.flex--gap-xxs, .flex--wrap.flex-gap--xxs {
  margin-bottom: -0.375em;
  margin-bottom: calc(-1*var(--space-xxs));
}

.flex--wrap.flex--gap-xxs > *, .flex--wrap.flex-gap--xxs > * {
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

.flex--gap-xs > *, .flex-gap--xs > * {
  margin-right: 0.5em;
  margin-right: var(--space-xs);
}

.flex--gap-xs > *:last-child, .flex-gap--xs > *:last-child {
  margin-right: 0;
}

.flex--wrap.flex--gap-xs, .flex--wrap.flex-gap--xs {
  margin-bottom: -0.5em;
  margin-bottom: calc(-1*var(--space-xs));
}

.flex--wrap.flex--gap-xs > *, .flex--wrap.flex-gap--xs > * {
  margin-bottom: 0.5em;
  margin-bottom: var(--space-xs);
}

.flex--gap-sm > *, .flex-gap--sm > * {
  margin-right: 0.75em;
  margin-right: var(--space-sm);
}

.flex--gap-sm > *:last-child, .flex-gap--sm > *:last-child {
  margin-right: 0;
}

.flex--wrap.flex--gap-sm, .flex--wrap.flex-gap--sm {
  margin-bottom: -0.75em;
  margin-bottom: calc(-1*var(--space-sm));
}

.flex--wrap.flex--gap-sm > *, .flex--wrap.flex-gap--sm > * {
  margin-bottom: 0.75em;
  margin-bottom: var(--space-sm);
}

.flex--gap-lg > *, .flex-gap--lg > * {
  margin-right: 2em;
  margin-right: var(--space-lg);
}

.flex--gap-lg > *:last-child, .flex-gap--lg > *:last-child {
  margin-right: 0;
}

.flex--wrap.flex--gap-lg, .flex--wrap.flex-gap--lg {
  margin-bottom: -2em;
  margin-bottom: calc(-1*var(--space-lg));
}

.flex--wrap.flex--gap-lg > *, .flex--wrap.flex-gap--lg > * {
  margin-bottom: 2em;
  margin-bottom: var(--space-lg);
}

.flex--gap-xl > *, .flex-gap--xl > * {
  margin-right: 3.25em;
  margin-right: var(--space-xl);
}

.flex--gap-xl > *:last-child, .flex-gap--xl > *:last-child {
  margin-right: 0;
}

.flex--wrap.flex--gap-xl, .flex--wrap.flex-gap--xl {
  margin-bottom: -3.25em;
  margin-bottom: calc(-1*var(--space-xl));
}

.flex--wrap.flex--gap-xl > *, .flex--wrap.flex-gap--xl > * {
  margin-bottom: 3.25em;
  margin-bottom: var(--space-xl);
}

.flex-item--end {
  -ms-flex-item-align: end;
      align-self: flex-end;
}

.flex-item--grow {
  -ms-flex-positive: 1;
      flex-grow: 1;
}

.flex-item--shrink-none {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

:root {
  --radius: 0.25em;
  --shadow-sm: 0 1px 1px rgba(0, 0, 0, .2), 0 1px 8px rgba(0, 0, 0, .1);
  --shadow-md: 0 1px 8px rgba(0, 0, 0, .1), 0 8px 24px rgba(0, 0, 0, .15);
  --shadow-lg: 0 1px 8px rgba(0, 0, 0, .1), 0 16px 48px rgba(0, 0, 0, .1), 0 24px 60px rgba(0, 0, 0, .1);
  --transition-bounce: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  --transition-ease-in-out: cubic-bezier(0.645, 0.045, 0.355, 1);
  --transition-ease-in: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --transition-ease-out: cubic-bezier(0.215, 0.61, 0.355, 1);
}

:root {
  --font-primary: Raleway, sans-serif;
  --font-secondary: Roboto Slab, serif;
  --text-base-size: 1em;
  --text-scale-ratio: 1.2;
  --text-xs: calc(1em/var(--text-scale-ratio)/var(--text-scale-ratio));
  --text-sm: calc(var(--text-xs)*var(--text-scale-ratio));
  --text-md: calc(var(--text-sm)*var(--text-scale-ratio)*var(--text-scale-ratio));
  --text-lg: calc(var(--text-md)*var(--text-scale-ratio));
  --text-xl: calc(var(--text-lg)*var(--text-scale-ratio));
  --text-xxl: calc(var(--text-xl)*var(--text-scale-ratio));
  --text-xxxl: calc(var(--text-xxl)*var(--text-scale-ratio));
  --body-line-height: 1.4;
  --heading-line-height: 1.2;
  --font-primary-capital-letter: 1;
  --font-secondary-capital-letter: 1;
}

@supports (--css: variables) {
  @media (min-width: 64rem) {
    :root {
      --text-base-size: 1em;
      --text-scale-ratio: 1.25;
    }
  }
}

body {
  font-size: 1em;
  font-size: var(--text-base-size);
  color: hsl(0, 0%, 88%);
  color: var(--color-contrast-high);
  font-family: Raleway, sans-serif;
  font-family: var(--font-primary);
  font-weight: 500;
}

h1, h2, h3, h4 {
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
  line-height: 1.2;
  line-height: var(--heading-line-height);
  font-family: Roboto Slab, serif;
  font-family: var(--font-secondary);
}

.text--xxxl {
  font-size: 2.48832em;
  font-size: var(--text-xxxl);
}

h1, .text--xxl {
  font-size: 2.0736em;
  font-size: var(--text-xxl);
}

h2, .text--xl {
  font-size: 1.728em;
  font-size: var(--text-xl);
}

h3, .text--lg {
  font-size: 1.44em;
  font-size: var(--text-lg);
}

h4, .text--md {
  font-size: 1.2em;
  font-size: var(--text-md);
}

.text--sm, small {
  font-size: 0.83333em;
  font-size: var(--text-sm);
}

.text--xs {
  font-size: 0.69444em;
  font-size: var(--text-xs);
}

a, .link {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
  text-decoration: none;
}

mark {
  background-color: hsla(201, 98%, 41%, 0.2);
  background-color: hsla(var(--color-accent-h), var(--color-accent-s), var(--color-accent-l), 0.2);
  color: inherit;
}

strong {
  font-weight: bold;
}

s {
  text-decoration: line-through;
}

u {
  text-decoration: underline;
}

.text--subtle, .text-component .text--subtle {
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
}

.text--inherit, .text-component .text--inherit {
  color: inherit;
}

.text-component {
  --component-body-line-height: calc(var(--body-line-height)*var(--line-height-multiplier, 1));
  --component-heading-line-height: calc(var(--heading-line-height)*var(--line-height-multiplier, 1));
  --line-height-multiplier: 1;
  --text-vspace-multiplier: 1;
}

.text-component h1, .text-component h2, .text-component h3, .text-component h4 {
  line-height: 1.2;
  line-height: var(--component-heading-line-height);
  margin-bottom: 0.25em;
  margin-bottom: calc(var(--space-xxxs)*var(--text-vspace-multiplier));
}

.text-component h2, .text-component h3, .text-component h4 {
  margin-top: 0.75em;
  margin-top: calc(var(--space-sm)*var(--text-vspace-multiplier));
}

.text-component p, .text-component blockquote, .text-component ul li, .text-component ol li {
  line-height: 1.4;
  line-height: var(--component-body-line-height);
  color: hsl(0, 0%, 88%);
  color: var(--color-contrast-high);
}

.text-component ul, .text-component ol, .text-component p, .text-component blockquote, .text-component .text-component__block, .text-component .text-component__img {
  margin-bottom: 0.75em;
  margin-bottom: calc(var(--space-sm)*var(--text-vspace-multiplier));
}

.text-component ul, .text-component ol {
  padding-left: 1em;
}

.text-component ul {
  list-style-type: disc;
}

.text-component ol {
  list-style-type: decimal;
}

.text-component em {
  font-style: italic;
}

.text-component blockquote {
  padding-left: 1em;
  border-left: 4px solid hsl(0, 0%, 20%);
  border-left: 4px solid var(--color-contrast-low);
}

.text-component hr {
  background: hsl(0, 0%, 20%);
  background: var(--color-contrast-low);
  height: 1px;
  margin: 2em auto;
  margin: calc(var(--space-lg)*var(--text-vspace-multiplier)) auto;
}

.text-component > *:first-child {
  margin-top: 0;
}

.text-component > *:last-child {
  margin-bottom: 0;
}

.article.text-component {
  --line-height-multiplier: 1.13;
  --text-vspace-multiplier: 1.2;
}

.text-component__img {
  text-align: center;
}

.text-component__img img {
  display: block;
  margin: 0 auto;
}

.text-component__img figcaption {
  text-align: center;
  font-size: 0.83333em;
  font-size: var(--text-sm);
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
  margin-top: 0.5em;
  margin-top: var(--space-xs);
}

.text-component__block .text-component__img {
  margin-bottom: 0;
}

@media (min-width: 37.5rem) {
  .text-component__block--left, .text-component__block--right,
  .text-component__img--left, .text-component__img--right {
    width: 45%;
  }
  .text-component__block--left img, .text-component__block--right img,
  .text-component__img--left img, .text-component__img--right img {
    width: 100%;
  }
  .text-component__block--left, .text-component__img--left {
    float: left;
    margin-right: 0.75em;
    margin-right: calc(var(--space-sm)*var(--text-vspace-multiplier, 1));
  }
  .text-component__block--right, .text-component__img--right {
    float: right;
    margin-left: 0.75em;
    margin-left: calc(var(--space-sm)*var(--text-vspace-multiplier, 1));
  }
}

@media (min-width: 90rem) {
  .text-component__block--outset, .text-component__img--outset {
    width: calc(100% + 10.5em);
    width: calc(100% + 2*var(--space-xxl));
  }
  .text-component__block--outset img, .text-component__img--outset img {
    width: 100%;
  }
  .text-component__block--outset:not(.text-component__block--right),
  .text-component__img--outset:not(.text-component__img--right) {
    margin-left: -5.25em;
    margin-left: calc(-1*var(--space-xxl));
  }
  .text-component__block--left, .text-component__block--right,
  .text-component__img--left, .text-component__img--right {
    width: 50%;
  }
  .text-component__block--right.text-component__block--outset,
  .text-component__img--right.text-component__img--outset {
    margin-right: -5.25em;
    margin-right: calc(-1*var(--space-xxl));
  }
}

.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

.text--replace {
  overflow: hidden;
  color: transparent;
  text-indent: 100%;
  white-space: nowrap;
}

:root {
  --icon-xs: 16px;
  --icon-sm: 24px;
  --icon-md: 32px;
  --icon-lg: 48px;
  --icon-xl: 64px;
}

.icon {
  display: inline-block;
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
  fill: currentColor;
  height: 1em;
  width: 1em;
  line-height: 1;
}

.icon--xs {
  font-size: 16px;
  font-size: var(--icon-xs);
}

.icon--sm {
  font-size: 24px;
  font-size: var(--icon-sm);
}

.icon--md {
  font-size: 32px;
  font-size: var(--icon-md);
}

.icon--lg {
  font-size: 48px;
  font-size: var(--icon-lg);
}

.icon--xl {
  font-size: 64px;
  font-size: var(--icon-xl);
}

.icon-text {
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
      align-items: center;
}

.icon-text > *:nth-child(2) {
  margin-left: 0.375em;
  margin-left: var(--space-xxs);
}

.icon-text .icon {
  color: inherit;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.icon-text.icon-text-gap--none > *:nth-child(2) {
  margin-left: 0;
}

.icon--is-spinning {
  -webkit-animation: icon-spin 1s infinite linear;
          animation: icon-spin 1s infinite linear;
}

@-webkit-keyframes icon-spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes icon-spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

.icon use {
  color: inherit;
  fill: currentColor;
}

:root {
  --btn-font-size: 1em;
  --btn-sm: calc(var(--btn-font-size) - 0.2em);
  --btn-md: calc(var(--btn-font-size) + 0.2em);
  --btn-lg: calc(var(--btn-font-size) + 0.4em);
}

.btn {
  display: -ms-inline-flexbox;
  display: inline-flex;
  position: relative;
  white-space: nowrap;
  text-decoration: none;
  line-height: 1;
  padding: 0.5em 0.75em;
  padding: var(--space-xs) var(--space-sm);
  border-radius: 0.25em;
  font-size: 1em;
  font-size: var(--btn-font-size);
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}

.btn--primary {
  background-color: hsl(199, 92%, 74%);
  background-color: var(--color-primary);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.btn--subtle {
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
  border: 1px solid hsl(0, 0%, 20%);
  border: 1px solid var(--color-contrast-low);
}

.btn--accent {
  background-color: hsl(201, 98%, 41%);
  background-color: var(--color-accent);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.btn--disabled {
  cursor: not-allowed;
  box-shadow: none;
  opacity: 0.6;
}

.btn--sm {
  font-size: 0.8em;
  font-size: var(--btn-sm);
}

.btn--md {
  font-size: 1.2em;
  font-size: var(--btn-md);
}

.btn--lg {
  font-size: 1.4em;
  font-size: var(--btn-lg);
}

.btn--full-width {
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}

.btn .icon {
  color: inherit;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.btn--icon-text {
  -ms-flex-align: center;
      align-items: center;
}

.btn--icon-text > *:nth-child(2) {
  margin-left: 0.375em;
  margin-left: var(--space-xxs);
}

.btn--icon {
  padding: 0.5em;
  padding: var(--space-xs);
}

.form-control {
  padding: 0.5em 0.75em;
  padding: var(--space-xs) var(--space-sm);
  background: hsl(0, 0%, 7%);
  background: var(--color-bg);
  border: 2px solid hsl(0, 0%, 20%);
  border: 2px solid var(--color-contrast-low);
  width: 100%;
}

.form-control:focus {
  outline: none;
  border-color: hsl(199, 92%, 74%);
  border-color: var(--color-primary);
  --color-shadow: hsla(199, 92%, 74%, 0.2);
  --color-shadow: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
  box-shadow: undefined;
  box-shadow: 0 0 0 3px var(--color-shadow);
}

.form-control:focus:focus{
  box-shadow: 0 0 0 3px hsla(199, 92%, 74%, 0.2);
  box-shadow: 0 0 0 3px var(--color-shadow);
}

.form-control::-webkit-input-placeholder {
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
}

.form-control::-moz-placeholder {
  opacity: 1;
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
}

.form-control:-ms-input-placeholder {
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
}

.form-control:-moz-placeholder {
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
}

.form-control[disabled], .form-control[readonly] {
  cursor: not-allowed;
}

.form-control[aria-invalid="true"] {
  border-color: hsl(355, 90%, 61%);
  border-color: var(--color-error);
}

.form-control[aria-invalid="true"]:focus {
  --color-shadow: hsla(355, 90%, 61%, 0.2);
  --color-shadow: hsla(var(--color-error-h), var(--color-error-s), var(--color-error-l), 0.2);
  box-shadow: undefined;
  box-shadow: 0 0 0 3px var(--color-shadow);
}

.form-control[aria-invalid="true"]:focus:focus{
  box-shadow: 0 0 0 3px hsla(355, 90%, 61%, 0.2);
  box-shadow: 0 0 0 3px var(--color-shadow);
}

.form-legend {
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
  line-height: 1.2;
  font-size: 1.2em;
  font-size: var(--text-md);
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

.form-label {
  display: inline-block;
  font-size: 0.83333em;
  font-size: var(--text-sm);
  margin-bottom: 0.25em;
  margin-bottom: var(--space-xxxs);
}

.form__msg-error {
  background-color: hsl(355, 90%, 61%);
  background-color: var(--color-error);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  font-size: 0.83333em;
  font-size: var(--text-sm);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding: 0.5em;
  padding: var(--space-xs);
  margin-top: 0.75em;
  margin-top: var(--space-sm);
  border-radius: 0.25em;
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
}

.form__msg-error::before {
  content: '';
  position: absolute;
  left: 0.75em;
  left: var(--space-sm);
  top: 0;
  -webkit-transform: translateY(-100%);
      -ms-transform: translateY(-100%);
          transform: translateY(-100%);
  width: 0;
  height: 0;
  border: 8px solid transparent;
  border-bottom-color: hsl(355, 90%, 61%);
  border-bottom-color: var(--color-error);
}

.form__msg-error--is-visible {
  position: relative;
  clip: auto;
}

.radio-list > *, .checkbox-list > * {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: baseline;
      align-items: baseline;
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

.radio-list > *:last-of-type, .checkbox-list > *:last-of-type {
  margin-bottom: 0;
}

.radio-list label, .checkbox-list label {
  line-height: 1.4;
  line-height: var(--body-line-height);
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.radio-list input, .checkbox-list input {
  vertical-align: top;
  margin-right: 0.25em;
  margin-right: var(--space-xxxs);
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.radio-list.radio-list--inline, .radio-list.checkbox-list--inline, .checkbox-list.radio-list--inline, .checkbox-list.checkbox-list--inline {
  display: -ms-flexbox;
  display: flex;
  margin-bottom: -1.25em;
  margin-bottom: calc(-1*var(--space-md));
}

.radio-list.radio-list--inline > *, .radio-list.checkbox-list--inline > *, .checkbox-list.radio-list--inline > *, .checkbox-list.checkbox-list--inline > * {
  margin: 0 1.25em 1.25em 0;
  margin: 0 var(--space-md) var(--space-md) 0;
}

:root {
  --zindex-header: 2;
  --zindex-popover: 4;
  --zindex-fixed-element: 5;
  --zindex-overlay: 10;
}

@media not all and (min-width: 30rem) {
  .display--xs {
    display: none !important;
  }
}

@media (min-width: 30rem) {
  .hide--xs {
    display: none !important;
  }
}

@media not all and (min-width: 37.5rem) {
  .display--sm {
    display: none !important;
  }
}

@media (min-width: 37.5rem) {
  .hide--sm {
    display: none !important;
  }
}

@media not all and (min-width: 64rem) {
  .display--md {
    display: none !important;
  }
}

@media (min-width: 64rem) {
  .hide--md {
    display: none !important;
  }
}

@media not all and (min-width: 80rem) {
  .display--lg {
    display: none !important;
  }
}

@media (min-width: 80rem) {
  .hide--lg {
    display: none !important;
  }
}

@media not all and (min-width: 90rem) {
  .display--xl {
    display: none !important;
  }
}

@media (min-width: 90rem) {
  .hide--xl {
    display: none !important;
  }
}

:root {
  --display: block;
}

.is-visible {
  display: block !important;
  display: var(--display) !important;
}

.is-hidden {
  display: none !important;
}

.sr-only {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  width: 1px;
  height: 1px;
  overflow: hidden;
  padding: 0;
  border: 0;
  white-space: nowrap;
}

/* --------------------------------

Title: Main Header
Descr: Accessible website navigation

-------------------------------- */
:root {
  --main-header-height: 50px;
  --main-header-height-md: 70px;
}

.main-header {
  position: relative;
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
  border-bottom: 1px solid hsl(0, 0%, 20%);
  border-bottom: 1px solid var(--color-contrast-low);
  z-index: 2;
  z-index: var(--zindex-header);
}

.main-header__layout {
  padding: 0.75em 0;
  padding: var(--space-sm) 0;
}

.main-header__logo a, .main-header__logo svg, .main-header__logo img {
  display: block;
}

.main-header__nav {
  margin-top: 0.75em;
  margin-top: var(--space-sm);
  font-size: 1.25em;
}

.main-header__nav-label {
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
  margin-bottom: 0.5em;
  margin-bottom: var(--space-xs);
}

.main-header__nav-item {
  margin-bottom: 0.5em;
  margin-bottom: var(--space-xs);
}

.main-header__nav-link {
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
}

.main-header__nav-link[aria-current] {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
}

.main-header__nav-divider {
  height: 1px;
  width: 100%;
  background-color: hsl(0, 0%, 20%);
  background-color: var(--color-contrast-low);
}

.main-header__nav-trigger {
  display: none;
}

.main-header__nav-trigger-icon {
  position: relative;
  display: block;
  height: 2px;
  width: 1em;
  background-color: currentColor;
  margin-right: 0.375em;
  margin-right: var(--space-xxs);
  transition: 0.2s;
}

.main-header__nav-trigger-icon::before, .main-header__nav-trigger-icon::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: inherit;
  height: inherit;
  background-color: currentColor;
  transition: 0.2s;
}

.main-header__nav-trigger-icon::before {
  -webkit-transform: translateY(-5px);
      -ms-transform: translateY(-5px);
          transform: translateY(-5px);
}

.main-header__nav-trigger-icon::after {
  -webkit-transform: translateY(5px);
      -ms-transform: translateY(5px);
          transform: translateY(5px);
}

.main-header__nav-trigger[aria-expanded="true"] .main-header__nav-trigger-icon {
  background-color: transparent;
}

.main-header__nav-trigger[aria-expanded="true"] .main-header__nav-trigger-icon::before {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}

.main-header__nav-trigger[aria-expanded="true"] .main-header__nav-trigger-icon::after {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.js .main-header, .js .main-header__layout {
  height: 50px;
  height: var(--main-header-height);
}

.js .main-header__layout {
  padding: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
}

.js .main-header__nav {
  margin-top: 0;
  position: absolute;
  top: 50px;
  top: var(--main-header-height);
  left: 0;
  width: 100%;
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
  box-shadow: 0 1px 8px rgba(0, 0, 0, .1), 0 8px 24px rgba(0, 0, 0, .15);
  box-shadow: var(--shadow-md);
  padding: 1.25em;
  padding: var(--component-padding);
  display: none;
}

.js .main-header__nav--is-visible {
  display: block;
}

.js .main-header__nav-trigger {
  display: -ms-inline-flexbox;
  display: inline-flex;
}

@media (min-width: 64rem) {
  .main-header, .main-header__layout {
    height: 70px;
    height: var(--main-header-height-md);
  }
  .main-header__layout {
    padding: 0;
    display: table;
    width: 100%;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
        justify-content: space-between;
    -ms-flex-align: center;
        align-items: center;
  }
  .main-header__logo {
    display: table-cell;
    vertical-align: middle;
  }
  .main-header__nav {
    float: right;
    margin-top: 0;
    font-size: 0.875em;
  }
  .main-header__nav-label {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
            clip-path: inset(50%);
  }
  .main-header__nav-list {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
        align-items: center;
  }
  .main-header__nav-item {
    display: inline-block;
    margin-bottom: 0;
    margin-left: 1.25em;
    margin-left: var(--space-md);
  }
  .main-header__nav-divider {
    height: 1em;
    width: 1px;
  }
  .js .main-header, .js .main-header__layout {
    height: 70px;
    height: var(--main-header-height-md);
  }
  .js .main-header__nav {
    padding: 0;
    background-color: transparent;
    position: static;
    width: auto;
    box-shadow: none;
    display: block;
  }
  .js .main-header__nav-trigger {
    display: none;
  }
}

/* --------------------------------

Title: Main Footer
Descr: Footer navigation

-------------------------------- */
.main-footer {
  padding: 2em 0;
  padding: var(--space-lg) 0;
  margin-left: 270px;
  position: fixed;
  bottom: 0;
  right: 0;
  left: 0;
  background: #333;
  z-index: 10;
}

@media (min-width: 64rem) {
  .main-footer__content {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
}

.main-footer__logo {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

.main-footer__logo a,
.main-footer__logo svg,
.main-footer__logo img {
  width: 130px;
  height: 32px;
  display: block;
}

@media (min-width: 64rem) {
  .main-footer__nav {
    width: calc(100% - 420px);
  }
}

@media (min-width: 80rem) {
  .main-footer__nav {
    width: auto;
  }
}

.main-footer__nav-list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: start;
      align-items: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.main-footer__nav-item {
  display: grid;
  grid-gap: 0.375em;
  grid-gap: var(--space-xxs);
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
  width: 100%;
  padding-right: 0.75em;
  padding-right: var(--space-sm);
}

@media (min-width: 30rem) {
  .main-footer__nav-item {
    width: 50%;
  }
}

@media (min-width: 80rem) {
  .main-footer__nav-item {
    grid-gap: 0.5em;
    grid-gap: var(--space-xs);
    width: 240px;
  }
}

.main-footer__nav-item a {
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
}

.main-footer__nav-item a:hover {
  color: hsl(0, 0%, 88%);
  color: var(--color-contrast-high);
}

@media (min-width: 80rem) {
  .main-footer__nav-item a {
    font-size: 0.9em;
  }
}

.main-footer__colophon {
  border-top: 1px solid hsl(0, 0%, 20%);
  border-top: 1px solid var(--color-contrast-low);
  padding-top: 0.25em;
  padding-top: var(--space-xxxs);
  margin-top: 1.25em;
  margin-top: var(--space-md);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-align: center;
      align-items: center;
}

.main-footer__colophon-nav {
  font-size: 0.83333em;
  font-size: var(--text-sm);
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
  margin-right: 0.75em;
  margin-right: var(--space-sm);
}

.main-footer__colophon-nav > * {
  margin-right: 0.375em;
  margin-right: var(--space-xxs);
}

.main-footer__colophon-nav a {
  color: inherit;
}

.main-footer__colophon-nav a:hover {
  color: hsl(0, 0%, 88%);
  color: var(--color-contrast-high);
}

.main-footer__socials {
  display: -ms-flexbox;
  display: flex;
  margin: 0.375em 0;
  margin: var(--space-xxs) 0;
}

.main-footer__socials a {
  text-decoration: none;
  display: inline-block;
  margin-left: 0.375em;
  margin-left: var(--space-xxs);
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
}

.main-footer__socials a:hover {
  color: hsl(0, 0%, 88%);
  color: var(--color-contrast-high);
}

.main-footer__socials a svg {
  display: block;
  width: 1em;
  height: 1em;
  color: inherit;
}

/* --------------------------------

Title: Accordion
Descr: Create stacked sections of content and allow the user to expand/collapse them

-------------------------------- */
:root {
  --accordion-icon-size: 1em;
  --accordion-icon-stroke-width: 2px;
}

.accordion__item {
  border: 0px solid hsl(0, 0%, 20%);
  border: 0px solid var(--color-contrast-low);
  border-bottom-width: 1px;
}

.accordion__item:first-child {
  border-top-width: 1px;
}

.accordion__header {
  background-color: transparent;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: inherit;
  line-height: inherit;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0.75em 1.25em;
  padding: var(--space-sm) var(--component-padding);
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: justify;
      justify-content: space-between;
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
  font-weight: bold;
}

.accordion__header:hover {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
}

.accordion__header-title {
  font-size: 1.2em;
  font-size: var(--text-md);
  text-align: left;
}

.accordion__header-icon {
  float: right;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-left: 0.75em;
  margin-left: var(--space-sm);
  display: none;
}

.accordion__header-icon i {
  position: relative;
  width: 1em;
  width: var(--accordion-icon-size);
  height: 1em;
  height: var(--accordion-icon-size);
  display: block;
  will-change: transform;
}

.accordion__header-icon i::before, .accordion__header-icon i::after {
  content: '';
  position: absolute;
  width: 2px;
  width: var(--accordion-icon-stroke-width);
  height: 80%;
  background: currentColor;
  top: 0;
  -webkit-transform-origin: 50% 100%;
      -ms-transform-origin: 50% 100%;
          transform-origin: 50% 100%;
  will-change: transform;
  transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
}

.accordion__header-icon i::before {
  left: 50%;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.accordion__header-icon i::after {
  left: calc(50% - 1px);
  left: calc(50% - var(--accordion-icon-stroke-width)/2);
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}

.accordion__item--is-open > .accordion__header > .accordion__header-icon i::before {
  -webkit-transform: translateY(-80%) rotate(-135deg);
      -ms-transform: translateY(-80%) rotate(-135deg);
          transform: translateY(-80%) rotate(-135deg);
}

.accordion__item--is-open > .accordion__header > .accordion__header-icon i::after {
  -webkit-transform: translateY(-80%) rotate(135deg);
      -ms-transform: translateY(-80%) rotate(135deg);
          transform: translateY(-80%) rotate(135deg);
}

.accordion__header-icon .icon {
  width: 1em;
  width: var(--accordion-icon-size);
  height: 1em;
  height: var(--accordion-icon-size);
  color: inherit;
}

.accordion__panel-content {
  padding: 0.25em 1.25em 1.25em;
  padding: var(--space-xxxs) var(--component-padding) var(--component-padding);
}

.js .accordion__header-icon {
  display: block;
}

.js .accordion__panel {
  display: none;
  overflow: hidden;
  will-change: height;
  -webkit-transform: translateZ(0px);
          transform: translateZ(0px);
}

.js .accordion__item--is-open > .accordion__panel {
  display: block;
}

:root {
  --drop-cap-lines: 3;
}

.drop-cap::first-letter {
  float: left;
  line-height: 1;
  font-size: 4.2em;
  font-size: calc(1em*var(--drop-cap-lines)*var(--body-line-height));
  padding: 0 0.125em 0 0;
  text-transform: uppercase;
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
}

.text-component .drop-cap::first-letter {
  font-size: 4.2em;
  font-size: calc(1em*var(--drop-cap-lines)*var(--component-body-line-height));
}

/* --------------------------------

Title: Drawer
Descr: A slide-in panel used to display critical content.

-------------------------------- */
:root {
  --drawer-width: 400px;
}

.drawer {
  position: fixed;
  z-index: 10;
  z-index: var(--zindex-overlay);
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  visibility: hidden;
}

@media (min-width: 30rem) {
  .drawer {
    width: 400px;
    width: var(--drawer-width);
  }
}

.drawer--is-visible {
  visibility: visible;
}

.drawer--open-left {
  right: auto;
  left: 0;
}

.drawer__content {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
  box-shadow: 0 1px 8px rgba(0, 0, 0, .1), 0 8px 24px rgba(0, 0, 0, .15);
  box-shadow: var(--shadow-md);
  -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
          transform: translateX(100%);
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  transition-timing-function: cubic-bezier(0.645, 0.045, 0.355, 1);
  transition-timing-function: var(--transition-ease-in-out);
}

.drawer--open-left .drawer__content {
  -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
          transform: translateX(-100%);
}

.drawer--is-visible .drawer__content {
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}

.drawer__body {
  padding: 0.75em 1.25em;
  padding: var(--space-sm) var(--component-padding);
  height: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.drawer__close-btn {
  position: fixed;
  z-index: 5;
  z-index: var(--zindex-fixed-element);
  top: 0.375em;
  top: var(--space-xxs);
  right: 0.375em;
  right: var(--space-xxs);
  width: 32px;
  height: 32px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  border-radius: 50%;
  background-color: hsla(0, 0%, 100%, 0.85);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.85);
}

.drawer__close-btn:hover {
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-contrast-higher);
}

.drawer__close-btn .icon {
  display: block;
  color: hsl(0, 0%, 7%);
  color: var(--color-bg);
  font-size: 16px;
}

.drawer--fixed-header .drawer__content {
  overflow: auto;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
}

.drawer--fixed-header .drawer__header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  padding: 0.5em 1.25em;
  padding: var(--space-xs) var(--component-padding);
  border-bottom: 1px solid hsl(0, 0%, 20%);
  border-bottom: 1px solid var(--color-contrast-low);
}

.drawer--fixed-header .drawer__close-btn {
  position: static;
}

.drawer--modal {
  width: 100%;
  background-color: hsla(0, 0%, 100%, 0);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0);
  transition: background-color 0.3s;
}

.drawer--modal.drawer--is-visible {
  background-color: hsla(0, 0%, 100%, 0.6);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.6);
}

.drawer--modal.drawer--open-left .drawer__content {
  right: auto;
  left: 0;
}

@media (min-width: 30rem) {
  .drawer--modal .drawer__content {
    width: 400px;
    width: var(--drawer-width);
  }
}

/* --------------------------------

Title: Scrollbar
Descr: (WebKit) Custom Scrollbar

-------------------------------- */
.scrollbar::-webkit-scrollbar {
  width: 5px;
}

.scrollbar::-webkit-scrollbar-track {
  background-color: transparent;
}

.scrollbar:hover::-webkit-scrollbar-thumb {
  background-color: hsla(0, 0%, 100%, 0.5);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.5);
  border-radius: 0;
}

.scrollbar::-webkit-scrollbar-thumb:hover {
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-contrast-higher);
}

/* --------------------------------

Title: Slideshow
Descr: Show a collection of items one at a time.

-------------------------------- */
.slideshow__item {
  height: 280px;
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.slideshow__item > .flex {
  height: 100%;
}

.slideshow__item:focus {
  outline: none;
}

@media (min-width: 64rem) {
  .slideshow__item {
    height: 400px;
  }
}

@media (min-width: 80rem) {
  .slideshow__item {
    height: 480px;
  }
}

.slideshow__item-content {
  width: calc(100% - 2.5em);
  width: calc(100% - 2*var(--component-padding));
  max-width: 600px;
}

.slideshow__item-content--center {
  text-align: center;
}

.slideshow__item-content--center .slideshow__cta {
  -ms-flex-pack: center;
      justify-content: center;
}

.js .slideshow {
  position: relative;
  overflow: hidden;
}

.js .slideshow__content {
  overflow: hidden;
}

.js .slideshow__item {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
}

.js .slideshow__item--selected {
  position: relative;
  z-index: 3;
}

.js .slideshow--transition-fade .slideshow__item {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0s 0.5s, visibility 0s 0.5s;
}

.js .slideshow--transition-fade .slideshow__item--selected {
  visibility: visible;
  opacity: 1;
  transition: opacity 0.5s, visibility 0.5s;
}

.js .slideshow--transition-slide .slideshow__item {
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  -webkit-animation-timing-function: var(--transition-ease-out);
          animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
          animation-timing-function: var(--transition-ease-out);
}

.js .slideshow--transition-slide .slideshow__item > * {
  visibility: hidden;
}

.js .slideshow--transition-slide .slideshow__item--selected > * {
  visibility: visible;
}

.js .slideshow--transition-slide .slideshow__item--slide-in-left {
  -webkit-animation-name: slide-in-left;
          animation-name: slide-in-left;
}

.js .slideshow--transition-slide .slideshow__item--slide-in-right {
  -webkit-animation-name: slide-in-right;
          animation-name: slide-in-right;
}

.js .slideshow--transition-slide .slideshow__item--slide-out-left {
  -webkit-animation-name: slide-out-left;
          animation-name: slide-out-left;
}

.js .slideshow--transition-slide .slideshow__item--slide-out-right {
  -webkit-animation-name: slide-out-right;
          animation-name: slide-out-right;
}

.js .slideshow--transition-slide .slideshow__item--slide-out-left,
.js .slideshow--transition-slide .slideshow__item--slide-out-right {
  z-index: 2;
}

.js .slideshow--transition-slide .slideshow__item--slide-out-left.slideshow__item--selected,
.js .slideshow--transition-slide .slideshow__item--slide-out-right.slideshow__item--selected {
  z-index: 3;
}

.js .slideshow--transition-slide .slideshow__item--slide-out-left > *,
.js .slideshow--transition-slide .slideshow__item--slide-out-right > * {
  visibility: visible;
}

@-webkit-keyframes slide-in-left {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes slide-in-left {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@-webkit-keyframes slide-in-right {
  0% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes slide-in-right {
  0% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@-webkit-keyframes slide-out-left {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}

@keyframes slide-out-left {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}

@-webkit-keyframes slide-out-right {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes slide-out-right {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

.js .slideshow[data-swipe="on"] .slideshow__content {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.js .slideshow[data-swipe="on"] .slideshow__content img {
  pointer-events: none;
}

.slideshow__control {
  display: none;
}

.js .slideshow[data-swipe="on"] .slideshow__control {
  display: none;
}

.js .slideshow__control {
  display: block;
  position: absolute;
  z-index: 4;
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
}

.js .slideshow__control:first-of-type {
  left: 0.5em;
  left: var(--space-xs);
}

.js .slideshow__control:last-of-type {
  right: 0.5em;
  right: var(--space-xs);
}

.js .slideshow__control button,
.js .slideshow__control .icon {
  display: block;
}

.js .slideshow__control button {
  background-color: hsla(0, 0%, 0%, 0.75);
  background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.75);
  height: 48px;
  width: 24px;
  border-radius: 0.25em;
  cursor: pointer;
  transition: background .2s, -webkit-transform 0.2s;
  transition: background .2s, transform 0.2s;
  transition: background .2s, transform 0.2s, -webkit-transform 0.2s;
}

.js .slideshow__control button:hover {
  background-color: hsla(0, 0%, 100%, 0.85);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.85);
}

.js .slideshow__control button:hover .icon {
  color: hsl(0, 0%, 7%);
  color: var(--color-bg);
}

.js .slideshow__control button:active {
  -webkit-transform: scale(0.95);
      -ms-transform: scale(0.95);
          transform: scale(0.95);
}

.js .slideshow__control .icon {
  width: 24px;
  height: 24px;
  margin: 0 auto;
  transition: color .2s;
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
}

@supports (grid-area: auto) {
  .js .slideshow__control button {
    background-color: transparent;
  }
  .js .slideshow__control .icon {
    color: hsl(0, 0%, 100%);
    color: var(--color-contrast-higher);
  }
}

@media (min-width: 64rem) {
  .js .slideshow[data-swipe="on"] .slideshow__control {
    display: block;
  }
  .js .slideshow__control button {
    height: 64px;
    width: 32px;
  }
  .js .slideshow__control .icon {
    width: 32px;
    height: 32px;
  }
}

.slideshow__navigation {
  position: absolute;
  z-index: 4;
  bottom: 0;
  width: 100%;
  height: 32px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: transparent;
}

.slideshow__nav-item {
  display: inline-block;
  margin: 0 0.25em;
  margin: 0 var(--space-xxxs);
}

.slideshow__nav-item button {
  display: block;
  position: relative;
  font-size: 8px;
  color: hsl(0, 0%, 88%);
  color: var(--color-contrast-high);
  height: 1em;
  width: 1em;
  border-radius: 50%;
  background-color: currentColor;
  opacity: 0.4;
  cursor: pointer;
  transition: background .3s;
}

.slideshow__nav-item button::before {
  content: '';
  position: absolute;
  top: calc(50% - 0.5em);
  left: calc(50% - 0.5em);
  height: 1em;
  width: 1em;
  font-size: 14px;
  border-radius: inherit;
  border: 1px solid hsl(0, 0%, 88%);
  border: 1px solid var(--color-contrast-high);
  opacity: 0;
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
  transition: 0.3s;
}

.slideshow__nav-item button:focus {
  outline: none;
}

.slideshow__nav-item button:focus::before {
  opacity: 1;
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

.slideshow__nav-item--selected button {
  opacity: 1;
}

@media (min-width: 64rem) {
  .slideshow__navigation {
    height: 40px;
  }
  .slideshow__nav-item button {
    font-size: 10px;
  }
  .slideshow__nav-item button::before {
    font-size: 16px;
  }
}

/* --------------------------------

Title: Tabs
Descr: Tabs are multiple content sections (panels), accessible one at a time using control labels

-------------------------------- */
:root {
  --tabs-border-width: 2px;
  --tabs-radius: 0.25em;
  --tabs-control-gap: 0;
  --tabs-control-radius: 0;
}

.tabs {
  border: 2px solid hsl(0, 0%, 20%);
  border: var(--tabs-border-width) solid var(--color-contrast-low);
  padding: 1.25em;
  padding: var(--component-padding);
  border-radius: 0.25em;
  border-radius: var(--tabs-radius);
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
}

.tabs__controls {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 0.5em;
  margin-bottom: var(--space-xs);
  background-color: hsl(0, 0%, 20%);
  background-color: var(--color-contrast-low);
}

.tabs__controls li {
  display: inline-block;
  margin: 0 0.5em 0.5em 0;
  margin: 0 var(--space-xs) var(--space-xs) 0;
}

.tabs__controls a {
  display: -ms-inline-flexbox;
  display: inline-flex;
  background-color: hsl(0, 0%, 20%);
  background-color: var(--color-contrast-low);
  padding: 0.5em 0.75em;
  padding: var(--space-xs) var(--space-sm);
  white-space: nowrap;
  color: inherit;
  border-radius: 0;
  border-radius: var(--tabs-control-radius);
}

.tabs__controls a:hover {
  background-color: hsl(0, 0%, 20%);
  background-color: var(--color-contrast-low);
}

.tabs__panel {
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

.js .tabs__controls a {
  text-decoration: none;
}

.js .tabs__controls .tabs__control--selected {
  background-color: hsl(199, 92%, 74%);
  background-color: var(--color-primary);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.js .tabs__controls .tabs__control--selected:hover {
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
}

.js .tabs__panel {
  margin-bottom: 0;
  display: none;
}

.js .tabs__panel--selected {
  display: block;
}

@media (min-width: 64rem) {
  .js .tabs {
    padding: 0;
    border: none;
    background-color: transparent;
  }
  .js .tabs__controls {
    margin-bottom: 0;
  }
  .js .tabs__controls li {
    margin-top: 0;
    margin-left: -2px;
    margin-left: calc(-1*var(--tabs-border-width));
    margin-right: 0;
    margin-right: var(--tabs-control-gap);
    margin-bottom: 0;
  }
  .js .tabs__controls li:first-child {
    margin-left: 0;
  }
  .js .tabs__controls li:first-child a {
    border-radius: 0.25em 0 0 0;
    border-radius: var(--tabs-radius) var(--tabs-control-radius) 0 0;
  }
  .js .tabs__controls li:last-child a {
    border-radius: 0 0.25em 0 0;
    border-radius: var(--tabs-control-radius) var(--tabs-radius) 0 0;
  }
  .js .tabs__controls a {
    height: 100%;
    border: 2px solid transparent;
    border: var(--tabs-border-width) solid transparent;
    border-bottom: none;
    border-bottom-width: 0;
    border-radius: 0 0 0 0;
    border-radius: var(--tabs-control-radius) var(--tabs-control-radius) 0 0;
  }
  .js .tabs__controls .tabs__control--selected {
    background-color: hsl(0, 0%, 7%);
    background-color: var(--color-bg);
    color: hsl(199, 92%, 74%);
    color: var(--color-primary);
    position: relative;
    border-color: hsl(0, 0%, 20%);
    border-color: var(--color-contrast-low);
  }
  .js .tabs__controls .tabs__control--selected:hover {
    background-color: hsl(0, 0%, 7%);
    background-color: var(--color-bg);
  }
  .js .tabs__controls .tabs__control--selected::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -2px;
    bottom: calc(-1*var(--tabs-border-width));
    width: 100%;
    height: 2px;
    height: var(--tabs-border-width);
    background-color: hsl(0, 0%, 7%);
    background-color: var(--color-bg);
    z-index: 1;
  }
  .js .tabs__panels {
    border: 2px solid hsl(0, 0%, 20%);
    border: var(--tabs-border-width) solid var(--color-contrast-low);
    border-radius: 0;
    background-color: hsl(0, 0%, 7%);
    background-color: var(--color-bg);
  }
  .js .tabs__panel {
    padding: 0.75em;
    padding: var(--space-sm);
  }
}

/* --------------------------------

Title: Table
Descr: Data tables used to organize and display information in rows and columns

-------------------------------- */
:root {
  --table-cell-width-xs: 40px;
  --table-cell-width-sm: 80px;
  --table-cell-width-md: 120px;
  --table-cell-width-lg: 360px;
  --table-cell-width-xl: 420px;
}

.table {
  font-size: 0.875em;
  overflow: hidden;
  position: relative;
  border-bottom: 2px solid hsl(0, 0%, 20%);
  border-bottom: 2px solid var(--color-contrast-low);
}

.table table {
  vertical-align: top;
  width: 100%;
}

.table th,
.table td {
  padding: 0.75em;
  padding: var(--space-sm);
  text-align: left;
}

.table th {
  font-weight: bold;
  color: hsl(0, 0%, 100%);
  color: var(--color-contrast-higher);
}

.table__inner {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

.table__header {
  border-bottom: 2px solid hsl(0, 0%, 20%);
  border-bottom: 2px solid var(--color-contrast-low);
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
}

.table__body tr:nth-child(odd) {
  background-color: hsl(0, 0%, 11%);
  background-color: var(--color-contrast-lower);
}

.table th .icon,
.table td .icon {
  display: block;
  max-width: initial;
}

.table__scrolling-indicator,
.table__body-shadow {
  display: none;
}

.js .table::after {
  content: '';
  position: absolute;
  top: 0;
  right: -1px;
  height: 100%;
  width: 36px;
  background: linear-gradient(to right, hsla(0, 0%, 7%, 0), hsl(0, 0%, 7%));
  background: linear-gradient(to right, hsla(var(--color-bg-h), var(--color-bg-s), var(--color-bg-l), 0), var(--color-bg));
  z-index: 1;
  pointer-events: none;
  display: none;
}

.js .table.table--show-scrolling-indicator::after {
  display: block;
}

.js .table.table--show-scrolling-indicator .table__scrolling-indicator {
  display: -ms-flexbox;
  display: flex;
}

.js .table.table--scrolling-x-started .table__scrolling-indicator {
  display: none;
}

.js .table__scrolling-indicator {
  background-color: transparent;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: inherit;
  line-height: inherit;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: absolute;
  width: 40px;
  height: 40px;
  top: calc(50% - 20px);
  right: 6px;
  z-index: 2;
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-contrast-higher);
  border-radius: 50%;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  -webkit-animation: hintRight 1s;
          animation: hintRight 1s;
  display: none;
}

.js .table__scrolling-indicator .icon {
  width: 24px;
  height: 24px;
  display: block;
  color: hsl(0, 0%, 7%);
  color: var(--color-bg);
}

@supports (--css: variables) {
  .js .table--sticky-header {
    border-bottom: 0;
  }
  .js .table--sticky-header .table__header {
    border-bottom: 0;
  }
  .js .table--sticky-header .table__header tr {
    display: block;
  }
  .js .table--sticky-header .table__body {
    display: block;
    height: 500px;
    max-height: 60vh;
    width: 100%;
    overflow: auto;
  }
  .js .table--sticky-header .table__body tr {
    background-color: var(--color-bg);
  }
  .js .table--sticky-header .table__body tr:nth-child(even) {
    background-color: var(--color-contrast-lower);
  }
  .js .table--sticky-header .table__body-shadow {
    display: block;
    position: absolute;
    width: 120%;
    margin-left: -10%;
    left: 0;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2), inset 0 -1px 3px rgba(0, 0, 0, 0.2);
    pointer-events: none;
  }
  .js .table--sticky-header.table--scrolling-x .table__body {
    overflow-x: hidden;
  }
  .js .table--sticky-header.table--scrolling-x tr > :last-child {
    padding-right: 1.6rem;
  }
  .js .table--sticky-header.table--js-is-loading {
    opacity: 0;
  }
}

@-webkit-keyframes hintRight {
  0%,
  50%,
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  25%,
  75% {
    -webkit-transform: translateX(6px);
            transform: translateX(6px);
  }
}

@keyframes hintRight {
  0%,
  50%,
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  25%,
  75% {
    -webkit-transform: translateX(6px);
            transform: translateX(6px);
  }
}

.table .table__cell--no-wrap {
  white-space: nowrap;
}

.table .table__cell--center-x {
  text-align: center;
}

.table .table__cell--center-x > * {
  margin-left: auto;
  margin-right: auto;
}

.table .table__cell--center-y {
  vertical-align: middle;
}

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

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

.table .table__cell--right > * {
  margin-left: auto;
}

.table .table__cell--top {
  vertical-align: top;
}

.table .table__cell--bottom {
  vertical-align: bottom;
}

.table .table__row--is-hidden {
  height: 0;
  margin: 0;
  visibility: hidden;
  overflow: hidden;
}

.table .table__row--is-hidden > * {
  height: 0;
  padding-top: 0;
  padding-bottom: 0;
  line-height: 0;
}

.table .table__row--is-hidden > * * {
  display: none;
}

/* --------------------------------

Title: Text divider
Descr: Labelled horizontal divider for text components

-------------------------------- */
.text-divider {
  margin: 2em auto;
  margin: var(--space-lg) auto;
  display: -ms-flexbox;
  display: flex;
  text-align: center;
  -ms-flex-align: center;
      align-items: center;
}

.text-divider span {
  font-size: 0.69444em;
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  white-space: nowrap;
  padding: 0 0.75em;
  padding: 0 var(--space-sm);
}

.text-divider::before, .text-divider::after {
  content: '';
  display: inline-block;
  height: 1px;
  width: 20px;
  -ms-flex-positive: 1;
      flex-grow: 1;
  background: hsl(0, 0%, 20%);
  background: var(--color-contrast-low);
  vertical-align: middle;
}

.text-component .text-divider {
  margin: 1.25em auto;
  margin: calc(var(--space-md)*var(--text-vspace-multiplier)) auto;
}

/* --------------------------------

Title: Modal Window
Descr: A modal dialog used to display critical information.

-------------------------------- */
:root {
  /* close button */
  --modal-close-btn-size: 1.25em;
  --modal-close-btn-padding: var(--space-sm);
}

.modal {
  position: fixed;
  z-index: 10;
  z-index: var(--zindex-overlay);
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  background-color: hsla(0, 0%, 100%, 0.9);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.9);
  opacity: 0;
  visibility: hidden;
}

.modal--is-visible {
  opacity: 1;
  visibility: visible;
}

.modal__content {
  border-radius: 0.25em;
  overflow: auto;
  width: calc(100% - 1.25em);
  width: calc(100% - 2*var(--component-padding));
  max-width: 37.5rem;
  max-width: var(--container-width-xs);
  max-height: calc(100vh - 8em);
  max-height: calc(100vh - 4*(var(--modal-close-btn-size) + var(--modal-close-btn-padding)));
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
}

.modal__content--sm {
  max-width: 45rem;
  max-width: var(--container-width-sm);
}

.modal__content--md {
  max-width: 64rem;
  max-width: var(--container-width-md);
}

.modal__content--lg {
  max-width: 80rem;
  max-width: var(--container-width-lg);
}

.modal__header {
  padding: 0.75em 1.25em;
  padding: var(--space-sm) var(--component-padding);
  background-color: hsl(0, 0%, 11%);
  background-color: var(--color-contrast-lower);
}

.modal__body {
  padding: 0.75em 1.25em;
  padding: var(--space-sm) var(--component-padding);
}

.modal__footer {
  padding: 1.25em;
  padding: var(--component-padding);
}

.modal__close-btn {
  position: fixed;
  top: 0.75em;
  top: var(--space-sm);
  right: 0.75em;
  right: var(--space-sm);
  z-index: 5;
  z-index: var(--zindex-fixed-element);
  padding: 0.75em;
  padding: var(--modal-close-btn-padding);
  border-radius: 50%;
  background-color: hsla(0, 0%, 100%, 0.9);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.9);
}

.modal__close-btn:hover {
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-contrast-higher);
}

.modal__close-btn .icon {
  display: block;
  color: hsl(0, 0%, 7%);
  color: var(--color-bg);
  width: 1.25em;
  width: var(--modal-close-btn-size);
  height: 1.25em;
  height: var(--modal-close-btn-size);
  transition: -webkit-transform .2s;
  transition: transform .2s;
  transition: transform .2s, -webkit-transform .2s;
}

.modal__close-btn:hover .icon {
  -webkit-transform: scale(1.1);
      -ms-transform: scale(1.1);
          transform: scale(1.1);
}

.modal__header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
}

.modal__header .modal__close-btn {
  --modal-close-btn-size: 1em;
  --modal-close-btn-padding: 0;
  position: static;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background-color: transparent;
}

.modal__header .modal__close-btn .icon {
  color: inherit;
}

.modal[data-animation="on"] {
  transition: opacity .3s, visibility .3s;
}

.modal[data-animation="on"] .modal__content {
  will-change: transform;
  transition: -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 0.3s var(--transition-ease-out);
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.3s var(--transition-ease-out);
  transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.3s var(--transition-ease-out), -webkit-transform 0.3s var(--transition-ease-out);
  -webkit-transform: translateY(10%);
      -ms-transform: translateY(10%);
          transform: translateY(10%);
}

.modal[data-animation="on"].modal--is-visible .modal__content {
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}

/* --------------------------------

Title: Off-Canvas Content
Descr: An off-canvas section used for complementary content

-------------------------------- */
:root {
  --off-canvas-panel-width: 400px;
  --off-canvas-panel-width-opposite: -400px;
  --off-canvas-animation-duration: 0.4s;
}

.off-canvas {
  overflow: hidden;
}

.off-canvas--full-width {
  --off-canvas-animation-duration: 0.75s;
}

.off-canvas__main {
  position: relative;
  z-index: 2;
  height: 100vh;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
  box-shadow: 0 1px 8px rgba(0, 0, 0, .1), 0 8px 24px rgba(0, 0, 0, .15);
  box-shadow: var(--shadow-md);
  will-change: transform;
  transition: -webkit-transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: -webkit-transform var(--off-canvas-animation-duration) var(--transition-ease-in-out);
  transition: transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: transform var(--off-canvas-animation-duration) var(--transition-ease-in-out);
  transition: transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1), -webkit-transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: transform var(--off-canvas-animation-duration) var(--transition-ease-in-out), -webkit-transform var(--off-canvas-animation-duration) var(--transition-ease-in-out);
}

.off-canvas--visible .off-canvas__main {
  -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
          transform: translateX(100%);
}

@media (min-width: 37.5rem) {
  .off-canvas--visible:not(.off-canvas--full-width) .off-canvas__main {
    -webkit-transform: translateX(400px);
    -webkit-transform: translateX(var(--off-canvas-panel-width));
        -ms-transform: translateX(400px);
        -ms-transform: translateX(var(--off-canvas-panel-width));
            transform: translateX(400px);
            transform: translateX(var(--off-canvas-panel-width));
  }
}

.off-canvas--right.off-canvas--visible .off-canvas__main {
  -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
          transform: translateX(-100%);
}

@media (min-width: 37.5rem) {
  .off-canvas--right.off-canvas--visible:not(.off-canvas--full-width) .off-canvas__main {
    -webkit-transform: translateX(-400px);
    -webkit-transform: translateX(var(--off-canvas-panel-width-opposite));
        -ms-transform: translateX(-400px);
        -ms-transform: translateX(var(--off-canvas-panel-width-opposite));
            transform: translateX(-400px);
            transform: translateX(var(--off-canvas-panel-width-opposite));
  }
}

.off-canvas__close-btn {
  display: none;
}

.js .off-canvas__panel {
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  visibility: hidden;
  background-color: hsl(0, 0%, 11%);
  background-color: var(--color-contrast-lower);
  transition: visibility 0.4s;
  transition: visibility var(--off-canvas-animation-duration);
}

.js .off-canvas__panel:focus {
  outline: none;
}

@media (min-width: 37.5rem) {
  .js .off-canvas:not(.off-canvas--full-width) .off-canvas__panel {
    width: 400px;
    width: var(--off-canvas-panel-width);
  }
}

.js .off-canvas__content {
  height: 100%;
  padding: 50px 1.25em 0.75em;
  padding: 50px var(--component-padding) var(--space-sm);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  will-change: transform;
  transition: -webkit-transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: -webkit-transform var(--off-canvas-animation-duration) var(--transition-ease-in-out);
  transition: transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: transform var(--off-canvas-animation-duration) var(--transition-ease-in-out);
  transition: transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1), -webkit-transform 0.4s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: transform var(--off-canvas-animation-duration) var(--transition-ease-in-out), -webkit-transform var(--off-canvas-animation-duration) var(--transition-ease-in-out);
}

.js .off-canvas__close-btn {
  display: block;
  position: fixed;
  top: 0.375em;
  top: var(--space-xxs);
  left: 0.375em;
  left: var(--space-xxs);
  width: 32px;
  height: 32px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  border-radius: 50%;
  background-color: hsla(0, 0%, 100%, 0.85);
  background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.85);
  -webkit-transform: translateX(-60px);
      -ms-transform: translateX(-60px);
          transform: translateX(-60px);
  transition: -webkit-transform .4s;
  transition: transform .4s;
  transition: transform .4s, -webkit-transform .4s;
}

.js .off-canvas__close-btn:hover {
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-contrast-higher);
}

.js .off-canvas__close-btn .icon {
  display: block;
  color: hsl(0, 0%, 7%);
  color: var(--color-bg);
  font-size: 16px;
}

.js .off-canvas--visible .off-canvas__panel {
  visibility: visible;
}

.js .off-canvas--visible .off-canvas__content {
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}

.js .off-canvas--visible .off-canvas__close-btn {
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
  transition-delay: 0.4s;
  transition-delay: var(--off-canvas-animation-duration);
}

.js .off-canvas--right .off-canvas__panel {
  left: auto;
  right: 0;
}

.js .off-canvas--right:not(.off-canvas--visible) .off-canvas__content {
  -webkit-transform: translateX(50%);
      -ms-transform: translateX(50%);
          transform: translateX(50%);
}

.js .off-canvas--right .off-canvas__close-btn {
  left: auto;
  right: 0.375em;
  right: var(--space-xxs);
}

.js .off-canvas--right:not(.off-canvas--visible) .off-canvas__close-btn {
  -webkit-transform: translateX(60px);
      -ms-transform: translateX(60px);
          transform: translateX(60px);
}

/* --------------------------------

Title: Testimonials
Descr: A gallery of testimonial cards

-------------------------------- */
.testimonials__grid > * {
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

@media (min-width: 64rem) {
  @supports (grid-area: auto) {
    .testimonials__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      grid-gap: 0.75em;
      grid-gap: var(--space-sm);
    }
    .testimonials__grid > * {
      margin-bottom: 0;
    }
  }
}

.testimonials__card {
  background-color: hsl(0, 0%, 11%);
  background-color: var(--color-contrast-lower);
  padding: 1.25em;
  padding: var(--component-padding);
  border-radius: 0.25em;
  border-radius: var(--radius);
}

.testimonials__card .icon {
  display: block;
  width: 64px;
  height: 64px;
  color: hsl(0, 0%, 20%);
  color: var(--color-contrast-low);
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

.testimonials__card footer {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media (min-width: 64rem) {
  .testimonials__card {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .testimonials__card footer {
    margin-top: auto;
  }
}

.testimonials__quote {
  line-height: 1.4;
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

.testimonials__img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin-right: 0.375em;
  margin-right: var(--space-xxs);
}

.testimonials__img img {
  display: block;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid hsl(0, 0%, 7%);
  border: 2px solid var(--color-bg);
}

.testimonials__cite {
  font-size: 0.83333em;
  font-size: var(--text-sm);
}

.testimonials__cite span {
  display: block;
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
  margin-top: 0.125em;
  margin-top: var(--space-xxxxs);
}

.testimonials--center-content .testimonials__card {
  text-align: center;
}

.testimonials--center-content .testimonials__card .icon {
  margin-left: auto;
  margin-right: auto;
}

.testimonials--center-content .testimonials__card footer {
  display: block;
}

.testimonials--center-content .testimonials__card .testimonials__img {
  margin: 0 0 0.25em;
  margin: 0 0 var(--space-xxxs);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
}

/* --------------------------------

Title: Tabbed Navigation
Descr: Tabbed secondary navigation

-------------------------------- */
:root {
  --s-tabs-border-bottom-width: 1px;
  --s-tabs-selected-item-border-bottom-width: 1px;
}

.s-tabs {
  position: relative;
}

.s-tabs::after {
  content: '';
  position: absolute;
  right: -1px;
  top: 0;
  height: calc(100% - 1px);
  height: calc(100% - var(--s-tabs-border-bottom-width));
  width: 2em;
  background: linear-gradient(90deg, hsla(0, 0%, 7%, 0), hsl(0, 0%, 7%));
  background: linear-gradient(90deg, hsla(var(--color-bg-h), var(--color-bg-s), var(--color-bg-l), 0), var(--color-bg));
  pointer-events: none;
  z-index: 1;
}

.s-tabs__list {
  display: -ms-flexbox;
  display: flex;
  overflow: auto;
  -webkit-overflow-scrolling: auto;
}

.s-tabs__list::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 1px;
  height: var(--s-tabs-border-bottom-width);
  left: 0;
  bottom: 0;
  background-color: hsl(0, 0%, 20%);
  background-color: var(--color-contrast-low);
}

.s-tabs__list li {
  margin-right: 0.75em;
  margin-right: var(--space-sm);
}

.s-tabs__list a {
  color: inherit;
  text-decoration: none;
  display: inline-block;
  padding: 0.5em;
  padding: var(--space-xs);
  white-space: nowrap;
  border-bottom: 1px solid transparent;
  border-bottom: var(--s-tabs-selected-item-border-bottom-width) solid transparent;
  z-index: 1;
}

.s-tabs__list a:hover {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
}

.s-tabs__list .s-tabs__item--selected {
  position: relative;
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
  border-bottom-color: hsl(199, 92%, 74%);
  border-bottom-color: var(--color-primary);
}

/* --------------------------------

Title: Advanced Gallery
Descr: Advanced image gallery template

-------------------------------- */
.adv-gallery__img-wrapper img {
  width: 100%;
  display: block;
}

.adv-gallery__label {
  background-color: hsl(0, 0%, 11%);
  background-color: var(--color-contrast-lower);
  padding: 1.25em;
  padding: var(--space-md);
}

.adv-gallery__grid > * {
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

@media (min-width: 64rem) {
  .adv-gallery__grid > :nth-child(1), .adv-gallery__grid > :nth-child(2), .adv-gallery__grid > :nth-child(3) {
    width: 32%;
    float: left;
  }
  .adv-gallery__grid > :nth-child(1), .adv-gallery__grid > :nth-child(2) {
    margin-right: 2%;
  }
  .adv-gallery__grid > :nth-child(4) {
    clear: both;
  }
}

@supports (grid-area: auto) {
  .adv-gallery__grid {
    display: grid;
    grid-gap: 1.25em;
    grid-gap: var(--space-md);
  }
  .adv-gallery__grid > * {
    margin: 0 !important;
    width: auto !important;
    float: none !important;
  }
  @media (min-width: 64rem) {
    .adv-gallery__grid {
      grid-template-columns: repeat(12, 1fr);
    }
    .adv-gallery__grid > :nth-child(1) {
      grid-column: span 5;
    }
    .adv-gallery__grid > :nth-child(2) {
      grid-column: span 7;
    }
    .adv-gallery__grid > :nth-child(3) {
      grid-column: span 9;
    }
    .adv-gallery__grid > :nth-child(4) {
      grid-column: span 3;
    }
  }
  @media (min-width: 90rem) {
    .adv-gallery__grid {
      grid-gap: 0.75em;
      grid-gap: var(--space-sm);
      grid-template-rows: repeat(12, 50px);
    }
    .adv-gallery__grid > :nth-child(1) {
      grid-column: 1 / 4;
      grid-row: 1 / 7;
    }
    .adv-gallery__grid > :nth-child(2) {
      grid-column: 1 / 4;
      grid-row: 7 / -1;
    }
    .adv-gallery__grid > :nth-child(3) {
      grid-column: 4 / 11;
      grid-row: 1 / -1;
    }
    .adv-gallery__grid > :nth-child(4) {
      grid-column: 11 / 13;
      grid-row: 1 / -1;
    }
    .adv-gallery__img-wrapper img {
      -o-object-fit: cover;
         object-fit: cover;
      height: 100%;
    }
    .adv-gallery__label {
      display: -ms-flexbox;
      display: flex;
    }
    .adv-gallery__label p {
      margin-top: auto;
    }
    .adv-gallery__label p::before {
      content: '';
      display: block;
      height: 80px;
      width: 1px;
      background-color: hsl(0, 0%, 88%);
      background-color: var(--color-contrast-high);
      margin-bottom: 0.75em;
      margin-bottom: var(--space-sm);
    }
  }
}

.fc-unthemed .fc-divider, .fc-unthemed .fc-popover .fc-header, .fc-unthemed .fc-list-heading td {
  background-color: transparent;
}

.fc-unthemed .fc-list-item:hover td {
  background-color: hsl(0, 0%, 11%);
  background-color: var(--color-contrast-lower);
}

.fc-unthemed td.fc-today {
  background-color: hsl(0, 0%, 11%);
  background-color: var(--color-contrast-lower);
}

/* --------------------------------

File#: _1_custom-select
Title: Custom Select
Descr: Custom Select Control

-------------------------------- */
:root {
  --select-icon-size: 1em;
  --select-icon-right-margin: var(--space-sm);
}

.select {
  position: relative;
}

.select select {
  padding-right: 2.5em;
  padding-right: calc(var(--select-icon-size) + var(--select-icon-right-margin)*2);
}

.select .icon {
  width: 1em;
  width: var(--select-icon-size);
  height: 1em;
  height: var(--select-icon-size);
  position: absolute;
  right: 0.75em;
  right: var(--select-icon-right-margin);
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  pointer-events: none;
}

/* --------------------------------

File#: _1_fill-loader
Title: Loader
Descr: A collection of animated loaders with a filling effect

-------------------------------- */
.fill-loader {
  position: relative;
  overflow: hidden;
  display: inline-block;
}

.fill-loader__fill {
  position: absolute;
}

@supports ((-webkit-animation-name: this) or (animation-name: this)) {
  .fill-loader__label {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
            clip-path: inset(50%);
  }
}

@supports ((-webkit-animation-name: this) or (animation-name: this)) {
  .fill-loader--v1 .fill-loader__base,
  .fill-loader--v2 .fill-loader__base {
    width: 64px;
    height: 4px;
    background-color: hsl(0, 0%, 20%);
    background-color: var(--color-contrast-low);
  }
  .fill-loader--v1 .fill-loader__fill,
  .fill-loader--v2 .fill-loader__fill {
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    will-change: transform;
  }
  .fill-loader--v1 .fill-loader__fill {
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-1 0.8s infinite var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-1 0.8s infinite var(--ease-in-out);
  }
  .fill-loader--v2 .fill-loader__fill {
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-2 0.8s infinite alternate var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-2 0.8s infinite alternate var(--ease-in-out);
  }
}

@-webkit-keyframes fill-loader-1 {
  0% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  49% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  51% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
  100% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
}

@keyframes fill-loader-1 {
  0% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  49% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  51% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
  100% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
}

@-webkit-keyframes fill-loader-2 {
  0% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(0.1);
            transform: scaleX(0.1);
  }
  49% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  51% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
  100% {
    -webkit-transform: scaleX(0.1);
            transform: scaleX(0.1);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
}

@keyframes fill-loader-2 {
  0% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(0.1);
            transform: scaleX(0.1);
  }
  49% {
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  51% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
  100% {
    -webkit-transform: scaleX(0.1);
            transform: scaleX(0.1);
    -webkit-transform-origin: 100% 0;
            transform-origin: 100% 0;
  }
}

@supports ((-webkit-animation-name: this) or (animation-name: this)) {
  .fill-loader--v3 .fill-loader__base {
    width: 120px;
    height: 10px;
    background-color: hsl(0, 0%, 20%);
    background-color: var(--color-contrast-low);
  }
  .fill-loader--v3 .fill-loader__fill {
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    -webkit-transform: scaleX(0);
        -ms-transform: scaleX(0);
            transform: scaleX(0);
    will-change: transform;
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-1 1s infinite var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-1 1s infinite var(--ease-in-out);
  }
  .fill-loader--v3 .fill-loader__fill--1st {
    background-color: hsl(0, 0%, 54%);
    background-color: var(--color-contrast-medium);
  }
  .fill-loader--v3 .fill-loader__fill--2nd {
    background-color: hsl(0, 0%, 100%);
    background-color: var(--color-contrast-higher);
    -webkit-animation-delay: 0.1s;
            animation-delay: 0.1s;
  }
  .fill-loader--v3 .fill-loader__fill--3rd {
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
}

@supports ((-webkit-animation-name: this) or (animation-name: this)) {
  .fill-loader--v4 {
    width: 90%;
    max-width: 300px;
  }
  .fill-loader--v4 .fill-loader__base {
    height: 4px;
    background-color: hsl(0, 0%, 20%);
    background-color: var(--color-contrast-low);
  }
  .fill-loader--v4 .fill-loader__fill {
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-4 1.6s infinite var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-4 1.6s infinite var(--ease-in-out);
    will-change: left, right;
  }
}

@-webkit-keyframes fill-loader-4 {
  0% {
    left: 0;
    right: 100%;
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
  }
  10%,
  60% {
    left: 0;
  }
  40%,
  90% {
    right: 0;
  }
  50% {
    left: 100%;
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
  }
  51% {
    left: 0;
    right: 100%;
    background-color: hsl(201, 98%, 41%);
    background-color: var(--color-accent);
  }
  100% {
    left: 100%;
    background-color: hsl(201, 98%, 41%);
    background-color: var(--color-accent);
  }
}

@keyframes fill-loader-4 {
  0% {
    left: 0;
    right: 100%;
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
  }
  10%,
  60% {
    left: 0;
  }
  40%,
  90% {
    right: 0;
  }
  50% {
    left: 100%;
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
  }
  51% {
    left: 0;
    right: 100%;
    background-color: hsl(201, 98%, 41%);
    background-color: var(--color-accent);
  }
  100% {
    left: 100%;
    background-color: hsl(201, 98%, 41%);
    background-color: var(--color-accent);
  }
}

@supports ((-webkit-animation-name: this) or (animation-name: this)) {
  .fill-loader--v5 .fill-loader__base {
    width: 48px;
    height: 48px;
    background-color: hsl(0, 0%, 20%);
    background-color: var(--color-contrast-low);
  }
  .fill-loader--v5 .fill-loader__fill {
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    will-change: transform;
  }
  .fill-loader--v5 .fill-loader__fill--1st {
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
    -webkit-transform-origin: 0 50%;
        -ms-transform-origin: 0 50%;
            transform-origin: 0 50%;
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-5-1st 2s infinite var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-5-1st 2s infinite var(--ease-in-out);
  }
  .fill-loader--v5 .fill-loader__fill--2nd {
    background-color: hsl(0, 0%, 100%);
    background-color: var(--color-contrast-higher);
    -webkit-transform-origin: 50% 100%;
        -ms-transform-origin: 50% 100%;
            transform-origin: 50% 100%;
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-5-2nd 2s infinite var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-5-2nd 2s infinite var(--ease-in-out);
  }
  .fill-loader--v5 .fill-loader__fill--3rd {
    background-color: hsl(201, 98%, 41%);
    background-color: var(--color-accent);
    -webkit-transform-origin: 100% 50%;
        -ms-transform-origin: 100% 50%;
            transform-origin: 100% 50%;
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-5-3rd 2s infinite var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-5-3rd 2s infinite var(--ease-in-out);
  }
  .fill-loader--v5 .fill-loader__fill--4th {
    background-color: hsl(0, 0%, 20%);
    background-color: var(--color-contrast-low);
    -webkit-transform-origin: 50% 0%;
        -ms-transform-origin: 50% 0%;
            transform-origin: 50% 0%;
    -webkit-animation: undefined;
    -webkit-animation: fill-loader-5-4th 2s infinite var(--ease-in-out);
            animation: undefined;
            animation: fill-loader-5-4th 2s infinite var(--ease-in-out);
  }
}

@-webkit-keyframes fill-loader-5-1st {
  0% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  25%,
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}

@keyframes fill-loader-5-1st {
  0% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  25%,
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}

@-webkit-keyframes fill-loader-5-2nd {
  0%,
  25% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
  }
  50%,
  100% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
  }
}

@keyframes fill-loader-5-2nd {
  0%,
  25% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
  }
  50%,
  100% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
  }
}

@-webkit-keyframes fill-loader-5-3rd {
  0%,
  50% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  75%,
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}

@keyframes fill-loader-5-3rd {
  0%,
  50% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  75%,
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}

@-webkit-keyframes fill-loader-5-4th {
  0%,
  75% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
  }
  100% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
  }
}

@keyframes fill-loader-5-4th {
  0%,
  75% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
  }
  100% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
  }
}

@supports ((-webkit-animation-name: this) or (animation-name: this)) {
  .fill-loader--v6 .fill-loader__grid {
    display: -ms-flexbox;
    display: flex;
  }
  .fill-loader--v6 .fill-loader__bar {
    position: relative;
  }
  .fill-loader--v6 .fill-loader__bar:nth-child(2) {
    margin: 0 8px;
  }
  .fill-loader--v6 .fill-loader__base {
    width: 6px;
    height: 30px;
    background-color: hsl(0, 0%, 20%);
    background-color: var(--color-contrast-low);
  }
  .fill-loader--v6 .fill-loader__fill {
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    will-change: transform;
    -webkit-transform: scaleY(0);
        -ms-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: 50% 100%;
        -ms-transform-origin: 50% 100%;
            transform-origin: 50% 100%;
    background-color: hsl(199, 92%, 74%);
    background-color: var(--color-primary);
    -webkit-animation: fill-loader-6 0.8s infinite;
            animation: fill-loader-6 0.8s infinite;
  }
  .fill-loader--v6 .fill-loader__fill--2nd {
    -webkit-animation-delay: 0.1s;
            animation-delay: 0.1s;
  }
  .fill-loader--v6 .fill-loader__fill--3rd {
    -webkit-animation-delay: 0.2s;
            animation-delay: 0.2s;
  }
}

@-webkit-keyframes fill-loader-6 {
  0% {
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
  }
  49% {
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
  }
  51% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  100% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
}

@keyframes fill-loader-6 {
  0% {
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
  }
  49% {
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
  }
  51% {
    -webkit-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  100% {
    -webkit-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
}

/* --------------------------------

File#: _1_badge
Title: Badge
Descr: A small label containing a text string

-------------------------------- */
.badge {
  background-color: transparent;
  padding: 0;
  border: 0;
  border-radius: 0;
  color: inherit;
  line-height: inherit;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
      align-items: center;
  font-size: 0.83333em;
  font-size: var(--text-sm);
  background-color: hsl(0, 0%, 20%);
  background-color: var(--color-contrast-low);
  padding: 0.125em 0.375em;
  padding: var(--space-xxxxs) var(--space-xxs);
  border-radius: undefined;
  border-radius: var(--radius-md);
}

.badge--outlined {
  background-color: transparent;
  border: 1px solid hsl(0, 0%, 20%);
  border: 1px solid var(--color-contrast-low);
}

.badge--high-contrast {
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-contrast-higher);
  color: hsl(0, 0%, 7%);
  color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.badge--primary {
  background-color: hsl(199, 92%, 74%);
  background-color: var(--color-primary);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.badge--error {
  background-color: hsl(355, 90%, 61%);
  background-color: var(--color-error);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.badge--success {
  background-color: hsl(94, 48%, 56%);
  background-color: var(--color-success);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.js .main-header__nav {
  background-color: #000;
  top: 69px;
  top: calc(var(--main-header-height-md) - 1px);
}

.js .main-header__logo .custom-mobile-logo {
  height: 50px;
  width: 50px;
}

.js .main-header,
.js .main-header__layout {
  height: 70px;
  height: var(--main-header-height-md);
}

.js .modal-is--open {
  overflow: hidden;
}

a:visited {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
}

.rl-basicmasonry-gallery .rl-gallery-item img {
  width: 100%;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
  background-color: hsl(0, 0%, 7%);
  background-color: var(--color-bg);
  color: hsl(0, 0%, 54%);
  color: var(--color-contrast-medium);
  border-color: hsl(0, 0%, 54%);
  border-color: var(--color-contrast-medium);
  min-width: 100%;
}

.main-header {
  background-color: #000;
}

.main-header .btn--subtle {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
  border-color: hsl(199, 92%, 74%);
  border-color: var(--color-primary);
}

.main-header .menu-item a,
.nirvana__menu-sidebar .menu-item a {
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  line-height: 24px;
  font-weight: bold;
}

.main-header .menu-item a:visited,
.nirvana__menu-sidebar .menu-item a:visited {
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
}

.main-header .menu-item a[aria-current], .main-header .menu-item a.current-menu-item,
.nirvana__menu-sidebar .menu-item a[aria-current],
.nirvana__menu-sidebar .menu-item a.current-menu-item {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
}

.text-component ul.itinerary {
  list-style: none;
  padding-left: 0;
}

.text-component .rl-gallery {
  padding-left: 0;
}

.site-main {
  padding: 1.25em;
  padding: var(--space-md);
  position: relative;
}

.nirvana__menu-sidebar {
  display: none;
  left: 0;
  width: 270px;
}

.nirvana__menu-sidebar .drawer__content {
  box-shadow: none;
  background-color: #000;
}

#cbp-bislideshow li .caption {
  position: absolute;
  right: 0;
  top: 0;
  left: 0;
  bottom: 0;
  color: #fff;
}

#cbp-bislideshow li .caption h2 {
  color: #fff;
  position: absolute;
  top: 20px;
  right: 52px;
  font-size: 3em;
  font-weight: bold;
}

#cbp-bislideshow li .caption h1 {
  color: #fff;
  position: absolute;
  bottom: 20px;
  width: 100%;
  text-align: center;
  font-size: 3.5em;
  font-weight: bold;
  font-family: Raleway, sans-serif;
  font-family: var(--font-primary);
}

.off-canvas__main {
  height: 100%;
}

.nirvana-tabs {
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
}

.nirvana-tabs .s-tabs__list {
  -ms-flex-pack: center;
      justify-content: center;
}

.nirvana-tabs .s-tabs__list:after {
  background-color: hsl(199, 92%, 74%);
  background-color: var(--color-primary);
  height: 2px;
}

.nirvana-tabs a {
  color: hsl(199, 92%, 74%);
  color: var(--color-primary);
  border: 2px solid hsl(199, 92%, 74%);
  border: 2px solid var(--color-primary);
  border-bottom-color: transparent;
  padding: .6em;
  transition: all .2s;
}

.nirvana-tabs .s-tabs__item--selected {
  color: #edeade;
  background: hsl(199, 92%, 74%);
  background: var(--color-primary);
  border-color: hsl(199, 92%, 74%);
  border-color: var(--color-primary);
  border-bottom-color: transparent;
  cursor: default;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.nirvana-isotope-grid-sizer,
.nirvana-isotope-item {
  width: 50%;
  float: left;
}

.nirvana-isotope-grid-sizer img,
.nirvana-isotope-item img {
  width: 100%;
}

.modal {
  background-color: hsla(0, 0%, 0%, 0.9);
  background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.9);
}

h1,
h2,
h3,
h4 {
  margin-bottom: 0.75em;
}

h2,
h3,
h4 {
  margin-top: 0.25em;
}

p {
  margin-bottom: 0.5em;
  line-height: undefined;
  line-height: var(--component-body-line-height);
}

.form-control {
  font-family: Raleway, sans-serif;
  font-family: var(--font-primary);
}

.nirvana__date-selector {
  padding: 16px;
  background: hsl(201, 98%, 21%);
  background: var(--color-accent-darker);
}

.header-box {
  position: relative;
  height: 50vw;
}

.header-box .nirvana__post-thumbnail {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background-repeat: no-repeat;
  background-size: cover;
}

.header-box h1 {
  position: absolute;
  bottom: 20px;
  left: 20px;
}

#rl-gallery-container-1 .rl-basicmasonry-gallery .rl-gallery-item:hover {
  margin: 0;
  width: 25%;
  transition: all .5s ease;
}

@media (min-width: 64rem) {
  .main-header {
    display: none;
  }
  .site-main {
    margin-left: 270px;
    padding: 1.25em;
    padding: var(--space-md);
  }
  .nirvana__menu-sidebar {
    display: block;
  }
  .nirvana__menu-sidebar .drawer__body {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-align: center;
        align-items: center;
    height: 100%;
  }
  .nirvana__menu-sidebar .main-header__logo {
    margin-bottom: 10px;
    display: table-cell;
    vertical-align: middle;
    text-align: center;
    font-size: 1.728em;
    font-size: var(--text-xl);
    width: 100%;
  }
  .nirvana__menu-sidebar .main-header__logo a {
    display: block;
    max-width: 150PX;
    margin: 0 auto;
  }
  .main-header__social-icons {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: row;
        flex-direction: row;
    -ms-flex-pack: space-evenly;
        justify-content: space-evenly;
    margin-bottom: 30px;
  }
  .main-header__social-icons a {
    color: hsl(199, 92%, 74%);
    color: var(--color-primary);
  }
  .main-header__nav-list {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-align: center;
        align-items: center;
    height: 100%;
    -ms-flex-pack: center;
        justify-content: center;
    margin-bottom: 30px;
  }
  .menu-item {
    margin-bottom: 10px;
  }
  .main-header__bottom-text {
    width: 100%;
    margin-bottom: 30px;
    text-align: center;
    color: hsl(0, 0%, 100%);
    color: var(--color-white);
  }
  .main-header__copyright {
    font-size: 0.69444em;
    font-size: var(--text-xs);
  }
  .nirvana__tour-sidebar {
    height: 100%;
    position: relative;
  }
  .nirvana__tour-sidebar-content {
    padding: 0 1.25em;
    padding: 0 var(--space-md);
    height: 100%;
    position: absolute;
  }
  .nirvana__tour-sidebar-content .scrollbar {
    height: inherit;
    overflow-y: scroll;
  }
  .nirvana__departure {
    margin-bottom: 1.25em;
    margin-bottom: var(--space-md);
  }
  .nirvana-isotope-grid-sizer,
  .nirvana-isotope-item {
    width: 33.33333%;
    float: left;
  }
  .nirvana-isotope-grid-sizer img,
  .nirvana-isotope-item img {
    width: 100%;
  }
  .cbp-bislideshow {
    width: calc(100% - 270px);
    margin-left: 270px;
  }
  .header-box {
    height: 400px;
  }
  .nirvana__main-slider-container {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 270px;
    right: 0;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
        align-items: center;
  }
  .nirvana__main-slider-wrapper {
    width: 50VW;
    height: 50vw;
    display: -ms-flexbox;
    display: flex;
  }
  #nirvana__main-slider {
    -ms-flex-item-align: center;
        align-self: center;
  }
}

.nirvana_itinerary_wrapper {
  position: relative;
  min-height: 64px;
}

.nirvana_itinerary_loader {
  position: absolute;
  right: 50%;
}

.lds-ripple {
  display: inline-block;
  position: relative;
  width: 64px;
  height: 64px;
}

.lds-ripple div {
  position: absolute;
  border: 4px solid #fff;
  opacity: 1;
  border-radius: 50%;
  -webkit-animation: lds-ripple 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
          animation: lds-ripple 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
}

.lds-ripple div:nth-child(2) {
  -webkit-animation-delay: -0.5s;
          animation-delay: -0.5s;
}

@-webkit-keyframes lds-ripple {
  0% {
    top: 28px;
    left: 28px;
    width: 0;
    height: 0;
    opacity: 1;
  }
  100% {
    top: -1px;
    left: -1px;
    width: 58px;
    height: 58px;
    opacity: 0;
  }
}

@keyframes lds-ripple {
  0% {
    top: 28px;
    left: 28px;
    width: 0;
    height: 0;
    opacity: 1;
  }
  100% {
    top: -1px;
    left: -1px;
    width: 58px;
    height: 58px;
    opacity: 0;
  }
}
