@charset "UTF-8";
*, *::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%, 100%);
  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(220, 90%, 36%);
  --color-primary-darker-h: 220;
  --color-primary-darker-s: 90%;
  --color-primary-darker-l: 36%;
  --color-primary-dark: hsl(220, 90%, 46%);
  --color-primary-dark-h: 220;
  --color-primary-dark-s: 90%;
  --color-primary-dark-l: 46%;
  --color-primary: hsl(360, 100%, 100%);
  --color-primary-h: 360;
  --color-primary-s: 100%;
  --color-primary-l: 100%;
  --color-primary-light: hsl(220, 90%, 66%);
  --color-primary-light-h: 220;
  --color-primary-light-s: 90%;
  --color-primary-light-l: 66%;
  --color-primary-lighter: hsl(220, 90%, 76%);
  --color-primary-lighter-h: 220;
  --color-primary-lighter-s: 90%;
  --color-primary-lighter-l: 76%;
  --color-accent-darker: hsl(355, 90%, 41%);
  --color-accent-darker-h: 355;
  --color-accent-darker-s: 90%;
  --color-accent-darker-l: 41%;
  --color-accent-dark: hsl(355, 90%, 51%);
  --color-accent-dark-h: 355;
  --color-accent-dark-s: 90%;
  --color-accent-dark-l: 51%;
  --color-accent: hsl(355, 90%, 61%);
  --color-accent-h: 355;
  --color-accent-s: 90%;
  --color-accent-l: 61%;
  --color-accent-light: hsl(355, 90%, 71%);
  --color-accent-light-h: 355;
  --color-accent-light-s: 90%;
  --color-accent-light-l: 71%;
  --color-accent-lighter: hsl(355, 90%, 81%);
  --color-accent-lighter-h: 355;
  --color-accent-lighter-s: 90%;
  --color-accent-lighter-l: 81%;
  --color-black: hsl(240, 8%, 12%);
  --color-black-h: 240;
  --color-black-s: 8%;
  --color-black-l: 12%;
  --color-white: hsl(0, 0%, 100%);
  --color-white-h: 0;
  --color-white-s: 0%;
  --color-white-l: 100%;
  --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-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-bg: hsl(0, 0%, 100%);
  --color-bg-h: 0;
  --color-bg-s: 0%;
  --color-bg-l: 100%;
  --color-kaptur-yellow: hsl(45, 97%, 53%);
  --color-kaptur-yellow-h: 45;
  --color-kaptur-yellow-s: 97%;
  --color-kaptur-yellow-l: 53%;
  --color-header-bg: hsl(0, 0%, 14%);
  --color-header-bg-h: 0;
  --color-header-bg-s: 0%;
  --color-header-bg-l: 14%;
  --color-contrast-lower: hsl(0, 0%, 95%);
  --color-contrast-lower-h: 0;
  --color-contrast-lower-s: 0%;
  --color-contrast-lower-l: 95%;
  --color-contrast-low: hsl(240, 1%, 83%);
  --color-contrast-low-h: 240;
  --color-contrast-low-s: 1%;
  --color-contrast-low-l: 83%;
  --color-contrast-medium: hsl(240, 1%, 48%);
  --color-contrast-medium-h: 240;
  --color-contrast-medium-s: 1%;
  --color-contrast-medium-l: 48%;
  --color-contrast-high: hsl(240, 4%, 20%);
  --color-contrast-high-h: 240;
  --color-contrast-high-s: 4%;
  --color-contrast-high-l: 20%;
  --color-contrast-higher: hsl(0, 0%, 1%);
  --color-contrast-higher-h: 0;
  --color-contrast-higher-s: 0%;
  --color-contrast-higher-l: 1%;
}

[data-theme] {
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-bg);
  color: hsl(240, 4%, 20%);
  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;
    }
  }
}

:root {
  --max-width-xs: 32rem;
  --max-width-sm: 48rem;
  --max-width-md: 64rem;
  --max-width-lg: 80rem;
  --max-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-xs {
  max-width: 32rem;
  max-width: var(--max-width-xs);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

@media (min-width: 90rem) {
  .container--adaptive-xl, .max-width-adaptive-xl {
    max-width: 90rem;
    max-width: var(--max-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, .grid-gap--xs {
  margin-top: -0.5em;
  margin-top: calc(var(--space-xs)*-1);
  margin-left: -0.5em;
  margin-left: calc(var(--space-xs)*-1);
}

.grid-gap-xs > *, .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, .grid-gap--sm {
  margin-top: -0.75em;
  margin-top: calc(var(--space-sm)*-1);
  margin-left: -0.75em;
  margin-left: calc(var(--space-sm)*-1);
}

.grid-gap-sm > *, .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, .grid-gap--md {
  margin-top: -1.25em;
  margin-top: calc(var(--space-md)*-1);
  margin-left: -1.25em;
  margin-left: calc(var(--space-md)*-1);
}

.grid-gap-md > *, .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, .grid-gap--lg {
  margin-top: -2em;
  margin-top: calc(var(--space-lg)*-1);
  margin-left: -2em;
  margin-left: calc(var(--space-lg)*-1);
}

.grid-gap-lg > *, .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, .grid-gap--xl {
  margin-top: -3.25em;
  margin-top: calc(var(--space-xl)*-1);
  margin-left: -3.25em;
  margin-left: calc(var(--space-xl)*-1);
}

.grid-gap-xl > *, .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, .col--1 {
  -ms-flex-preferred-size: 8.33%;
      flex-basis: 8.33%;
  max-width: 8.33%;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

:root {
  --radius: 0.25em;
  --radius-sm: calc(var(--radius)/2);
  --radius-md: var(--radius);
  --radius-lg: calc(var(--radius)*2);
  --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);
}

@font-face {
  font-family: 'Gotham Narrow Bold';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Bold"), url("../fonts/GothamNarrow-Bold.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Bold Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Bold Italic"), url("../fonts/GothamNarrow-BoldItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Thin';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Thin"), url("../fonts/GothamNarrow-Thin.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Thin Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Thin Italic"), url("../fonts/GothamNarrow-ThinItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Extra Light';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Extra Light"), url("../fonts/GothamNarrow-XLight.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Extra Light Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Extra Light Italic"), url("../fonts/GothamNarrow-XLightItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Light';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Light"), url("../fonts/GothamNarrow-Light.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Light Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Light Italic"), url("../fonts/GothamNarrow-LightItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Book';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Book"), url("../fonts/GothamNarrow-Book.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Book Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Book Italic"), url("../fonts/GothamNarrow-BookItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Medium';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Medium"), url("../fonts/GothamNarrow-Medium.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Medium Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Medium Italic"), url("../fonts/GothamNarrow-MediumItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Black';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Black"), url("../fonts/GothamNarrow-Black.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Black Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Black Italic"), url("../fonts/GothamNarrow-BlackItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Ultra';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Ultra"), url("../fonts/GothamNarrow-Ultra.woff") format("woff");
}

@font-face {
  font-family: 'Gotham Narrow Ultra Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham Narrow Ultra Italic"), url("../fonts/GothamNarrow-UltraItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Bold';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Bold"), url("../fonts/GothamXNarrow-Bold.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Bold Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Bold Italic"), url("../fonts/GothamXNarrow-BoldItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Thin';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Thin"), url("../fonts/GothamXNarrow-Thin.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Thin Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Thin Italic"), url("../fonts/GothamXNarrow-ThinItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Extra Light';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Extra Light"), url("../fonts/GothamXNarrow-XLight.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Extra Light Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Extra Light Italic"), url("../fonts/GothamXNarrow-XLightItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Light';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Light"), url("../fonts/GothamXNarrow-Light.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Light Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Light Italic"), url("../fonts/GothamXNarrow-LightItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Book';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Book"), url("../fonts/GothamXNarrow-Book.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Book Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Book Italic"), url("../fonts/GothamXNarrow-BookItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Medium';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Medium"), url("../fonts/GothamXNarrow-Medium.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Medium Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Medium Italic"), url("../fonts/GothamXNarrow-MediumItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Black';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Black"), url("../fonts/GothamXNarrow-Black.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Black Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Black Italic"), url("../fonts/GothamXNarrow-BlackItalic.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Ultra';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Ultra"), url("../fonts/GothamXNarrow-Ultra.woff") format("woff");
}

@font-face {
  font-family: 'Gotham XNarrow Ultra Italic';
  font-style: normal;
  font-weight: normal;
  src: local("Gotham XNarrow Ultra Italic"), url("../fonts/GothamXNarrow-UltraItalic.woff") format("woff");
}

:root {
  --font-primary: 'Gotham Narrow Book';
  --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;
}

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

body {
  font-size: 1em;
  font-size: var(--text-base-size);
  font-family: 'Gotham Narrow Book';
  font-family: var(--font-primary);
  color: hsl(240, 4%, 20%);
  color: var(--color-contrast-high);
}

h1, h2, h3, h4 {
  font-family: 'Gotham Narrow Black';
  text-transform: uppercase;
  color: hsl(0, 0%, 1%);
  color: var(--color-contrast-higher);
  line-height: 1.2;
  line-height: var(--heading-line-height);
}

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

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

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

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

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

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

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

a, .link {
  color: hsl(360, 100%, 100%);
  color: var(--color-primary);
  text-decoration: none;
}

a:hover, .link:hover {
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
}

mark {
  background-color: hsla(355, 90%, 61%, 0.2);
  background-color: hsla(var(--color-accent-h), var(--color-accent-s), var(--color-accent-l), 0.2);
  color: inherit;
}

strong, .text-bold {
  font-family: 'Gotham Narrow Bold';
  font-weight: bold;
}

s {
  text-decoration: line-through;
}

u, .text-underline {
  text-decoration: underline;
}

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

.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(240, 1%, 83%);
  border-left: 4px solid var(--color-contrast-low);
}

.text-component hr {
  background: hsl(240, 1%, 83%);
  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__block--full-width {
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

.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(240, 1%, 48%);
  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));
  }
}

.color-contrast-medium, .text--subtle {
  color: hsl(240, 1%, 48%);
  color: var(--color-contrast-medium);
}

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

.color-contrast-high {
  color: hsl(240, 4%, 20%);
  color: var(--color-contrast-high);
}

.color-contrast-higher {
  color: hsl(0, 0%, 1%);
  color: var(--color-contrast-higher);
}

.color-primary {
  color: hsl(360, 100%, 100%);
  color: var(--color-primary);
}

.color-accent {
  color: hsl(355, 90%, 61%);
  color: var(--color-accent);
}

.color-success {
  color: hsl(94, 48%, 56%);
  color: var(--color-success);
}

.color-warning {
  color: hsl(46, 100%, 61%);
  color: var(--color-warning);
}

.color-error {
  color: hsl(355, 90%, 61%);
  color: var(--color-error);
}

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

.icon {
  display: inline-block;
  color: inherit;
  fill: currentColor;
  height: 1em;
  width: 1em;
  line-height: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.icon--xxs {
  font-size: 12px;
  font-size: var(--icon-xxs);
}

.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--xxl {
  font-size: 128px;
  font-size: var(--icon-xxl);
}

.icon-text {
  display: inline-block;
  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-text--gap-none > *:nth-child(2), .icon-text.icon-text--gap-0 > *:nth-child(2) {
  margin-left: 0;
}

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

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

.icon-text--space-between {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.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 {
  position: relative;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0.5em 0.75em;
  padding: var(--space-xs) var(--space-sm);
  border-radius: 0.25em;
  --color-shadow: hsla(240, 8%, 12%, 0.15);
  --color-shadow: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.15);
  box-shadow: 0 4px 16px 0 hsla(240, 8%, 12%, 0.15);
  box-shadow: 0 4px 16px 0 var(--color-shadow);
  white-space: nowrap;
  text-decoration: none;
  line-height: 1;
  font-size: 1em;
  font-size: var(--btn-font-size);
  cursor: pointer;
}

.btn--primary {
  background-color: hsl(360, 100%, 100%);
  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 {
  background-color: hsl(240, 1%, 83%);
  background-color: var(--color-contrast-low);
  color: hsl(0, 0%, 1%);
  color: var(--color-contrast-higher);
}

.btn--accent {
  background-color: hsl(355, 90%, 61%);
  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 {
  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%, 100%);
  background: var(--color-bg);
  border: 2px solid hsl(240, 1%, 83%);
  border: 2px solid var(--color-contrast-low);
  width: 100%;
}

.form-control:focus {
  outline: none;
  border-color: hsl(360, 100%, 100%);
  border-color: var(--color-primary);
  --color-shadow: hsla(360, 100%, 100%, 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(360, 100%, 100%, 0.2);
  box-shadow: 0 0 0 3px var(--color-shadow);
}

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

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

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

.form-control:-moz-placeholder {
  color: hsl(240, 1%, 48%);
  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%, 1%);
  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--xs {
    display: none !important;
  }
}

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

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

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

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

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

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

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

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

@media (min-width: 90rem) {
  .hide\@xl, .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;
}

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

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

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

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

.flex-row, .flex--row {
  -ms-flex-direction: row;
      flex-direction: row;
}

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

.justify-start, .flex--start {
  -ms-flex-pack: start;
      justify-content: flex-start;
}

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

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

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

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

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

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

@media (min-width: 30rem) {
  .flex-wrap\@xs {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .flex-column\@xs {
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .flex-row\@xs {
    -ms-flex-direction: row;
        flex-direction: row;
  }
  .flex-center\@xs {
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
  }
  .justify-start\@xs {
    -ms-flex-pack: start;
        justify-content: flex-start;
  }
  .justify-end\@xs {
    -ms-flex-pack: end;
        justify-content: flex-end;
  }
  .justify-center\@xs {
    -ms-flex-pack: center;
        justify-content: center;
  }
  .justify-between\@xs {
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  .items-center\@xs {
    -ms-flex-align: center;
        align-items: center;
  }
  .flex-grow\@xs > * {
    -ms-flex-positive: 1;
        flex-grow: 1;
  }
  .flex-shrink-0\@xs > * {
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

@media (min-width: 37.5rem) {
  .flex-wrap\@sm {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .flex-column\@sm {
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .flex-row\@sm {
    -ms-flex-direction: row;
        flex-direction: row;
  }
  .flex-center\@sm {
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
  }
  .justify-start\@sm {
    -ms-flex-pack: start;
        justify-content: flex-start;
  }
  .justify-end\@sm {
    -ms-flex-pack: end;
        justify-content: flex-end;
  }
  .justify-center\@sm {
    -ms-flex-pack: center;
        justify-content: center;
  }
  .justify-between\@sm {
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  .items-center\@sm {
    -ms-flex-align: center;
        align-items: center;
  }
  .flex-grow\@sm > * {
    -ms-flex-positive: 1;
        flex-grow: 1;
  }
  .flex-shrink-0\@sm > * {
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

@media (min-width: 64rem) {
  .flex-wrap\@md {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .flex-column\@md {
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .flex-row\@md {
    -ms-flex-direction: row;
        flex-direction: row;
  }
  .flex-center\@md {
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
  }
  .justify-start\@md {
    -ms-flex-pack: start;
        justify-content: flex-start;
  }
  .justify-end\@md {
    -ms-flex-pack: end;
        justify-content: flex-end;
  }
  .justify-center\@md {
    -ms-flex-pack: center;
        justify-content: center;
  }
  .justify-between\@md {
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  .items-center\@md {
    -ms-flex-align: center;
        align-items: center;
  }
  .flex-grow\@md > * {
    -ms-flex-positive: 1;
        flex-grow: 1;
  }
  .flex-shrink-0\@md > * {
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

@media (min-width: 80rem) {
  .flex-wrap\@lg {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .flex-column\@lg {
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .flex-row\@lg {
    -ms-flex-direction: row;
        flex-direction: row;
  }
  .flex-center\@lg {
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
  }
  .justify-start\@lg {
    -ms-flex-pack: start;
        justify-content: flex-start;
  }
  .justify-end\@lg {
    -ms-flex-pack: end;
        justify-content: flex-end;
  }
  .justify-center\@lg {
    -ms-flex-pack: center;
        justify-content: center;
  }
  .justify-between\@lg {
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  .items-center\@lg {
    -ms-flex-align: center;
        align-items: center;
  }
  .flex-grow\@lg > * {
    -ms-flex-positive: 1;
        flex-grow: 1;
  }
  .flex-shrink-0\@lg > * {
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

@media (min-width: 90rem) {
  .flex-wrap\@xl {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .flex-column\@xl {
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .flex-row\@xl {
    -ms-flex-direction: row;
        flex-direction: row;
  }
  .flex-center\@xl {
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
  }
  .justify-start\@xl {
    -ms-flex-pack: start;
        justify-content: flex-start;
  }
  .justify-end\@xl {
    -ms-flex-pack: end;
        justify-content: flex-end;
  }
  .justify-center\@xl {
    -ms-flex-pack: center;
        justify-content: center;
  }
  .justify-between\@xl {
    -ms-flex-pack: justify;
        justify-content: space-between;
  }
  .items-center\@xl {
    -ms-flex-align: center;
        align-items: center;
  }
  .flex-grow\@xl > * {
    -ms-flex-positive: 1;
        flex-grow: 1;
  }
  .flex-shrink-0\@xl > * {
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.flex-gap, .flex-gap-md, .flex--gap, .flex--gap-md, .flex-gap, .flex-gap--md {
  margin-bottom: -1.25em;
  margin-bottom: calc(-1*var(--space-md));
  margin-right: -0.625em;
  margin-right: calc(-1*var(--space-md)/2);
  margin-left: -0.625em;
  margin-left: calc(-1*var(--space-md)/2);
}

.flex-gap > *, .flex-gap-md > *, .flex--gap > *, .flex--gap-md > *, .flex-gap > *, .flex-gap--md > * {
  margin-bottom: 1.25em;
  margin-bottom: var(--space-md);
  margin-right: 0.625em;
  margin-right: calc(var(--space-md)/2);
  margin-left: 0.625em;
  margin-left: calc(var(--space-md)/2);
}

.flex-gap-xxxs, .flex--gap-xxxs, .flex-gap--xxxs {
  margin-bottom: -0.25em;
  margin-bottom: calc(-1*var(--space-xxxs));
  margin-right: -0.125em;
  margin-right: calc(-1*var(--space-xxxs)/2);
  margin-left: -0.125em;
  margin-left: calc(-1*var(--space-xxxs)/2);
}

.flex-gap-xxxs > *, .flex--gap-xxxs > *, .flex-gap--xxxs > * {
  margin-bottom: 0.25em;
  margin-bottom: var(--space-xxxs);
  margin-right: 0.125em;
  margin-right: calc(var(--space-xxxs)/2);
  margin-left: 0.125em;
  margin-left: calc(var(--space-xxxs)/2);
}

.flex-gap-xxs, .flex--gap-xxs, .flex-gap--xxs {
  margin-bottom: -0.375em;
  margin-bottom: calc(-1*var(--space-xxs));
  margin-right: -0.1875em;
  margin-right: calc(-1*var(--space-xxs)/2);
  margin-left: -0.1875em;
  margin-left: calc(-1*var(--space-xxs)/2);
}

.flex-gap-xxs > *, .flex--gap-xxs > *, .flex-gap--xxs > * {
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
  margin-right: 0.1875em;
  margin-right: calc(var(--space-xxs)/2);
  margin-left: 0.1875em;
  margin-left: calc(var(--space-xxs)/2);
}

.flex-gap-xs, .flex--gap-xs, .flex-gap--xs {
  margin-bottom: -0.5em;
  margin-bottom: calc(-1*var(--space-xs));
  margin-right: -0.25em;
  margin-right: calc(-1*var(--space-xs)/2);
  margin-left: -0.25em;
  margin-left: calc(-1*var(--space-xs)/2);
}

.flex-gap-xs > *, .flex--gap-xs > *, .flex-gap--xs > * {
  margin-bottom: 0.5em;
  margin-bottom: var(--space-xs);
  margin-right: 0.25em;
  margin-right: calc(var(--space-xs)/2);
  margin-left: 0.25em;
  margin-left: calc(var(--space-xs)/2);
}

.flex-gap-sm, .flex--gap-sm, .flex-gap--sm {
  margin-bottom: -0.75em;
  margin-bottom: calc(-1*var(--space-sm));
  margin-right: -0.375em;
  margin-right: calc(-1*var(--space-sm)/2);
  margin-left: -0.375em;
  margin-left: calc(-1*var(--space-sm)/2);
}

.flex-gap-sm > *, .flex--gap-sm > *, .flex-gap--sm > * {
  margin-bottom: 0.75em;
  margin-bottom: var(--space-sm);
  margin-right: 0.375em;
  margin-right: calc(var(--space-sm)/2);
  margin-left: 0.375em;
  margin-left: calc(var(--space-sm)/2);
}

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

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

.flex-gap-xl, .flex--gap-xl, .flex-gap--xl {
  margin-bottom: -3.25em;
  margin-bottom: calc(-1*var(--space-xl));
  margin-right: -1.625em;
  margin-right: calc(-1*var(--space-xl)/2);
  margin-left: -1.625em;
  margin-left: calc(-1*var(--space-xl)/2);
}

.flex-gap-xl > *, .flex--gap-xl > *, .flex-gap--xl > * {
  margin-bottom: 3.25em;
  margin-bottom: var(--space-xl);
  margin-right: 1.625em;
  margin-right: calc(var(--space-xl)/2);
  margin-left: 1.625em;
  margin-left: calc(var(--space-xl)/2);
}

.flex-gap-xxl, .flex--gap-xxl, .flex-gap--xxl {
  margin-bottom: -5.25em;
  margin-bottom: calc(-1*var(--space-xxl));
  margin-right: -2.625em;
  margin-right: calc(-1*var(--space-xxl)/2);
  margin-left: -2.625em;
  margin-left: calc(-1*var(--space-xxl)/2);
}

.flex-gap-xxl > *, .flex--gap-xxl > *, .flex-gap--xxl > * {
  margin-bottom: 5.25em;
  margin-bottom: var(--space-xxl);
  margin-right: 2.625em;
  margin-right: calc(var(--space-xxl)/2);
  margin-left: 2.625em;
  margin-left: calc(var(--space-xxl)/2);
}

.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-0 {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

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

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

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

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

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

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

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

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

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

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

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

.margin-auto {
  margin: auto;
}

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

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

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

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

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

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

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

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

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

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

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

.margin-top-auto, .margin-top--auto {
  margin-top: auto;
}

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

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

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

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

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

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

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

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

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

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

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

.margin-bottom-auto, .margin-bottom--auto {
  margin-bottom: auto;
}

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

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

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

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

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

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

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

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

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

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

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

.margin-right-auto {
  margin-right: auto;
}

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

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

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

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

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

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

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

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

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

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

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

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

.margin-x-xxxxs {
  margin-left: 0.125em;
  margin-left: var(--space-xxxxs);
  margin-right: 0.125em;
  margin-right: var(--space-xxxxs);
}

.margin-x-xxxs {
  margin-left: 0.25em;
  margin-left: var(--space-xxxs);
  margin-right: 0.25em;
  margin-right: var(--space-xxxs);
}

.margin-x-xxs {
  margin-left: 0.375em;
  margin-left: var(--space-xxs);
  margin-right: 0.375em;
  margin-right: var(--space-xxs);
}

.margin-x-xs {
  margin-left: 0.5em;
  margin-left: var(--space-xs);
  margin-right: 0.5em;
  margin-right: var(--space-xs);
}

.margin-x-sm {
  margin-left: 0.75em;
  margin-left: var(--space-sm);
  margin-right: 0.75em;
  margin-right: var(--space-sm);
}

.margin-x-md {
  margin-left: 1.25em;
  margin-left: var(--space-md);
  margin-right: 1.25em;
  margin-right: var(--space-md);
}

.margin-x-lg {
  margin-left: 2em;
  margin-left: var(--space-lg);
  margin-right: 2em;
  margin-right: var(--space-lg);
}

.margin-x-xl {
  margin-left: 3.25em;
  margin-left: var(--space-xl);
  margin-right: 3.25em;
  margin-right: var(--space-xl);
}

.margin-x-xxl {
  margin-left: 5.25em;
  margin-left: var(--space-xxl);
  margin-right: 5.25em;
  margin-right: var(--space-xxl);
}

.margin-x-xxxl {
  margin-left: 8.5em;
  margin-left: var(--space-xxxl);
  margin-right: 8.5em;
  margin-right: var(--space-xxxl);
}

.margin-x-xxxxl {
  margin-left: 13.75em;
  margin-left: var(--space-xxxxl);
  margin-right: 13.75em;
  margin-right: var(--space-xxxxl);
}

.margin-x-auto {
  margin-left: auto;
  margin-right: auto;
}

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

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

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

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

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

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

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

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

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

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

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

.margin-y-auto {
  margin-top: auto;
  margin-bottom: auto;
}

@media not all and (min-width: 30rem) {
  .has-margin\@xs {
    margin: 0 !important;
  }
}

@media not all and (min-width: 37.5rem) {
  .has-margin\@sm {
    margin: 0 !important;
  }
}

@media not all and (min-width: 64rem) {
  .has-margin\@md {
    margin: 0 !important;
  }
}

@media not all and (min-width: 80rem) {
  .has-margin\@lg {
    margin: 0 !important;
  }
}

@media not all and (min-width: 90rem) {
  .has-margin\@xl {
    margin: 0 !important;
  }
}

.padding-md {
  padding: 1.25em;
  padding: var(--space-md);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.padding-right-md {
  padding-right: 1.25em;
  padding-right: var(--space-md);
}

.padding-right-xxxxs {
  padding-right: 0.125em;
  padding-right: var(--space-xxxxs);
}

.padding-right-xxxs {
  padding-right: 0.25em;
  padding-right: var(--space-xxxs);
}

.padding-right-xxs {
  padding-right: 0.375em;
  padding-right: var(--space-xxs);
}

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

.padding-right-sm {
  padding-right: 0.75em;
  padding-right: var(--space-sm);
}

.padding-right-lg {
  padding-right: 2em;
  padding-right: var(--space-lg);
}

.padding-right-xl {
  padding-right: 3.25em;
  padding-right: var(--space-xl);
}

.padding-right-xxl {
  padding-right: 5.25em;
  padding-right: var(--space-xxl);
}

.padding-right-xxxl {
  padding-right: 8.5em;
  padding-right: var(--space-xxxl);
}

.padding-right-xxxxl {
  padding-right: 13.75em;
  padding-right: var(--space-xxxxl);
}

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

.padding-left-md {
  padding-left: 1.25em;
  padding-left: var(--space-md);
}

.padding-left-xxxxs {
  padding-left: 0.125em;
  padding-left: var(--space-xxxxs);
}

.padding-left-xxxs {
  padding-left: 0.25em;
  padding-left: var(--space-xxxs);
}

.padding-left-xxs {
  padding-left: 0.375em;
  padding-left: var(--space-xxs);
}

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

.padding-left-sm {
  padding-left: 0.75em;
  padding-left: var(--space-sm);
}

.padding-left-lg {
  padding-left: 2em;
  padding-left: var(--space-lg);
}

.padding-left-xl {
  padding-left: 3.25em;
  padding-left: var(--space-xl);
}

.padding-left-xxl {
  padding-left: 5.25em;
  padding-left: var(--space-xxl);
}

.padding-left-xxxl {
  padding-left: 8.5em;
  padding-left: var(--space-xxxl);
}

.padding-left-xxxxl {
  padding-left: 13.75em;
  padding-left: var(--space-xxxxl);
}

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

.padding-x-md {
  padding-left: 1.25em;
  padding-left: var(--space-md);
  padding-right: 1.25em;
  padding-right: var(--space-md);
}

.padding-x-xxxxs {
  padding-left: 0.125em;
  padding-left: var(--space-xxxxs);
  padding-right: 0.125em;
  padding-right: var(--space-xxxxs);
}

.padding-x-xxxs {
  padding-left: 0.25em;
  padding-left: var(--space-xxxs);
  padding-right: 0.25em;
  padding-right: var(--space-xxxs);
}

.padding-x-xxs {
  padding-left: 0.375em;
  padding-left: var(--space-xxs);
  padding-right: 0.375em;
  padding-right: var(--space-xxs);
}

.padding-x-xs {
  padding-left: 0.5em;
  padding-left: var(--space-xs);
  padding-right: 0.5em;
  padding-right: var(--space-xs);
}

.padding-x-sm {
  padding-left: 0.75em;
  padding-left: var(--space-sm);
  padding-right: 0.75em;
  padding-right: var(--space-sm);
}

.padding-x-lg {
  padding-left: 2em;
  padding-left: var(--space-lg);
  padding-right: 2em;
  padding-right: var(--space-lg);
}

.padding-x-xl {
  padding-left: 3.25em;
  padding-left: var(--space-xl);
  padding-right: 3.25em;
  padding-right: var(--space-xl);
}

.padding-x-xxl {
  padding-left: 5.25em;
  padding-left: var(--space-xxl);
  padding-right: 5.25em;
  padding-right: var(--space-xxl);
}

.padding-x-xxxl {
  padding-left: 8.5em;
  padding-left: var(--space-xxxl);
  padding-right: 8.5em;
  padding-right: var(--space-xxxl);
}

.padding-x-xxxxl {
  padding-left: 13.75em;
  padding-left: var(--space-xxxxl);
  padding-right: 13.75em;
  padding-right: var(--space-xxxxl);
}

.padding-x-component {
  padding-left: 1.25em;
  padding-left: var(--component-padding);
  padding-right: 1.25em;
  padding-right: var(--component-padding);
}

.padding-y-md {
  padding-top: 1.25em;
  padding-top: var(--space-md);
  padding-bottom: 1.25em;
  padding-bottom: var(--space-md);
}

.padding-y-xxxxs {
  padding-top: 0.125em;
  padding-top: var(--space-xxxxs);
  padding-bottom: 0.125em;
  padding-bottom: var(--space-xxxxs);
}

.padding-y-xxxs {
  padding-top: 0.25em;
  padding-top: var(--space-xxxs);
  padding-bottom: 0.25em;
  padding-bottom: var(--space-xxxs);
}

.padding-y-xxs {
  padding-top: 0.375em;
  padding-top: var(--space-xxs);
  padding-bottom: 0.375em;
  padding-bottom: var(--space-xxs);
}

.padding-y-xs {
  padding-top: 0.5em;
  padding-top: var(--space-xs);
  padding-bottom: 0.5em;
  padding-bottom: var(--space-xs);
}

.padding-y-sm {
  padding-top: 0.75em;
  padding-top: var(--space-sm);
  padding-bottom: 0.75em;
  padding-bottom: var(--space-sm);
}

.padding-y-lg {
  padding-top: 2em;
  padding-top: var(--space-lg);
  padding-bottom: 2em;
  padding-bottom: var(--space-lg);
}

.padding-y-xl {
  padding-top: 3.25em;
  padding-top: var(--space-xl);
  padding-bottom: 3.25em;
  padding-bottom: var(--space-xl);
}

.padding-y-xxl {
  padding-top: 5.25em;
  padding-top: var(--space-xxl);
  padding-bottom: 5.25em;
  padding-bottom: var(--space-xxl);
}

.padding-y-xxxl {
  padding-top: 8.5em;
  padding-top: var(--space-xxxl);
  padding-bottom: 8.5em;
  padding-bottom: var(--space-xxxl);
}

.padding-y-xxxxl {
  padding-top: 13.75em;
  padding-top: var(--space-xxxxl);
  padding-bottom: 13.75em;
  padding-bottom: var(--space-xxxxl);
}

.padding-y-component {
  padding-top: 1.25em;
  padding-top: var(--component-padding);
  padding-bottom: 1.25em;
  padding-bottom: var(--component-padding);
}

@media not all and (min-width: 30rem) {
  .has-padding\@xs {
    padding: 0 !important;
  }
}

@media not all and (min-width: 37.5rem) {
  .has-padding\@sm {
    padding: 0 !important;
  }
}

@media not all and (min-width: 64rem) {
  .has-padding\@md {
    padding: 0 !important;
  }
}

@media not all and (min-width: 80rem) {
  .has-padding\@lg {
    padding: 0 !important;
  }
}

@media not all and (min-width: 90rem) {
  .has-padding\@xl {
    padding: 0 !important;
  }
}

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

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

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

.text-left, .text--left {
  text-align: left;
}

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

@media (min-width: 30rem) {
  .text-center\@xs {
    text-align: center;
  }
  .text-left\@xs {
    text-align: left;
  }
  .text-right\@xs {
    text-align: right;
  }
}

@media (min-width: 37.5rem) {
  .text-center\@sm {
    text-align: center;
  }
  .text-left\@sm {
    text-align: left;
  }
  .text-right\@sm {
    text-align: right;
  }
}

@media (min-width: 64rem) {
  .text-center\@md {
    text-align: center;
  }
  .text-left\@md {
    text-align: left;
  }
  .text-right\@md {
    text-align: right;
  }
}

@media (min-width: 80rem) {
  .text-center\@lg {
    text-align: center;
  }
  .text-left\@lg {
    text-align: left;
  }
  .text-right\@lg {
    text-align: right;
  }
}

@media (min-width: 90rem) {
  .text-center\@xl {
    text-align: center;
  }
  .text-left\@xl {
    text-align: left;
  }
  .text-right\@xl {
    text-align: right;
  }
}

.width-100\% {
  width: 100%;
}

.height-100\% {
  height: 100%;
}

.media-wrapper {
  position: relative;
  height: 0;
  padding-bottom: 56.25%;
}

.media-wrapper iframe, .media-wrapper video, .media-wrapper img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.media-wrapper video, .media-wrapper img {
  -o-object-fit: cover;
     object-fit: cover;
}

.media-wrapper--4\:3 {
  padding-bottom: 75%;
}

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

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%, 100%);
  background-color: var(--color-bg);
  border-bottom: 1px solid hsl(240, 1%, 83%);
  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(240, 1%, 48%);
  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%, 1%);
  color: var(--color-contrast-higher);
}

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

.main-header__nav-divider {
  height: 1px;
  width: 100%;
  background-color: hsl(240, 1%, 83%);
  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%, 100%);
  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: Hero
Descr: A full-width callout section

-------------------------------- */
.hero {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  padding: 5.25em 0;
  padding: var(--space-xxl) 0;
  background-color: hsl(0, 0%, 100%);
  background-color: var(--color-bg);
  min-height: 380px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

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

.hero__content--max-width-sm {
  max-width: 480px;
}

.hero__content--max-width-md {
  max-width: 600px;
}

.hero__content--max-width-lg {
  max-width: 720px;
}

.hero__label {
  color: hsl(240, 8%, 12%);
  color: var(--color-black);
  font-size: 1.2em;
  font-size: var(--text-md);
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

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

.hero--center .hero__content {
  margin: 0 auto;
}

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

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

.hero--right .hero__content {
  margin: 0 0 0 auto;
}

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

.hero--overlay-layer {
  position: relative;
}

.hero--overlay-layer .hero__content {
  position: relative;
  z-index: 2;
}

.hero--overlay-layer::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: hsla(0, 0%, 100%, 0.65);
  background-color: hsla(var(--color-bg-h), var(--color-bg-s), var(--color-bg-l), 0.65);
  z-index: 1;
}

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

Title: Features
Descr: A section containing a list of features

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

.features__item img {
  display: block;
  width: 100%;
  margin-bottom: 0.75em;
  margin-bottom: var(--space-sm);
}

@supports (grid-area: auto) {
  @media (min-width: 64rem) {
    .features__grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      grid-gap: 2em;
      grid-gap: var(--space-lg);
    }
    .features__item {
      margin-bottom: 0;
    }
  }
  @media (min-width: 90rem) {
    .features__grid {
      grid-template-columns: repeat(4, 1fr);
    }
  }
}

.features--img-sm img {
  max-width: 128px;
}

.features--center-content .features__item {
  text-align: center;
}

.features--center-content .features__item img {
  margin-left: auto;
  margin-right: auto;
}

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

Title: Feature
Descr: Content group containing text + media (img, video, iframe, inline SVG)

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

.feature__item--max-width-sm {
  max-width: 480px;
}

.feature__item--max-width-md {
  max-width: 600px;
}

.feature__item--max-width-lg {
  max-width: 720px;
}

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

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

.feature__item--center-x.feature__item--max-width-sm, .feature__item--center-x.feature__item--max-width-md, .feature__item--center-x.feature__item--max-width-lg {
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 64rem) {
  .feature__item--md-center-x {
    text-align: center;
  }
  .feature__item--md-center-x .feature__cta {
    -ms-flex-pack: center;
        justify-content: center;
  }
  .feature__item--md-center-x.feature__item--max-width-sm, .feature__item--md-center-x.feature__item--max-width-md, .feature__item--md-center-x.feature__item--max-width-lg {
    margin-left: auto;
    margin-right: auto;
  }
}

.feature__label {
  color: hsl(240, 8%, 12%);
  color: var(--color-black);
  font-size: 1.2em;
  font-size: var(--text-md);
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

.feature__item--media {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.feature__item--media figure {
  width: 100%;
}

.feature__item--media video, .feature__item--media img, .feature__item--media svg {
  display: block;
}

.feature__item--media video, .feature__item--media img {
  width: 100%;
  height: auto;
}

@supports (display: grid) {
  .feature__item--media svg {
    width: 100%;
    height: auto;
  }
}

.feature__iframe-wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  width: 100%;
}

.feature__iframe-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media (min-width: 37.5rem) {
  .feature--sm-invert .feature__grid > *:first-child {
    -ms-flex-order: 2;
        order: 2;
  }
  .feature--sm-invert .feature__grid > *:last-child {
    -ms-flex-order: 1;
        order: 1;
  }
}

@media (min-width: 64rem) {
  .feature--md-invert .feature__grid > *:first-child {
    -ms-flex-order: 2;
        order: 2;
  }
  .feature--md-invert .feature__grid > *:last-child {
    -ms-flex-order: 1;
        order: 1;
  }
}

@media (min-width: 80rem) {
  .feature--lg-invert .feature__grid > *:first-child {
    -ms-flex-order: 2;
        order: 2;
  }
  .feature--lg-invert .feature__grid > *:last-child {
    -ms-flex-order: 1;
        order: 1;
  }
}

@media (min-width: 37.5rem) {
  .feature-group--sm-auto-invert .feature:nth-child(2n) .feature__grid > *:first-child {
    -ms-flex-order: 2;
        order: 2;
  }
  .feature-group--sm-auto-invert .feature:nth-child(2n) .feature__grid > *:last-child {
    -ms-flex-order: 1;
        order: 1;
  }
}

@media (min-width: 64rem) {
  .feature-group--md-auto-invert .feature:nth-child(2n) .feature__grid > *:first-child {
    -ms-flex-order: 2;
        order: 2;
  }
  .feature-group--md-auto-invert .feature:nth-child(2n) .feature__grid > *:last-child {
    -ms-flex-order: 1;
        order: 1;
  }
}

@media (min-width: 80rem) {
  .feature-group--lg-auto-invert .feature:nth-child(2n) .feature__grid > *:first-child {
    -ms-flex-order: 2;
        order: 2;
  }
  .feature-group--lg-auto-invert .feature:nth-child(2n) .feature__grid > *:last-child {
    -ms-flex-order: 1;
        order: 1;
  }
}

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

Title: Swipe Content
Descr: A Vanilla JavaScript plugin to detect touch interactions.

-------------------------------- */
.swipe-content {
  height: 280px;
  width: 280px;
  background-color: hsl(240, 1%, 83%);
  background-color: var(--color-contrast-low);
  border-radius: 0.25em;
  border-radius: var(--radius);
  cursor: default;
  transition: background 0.2s;
}

.swipe-content:active {
  background-color: hsl(240, 1%, 48%);
  background-color: var(--color-contrast-medium);
}

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

Title: Carousel
Descr: Display and cycle through a collection of items

-------------------------------- */
:root {
  --carousel-grid-gap: 0;
  --carousel-item-auto-size: 260px;
}

.carousel {
  position: relative;
}

@supports (display: flex) {
  .carousel {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
  }
  .carousel__controls {
    -ms-flex-order: 1;
        order: 1;
  }
  .carousel__wrapper {
    -ms-flex-order: 2;
        order: 2;
  }
}

.carousel__wrapper {
  overflow: hidden;
  padding: 0;
}

.carousel__list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  will-change: transform;
}

.carousel__item {
  display: inline-block;
  float: left;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 260px;
  width: var(--carousel-item-auto-size);
  margin-right: 0;
  margin-bottom: 0;
  margin-bottom: var(--carousel-grid-gap);
  background: hsl(0, 0%, 95%);
  background: var(--color-contrast-lower);
  height: 300px;
}

.carousel__control {
  display: none;
}

.js .carousel__list--animating {
  transition: -webkit-transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: -webkit-transform 0.5s var(--transition-ease-out);
  transition: transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.5s var(--transition-ease-out);
  transition: transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
  transition: transform 0.5s var(--transition-ease-out), -webkit-transform 0.5s var(--transition-ease-out);
}

.js .carousel__item {
  opacity: 0;
  margin-bottom: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: end;
      justify-content: flex-end;
  -ms-flex-direction: column;
      flex-direction: column;
}

.js .carousel--loaded .carousel__item {
  opacity: 1;
}

.js .carousel:not(.carousel--is-dragging) .carousel__list:not(.carousel__list--animating) .carousel__item[tabindex="-1"] > * {
  visibility: hidden;
}

.js .carousel[data-drag="on"] .carousel__item {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.js .carousel[data-drag="on"] .carousel__item img {
  pointer-events: none;
}

.js .carousel__controls {
  margin: 0.375em 0;
  margin: var(--space-xxs) 0;
}

.js .carousel__controls ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
      justify-content: flex-start;
}

.js .carousel__controls li:first-child {
  display: inline-block;
  margin-right: 2px;
}

.js .carousel__control {
  display: inline-block;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 32px;
  height: 32px;
  background-color: hsla(45, 97%, 53%, 0.95);
  background-color: hsla(var(--color-kaptur-yellow-h), var(--color-kaptur-yellow-s), var(--color-kaptur-yellow-l), 0.95);
  z-index: 1;
  transition: -webkit-transform .2s;
  transition: transform .2s;
  transition: transform .2s, -webkit-transform .2s;
}

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

.js .carousel__control:hover {
  background-color: hsl(240, 4%, 20%);
  background-color: var(--color-contrast-high);
}

.js .carousel__control .icon {
  display: block;
  width: 16px;
  height: 16px;
  color: hsl(0, 0%, 100%);
  color: var(--color-bg);
}

html:not(.js) .carousel__list {
  overflow: auto;
}

.carousel__content {
  background: hsl(45, 97%, 53%);
  background: var(--color-kaptur-yellow);
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: bottom;
      align-items: bottom;
  font-size: 0.83333em;
  font-size: var(--text-sm);
  text-align: center;
  font-family: 'Gotham Narrow Thin';
  padding: 0.75em;
  padding: var(--space-sm);
  text-transform: uppercase;
}

.carousel__content .title {
  text-align: center;
  font-family: 'Gothic Narrow Medium';
  margin-bottom: 0.75em;
  margin-bottom: var(--space-sm);
}

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

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

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%, 95%);
  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(14, 50px);
    }
    .adv-gallery__grid > :nth-child(1) {
      grid-column: 1 / 7;
      grid-row: 1 / 5;
    }
    .adv-gallery__grid > :nth-child(2) {
      grid-column: 1 / 4;
      grid-row: 5 / 10;
    }
    .adv-gallery__grid > :nth-child(3) {
      grid-column: 4 / 7;
      grid-row: 5 / 10;
    }
    .adv-gallery__grid > :nth-child(4) {
      grid-column: 1 / 7;
      grid-row: 10 / 14;
    }
    .adv-gallery__grid > :nth-child(5) {
      grid-column: 7 / 13;
      grid-row: 1 / 10;
    }
    .adv-gallery__grid > :nth-child(6) {
      grid-column: 7 / 13;
      grid-row: 10 / 14;
    }
    .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(240, 4%, 20%);
      background-color: var(--color-contrast-high);
      margin-bottom: 0.75em;
      margin-bottom: var(--space-sm);
    }
  }
}

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

Title: Contact
Descr: Contact block w/ info about how to get in touch

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

@media (min-width: 64rem) {
  @supports (grid-area: auto) {
    .contact__list {
      margin-bottom: 0;
    }
  }
}

.contact__item {
  padding: 1.25em 0;
  padding: var(--space-md) 0;
  border-bottom: 1px solid hsl(240, 1%, 83%);
  border-bottom: 1px solid var(--color-contrast-low);
}

.contact__item dt {
  font-size: 1.2em;
  font-size: var(--text-md);
  font-weight: bold;
  margin-bottom: 0.375em;
  margin-bottom: var(--space-xxs);
}

.contact__item dd {
  line-height: 1.4;
}

@media (min-width: 64rem) {
  @supports (grid-area: auto) {
    .contact__item {
      display: -ms-flexbox;
      display: flex;
      -ms-flex-pack: justify;
          justify-content: space-between;
      -ms-flex-align: baseline;
          align-items: baseline;
    }
    .contact__item dt {
      margin-bottom: 0;
    }
    .contact__item dd {
      text-align: right;
    }
  }
}

.contact__map {
  height: 0;
  padding-bottom: 50%;
}

@media (min-width: 64rem) {
  @supports (grid-area: auto) {
    .contact__grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      grid-gap: 2em;
      grid-gap: var(--space-lg);
    }
    .contact__map {
      height: auto;
      padding-bottom: 0;
    }
  }
}

* {
  letter-spacing: 1px;
}

h2::after {
  content: "";
  display: block;
  margin-left: 0;
  width: 50px;
  padding-top: 16px;
  border-bottom: 8px solid hsl(45, 97%, 53%);
  border-bottom: 8px solid var(--color-kaptur-yellow);
  -webkit-transform: skew(-10deg);
      -ms-transform: skew(-10deg);
          transform: skew(-10deg);
  margin-bottom: 2em;
  margin-bottom: var(--space-lg);
}

b {
  font-family: 'Gotham Narrow Medium';
}

/**
* Fejléc
*/
#fejlec {
  background: hsl(0, 0%, 14%) url("../img/header-bg.jpg") repeat;
  background: var(--color-header-bg) url("../img/header-bg.jpg") repeat;
}

/**
* Navigáció
*/
#navbar {
  background: hsl(45, 97%, 53%);
  background: var(--color-kaptur-yellow);
  border-bottom: 0;
}

#navbar .main-header__nav-link {
  text-transform: uppercase;
}

/**
* Rólunk
*/
#rolunk h2::after {
  margin-left: 0;
}

/**
* TEVÉKENYSÉGI KÖREINK
*/
#tevekenyseg {
  padding-bottom: 0.5em;
  padding-bottom: var(--space-xs);
}

#tevekenyseg h2::after {
  left: 50%;
  margin-left: calc(50% - 25px);
}

#tevekenyseg-ikonok .features__item img {
  min-height: 80px;
}

/**
* KARRIER
*/
#karrier {
  background: #595959 url("../img/karrier-bg.png");
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-position: bottom center;
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
}

#karrier .feature__item * {
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
}

/**
* TÉRKÉP
*/
#terkep {
  min-height: 500px;
}

/**
* LÁBLÉC
*/
footer {
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
  background: #242424;
}

footer h2 {
  color: hsl(0, 0%, 100%);
  color: var(--color-white);
}

footer div.col--md-6:nth-child(2) {
  background: hsl(45, 97%, 53%);
  background: var(--color-kaptur-yellow);
}

footer form {
  position: relative;
  top: -50px;
}

footer .form-control {
  border: 0;
  border-radius: 10px;
}

footer .btn {
  background: #0a0a0a;
  float: right;
}

footer .form-control {
  color: black;
}