@charset "UTF-8";

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

main {
    display: block
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button,
input {
    overflow: visible
}

button,
select {
    text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
    -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    padding: .35em .75em .625em
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox],
[type=radio] {
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

template {
    display: none
}

[hidden] {
    display: none
}

html {
    box-sizing: border-box;
    scroll-behavior: smooth
}

*,
:after,
:before {
    box-sizing: inherit
}

@font-face {
    font-family: 'Mark Pro';
    src: local("Mark Pro Heavy"), local("MarkPro-Heavy"), url(https://d33wubrfki0l68.cloudfront.net/7c27f91109360b63ae10570e12ac6353a76e1e60/5b180/fonts/markpro-heavy.woff2) format("woff2"), url(https://d33wubrfki0l68.cloudfront.net/fb2f049dfdde3b2bbf12146440093ef68e535656/99038/fonts/markpro-heavy.woff) format("woff");
    font-weight: 800;
    font-style: normal
}

@font-face {
    font-family: 'Mark Pro';
    src: local("Mark Pro Bold"), local("MarkPro-Bold"), url(https://d33wubrfki0l68.cloudfront.net/f919a22c421b5b1c87713fe76d10256964853793/aff49/fonts/markpro-bold.woff2) format("woff2"), url(https://d33wubrfki0l68.cloudfront.net/cbcbe49c83a8b234347638bac6d50fb6f467a48f/54980/fonts/markpro-bold.woff) format("woff");
    font-weight: 600;
    font-style: normal
}

@font-face {
    font-family: Eina01;
    src: local("Eina01-Regular"), local("3A2AFF_0_0"), url(https://d33wubrfki0l68.cloudfront.net/ccf71496653e35f224872e7159a03be4dae3cae6/797b4/fonts/3a2aff_0_0.eot#iefix) format("embedded-opentype"), url(https://d33wubrfki0l68.cloudfront.net/5bbb12e7a2830eccd978f2a906b7cc81ad5e6671/60db6/fonts/3a2aff_0_0.woff2) format("woff2"), url(https://d33wubrfki0l68.cloudfront.net/8f8ed216aee209ac60c76015760d4820c324a4f0/b6905/fonts/3a2aff_0_0.woff) format("woff"), url(webfonts/3A2AFF_0_0.html) format("truetype");
    font-weight: 400;
    font-style: normal
}

@font-face {
    font-family: Eina01;
    src: local("Eina01-Bold"), local("3A2AFF_0_1"), url(https://d33wubrfki0l68.cloudfront.net/ccd9996d6b9834f15c948d821dc0b6b963ef6d36/6dbd0/fonts/3a2aff_1_0.eot#iefix) format("embedded-opentype"), url(https://d33wubrfki0l68.cloudfront.net/eb7ef6a310b8cdebcb6dda81e6d7415e34c9a227/0c881/fonts/3a2aff_1_0.woff2) format("woff2"), url(https://d33wubrfki0l68.cloudfront.net/88e28b9e211fefa0bd1d8a93f8650f9e69148da1/ced78/fonts/3a2aff_1_0.woff) format("woff"), url(webfonts/3A2AFF_1_0.html) format("truetype");
    font-weight: 700;
    font-style: normal
}

html {
    color: #2b2a35;
    font-family: Eina01, sans-serif;
    font-size: 62.5%;
    line-height: 2
}

body {
    font-size: 1.6rem;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

@media (min-width:40em) {
    body {
        font-size: 1.8rem
    }
}

a {
    color: #4173a7;
    text-decoration: none
}

li a:focus,
li a:hover,
p a:focus,
p a:hover {
    text-decoration: underline
}

a svg,
button svg {
    pointer-events: none
}

p {
    word-break: break-word
}

p+p {
    margin: 0 0 1em
}

p.light {
    color: #939da8
}

p.small {
    font-size: 1.2rem
}

.heading-large,
.heading-medium,
.page-heading,
h1,
h2,
h3 {
    font-family: Mark Pro, Eina01, sans-serif
}

h4,
h5,
h6 {
    font-family: Eina01, sans-serif
}

h1,
h2,
h3,
h4,
h5,
h6 {
    line-height: 1.25;
    margin: 0 0 1rem
}

@media (min-width:40em) {
    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        margin-bottom: 1.5rem
    }
}

@media (min-width:60em) {
    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        margin-bottom: 2rem
    }
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
    color: inherit;
    transition: .3s color
}

h1 a[id],
h2 a[id],
h3 a[id],
h4 a[id],
h5 a[id],
h6 a[id] {
    margin-top: -12rem;
    padding-top: 12rem;
    position: absolute;
    display: block
}

h1 a:focus,
h1 a:hover,
h2 a:focus,
h2 a:hover,
h3 a:focus,
h3 a:hover,
h4 a:focus,
h4 a:hover,
h5 a:focus,
h5 a:hover,
h6 a:focus,
h6 a:hover {
    color: #4173a7;
    text-decoration: none
}

.negative h1 a:focus,
.negative h1 a:hover,
.negative h2 a:focus,
.negative h2 a:hover,
.negative h3 a:focus,
.negative h3 a:hover,
.negative h4 a:focus,
.negative h4 a:hover,
.negative h5 a:focus,
.negative h5 a:hover,
.negative h6 a:focus,
.negative h6 a:hover {
    color: inherit;
    text-decoration: underline
}

a h1:focus,
a h1:hover,
a h2:focus,
a h2:hover,
a h3:focus,
a h3:hover,
a h4:focus,
a h4:hover,
a h5:focus,
a h5:hover,
a h6:focus,
a h6:hover {
    text-decoration: underline
}

.center {
    text-align: center
}

.page-heading,
h1 {
    font-size: calc(5vw + 1.6rem);
    font-weight: 800;
    line-height: 1.2
}

@media (min-width:55em) {
    .page-heading,
    h1 {
        font-size: 6rem
    }
}

.heading-large,
h2 {
    font-size: 3.4rem;
    font-weight: 800
}

@media (min-width:40em) {
    .heading-large,
    h2 {
        font-size: 4.2rem;
        line-height: 1.1
    }
}

@media (min-width:60em) {
    .heading-large,
    h2 {
        font-size: 6rem;
        line-height: 1
    }
}

h2.subheadline {
    font-size: 1.4rem;
    font-family: Eina01, sans-serif;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: .1rem
}

@media (min-width:60em) {
    h2.subheadline {
        font-size: 1.8rem
    }
}

.heading-medium,
h3 {
    font-weight: 600;
    font-size: 2rem;
    line-height: 1.5;
    letter-spacing: -.02em
}

@media (min-width:40em) {
    .heading-medium,
    h3 {
        font-size: 2.4rem;
        line-height: 1.75
    }
}

@media (min-width:60em) {
    .heading-medium,
    h3 {
        font-size: 3.6rem;
        line-height: 1.5
    }
}

@media (min-width:80em) {
    .heading-medium,
    h3 {
        font-size: 4.2rem
    }
}

.large-copy,
h4 {
    font-size: 1.8rem;
    line-height: 1.5
}

@media (min-width:40em) {
    .large-copy,
    h4 {
        font-size: 2.1rem;
        line-height: 1.8
    }
}

@media (min-width:60em) {
    h4 {
        font-size: 2.7rem;
        line-height: 1.5
    }
}

h4 {
    font-weight: 600
}

h5,
h6 {
    font-size: 1em
}

@media (min-width:60em) {
    h5,
    h6 {
        font-size: 1.8rem
    }
}

.visually-hidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    white-space: nowrap;
    width: 1px
}

.negative {
    color: #fff
}

.negative a {
    color: inherit
}

strong {
    font-weight: 700
}

figcaption {
    color: #545465;
    font-size: 1.5rem;
    font-style: italic;
    margin: .5em auto 1em;
    max-width: 80rem;
    text-align: center
}

.read-more-link {
    display: flex;
    align-items: center;
    margin-top: 2rem;
    font-weight: 700;
    font-size: 1.8rem
}

.negative .read-more-link {
    color: rgba(255, 255, 255, .8)
}

.read-more-link svg {
    margin-left: .8rem;
    fill: currentColor
}

.read-more-link:hover {
    text-decoration: none;
    color: #4880ba
}

.negative .read-more-link:hover {
    color: #fff
}

ol {
    counter-reset: item
}

ol li {
    counter-increment: item;
    padding-left: .5rem
}

ol ol {
    margin-left: -4.7rem;
    padding-left: 0
}

ol ol li {
    padding-left: 4.7rem
}

.long-list ol {
    list-style: none;
    padding: 0 0 0 4.7rem
}

.long-list ol ol ol li {
    padding-left: 3.2rem
}

.long-list ol ol ol li>:first-child:before {
    content: counter(item, lower-alpha) ")";
    margin-left: -3.2rem
}

.long-list li {
    display: block
}

.long-list li>:first-child:before {
    content: counters(item, ".") ". ";
    position: absolute;
    margin-left: -4.7rem
}

@keyframes fadein {
    from {
        opacity: 0
    }
    to {
        opacity: 1
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translate3d(0, 4rem, 0)
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0)
    }
}

.fadeInUp {
    animation: fadeInUp .3s ease-out;
    animation-fill-mode: both
}

html {
    overflow-x: hidden
}

img,
svg,
video {
    max-width: 100%;
    height: auto;
    vertical-align: middle
}

ul {
    margin: 0;
    padding: 0
}

figure {
    margin: 0
}

.container {
    padding: 0 1.5rem
}

@media (min-width:40em) {
    .container {
        padding: 0 calc(18vw - 10rem)
    }
}

.container.gray {
    background-color: #f6f6f6
}

.container.coverColor {
    background: url("../images/about-cover.jpg") no-repeat 50% 50% / cover #ffffff;
}

.container.blue {
    background: #fff;
    color: #4173a7;
    /* bug: logo svg has a white blob which glares in the face */
    /* background: #66c2e7 */
}

.container.primaryGradientColor {
    background: #f3bdd7 linear-gradient(95.24deg, #E6717D 0, #E6717D 122.55%)
}

.container.separator {
    background-color: #fff;
    background-image: linear-gradient(white, #f6f6f6);
    background-position: bottom;
    background-repeat: no-repeat;
    background-size: 100% 12rem
}

.container-inner {
    margin: 0 auto;
    max-width: 138rem
}

.spacing,
.text {
    padding-top: 3rem;
    padding-bottom: 3rem;
    width: 100%
}

@media (min-width:40em) {
    .spacing,
    .text {
        padding-top: 5rem;
        padding-bottom: 5rem
    }
}

@media (min-width:60em) {
    .spacing,
    .text {
        padding-top: 8rem;
        padding-bottom: 8rem
    }
}

.to-edge {
    margin-left: -1.5rem;
    margin-right: -1.5rem
}

.hidden {
    opacity: 0
}

table {
    border-collapse: collapse
}

table td,
table th {
    border: .1rem solid #dddfe5;
    padding: .2em .5em
}

.break-out>img,
.break-out>video {
    display: block;
    width: 100%
}

@media (min-width:40em) {
    .break-out {
        margin-left: -2rem;
        margin-right: -2rem
    }
}

@media (min-width:60em) {
    .break-out {
        margin-left: -10rem;
        margin-right: -10rem
    }
}

@media (min-width:75em) {
    .break-out {
        margin-left: -20rem;
        margin-right: -20rem
    }
}

input[type=email],
input[type=text] {
    font-size: 1.6rem;
    line-height: normal;
    padding: .75em 1em .7em;
    border: none;
    border: 1px solid #dddfe5;
    border-radius: .6rem;
    margin-right: .5rem;
    transition: all .1s ease-in-out;
    -webkit-appearance: none
}

input[type=email]:hover,
input[type=text]:hover {
    border-color: #c0c4cf
}

input[type=email]:focus,
input[type=text]:focus {
    border-color: #4173a7;
    outline: 0
}

.negative input[type=email],
.negative input[type=text] {
    background-color: transparent;
    border: 1px solid rgba(255, 255, 255, .8);
    color: #fff
}

.negative input[type=email]::placeholder,
.negative input[type=text]::placeholder {
    color: #fff
}

.negative input[type=email]::-ms-input-placeholder,
.negative input[type=text]::-ms-input-placeholder {
    color: #fff
}

.negative input[type=email]:focus,
.negative input[type=text]:focus {
    outline: 0;
    border: 1px solid #fff
}

.button {
    font-size: 1.6rem;
    line-height: 1;
    padding: .75em 1.6em .7em;
    background-color: #4173a7;
    border: none;
    border-radius: .6rem;
    color: #fff;
    font-weight: bolder;
    cursor: pointer;
    transition: box-shadow 120ms, background-color 120ms;
    box-shadow: 0 .1rem .1rem transparent;
    text-align: center
}

.button:focus,
.button:hover {
    background: #4880ba;
    box-shadow: 0 .1rem .1rem rgba(0, 0, 0, .3);
    outline: 0
}

.negative .button {
    color: #4173a7;
    box-shadow: 0 .1rem .2rem rgba(0, 0, 0, .1);
    background-color: #fff;
    outline: 0
}

.negative .button:focus,
.negative .button:hover {
    background-color: #f2f2f2;
    box-shadow: 0 .1rem .2rem rgba(0, 0, 0, .4)
}

.button.outline {
    color: #4173a7;
    background-color: transparent;
    box-shadow: inset 0 0 0 .2rem #4173a7
}

.negative .button.outline {
    color: #fff;
    box-shadow: inset 0 0 0 .2rem #fff
}

.negative .button.outline:focus,
.negative .button.outline:hover {
    background-color: rgba(255, 255, 255, .1)
}

.button.light {
    background-color: #fff;
    color: #4173a7;
    box-shadow: 0 .2rem .5rem rgba(103, 110, 144, .2), 0 0 0 .1rem rgba(103, 110, 144, .05)
}

.button.light:focus,
.button.light:hover {
    box-shadow: 0 .2rem .5rem rgba(103, 110, 144, .4), 0 0 0 .1rem rgba(103, 110, 144, .05)
}

.buttons-social {
    display: flex
}

.buttons-social>* {
    margin-right: 1rem
}

.button-social {
    display: block;
    width: 24px;
    height: 24px;
    opacity: .85;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center
}

.button-social:hover {
    opacity: 1
}

.button-social.github {
    background-image: url(/images/icons/share-github.svg);
}

.button-social.twitter {
    background-image: url(/images/icons/share-twitter.svg)
}

.button-social.facebook {
    background-image: url(/images/icons/share-facebook.svg)
}

.button-social.instagram {
    background-image: url(/images/icons/share-instagram.svg)
}

.button-social.linkedIn {
    background-image: url(/images/icons/share-linkedin.svg)
}

.text-button {
    display: inline;
    border: none;
    padding: 0;
    margin: 0;
    text-decoration: none;
    background: 0 0;
    color: #4173a7;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    text-decoration: none
}

.text-button:focus,
.text-button:hover {
    text-decoration: underline
}

.negative .text-button {
    color: inherit
}

.author {
    align-items: center;
    display: flex;
    font-style: normal;
    justify-content: center;
    text-align: left;
    font-size: 1.5rem
}

.author__info {
    color: #545465;
    font-weight: 300;
    line-height: 1.5
}

.author__name {
    color: #545465;
    font-weight: 700
}

.author__image {
    margin-right: 2rem
}

.author__image img {
    border-radius: 50%;
    height: 6rem;
    object-fit: cover;
    width: 6rem
}

.article-preview {
    display: flex;
    flex-direction: column;
    position: relative
}

.article-preview__media {
    order: -1;
    border-radius: .6rem;
    padding-bottom: 71.43%;
    position: relative;
    margin-bottom: 2rem
}

.article-preview__image {
    border-radius: .6rem;
    height: 100%;
    object-fit: contain;
    position: absolute;
    width: 100%
}

.article-preview__header {
    font-size: 2.2rem;
    line-height: 1.4;
    margin-bottom: 2rem
}

@media (min-width:40em) {
    .article-preview__header {
        font-size: 2.7rem
    }
}

.article-preview__teaser-text {
    line-height: 1.8;
    margin: 0
}

@media (max-width:80em) {
    .article-preview__teaser-text {
        font-size: 1.6rem
    }
}

.banner {
    display: grid;
    grid-gap: 3rem;
    text-align: left
}

.banner.newsletter {
    margin: 0
}

@media (min-width:60em) {
    .banner {
        grid-template-columns: 2fr 1fr
    }
}

.banner::before {
    background: #4966f7 linear-gradient(11.5deg, #4966f7 41.89%, #8253ff 93.69%);
    border-radius: .6rem;
    content: "";
    grid-area: 1/1/2/2;
    z-index: -1
}

@media (min-width:60em) {
    .banner::before {
        grid-area: 2/1/3/3
    }
}

.banner .banner__fields {
    justify-content: start;
    max-width: 49.8rem
}

.banner input {
    flex: 1 1 auto
}

.banner .button {
    white-space: nowrap
}

.banner .legal-note {
    max-width: 49.8rem;
    text-align: left
}

.banner .newsletter-response {
    max-width: 49.8rem;
    position: static
}

.banner__content {
    grid-area: 1/1/2/2;
    padding: 3rem 3rem 1.5rem
}

@media (min-width:60em) {
    .banner__content {
        grid-area: 2/1/3/2
    }
}

@media (min-width:80em) {
    .banner__content {
        padding: 4.5rem 6rem 3.5rem
    }
}

.banner__heading {
    margin: 0 0 1rem;
    font-size: 2.4rem
}

@media (min-width:40em) {
    .banner__heading {
        font-size: 3.6rem
    }
}

@media (min-width:60em) {
    .banner__heading {
        font-size: 4.2rem
    }
}

.banner__subtext {
    margin: 0 0 1.5rem;
    opacity: .5;
    line-height: 1.8
}

.banner__media {
    align-items: flex-end;
    display: none;
    padding: 0 3rem
}

@media (min-width:60em) {
    .banner__media {
        display: flex;
        grid-area: 1/2/3/3
    }
}

.banner__media img {
    max-width: 28rem;
    width: 24vw
}

.columns {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: center
}

@media (min-width:60em) {
    .columns {
        margin-left: -2rem;
        margin-right: -2rem
    }
}

@media (min-width:60em) {
    .columns {
        flex-direction: row
    }
}

.columns .column {
    display: flex;
    flex: 1;
    flex-direction: column;
    margin: 0 0 4rem
}

@media (min-width:40em) {
    .columns .column {
        margin: 2rem
    }
}

.columns .column-card {
    flex: 1;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    padding: 3.6rem;
    border-radius: .8rem;
    box-shadow: 0 0 0 1px #dddfe5
}

.columns .column-card.centered {
    align-items: center
}

.columns .column-card.negative {
    background: linear-gradient(91.14deg, #4966f7 0, #8253ff 122.55%);
    box-shadow: none
}

.columns .column-card.gray {
    background-color: #f6f6f6
}

.columns .column-card.centered-image {
    display: flex;
    align-items: center;
    justify-content: center
}

.columns .column-card.centered-image img {
    min-width: 40%
}

.columns .column-card.no-padding {
    padding: 0
}

@media (min-width:60em) {
    .columns .heading-large,
    .columns h2 {
        font-size: 4.2rem;
        line-height: 1.1
    }
}

@media (min-width:100em) {
    .columns .heading-large,
    .columns h2 {
        font-size: 6rem;
        line-height: 1
    }
}

.column-card-top {
    flex: 1
}

.column-card-top.getting-started {
    max-width: 46rem
}

.column-meta {
    padding: 1em 0;
    display: flex;
    justify-content: space-between
}

.column-meta a:focus,
.column-meta a:hover {
    text-decoration: underline
}

@keyframes call-me-hand {
    0% {
        transform: rotate(0)
    }
    10% {
        transform: rotate(-10deg)
    }
    20% {
        transform: rotate(12deg)
    }
    30% {
        transform: rotate(-10deg)
    }
    40% {
        transform: rotate(9deg)
    }
    50% {
        transform: rotate(0)
    }
    100% {
        transform: rotate(0)
    }
}

.not-found {
    position: relative;
    width: 100%;
    padding-top: 50%
}

@media (max-width:40em) {
    .not-found {
        padding-top: 80%
    }
}

.not-found-image {
    position: absolute
}

.space-otto {
    left: 24%;
    top: 13.3%;
    width: 33%;
    z-index: 2;
    animation: space-otto 4s ease-in-out infinite
}

@media (max-width:40em) {
    .space-otto {
        left: 7.5%;
        top: 8.3%;
        width: 60%
    }
}

@keyframes space-otto {
    0% {
        transform: translateY(0)
    }
    50% {
        transform: translateY(15px)
    }
    100% {
        transform: translateY(0)
    }
}

.saturn-purple {
    left: 35.7%;
    top: 18.7%;
    width: 34%;
    z-index: 1;
    animation: saturn-purple 4.5s ease-in-out infinite
}

@media (max-width:40em) {
    .saturn-purple {
        left: 29%;
        top: 13.7%;
        width: 60%
    }
}

@keyframes saturn-purple {
    0% {
        transform: translateY(0)
    }
    50% {
        transform: translateY(-5px)
    }
    100% {
        transform: translateY(0)
    }
}

.planet-blue {
    left: 12.6%;
    top: 34%;
    width: 11%;
    animation: planet-blue 4s ease-in-out infinite
}

@keyframes planet-blue {
    0% {
        transform: translateY(0)
    }
    50% {
        transform: translateY(-15px)
    }
    100% {
        transform: translateY(0)
    }
}

.bone {
    left: 50.4%;
    top: 25.2%;
    width: 10.3%;
    z-index: 3;
    animation: bone 3.6s ease-in-out infinite
}

@media (max-width:40em) {
    .bone {
        left: 55%;
        top: 20.2%;
        width: 20%
    }
}

@keyframes bone {
    0% {
        transform: translateY(0)
    }
    50% {
        transform: translateY(-10px)
    }
    100% {
        transform: translateY(0)
    }
}

.moon-pink {
    left: 71.4%;
    top: 0;
    width: 15.6%;
    animation: moon-pink 4.8s ease-in-out infinite
}

@keyframes moon-pink {
    0% {
        transform: translateY(0)
    }
    50% {
        transform: translateY(12px)
    }
    100% {
        transform: translateY(0)
    }
}

.sat {
    left: 76.6%;
    top: 50.8%;
    width: 9.9%;
    animation: sat 4s ease-in-out infinite
}

@keyframes sat {
    0% {
        transform: translateY(0)
    }
    50% {
        transform: translateY(-15px)
    }
    100% {
        transform: translateY(0)
    }
}

.planet-yellow {
    left: 66.3%;
    top: 74.8%;
    width: 8.3%;
    animation: planet-yellow 4.8s ease-in-out infinite
}

@keyframes planet-yellow {
    0% {
        transform: translateY(0)
    }
    50% {
        transform: translateY(12px)
    }
    100% {
        transform: translateY(0)
    }
}

@media (max-width:40em) {
    .moon-pink,
    .planet-blue,
    .planet-yellow,
    .sat {
        display: none
    }
}

.footer {
    display: flex;
    font-size: 1.6rem;
    margin-bottom: 8rem;
    padding-top: 8rem;
    text-align: left;
    border-top: .1rem solid rgba(0, 0, 0, .2);
    margin-top: -.1rem
}

@media (min-width:40em) {
    .footer {
        margin-bottom: 5rem;
        padding-top: 5rem
    }
}

@media (max-width:60em) {
    .footer {
        text-align: center;
        flex-direction: column
    }
}

.footer .footer-right .left p:nth-child(2) {
    margin-top: 1rem
}

.footer .logo {
    color: inherit;
    display: block;
    margin-bottom: 1rem
}

.footer .links {
    margin: 0 1rem 1rem
}

.footer .links>a {
    color: inherit
}

.footer .links>a:focus,
.footer .links>a:hover {
    text-decoration: none
}

.footer .links h3 {
    font: inherit;
    font-weight: 700;
    margin: 0
}

.footer .buttons-social {
    margin: 1rem 0
}

@media (max-width:60em) {
    .footer .buttons-social {
        justify-content: space-around
    }
}

.footer-left {
    flex: 2
}

@media (max-width:60em) {
    .footer-left {
        order: 2;
        text-align: center;
        margin-top: 1em
    }
}

.footer-right {
    display: flex;
    flex: 1;
    justify-content: space-around;
    flex-wrap: wrap
}

.footer-right a {
    display: block;
    padding: .25ch 0
}

@media (min-width:60em) {
    .footer-right {
        flex: 3;
        justify-content: space-between
    }
}

.founder {
    position: relative;
    text-align: left
}

.founder__overlay {
    background: linear-gradient(180deg, rgba(47, 47, 48, 0) 0, #262e38 100%);
    bottom: 0;
    color: #fff;
    left: 0;
    padding: 3rem 2rem 1.5rem;
    position: absolute;
    right: 0;
    opacity: 0;
    transition: opacity .3s;
    pointer-events: none
}

.founder.toggle-active .founder__overlay,
.founder:focus .founder__overlay,
.founder:focus-within .founder__overlay,
.founder:hover .founder__overlay {
    opacity: 1;
    pointer-events: auto
}

@media (max-width:40em) {
    .founder__overlay {
        padding: 1rem
    }
}

.founder__overlay .comrade__name,
.founder__overlay .comrade__role,
.founder__overlay .founder__social {
    color: inherit;
    margin: 0
}

.comrade__name {
    line-height: 1.2;
    margin-bottom: .3rem
}

@media (max-width:50em) {
    .comrade__name {
        font-size: 1em
    }
}

.comrade__role {
    line-height: 1.4
}

@media (max-width:50em) {
    .comrade__role {
        font-size: .875em
    }
}

.founder__social {
    display: flex
}

.founder__social-link {
    color: rgba(255, 255, 255, .8);
    display: inline-flex;
    height: 1.75em;
    margin-bottom: -.25em;
    margin-left: .5em;
    padding: .25em;
    width: 1.75em;
    opacity: .8
}

.founder__social-link:first-child {
    margin-left: -.25em
}

.founder__social-link:focus,
.founder__social-link:hover {
    opacity: 1
}

.hamburger {
    padding: .3rem;
    display: inline-block;
    color: inherit;
    cursor: pointer;
    background: 0 0;
    border: none;
    width: 3.2rem;
    height: 2.2rem;
    position: relative;
    margin-left: 1.5rem
}

.hamburger-inner {
    display: block;
    top: 50%;
    margin-top: -.1rem;
    transition-duration: 75ms;
    transition-timing-function: cubic-bezier(.55, .055, .675, .19)
}

.hamburger-inner,
.hamburger-inner::after,
.hamburger-inner::before {
    width: 2.6rem;
    height: .2rem;
    background-color: currentColor;
    border-radius: .15rem;
    position: absolute;
    transition-property: transform
}

.hamburger-inner::after,
.hamburger-inner::before {
    content: "";
    display: block
}

.hamburger-inner::before {
    top: -.7rem;
    transition: top 75ms .12s ease, opacity 75ms ease
}

.hamburger-inner::after {
    bottom: -.7rem;
    transition: bottom 75ms .12s ease, transform 75ms cubic-bezier(.55, .055, .675, .19)
}

.toggle-active .hamburger-inner {
    transform: rotate(45deg);
    transition-delay: .12s;
    transition-timing-function: cubic-bezier(.215, .61, .355, 1)
}

.toggle-active .hamburger-inner::before {
    top: 0;
    opacity: 0;
    transition: top 75ms ease, opacity 75ms .12s ease
}

.toggle-active .hamburger-inner::after {
    bottom: 0;
    transform: rotate(-90deg);
    transition: bottom 75ms ease, transform 75ms .12s cubic-bezier(.215, .61, .355, 1)
}

body {
    padding-top: 7rem
}

@media (max-width:52em) {
    body {
        padding-top: 6rem
    }
}

.header-scroll-trigger {
    height: 1px;
    top: 0;
    position: absolute;
    z-index: -1
}

.header-container {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background-color: #fff;
    z-index: 10;
    padding-bottom: 1.5rem;
    padding-top: 1.5rem;
    height: 7.2rem;
    box-shadow: 0 0 1.8rem transparent;
    transition: box-shadow .3s, color .5s, background-color .5s
}

@media (prefers-reduced-motion:reduce) {
    .header-container {
        transition: none
    }
}

.header-container.scrolled {
    box-shadow: 0 0 1.8rem rgba(0, 0, 0, .15)
}

@media (max-width:52em) {
    .header-container {
        height: 6rem;
        padding-bottom: 1.5rem;
        padding-top: 1.5rem
    }
}

.header-container .container-inner {
    margin: 0 auto;
    display: flex;
    height: 100%
}

.header {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    font-size: 1.6rem;
    justify-content: space-between;
    width: 100%
}

.header .logo {
    align-items: center;
    color: inherit;
    display: flex;
    height: 3rem;
    margin-right: auto
}

.header .hamburger {
    display: none
}

@media (max-width:52em) {
    .header .hamburger {
        display: block
    }
}

.header.login-button--visible #login-button-mount {
    order: 1;
    margin-left: 1rem
}

@media (max-width:52em) {
    .header.login-button--visible #login-button-mount {
        margin-left: 0;
        order: 0
    }
}

.header .button {
    margin: -.7ch 0 -.7ch auto;
    display: block
}

@media (max-width:52em) {
    .header .button {
        margin: -.7ch 0 -.7ch 1.5rem;
        padding: .6em .7em .5em
    }
}

.header .header-signup {
    order: 1;
    display: none
}

@media (min-width:20em) {
    .header .header-signup {
        display: block
    }
}

@media (max-width:52em) {
    .header .header-signup {
        order: 0
    }
}

@media (max-width:24.5em) {
    .header.login-button--visible .header-signup {
        display: none
    }
}

.menu {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 -.5rem
}

@media (max-width:52em) {
    .menu {
        align-items: stretch;
        align-self: baseline;
        color: #2b2a35;
        flex-direction: column;
        flex: 100%;
        left: 0;
        margin: 4.5rem 0 0;
        opacity: 0;
        pointer-events: none;
        position: absolute;
        right: 0;
        transform: translateY(-100%);
        transition: transform .2s, opacity .2s;
        z-index: -2
    }
    .menu:after {
        content: '';
        display: block;
        position: absolute;
        bottom: 0;
        width: 100%;
        z-index: -1;
        box-shadow: 0 0 2rem .5rem rgba(0, 0, 0, .3)
    }
    .toggle-active .menu {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0)
    }
    .menu:focus-within {
        transform: translateY(0);
        opacity: 1
    }
}

.menu a {
    color: inherit;
    display: block;
    margin-left: 5rem;
    padding: .5rem 0;
    line-height: 1
}

.menu a:first-of-type {
    margin-left: 0
}

.menu a.press {
    position: relative;
    display: flex
}

.menu a.press span {
    background: #4173a7;
    border-radius: .9rem;
    color: #fff;
    font-size: 1.1rem;
    font-weight: 600;
    left: 100%;
    line-height: .9rem;
    margin: -1rem 0 0 .6ch;
    min-width: 1.8rem;
    padding: .5rem .5rem .4rem;
    position: absolute;
    text-align: center;
    transition: color .5s, background-color .5s
}

@media (prefers-reduced-motion:reduce) {
    .menu a.press span {
        transition: none
    }
}

@media (min-width:52em) {
    .negative .menu a.press span {
        background-color: #fff;
        color: #4173a7
    }
}

@media (max-width:52em) {
    .menu a.press {
        display: flex;
        align-items: center
    }
    .menu a.press span {
        position: static;
        margin-left: auto
    }
}

@media (min-width:52em) {
    .menu a:hover {
        box-shadow: 0 2px 0 #dddfe5
    }
}

.menu a.active {
    color: #4173a7
}

@media (min-width:52em) {
    .menu a.active {
        box-shadow: 0 2px 0 currentColor
    }
    .negative .menu a.active {
        color: inherit
    }
}

@media (max-width:52em) {
    .menu a {
        background-color: #fff;
        border-top: 1px solid #eee;
        line-height: 2;
        margin-left: 0;
        padding: 1.5rem
    }
}

@media (min-width:40em) and (max-width:52em) {
    .menu a {
        padding: 1.5rem calc(20vw - 10rem)
    }
    .menu a:hover {
        background-color: #fcfcfc
    }
}

.hero {
    margin-bottom: calc(12vw - 40vh);
    padding: 0;
    text-align: center;
    z-index: 1
}

.js .hero {
    height: calc(100vh + 60rem + 5vw)
}

@media (prefers-reduced-motion:reduce) {
    .js .hero {
        height: auto
    }
}

.reduced-motion .hero {
    height: auto
}

.hero .container-inner {
    height: 100%;
    max-width: none
}

.hero-ui {
    display: block;
    left: 50%;
    margin-left: -8.75em;
    margin-top: -3.75em;
    max-width: none;
    opacity: 0;
    position: absolute;
    top: .6em;
    width: 16.25em;
    will-change: opacity;
    z-index: -1
}

.hero-scroll-container {
    animation: fadein .5s;
    height: calc(100vh + 5vw);
    margin-top: -7rem;
    margin-bottom: 0;
    overflow: hidden;
    position: -webkit-sticky;
    position: sticky;
    top: 0
}

@media (max-width:45em) {
    .hero-scroll-container {
        margin-top: -6rem
    }
}

.hero-transform-target {
    font-size: 12vw;
    height: 100%;
    transform-origin: 50% 40%;
    will-change: transform
}

@media (min-width:80em) {
    .hero-transform-target {
        font-size: 10vw
    }
}

.hero-headline {
    color: #4173a7;
    font-size: inherit;
    left: 0;
    line-height: .95;
    margin: 0 auto;
    max-width: 8ch;
    position: absolute;
    right: 0;
    top: 26vh
}

.hero-inverted {
    background-color: #4173a7;
    color: #fff
}

.hero-headline-text {
    display: block
}

.hero-intro {
    font: inherit;
    color: #545465;
    font-size: calc(.125em + .8rem);
    line-height: 1.75;
    left: 50%;
    margin-top: calc(34vw - 2em);
    max-width: 42ch;
    padding: 0 2rem;
    position: absolute;
    top: 32vh;
    transform: translate(-50%, -50%);
    width: 80vw;
    z-index: 1
}

@media (min-width:80em) {
    .hero-intro {
        font-size: calc(.1em + .75rem);
        transform: translate(-50%, 0);
        margin-top: 22vw
    }
}

.hero-gurl-center {
    width: 5em;
    margin-top: -.25em;
    position: relative;
    margin-left: 1.1em
}

.hero-hand {
    left: 50%;
    max-width: none;
    pointer-events: none;
    position: absolute;
    margin-left: -5em;
    top: -1.15em;
    width: 10em
}

.section.newsletter-signup .text {
    padding-top: 8rem;
    padding-bottom: 8rem
}

.newsletter {
    margin-bottom: 4rem;
    position: relative;
    margin-top: 4rem
}

h4+.newsletter {
    margin-top: 0
}

@media (max-width:30em) {
    .newsletter button,
    .newsletter input[type=email],
    .newsletter input[type=text] {
        padding-left: 1.2rem;
        padding-right: 1.2rem
    }
}

.newsletter .button {
    padding-left: 4.8rem;
    padding-right: 4.8rem
}

@media (max-width:40em) {
    .newsletter .button {
        padding-left: 3.6rem;
        padding-right: 3.6rem
    }
}

@media (max-width:30em) {
    .newsletter .button {
        padding-left: 1rem;
        padding-right: 1rem
    }
}

.newsletter.connected .email {
    margin-right: 0;
    margin-bottom: 1rem
}

@media (min-width:24em) {
    .newsletter.connected .email {
        border-radius: 6px 0 0 6px;
        margin-bottom: 0
    }
    .newsletter.connected .button {
        margin-left: -1px;
        border-radius: 0 6px 6px 0
    }
}

.newsletter-fields {
    display: flex;
    justify-content: center;
    flex-direction: column
}

@media (min-width:24em) {
    .newsletter-fields {
        flex-direction: row
    }
}

.newsletter-response {
    display: none;
    border-radius: .6rem;
    padding: 1ch;
    position: absolute;
    width: 100%;
    font-size: .75em;
    line-height: 1.5;
    top: 100%;
    margin-top: .5em
}

.negative .newsletter-response {
    color: #fff
}

.negative .newsletter-response .text-button,
.negative .newsletter-response a {
    font-weight: 700
}

.newsletter-response.notice {
    display: block;
    border: .1rem solid #dddfe5
}

.newsletter-response.error {
    display: block;
    color: #fff;
    background: #ff7673
}

.legal-note {
    font-size: 12px;
    text-align: center;
    margin: 1rem 0 0
}

.legal-note span {
    opacity: .6
}

.overflow-content {
    overflow-x: auto;
    margin-bottom: 1rem;
    max-width: 100vw;
    min-width: 0;
    padding: 1.5rem;
    margin-left: -1.5rem;
    margin-right: -1.5rem
}

.overflow-content table {
    min-width: 64rem
}

.overflow-content th {
    white-space: nowrap
}

@media (max-width:40em) {
    .overflow-content {
        width: 100vw
    }
}

@media (min-width:40em) {
    .overflow-content.overflow-content--wide {
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw)
    }
}

@media (min-width:75em) {
    .overflow-content.overflow-content--wide {
        margin-left: calc(50% - 60rem);
        margin-right: calc(50% - 60rem)
    }
}

.section {
    position: relative
}

.section .container-inner {
    align-items: center;
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    text-align: center
}

.section .container-inverted {
    background-color: #4173a7;
    color: #fff
}

.section .text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 80rem;
    width: 100%
}

.section .left {
    align-items: flex-start;
    text-align: left
}

.section .wide {
    max-width: 77rem
}

.section .full {
    align-items: initial;
    width: 64rem
}

@media (max-width:64rem) {
    .section .full {
        width: 100%
    }
}

.section p {
    color: #545465
}

.section.negative p {
    color: inherit
}

.section .border {
    border-bottom: 1px solid #dddfe5
}

@media (min-width:60em) {
    .section.media-text .container-inner,
    .section.text-media .container-inner {
        flex-direction: row;
        text-align: left
    }
    .section.media-text .text,
    .section.text-media .text {
        max-width: 54rem
    }
}

@media (min-width:60em) {
    .section.media-text .media {
        order: -1
    }
}

.slider {
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
    -ms-overflow-style: none;
    overflow: -moz-scrollbars-none;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.slider::-webkit-scrollbar {
    width: 0!important
}

.slider__list {
    display: flex;
    overflow-x: visible
}

.slider__list::after {
    content: '';
    display: block;
    flex: 0 0 calc(50vw - 50%);
    margin-left: -6.25%
}

@media (min-width:60em) {
    .slider__list::after {
        margin-left: -4.347826087%
    }
}

.slider__item {
    scroll-snap-align: center;
    display: inline-flex;
    margin-right: 6.25%;
    max-width: 42rem;
    flex: 0 0 80%
}

@media (min-width:36em) {
    .slider__item {
        flex: 0 0 43.75%
    }
}

@media (min-width:60em) {
    .slider__item {
        margin-right: 4.347826087%;
        flex: 0 0 30.434783%
    }
}

.testimonials .testimonial__name,
.testimonials .testimonial__role,
.testimonials .testimonial__text {
    margin: 0
}

.testimonials .testimonial__avatar {
    width: 6rem;
    height: 6rem;
    border-radius: 50%;
    margin-top: 3.6rem;
    margin-bottom: 1.2rem
}

.testimonials .testimonial {
    flex: 0
}

@media (min-width:40em) {
    .testimonials .testimonial {
        flex-basis: calc(50% - 4rem)
    }
}

@media (min-width:75em) {
    .testimonials .testimonial {
        flex-basis: calc(33% - 4rem)
    }
}

.hero.about {
    font-size: calc(6.75vw + 1.5rem);
    height: 6.25em;
    margin-bottom: 0;
    padding-top: 0;
    position: relative;
    z-index: 0
}

@media (min-width:125em) {
    .hero.about {
        font-size: 15rem
    }
}

.hero.about::before {
    background: inherit;
    bottom: 100%;
    content: '';
    display: block;
    height: 100vh;
    left: 0;
    position: absolute;
    right: 0
}

.hero.about::after {
    background: #fff;
    content: '';
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    right: 0;
    top: 100%
}

.hero.about .container-inner {
    height: auto;
    position: sticky;
    position: -webkit-sticky;
    top: 8.2rem
}

@media (max-width:45em) {
    .hero.about .container-inner {
        top: 6rem
    }
}

.hero.about .hero-headline {
    color: #4173a7;
    margin-bottom: 0;
    max-width: 9ch;
    position: absolute;
    top: .8em;
    will-change: transform
}

.hero.about+.container {
    z-index: 1
}

.about-scroll-fix {
    display: none
}

.js .primaryGradientColor+.about-scroll-fix {
    display: block;
    height: 40vh;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    z-index: -1
}

.js .primaryGradientColor+.about-scroll-fix~.container {
    background-color: #fff
}

.beginning {
    font-size: 3.6rem;
    padding: 5rem 5rem 0;
    margin-top: -.5rem
}

@media (min-width:40em) {
    .beginning {
        font-size: 6rem;
        padding: 8rem 8rem 0
    }
}

@media (min-width:60em) {
    .beginning {
        font-size: 8rem;
        padding: 12rem 12rem 0
    }
}

@media (min-width:75em) {
    .beginning {
        font-size: 12rem;
        padding: 12rem 12rem 0
    }
}

.image-grid {
    display: grid;
    margin-bottom: 1rem;
    grid-template-columns: repeat(6, 1fr);
    grid-auto-flow: dense;
    list-style: none;
    grid-gap: 1.5rem;
    max-width: 120rem
}

@media (max-width:40em) {
    .image-grid {
        grid-template-columns: repeat(4, 1fr)
    }
}

.image-grid img {
    object-fit: cover;
    width: 100%;
    height: 100%
}

.image-grid>* {
    grid-column: span 2;
    grid-row: span 1
}

.image-grid .image-grid__big {
    grid-column: span 4;
    grid-row: span 2
}

.image-grid .image-grid__wide {
    grid-column: span 4
}

.image-grid .image-grid__medium {
    grid-column: span 3
}

@media (max-width:40em) {
    .image-grid .image-grid__medium {
        grid-column: span 2
    }
}

.investors {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(14em, 1fr));
    grid-gap: 2rem;
    margin: 0 auto;
    justify-content: center
}

@media (min-width:60em) {
    .investors {
        grid-template-columns: repeat(3, 1fr)
    }
}

.investors .investor {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 2.3rem 0;
    line-height: 1.8em
}

.investors .investor-image {
    align-items: center;
    display: flex;
    height: 5em;
    justify-content: center;
    margin-bottom: 1.8rem
}

.text-info {
    color: #939da8
}

.statistics {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
    margin: 1em 0
}

.statistics-item {
    align-items: center;
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 0 2rem
}

.statistics-item a:focus,
.statistics-item a:hover {
    text-decoration: underline
}

.statistics-description {
    color: #939da8;
    margin: 0
}

.glassdoor .statistics-description,
.statistics-value {
    font-family: Mark Pro, Eina01, sans-serif;
    font-size: 2rem;
    font-weight: 600;
    line-height: 1.5;
    margin: 0;
    order: -1;
    color: inherit
}

@media (min-width:40em) {
    .glassdoor .statistics-description,
    .statistics-value {
        font-size: 2.4rem;
        line-height: 1.75
    }
}

@media (min-width:60em) {
    .glassdoor .statistics-description,
    .statistics-value {
        font-size: 3.6rem;
        line-height: 2
    }
}

.glassdoor {
    width: 80%;
    margin-top: 3em;
    flex-wrap: wrap;
    flex-direction: row;
    flex: 0 0 auto
}

.glassdoor .statistics-description,
.glassdoor .statistics-value {
    flex-grow: 1
}

.glassdoor .statistics-value {
    order: 0;
    font: inherit
}

.glassdoor a {
    align-items: center;
    color: inherit;
    display: flex;
    flex-direction: column
}

.glassdoor .name {
    flex: 1;
    text-align: center;
    padding: 1rem
}

.glassdoor .right {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 1rem;
    color: inherit
}

.glassdoor .stars {
    display: flex;
    align-items: center;
    flex-wrap: nowrap
}

.glassdoor .stars img {
    width: 3.6rem
}

.glassdoor .stars .number {
    flex: 1
}

.benefits {
    width: 100%
}

.benefits ul {
    text-align: left;
    list-style: none;
    margin: 0;
    columns: 2 24ch;
    column-gap: 1em
}

@media (min-width:40em) {
    .benefits ul {
        column-gap: 3.5em
    }
}

.benefits ul li {
    padding-bottom: 2rem;
    padding-left: 2rem;
    position: relative
}

.benefits ul li:before {
    content: "•";
    color: #4173a7;
    position: absolute;
    left: 0
}

.cards .card {
    align-items: center;
    border-radius: 6px;
    box-shadow: 0 .2rem .5rem rgba(103, 110, 144, .2), 0 0 0 .1rem rgba(103, 110, 144, .05);
    color: #2b2a35;
    display: flex;
    margin-bottom: 2rem;
    padding: 2rem;
    text-align: left;
    transition: box-shadow .15s
}

.cards .card:focus,
.cards .card:hover {
    box-shadow: 0 .2rem .5rem rgba(103, 110, 144, .4), 0 0 0 .1rem rgba(103, 110, 144, .05)
}

.cards .card .location {
    flex: 0 0 auto;
    margin-left: auto
}

@media (min-width:40em) {
    .cards .card .location {
        padding: 0 1em
    }
}

.cards .info {
    flex: 1
}

@media (min-width:40em) {
    .cards .info {
        align-items: center;
        display: flex
    }
}

.cards .arrow {
    width: 1rem
}

.cards-section {
    margin-bottom: 4rem
}

.articles-count {
    opacity: 0
}

.articles-count.fadeIn {
    transition: opacity .2s ease;
    opacity: 1
}

.blog-image {
    border-radius: .6rem
}

.blog-highlight {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    position: relative
}

@media (min-width:60em) {
    .blog-highlight {
        flex-direction: row
    }
}

.blog-highlight .media {
    flex: 0 0 100%;
    order: -1
}

@media (min-width:60em) {
    .blog-highlight .media {
        align-items: stretch;
        align-self: stretch;
        flex-basis: 50%;
        margin-bottom: 4rem;
        margin-top: 4rem;
        order: 0
    }
    .blog-highlight .media,
    .blog-highlight .media picture {
        display: flex
    }
}

@media (min-width:60em) {
    .blog-highlight .blog-image {
        align-self: center;
        object-fit: cover
    }
}

.blog-highlight .text {
    flex: 0 0 100%
}

@media (min-width:60em) {
    .blog-highlight .text {
        flex-basis: 44%
    }
}

@media (min-width:60em) and (max-width:80em) {
    .blog-highlight h2 {
        font-size: 4.8rem
    }
}

.blog-section {
    padding-bottom: 3rem;
    width: 100%
}

@media (min-width:40em) {
    .blog-section {
        padding-bottom: 5rem
    }
}

@media (min-width:60em) {
    .blog-section {
        padding-bottom: 8rem
    }
}

.blog-section__header {
    border-bottom: 1px solid rgba(0, 0, 0, .2);
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: .2rem;
    line-height: 1.5;
    margin-bottom: 3rem;
    padding: 1rem 0;
    text-align: left;
    text-transform: uppercase;
    width: 100%
}

@media (min-width:60em) {
    .blog-section__header {
        margin-bottom: 4.2rem
    }
}

.blog-essentials {
    display: grid;
    grid-gap: 3rem;
    grid-template-columns: 1fr;
    list-style: none;
    margin: 0;
    padding: 0;
    text-align: left;
    width: 100%
}

@media (min-width:32em) {
    .blog-essentials {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media (min-width:68em) {
    .blog-essentials {
        grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr))
    }
}

@media (min-width:100em) {
    .blog-essentials {
        grid-gap: 6rem
    }
}

.blog-essentials__item {
    display: flex;
    flex-direction: column;
    flex: 0 0 auto;
    position: relative;
    padding: 0 0 1.2rem
}

.blog-essentials__item::before {
    color: #f1f1f2;
    content: counter(item, decimal-leading-zero) ". ";
    font-family: Mark Pro;
    font-size: 4.8rem;
    font-style: normal;
    font-weight: 800;
    line-height: 1;
    margin-bottom: 1rem;
    order: -1
}

@media (min-width:60em) {
    .blog-essentials__item::before {
        font-size: 6.6rem
    }
}

@media (min-width:100em) {
    .blog-essentials__item::before {
        font-size: 9.6rem
    }
}

.blog-essentials__item-link::before {
    bottom: 0;
    content: "";
    left: 0;
    position: absolute;
    right: 0;
    top: 0
}

.blog-essentials__heading {
    line-height: 1.4
}

@media (min-width:40em) {
    .blog-essentials__heading {
        font-size: 2.7rem
    }
}

.blog-essentials__category {
    font-family: Mark Pro, Eina01, sans-serif;
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0;
    order: -1;
    text-transform: uppercase
}

.blog-essentials__category,
.section .blog-essentials__category {
    color: #4880ba
}

.blog-feed {
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 6rem 5%;
    text-align: left;
    padding: 2rem 0
}

@media (min-width:32em) {
    .blog-feed {
        grid-template-columns: 1fr 1fr
    }
}

@media (min-width:60em) {
    .blog-feed {
        grid-template-columns: 1fr 1fr 1fr
    }
}

@media (min-width:32em) {
    .blog-feed__item:nth-child(2n) {
        animation-delay: 150ms
    }
}

@media (min-width:60em) {
    .blog-feed__item:nth-child(3n+2) {
        animation-delay: 150ms
    }
    .blog-feed__item:nth-child(3n+3) {
        animation-delay: .3s
    }
}

.article {
    display: flex;
    flex-direction: column
}

.article-intro .container-inner {
    max-width: 100rem
}

.article-intro a {
    color: inherit
}

.article__header {
    margin-top: 1em;
    margin-bottom: .5em;
    text-align: center
}

.article__media {
    order: -1;
    position: relative;
    left: 0;
    right: 0;
    align-self: center;
    overflow: hidden
}

.article__media {
    align-items: stretch;
    display: flex;
    justify-content: center;
    width: 100%
}

.article__media picture {
    width: 100%
}

@media (min-width:90em) {
    .article__media.article__image--wide-image {
        max-height: 60rem
    }
}

.article__image {
    object-fit: contain;
    max-height: 60rem
}

@media (max-width:40em) {
    .article__image {
        object-fit: cover;
        width: 100%
    }
}

@media (min-width:90em) {
    .article__image {
        max-height: 60rem;
        object-fit: cover;
        width: 100%
    }
}

.article__media--youtube {
    position: relative
}

.article__media--youtube::after {
    content: '';
    display: block;
    width: 100%;
    padding-bottom: 56.25%
}

.article__media--youtube iframe {
    border-radius: .6rem;
    height: 100%;
    position: absolute;
    width: 100%
}

.article-date {
    display: block;
    text-align: center;
    order: -1;
    margin: 5vw auto -5vw;
    color: #545465
}

@media (min-width:70em) {
    .article-date {
        margin: 5.6rem auto -5.6rem
    }
}

.article__content {
    margin-top: 5vw
}

@media (min-width:70em) {
    .article__content {
        margin-top: 5.6rem
    }
}

.article__text {
    max-width: 80rem;
    margin: 2rem auto 6rem;
    padding: 0
}

.article__text figure,
.article__text p {
    margin-bottom: 2rem
}

@media (min-width:50em) {
    .article__text figure,
    .article__text p {
        margin-bottom: 3.6rem
    }
}

.article__text>p:first-of-type {
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 1.8;
    margin-top: 0
}

@media (min-width:50em) {
    .article__text>p:first-of-type {
        font-size: 2.1rem
    }
}

.article__text h3,
.article__text h4,
.article__text h5,
.article__text h6 {
    margin-bottom: 2rem;
    margin-top: 3rem
}

@media (min-width:50em) {
    .article__text h3,
    .article__text h4,
    .article__text h5,
    .article__text h6 {
        margin-bottom: 3rem;
        margin-top: 4rem
    }
}

.article__text img,
.article__text video {
    border-radius: .6rem;
    box-shadow: 0 0 0 .1rem #f8f8fb
}

.article__text video {
    display: block;
    width: 100%
}

.article__text blockquote {
    text-align: center;
    margin: 4rem 0
}

@media (min-width:40em) {
    .article__text blockquote {
        margin: calc(5vw + 3rem) calc(-18vw + 11rem)
    }
}

@media (min-width:75em) {
    .article__text blockquote {
        margin: 9rem -20rem
    }
}

.article__text blockquote p {
    font-family: Mark Pro, Eina01, sans-serif;
    font-weight: 600;
    font-size: calc(5vw + .6rem);
    line-height: 1.2
}

@media (min-width:55em) {
    .article__text blockquote p {
        font-size: 5.4rem
    }
}

.article__text ul {
    padding-left: 2rem;
    margin-left: 10%;
    margin-bottom: 2rem
}

@media (min-width:50em) {
    .article__text ul {
        margin-bottom: 3.6rem
    }
}

.article__text ul li {
    padding-left: .5rem;
    margin-bottom: 1em
}

.article__teaser .container-inner {
    max-width: 80rem
}

.article-share {
    display: flex;
    flex-direction: row;
    margin-bottom: 2rem;
    justify-content: center
}

.article-share img {
    vertical-align: baseline;
    box-shadow: none
}

.article-share a {
    margin: 1rem;
    border-radius: 50%;
    width: 3rem;
    height: 3rem;
    margin: .6rem 1rem .6rem 0;
    display: flex;
    align-items: center;
    justify-content: center
}

.article-share a:focus,
.article-share a:hover {
    opacity: .85
}

@media (min-width:60em) {
    .article-share a {
        width: 4.2rem;
        height: 4.2rem
    }
}

.article-share-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 6rem
}

.article-share-bottom h5 {
    margin: 0
}

.article-share-twitter {
    background-color: #25a0ef
}

.article-share-facebook {
    background-color: #4367b0
}

.article-share-linkedin {
    background-color: #3375b0
}

@media (min-width:60em) {
    .article-share--top {
        flex-direction: column;
        margin-left: -7.2rem;
        position: absolute
    }
}

@media (min-width:60em) {
    .page-home .spacing,
    .page-home .text {
        padding-top: 16rem;
        padding-bottom: 16rem
    }
}

.home-newsletter .text:first-child {
    margin-top: 0;
    padding-top: 0;
    padding-bottom: 6rem
}

.home-teams {
    background: linear-gradient(#f6f6f6 0, #fff 100%);
    background-position: top
}

.home-teams h2 {
    padding-top: 10rem
}

.home-teams .team-logos {
    display: flex;
    justify-content: space-around;
    max-width: 60em;
    margin: 7rem auto 6rem;
    flex-wrap: wrap;
    align-items: center
}

@media (max-width:54em) {
    .home-teams .team-logos {
        flex-direction: column
    }
}

@media (max-width:54em) {
    .home-teams .team-logos img {
        margin-bottom: 6rem
    }
}

.home-formatting {
    overflow: hidden
}

.home-formatting .media {
    display: flex;
    justify-content: center;
    z-index: -1;
    margin-top: -4rem;
    overflow: hidden
}

@media (min-width:60em) {
    .home-formatting .media {
        align-self: flex-end;
        margin-top: 8rem;
        width: 50%
    }
}

.home-formatting img,
.home-formatting video {
    height: calc(30vw + 20rem);
    max-height: 58.6rem;
    object-fit: cover;
    margin-bottom: -3rem
}

@media (min-width:60em) {
    .home-formatting img,
    .home-formatting video {
        margin-bottom: 0
    }
}

.home-formatting .text>* {
    transition: transform .5s 230ms
}

.format-animation {
    overflow: hidden
}

.format-animation .text>* {
    transition: transform .15s
}

.format-animation .text :nth-child(1) {
    transform: translate(-3em, 0)
}

.format-animation .text :nth-child(2) {
    transform: translate(9em, 0)
}

.format-animation .text :nth-child(3) {
    transform: translate(-3em, 0)
}

.home-collaboration .media {
    max-width: 90rem
}

.home-collaboration .media img,
.home-collaboration .media video {
    width: 100%
}

@media (min-width:60em) {
    .home-collaboration .text {
        margin-right: auto
    }
    .home-collaboration .media {
        margin: 0 -5% 0 0;
        max-width: 72rem
    }
}

.home-templates {
    position: relative;
    overflow: hidden
}

.home-templates::before {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: linear-gradient(transparent, rgba(0, 0, 0, .1));
    height: 4vw;
    content: "";
    z-index: 1
}

.home-templates::after {
    content: '';
    display: block;
    margin-top: 2rem
}

.home-templates::after {
    height: 60vw;
    margin-top: -3rem
}

@media (min-width:40em) {
    .home-templates::after {
        height: 40vw;
        margin-top: -5rem
    }
}

@media (min-width:60em) {
    .home-templates::after {
        margin-top: 0
    }
}

.home-templates .text {
    z-index: 1;
    max-width: 52rem
}

@media (min-width:60em) {
    .home-templates .text {
        padding-bottom: 0
    }
}

.template-grid {
    display: flex;
    font-size: calc(100vw / 4.3);
    position: absolute;
    left: -.5em;
    right: -.5em;
    margin-top: -3rem
}

@media (min-width:40em) {
    .template-grid {
        font-size: calc(100vw / 6.45);
        margin-top: -5rem
    }
}

@media (min-width:60em) {
    .template-grid {
        margin-top: 0
    }
}

.template-grid__column {
    display: flex;
    flex-direction: column;
    will-change: transform
}

.template-grid__column:nth-child(1) {
    margin-top: .1em
}

.template-grid__column:nth-child(2) {
    margin-top: .55em
}

.template-grid__column:nth-child(3) {
    margin-top: .4em
}

.template-grid__column:nth-child(4) {
    margin-top: .3em
}

.template-grid__column:nth-child(5) {
    margin-top: .15em
}

.template-grid__column:nth-child(7) {
    margin-top: .1em
}

.template-grid__column:nth-child(3),
.template-grid__column:nth-child(7) {
    display: none
}

@media (min-width:40em) {
    .template-grid__column:nth-child(3),
    .template-grid__column:nth-child(7) {
        display: flex
    }
}

.template-grid__template {
    align-items: center;
    display: flex;
    position: relative;
    margin: .0375em
}

.template-grid__template::before {
    content: '';
    top: -.125em;
    left: -.125em;
    right: -.125em;
    bottom: -.125em;
    display: block;
    position: absolute;
    background-image: url(../images/shadow.png);
    background-size: 100%;
    z-index: -1
}

.template-grid__image {
    width: 1em;
    border-radius: .02em
}

.section.home-integrations .home-integrations-text {
    z-index: 1;
    display: flex;
    flex-direction: column
}

.section.home-integrations .media {
    align-self: start;
    margin-left: auto;
    padding-bottom: 10%;
    padding-left: 15%;
    position: relative
}

@media (min-width:60em) {
    .section.home-integrations .media {
        max-width: 50%;
        padding-left: 5rem;
        padding-bottom: 0
    }
}

.section.home-integrations .media::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 10%;
    background: linear-gradient(#f6f6f6, rgba(246, 246, 246, 0))
}

@media (min-width:60em) {
    .section.home-integrations .media::before {
        display: none
    }
}

@media (min-width:105em) {
    .section.home-integrations .media::before {
        background: linear-gradient(to left, #f6f6f6, rgba(246, 246, 246, 0));
        bottom: 0;
        display: block;
        height: auto;
        left: auto;
        right: 0;
        top: 0;
        width: 10%
    }
}

.section.home-integrations img,
.section.home-integrations video {
    height: 100%;
    max-height: 70rem;
    max-width: 70rem;
    width: 100%
}

@media (min-width:75em) {
    .section.home-integrations .container-inner {
        max-width: 168rem;
        position: relative;
        min-height: 70rem
    }
    .section.home-integrations .media {
        justify-content: end;
        display: flex;
        position: absolute;
        right: 0;
        top: 0
    }
    .section.home-integrations .text {
        max-width: 90rem;
        margin-left: auto;
        margin-right: auto;
        width: 100%;
        display: flex;
        align-items: start
    }
    .section.home-integrations .home-integrations-text {
        max-width: 42rem
    }
}

.home-sharing {
    overflow: hidden
}

.home-sharing .text {
    padding-bottom: 0;
    max-width: 55rem
}

@media (min-width:60em) {
    .home-sharing .text {
        padding-top: 12rem
    }
}

.sharing-visual {
    display: flex;
    font-size: 1vw;
    position: relative
}

@media (min-width:75em) {
    .sharing-visual {
        font-size: 1.2rem
    }
}

.sharing-visual__tablet {
    height: 50em;
    width: 100em;
    display: block;
    max-width: none
}

.sharing-visual__access,
.sharing-visual__hand,
.sharing-visual__invite,
.sharing-visual__plane,
.sharing-visual__shadow {
    left: 50%;
    position: absolute;
    will-change: transform
}

.sharing-visual__shadow {
    width: 10em;
    margin: 9.3em 0 0 27.2em
}

.sharing-visual__plane {
    width: 32em;
    margin: -4em 0 0 9em
}

.sharing-visual__access {
    width: 28em;
    margin: 13em 0 0 -48em
}

.sharing-visual__hand {
    width: 25em;
    margin: 21em 0 0 -38em
}

.sharing-visual__invite {
    width: 30em;
    margin: 26em 0 0 19em;
    box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
    border-radius: 12px;
}

.sharing-visual__invite svg {
    width: 100%;
    height: auto
}

@media (min-width:80em) {
    .home-links .column-card {
        padding: 6rem
    }
}

.home-testimonials .spacing {
    padding-top: 0;
    padding-bottom: 8rem
}

.home-testimonials .spacing h2 {
    margin-bottom: 6rem
}

.press-header {
    padding: 6em 0;
    display: flex
}

.press-header .press-header-image {
    flex: 1
}

.press-header .press-header-text {
    flex: 2
}

@media (max-width:60em) {
    .press-header {
        padding: 3em 0;
        flex-direction: column
    }
    .press-header .press-header-image:last-child {
        display: none
    }
    .press-header img {
        max-width: 40%
    }
}

.press-article {
    border-bottom: 1px solid #dddfe5;
    padding: 2em 0 1em 0
}

.press-article:last-child {
    border: none
}

.press-article h3 {
    margin: 0
}

.press-image {
    max-height: 1em
}

/* .button-white-outline {
    background: none;
    border: 1px solid hsla(0, 0%, 100%, .15);
    color: #2b2a35
}

.button-white-outline:hover:not(:disabled) {
    opacity: .8
}

.button-white-outline.is-loading:after {
    content: "";
    position: absolute;
    top: calc(50% - 1rem);
    left: calc(50% - 1rem);
    width: 2rem;
    height: 2rem;
    border: 2px solid transparent;
    border-top-color: #fff;
    border-radius: 50%;
    -webkit-animation: spin 1s ease infinite;
    animation: spin 1s ease infinite
} */

.form-group label {
    display: block;
    margin-bottom: 10px
}

.form-input {
    display: block;
    width: 100%;
    padding: 11px 16px;
    font-family: inherit;
    font-size: 14px;
    color: #fff;
    background-color: transparent;
    border: 1px solid hsla(0, 0%, 100%, .15);
    border-radius: 4px
}

.form-input:hover {
    border-color: hsla(0, 0%, 100%, .3)
}

.form-input:focus {
    border-color: hsla(0, 0%, 100%, .5)
}

.form-input:disabled {
    border-color: transparent;
    opacity: .5
}

.overlay {
    background-color: rgba(17, 17, 17, .9)!important
}

.overlay .app-modal {
    color: #fff!important;
    background: #272727!important;
    border-radius: 4px!important;
    box-shadow: none!important
}

.app-popup .app-popup-content {
    min-width: 130px;
    margin-right: 0!important
}

.info-page~footer {
    padding-top: 30px
}

@media (min-width:1170px) {
    .info-page~footer {
        padding-top: 50px
    }
}

.info-page {
    padding-top: 70px;
    padding-bottom: 70px;
    color: #1d1d1d;
    background-color: #fff
}

.info-page .container {
    width: 100%;
    max-width: 772px;
    margin: auto
}

@media (max-width:772px) {
    .info-page .container {
        padding: 20px
    }
}

.info-page .lead {
    font-weight: 400;
    font-size: 18px;
    line-height: 30px;
    letter-spacing: .01em
}

.info-page hr {
    display: block;
    margin-top: 2rem;
    margin-bottom: 2rem;
    border: 1px solid rgba(29, 29, 29, .1)
}

.info-page a {
    text-decoration: none;
    color: #1d1d1d;
    border-bottom: 1px solid #1d1d1d
}

.info-page h1 {
    margin-top: 0;
    margin-bottom: 20px;
    font-size: 42px;
    line-height: 50px
}

.info-page h2 {
    padding-top: 10px;
    margin-bottom: 10px;
    font-size: 17px
}

.info-page h2,
.info-page h5 {
    font-weight: 800;
    line-height: 22px;
    letter-spacing: .01em
}

.info-page h5 {
    margin-top: 0;
    margin-bottom: 15px;
    font-size: 14px
}

.info-page p {
    margin-top: 0;
    margin-bottom: 20px
}

.info-page ul {
    margin: 0 0 15px;
    padding-left: 0;
    list-style: none
}

.info-page ul li:not(:last-child) {
    margin-bottom: 15px
}

.info-page ul li:before {
    content: "·";
    margin-right: 10px;
    color: rgba(29, 29, 29, .5)
}

.info-page img {
    max-width: 100%;
    height: auto
}

.info-page .media-block {
    margin: 50px 0
}

.info-page .media-block.has-fullwidth img {
    width: 100%;
    max-width: 1300px
}

.info-page .media-block img {
    display: block;
    max-width: 100%;
    margin: auto
}

.info-page .media-block .media-caption {
    padding-top: 15px;
    font-size: 14px;
    line-height: 22px;
    letter-spacing: .01em;
    color: rgba(29, 29, 29, .5)
}

.video-responsive {
    position: relative;
    height: 0;
    padding-top: 56.25%
}

.video-responsive iframe {
    border: 0
}

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

.radio {
    position: relative;
    cursor: pointer
}

.radio:before {
    top: 0;
    width: 18px;
    height: 18px;
    border: 1px solid hsla(0, 0%, 100%, .5);
    background-color: transparent;
    border-radius: 50%
}

.radio:after,
.radio:before {
    content: "";
    position: absolute;
    left: 0
}

.radio:after {
    top: -1px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: #5162ff;
    transform: translate(6px, 7px) scale(0)
}

.radio:hover:before {
    border: 1px solid #fff
}

.radio.active {
    pointer-events: none
}

.radio.active:before {
    border-color: #5162ff;
    background-color: transparent
}

.radio.active:after {
    transform: translate(6px, 7px) scale(1)
}

.slide-in-out-enter-active {
    transition: all .3s ease
}

.slide-in-out-leave-active {
    transition: all .4s ease
}

.slide-in-out-enter,
.slide-in-out-leave-to {
    transform: translateY(500px)
}

.fade-enter-active,
.fade-leave-active {
    transition: opacity .4s ease
}

.fade-enter,
.fade-leave-to {
    opacity: 0
}

.api-section[data-v-68502174] {
    margin-bottom: 130px;
}

.api-section p[data-v-68502174] {
    margin-top: 0;
    margin-bottom: 50px;
    font-size: 18px;
    line-height: 30px;
    text-align: center;
    letter-spacing: .01em
}

.api-section .api-items[data-v-68502174] {
    display: flex;
    flex-wrap: wrap;
    margin-left: -20px;
    margin-right: -20px
}

.api-section .api-items .api-item[data-v-68502174] {
    width: 100%;
    padding: 20px
}

@media (min-width:650px) {
    .api-section .api-items .api-item[data-v-68502174] {
        width: 50%
    }
}

.card[data-v-68502174] {
    display: flex;
    justify-content: flex-end;
    flex-direction: column;
    padding: 30px;
    min-height: 460px;
    text-decoration: none;
    color: #2b2a35;
    background-color: #272727;
    border: 0;
    border-radius: 4px;
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover
}

@media (min-width:650px) {
    .card[data-v-68502174] {
        padding: 40px
    }
}

.card.has-api[data-v-68502174] {
    background-color: #fff;
    background-image: url(../images/collaboration.png);
    background-size: contain;
}

.card.has-partner[data-v-68502174] {
    background-color: #fff;
    background-image: url(../images/partnership.jpg);
    background-size: contain;
}

.card .card-title[data-v-68502174] {
    margin-bottom: 20px;
    font-weight: 600;
    font-size: 32px;
    line-height: 50px;
    letter-spacing: -.014em
}

.card .card-link .button[data-v-68502174] {
    display: inline-block;
    /* border: 1px solid hsla(0, 0%, 0%, .15) */
}

@-webkit-keyframes spin-data-v-672a19a0 {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(1turn)
    }
}

@keyframes spin-data-v-672a19a0 {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(1turn)
    }
}

.slider[data-v-672a19a0] {
    position: relative;
    width: 100%;
    overflow: hidden
}

@media (min-width:480px) {
    .slider[data-v-672a19a0]:after {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        width: 200px;
        background: linear-gradient(90deg, rgba(29, 29, 29, 0), rgba(29, 29, 29, .1) 10%, rgba(29, 29, 29, .2) 15%, rgba(29, 29, 29, .3) 20%, rgba(29, 29, 29, .5) 30%, rgba(29, 29, 29, .7) 40%, rgba(29, 29, 29, .8) 50%, rgba(29, 29, 29, .9) 60%, #1d1d1d 75%);
        pointer-events: none
    }
}

.slider .slider-track[data-v-672a19a0] {
    display: flex;
    margin-left: -10px;
    margin-right: -10px;
    transition: transform .55s cubic-bezier(.075, .82, .165, 1)
}

.slider .slider-item[data-v-672a19a0] {
    flex-shrink: 0;
    padding: 10px;
    width: 200px
}

.slider .slider-card[data-v-672a19a0] {
    display: block;
    padding: 20px 20px 0;
    text-decoration: none;
    font-size: 30px;
    font-weight: 900;
    text-align: center;
    color: #fff;
    background-color: #b8b9ee;
    border-radius: 4px
}

.slider .slider-card-title[data-v-672a19a0] {
    font-weight: 800;
    font-size: 13px;
    line-height: 18px;
    text-align: center;
    letter-spacing: .01em
}

.slider .slider-card-image[data-v-672a19a0] {
    position: relative;
    height: 150px
}

.slider .slider-card-image img[data-v-672a19a0] {
    position: absolute;
    bottom: 0;
    display: block;
    max-width: 100%;
    height: auto
}

@-webkit-keyframes spin-data-v-3eb9edf5 {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(1turn)
    }
}

@keyframes spin-data-v-3eb9edf5 {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(1turn)
    }
}

footer[data-v-3eb9edf5] {
    width: 100%;
    padding: 0 15px;
    font-size: 14px
}

footer ul[data-v-3eb9edf5] {
    margin-top: 0;
    margin-bottom: 0;
    padding-left: 0;
    list-style: none
}

footer h3[data-v-3eb9edf5] {
    margin-top: 0;
    margin-bottom: 15px;
    font-size: 14px;
    font-weight: 800;
    line-height: 22px;
    letter-spacing: .01em
}

footer a[data-v-3eb9edf5] {
    color: #fff;
    text-decoration: none;
    cursor: pointer
}

footer.is-narrow .footer-wrap[data-v-3eb9edf5] {
    max-width: 1160px
}

.footer-wrap[data-v-3eb9edf5] {
    max-width: 1370px;
    margin: auto
}

.footer-grid[data-v-3eb9edf5] {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    margin-left: -15px;
    margin-right: -15px;
    padding-bottom: 100px
}

@media (min-width:768px) {
    .footer-grid[data-v-3eb9edf5] {
        padding-bottom: 72px
    }
}

.footer-column[data-v-3eb9edf5] {
    width: 100%;
    padding: 15px
}

@media (min-width:480px) {
    .footer-column[data-v-3eb9edf5] {
        width: 50%
    }
}

@media (min-width:1170px) {
    .footer-column[data-v-3eb9edf5]:first-child {
        width: 25%
    }
    .footer-column[data-v-3eb9edf5]:nth-child(2) {
        width: 20%
    }
    .footer-column[data-v-3eb9edf5]:nth-child(3) {
        width: 35%
    }
    .footer-column[data-v-3eb9edf5]:nth-child(4) {
        width: 20%
    }
}

.about .about-logo[data-v-3eb9edf5] {
    margin-bottom: 20px
}

.about .about-logo[data-v-3eb9edf5] svg {
    width: 24px;
    height: 24px
}

.about .about-copy[data-v-3eb9edf5] {
    margin-bottom: 15px;
    font-size: 14px;
    letter-spacing: .01em
}

.about .about-text[data-v-3eb9edf5] {
    max-width: 258px;
    font-size: 14px;
    line-height: 22px;
    letter-spacing: .01em;
    color: grey
}

.links .links-list li[data-v-3eb9edf5] {
    line-height: 36px
}

.subscribe[data-v-3eb9edf5] {
    max-width: 397px
}

.subscribe p[data-v-3eb9edf5] {
    margin-bottom: 30px
}

.subscribe-ok-icon[data-v-3eb9edf5] {
    display: inline-block;
    vertical-align: middle;
    width: 20px;
    height: 20px;
    margin-right: 12px
}

.subscribe-ok-icon[data-v-3eb9edf5] svg {
    display: block
}

.footer-bottom[data-v-3eb9edf5] {
    position: relative;
    flex-wrap: wrap;
    height: 77px;
    border-top: 1px solid #4d4d4d
}

.footer-bottom[data-v-3eb9edf5],
.terms-list[data-v-3eb9edf5] {
    display: flex;
    align-items: center
}

.terms-list[data-v-3eb9edf5] {
    padding-right: 10px;
    list-style: none;
    font-size: 14px
}

@media (min-width:768px) {
    .terms-list[data-v-3eb9edf5] {
        width: 25%
    }
}

.terms-list li[data-v-3eb9edf5]:not(:last-child) {
    margin-right: 20px
}

.trained-link[data-v-3eb9edf5] {
    font-size: 14px;
    line-height: 23px;
    letter-spacing: .01em;
    text-decoration: none;
    color: hsla(0, 0%, 100%, .5)
}

@media (min-width:480px) {
    .trained-link[data-v-3eb9edf5] {
        margin-left: auto
    }
}

.trained-link a[data-v-3eb9edf5] {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid hsla(0, 0%, 100%, .15)
}

.trained-link a[data-v-3eb9edf5]:hover {
    border-color: hsla(0, 0%, 100%, .5)
}

.social-list[data-v-3eb9edf5] {
    position: absolute;
    left: 0;
    top: -70px;
    display: flex;
    align-items: center
}

@media (min-width:768px) {
    .social-list[data-v-3eb9edf5] {
        position: static;
        margin-left: auto
    }
}

.social-list li[data-v-3eb9edf5]:not(:last-child) {
    margin-right: 30px
}

.social-list a[data-v-3eb9edf5] {
    display: block;
    width: 16px;
    height: 16px;
    cursor: pointer
}

.social-list a[data-v-3eb9edf5] svg {
    display: block;
    fill: #fff
}

@-webkit-keyframes spin-data-v-1ef68966 {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(1turn)
    }
}

@keyframes spin-data-v-1ef68966 {
    0% {
        transform: rotate(0)
    }
    to {
        transform: rotate(1turn)
    }
}

.subscribe-form.has-error input[data-v-1ef68966] {
    border-color: rgba(255, 89, 89, .3)
}

.subscribe-form button.is-sending[data-v-1ef68966] {
    color: transparent;
    pointer-events: none
}

.subscribe-form button.is-sending[data-v-1ef68966]:after {
    content: "";
    position: absolute;
    top: calc(50% - 12px);
    left: calc(50% - 12px);
    width: 24px;
    height: 24px;
    border: 2px solid transparent;
    border-top-color: #fff;
    border-radius: 50%;
    -webkit-animation: spin-data-v-1ef68966 1s ease infinite;
    animation: spin-data-v-1ef68966 1s ease infinite
}

.subscribe-form-group[data-v-1ef68966] {
    display: flex;
    align-items: stretch;
    margin-bottom: 10px
}

.subscribe-form-group input[data-v-1ef68966] {
    min-width: 50px;
    margin-right: 8px
}

.subscribe-form-group button[data-v-1ef68966] {
    padding: 13px 24px
}

.subscribe-error-text[data-v-1ef68966] {
    font-size: 14px;
    font-weight: 400;
    line-height: 22px;
    letter-spacing: .01em;
    color: #ff5959
}

.subscribe-error-text[data-v-1ef68966]:first-letter {
    text-transform: uppercase
}

.notify[data-v-68502174] {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    max-width: 1100px;
    margin: 100px auto 100px;
    min-height: 400px;
    color: #1d1d1d;
}

@media (min-width:992px) {
    .notify[data-v-68502174] {
        flex-wrap: nowrap
    }
}

@media (min-width:1160px) {
    .notify[data-v-68502174] {
        border-radius: 4px
    }
}

.notify a[data-v-68502174] {
    display: inline-block;
    text-decoration: none
}

.notify .notify-content[data-v-68502174] {
    order: 2;
    padding: 30px
}

@media (min-width:992px) {
    .notify .notify-content[data-v-68502174] {
        order: 1;
        padding: 80px 60px
    }
}

.notify img[data-v-68502174] {
    order: 1;
    margin-left: auto;
    /*align-self: flex-end;
    flex-shrink: 1;*/
    display: block;
    max-width: 500px;
    width: 100%;
    max-height: 400px;
    height: auto
}

@media (min-width:992px) {
    .notify img[data-v-68502174] {
        order: 2
    }
}

.notify .notify-title[data-v-68502174] {
    margin-bottom: 20px;
    font-weight: 900;
    font-size: 32px;
    line-height: 40px;
    letter-spacing: -.01em
}

@media (min-width:480px) {
    .notify .notify-title[data-v-68502174] {
        font-size: 42px;
        line-height: 50px
    }
}

.notify p[data-v-68502174] {
    margin-top: 0;
    margin-bottom: 35px;
    line-height: 30px;
    letter-spacing: .01em;
    font-size: 16px;
    color: #1d1d1d
}

.notify .notify-form[data-v-68502174] {
    max-width: 400px
}

@media (max-width:480px) {
    .notify .notify-form[data-v-68502174] .subscribe-form-group {
        flex-wrap: wrap
    }
    .notify .notify-form[data-v-68502174] .subscribe-form-group .form-input {
        width: 100%;
        margin-bottom: 15px;
        margin-right: 0
    }
    .notify .notify-form[data-v-68502174] .subscribe-form-group .button {
        width: 100%
    }
}

.notify .notify-form[data-v-68502174] .form-input {
    color: #1d1d1d;
    border: 1px solid rgba(29, 29, 29, .15)
}

.notify .notify-form[data-v-68502174] .form-input::-webkit-input-placeholder {
    color: rgba(29, 29, 29, .5)
}

.notify .notify-form[data-v-68502174] .form-input::-moz-placeholder {
    color: rgba(29, 29, 29, .5)
}

.notify .notify-form[data-v-68502174] .form-input:-ms-input-placeholder {
    color: rgba(29, 29, 29, .5)
}

.notify .notify-form[data-v-68502174] .form-input::-ms-input-placeholder {
    color: rgba(29, 29, 29, .5)
}

.notify .notify-form[data-v-68502174] .form-input::placeholder {
    color: rgba(29, 29, 29, .5)
}

.notify .notify-info[data-v-68502174] {
    font-size: 14px;
    line-height: 25px;
    letter-spacing: .01em;
    color: rgba(29, 29, 29, .5)
}


.container-lg {
  max-width: 1012px
}

.container-lg {
  margin-right: auto;
  margin-left: auto
}

@media (min-width:768px) {
  .col-md-3 {
    width: 25%
  }
  .col-md-9 {
    width: 75%
  }
}

@media (min-width:1012px) {
  .col-lg-2 {
    width: 16.66667%
  }
  .col-lg-10 {
    width: 83.33333%
  }
}

@media (min-width:768px) {
  .gutter-md-spacious {
    margin-right: -24px;
    margin-left: -24px
  }
  .gutter-md-spacious>[class*=col-] {
    padding-right: 24px!important;
    padding-left: 24px!important
  }
}

@media (min-width:768px) {
  .border-md-left {
    border-left: 1px solid var(--color-border-primary)!important
  }
}

.text-gray {
  color: var(--color-text-secondary)!important
}

.mb-2 {
  margin-bottom: 8px!important
}

.my-2 {
  margin-top: 8px!important;
  margin-bottom: 8px!important
}

.mt-6 {
  margin-top: 40px!important
}

@media (min-width:768px) {
  .mb-md-4 {
    margin-bottom: 24px!important
  }
  .ml-md-4 {
    margin-left: 24px!important
  }
}

.p-responsive {
  padding-right: 16px!important;
  padding-left: 16px!important
}

@media (min-width:544px) {
  .p-responsive {
    padding-right: 40px!important;
    padding-left: 40px!important
  }
}

@media (min-width:1012px) {
  .p-responsive {
    padding-right: 16px!important;
    padding-left: 16px!important
  }
}

@media (min-width:768px) {
  .d-md-flex {
    display: flex!important
  }
}

.h00-mktg {
  font-size: 40px!important
}

@media (min-width:768px) {
  .h00-mktg {
    font-size: 48px!important
  }
}

.h1-mktg {
  font-size: 26px!important
}

@media (min-width:768px) {
  .h1-mktg {
    font-size: 32px!important
  }
}

.h4-mktg {
  font-size: 16px!important
}

.lead-mktg {
  font-size: 20px;
  font-weight: 400
}

.mb-2,
.my-2 {
  margin-bottom: 8px!important
}

.my-2 {
  margin-top: 8px!important
}

.mt-6 {
  margin-top: 40px!important
}

@media (min-width:768px) {
  .mb-md-4 {
    margin-bottom: 24px!important
  }
}

.py-7 {
  padding-top: 48px!important;
  padding-bottom: 48px!important
}

@media (min-width:768px) {
  .py-md-8 {
    padding-top: 64px!important;
    padding-bottom: 64px!important
  }
}

@media (min-width:1012px) {
  .py-lg-9 {
    padding-top: 80px!important;
    padding-bottom: 80px!important
  }
}