/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
progress, sub, sup {
    vertical-align: baseline
}

button, hr, input {
    overflow: visible
}

.slick-loading .slick-slide, .slick-loading .slick-track, .video-player__thumb--hidden {
    visibility: hidden
}

.accordion, .form .mktoButton {
    text-shadow: none;
    box-shadow: none
}

html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, summary {
    display: block
}

audio, canvas, progress, video {
    display: inline-block
}

    audio:not([controls]) {
        display: none;
        height: 0
    }

[hidden], template {
    display: none
}

a {
    background-color: transparent;
    -webkit-text-decoration-skip: objects
}

    a:active, a:hover {
        outline-width: 0
    }

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted
}

b, strong {
    font-weight: bold
}

dfn {
    font-style: italic
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

mark {
    background-color: #ff0;
    color: #000
}

small {
    font-size: 80%
}

sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

svg:not(:root) {
    overflow: hidden
}

code, kbd, pre, samp {
    font-family: monospace,monospace;
    font-size: 1em
}

figure {
    margin: 1em 40px
}

hr {
    box-sizing: content-box;
    height: 0
}

button, input, select, textarea {
    font: inherit;
    margin: 0
}

optgroup {
    font-weight: 700
}

button, select {
    text-transform: none
}

[type=reset], [type=submit], button, html [type=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: ButtonText dotted 1px
    }

fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

.slick-list, .slick-slider, .slick-track {
    display: block;
    position: relative
}

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-cancel-button, [type=search]::-webkit-search-decoration {
        -webkit-appearance: none
    }

::-webkit-input-placeholder {
    color: inherit;
    opacity: .54
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

.big-button, .card__sign-off, .form .mktoButton, .form .mktoField:not([type=checkbox]), .form [type=checkbox].mktoField + label, .wysiwyg a:not(.button), .wysiwyg p, .wysiwyg ul li {
    margin: 0;
    font-family: urw-din, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
    font-weight: 300;
    line-height: 1.3
}

.accordion__question, .card__title, .contact-form__title, .form .mktoLabel, .lightbox__close, .scroller__content, .scroller__title, .wysiwyg h1, .wysiwyg h2, .wysiwyg h3, .wysiwyg h4, .wysiwyg h5, .wysiwyg h6 {
    margin: 0;
    font-family: urw-din, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
    line-height: 1.2;
    font-weight: 400
}

.card-list, .content-slider .slick-dots {
    margin: 0;
    padding: 0;
    list-style: none
}

.slick-slider {
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent
}

.slick-list {
    overflow: hidden;
    margin: 0;
    padding: 0
}

    /*.slick-list:focus {
        outline: 0
    }*/

    .slick-list.dragging {
        cursor: pointer;
        cursor: hand
    }

.slick-slider .slick-list, .slick-slider .slick-track {
    -webkit-transform: translate3d(0,0,0);
    -moz-transform: translate3d(0,0,0);
    -ms-transform: translate3d(0,0,0);
    -o-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

.slick-track {
    left: 0;
    top: 0;
    margin-left: auto;
    margin-right: auto
}

    .slick-track:after, .slick-track:before {
        content: "";
        display: table
    }

    .slick-track:after {
        clear: both
    }

.slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
    display: none
}

[dir=rtl] .slick-slide {
    float: right
}

.slick-slide img {
    display: block
}

.slick-slide.slick-loading img {
    display: none
}

.slick-slide.dragging img {
    pointer-events: none
}

.slick-initialized .slick-slide {
    display: block
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent
}

.slick-arrow.slick-hidden {
    display: none
}

body {
    -webkit-font-smoothing: antialiased
}

.site-header {
    background: #fff;
    position: relative;
    z-index: 10
}

body header {
    height: auto;
    padding: 0
}

body footer {
    position: relative;
    z-index: 2;
    background: #2d3c48
}

.h2, h2 {
    width: auto
}

.wysiwyg .center-text {
    text-align: center
}

.wysiwyg h1, .wysiwyg h2, .wysiwyg h3, .wysiwyg h4, .wysiwyg h5, .wysiwyg h6 {
    font-weight: 700;
    margin-bottom: 20px
}

.wysiwyg h1 {
    font-size: 26px
}

.wysiwyg h2 {
    font-size: 18px
}

.wysiwyg h3, .wysiwyg p, .wysiwyg ul li {
    font-size: 14px
}

.wysiwyg p {
    color: #666;
    font-weight: 400;
    margin-bottom: 20px;
    line-height: 20px;
    letter-spacing: .14px
}

    .wysiwyg p:last-of-type {
        margin-bottom: 0
    }

.wysiwyg ul {
    list-style: none;
    margin: 0;
    padding: 0
}

    .wysiwyg ul li {
        padding-left: 20px;
        margin: 5px 0;
        position: relative;
        letter-spacing: .14px
    }

.card__title, .contact-form__title {
    letter-spacing: .1px;
    text-transform: uppercase
}

.wysiwyg ul li:before {
    width: 4px;
    height: 4px;
    position: absolute;
    top: 7px;
    left: 0;
    background-color: #248fcf;
    content: "";
    display: block;
    border-radius: 50%
}

.wysiwyg ul:last-child {
    padding-bottom: 0
}

.wysiwyg a:not(.button) {
    color: inherit;
    text-decoration: none
}

    .wysiwyg a:not(.button):hover {
        opacity: .8
    }

.accordion {
    padding-right: 15px !important;
    width: 100%;
    /*outline: 0;*/
    border: none;
    position: relative;
    overflow: hidden;
    text-align: left;
    cursor: pointer;
    border-radius: 0;
    transition: background .3s ease,transform .3s ease
}

.accordion--brand-three {
    color: #00aec7
}

.accordion--brand-four {
    color: #658b0c
}

.accordion--brand-five {
    color: #994878
}

.accordion:not(.accordion--open):hover {
    background: rgba(255,255,255,.95);
    transform: translateY(-2px)
}

    .accordion:not(.accordion--open):hover .accordion__icon {
        transform: scale(.9) rotate(-45deg)
    }

.accordion:hover {
    background: #fff
}

    .accordion:hover .accordion__icon {
        transform: scale(.9)
    }

.accordion__icon {
    width: 24px;
    height: 24px;
    position: absolute;
    right: 0;
    top: 4px;
    border: 1px solid #248fcf;
    border-radius: 50%;
    transform: rotate(-45deg);
    transition: transform .3s ease
}

    .accordion__icon:after, .accordion__icon:before {
        content: "";
        height: 16px;
        width: 2px;
        background: #248fcf;
        position: absolute;
        top: 50%;
        left: 50%
    }

    .accordion__icon:before {
        transform: translate(-50%,-50%) rotate(45deg)
    }

    .accordion__icon:after {
        transform: translate(-50%,-50%) rotate(-45deg)
    }

.accordion--open .accordion__icon {
    transform: rotate(0)
}

.accordion__question {
    font-family: urw-din, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
    font-size: 30px;
    text-transform: uppercase;
    font-weight: 400;
    position: relative;
    padding-right: 30px
}

    .accordion__question span:not(.accordion__icon) {
        color: #248fcf;
        transition: color .3s ease
    }

    .accordion__question strong {
        color: currentColor;
        font-weight: 400
    }

    .accordion__question sup {
        font-size: 15px;
        top: -11px
    }

.accordion__answer {
    display: none
}

    .accordion__answer:before {
        content: "";
        width: 110px;
        background: currentColor;
        height: 2px;
        margin-top: 18px;
        margin-bottom: 18px;
        display: block
    }

    .accordion__answer li, .accordion__answer p {
        color: #666
    }

@media screen and (max-width:639px) {
    .accordion__question {
        font-size: 24px;
        line-height: 24px
    }
}

.back-to-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 36px;
    height: 36px;
    z-index: 10;
    background: url(../svg/pointer-3.svg) no-repeat;
    background-size: 100% 100%;
    border-radius: 50%;
    overflow: hidden;
    transform: rotate(180deg) translateX(-100%);
    opacity: 0;
    transition: opacity .3s ease,transform .3s ease,background-color .3s ease
}

    .back-to-top:active, .back-to-top:hover {
        transform: rotate(180deg) scale(1.2) translateX(0);
        background: url(../svg/pointer-3.svg) no-repeat;
        background-color: rgba(0,0,0,.5);
        background-size: 100% 100%
    }

.back-to-top--active {
    opacity: 1;
    transform: rotate(180deg) translateX(0)
}

.card--link:hover .card__media img, .media-image__wrapper:hover .media-image__thumb {
    opacity: .8
}

@media screen and (max-width:767px) {
    .back-to-top {
        width: 26px;
        height: 26px;
        background-color: rgba(0,0,0,.2)
    }
}

.card__media > *, .card__media > * * {
    height: 100%;
    width: 100%
}

.big-button, .form .mktoButton {
    font-weight: 700;
    /*outline: 0;*/
    border: none;
    background: #00aec7;
    text-decoration: none;
    display: inline-block;
    text-align: center;
    cursor: pointer;
    color: #fff;
    font-size: 14px;
    text-transform: uppercase;
    box-sizing: border-box;
    border-radius: 0;
    padding: 10px 20px;
    min-width: 210px;
    transition: background .3s ease
}

.accordion, .card, .lightbox__body {
    padding: 20px;
    box-sizing: border-box
}

.big-button:hover, .form .mktoButton:hover {
    background: #008194;
    color: #fff
}

.big-button:disabled, .form .mktoButton:disabled {
    background: #00dbfa
}

.accordion, .card {
    display: block;
    background: #fff;
    text-decoration: none
}

.card--pad-bottom {
    padding-bottom: 45px
}

.card--link {
    transition: transform .3s ease
}

    .card--link:active {
        background: #fff
    }

    .card--link:hover {
        transform: translateY(-5px)
    }

.card__media {
    width: calc(100% + 40px);
    overflow: hidden;
    background: #000;
    position: relative;
    margin: -20px -20px 20px
}

.card__title:after, .contact-form__title:after {
    background: #ec731f;
    content: ""
}

.card__media:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 56.25%
}

.card__media > * {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0
}

.card__media img {
    width: 101%;
    height: 101%;
    object-fit: cover;
    transition: opacity .3s ease
}

.card__title {
    font-family: urw-din, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
    color: #248fcf;
    font-size: 29px;
    font-weight: 400;
    padding-bottom: 18px;
    line-height: 29px
}

.card__content--narrow p, .card__sign-off {
    line-height: 20px;
    font-family: urw-din, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
}

.card__title:after {
    width: 110px;
    height: 2px;
    display: block;
    margin-top: 18px
}

.card__title--inline {
    display: flex;
    align-items: flex-end
}

    .card__title--inline:after {
        flex: 1;
        margin-left: 10px;
        margin-bottom: 10px;
        display: inline-block;
        vertical-align: bottom;
        margin-top: 0
    }

.card__title--dark {
    color: #000
}

.card__title--small {
    font-size: 20px;
    padding-bottom: 9px
}

.card__content p strong {
    color: #248fcf;
    display: block
}

.card__sign-off {
    margin-top: 10px;
    letter-spacing: .06;
    font-size: 16px;
    color: #000;
    font-weight: 400
}

    .card__sign-off strong, .contact-form__title {
        color: #248fcf;
        font-weight: 400
    }

@media screen and (max-width:959px) {
    .card__content p br {
        display: none
    }
}

.media-image {
    position: relative;
    width: 100%;
    min-height: 1px
}

.media-image__expander {
    width: 17px;
    position: absolute;
    top: 11px;
    left: 11px;
    background: 0 0;
    padding: 0;
    border: none;
    cursor: pointer
}

    .media-image__expander img {
        display: block
    }

.media-image__wrapper {
    width: 100%;
    background: #fff;
    padding: 0;
    cursor: pointer;
    transition: width .3s ease
}

.media-image--expanded .media-image__wrapper {
    position: absolute;
    top: 0;
    right: 0
}

    .media-image--expanded .media-image__wrapper:hover .media-image__thumb {
        opacity: 1
    }

.media-image__thumb {
    width: 100%;
    transition: width .3s ease,opacity .3s ease
}

@media screen and (max-width:639px) {
    .media-image__wrapper {
        pointer-events: none
    }

    .media-image__expander {
        display: none
    }
}

.video-player {
    position: relative
}

.video-player__inner {
    position: relative;
    max-height: 100vh;
    z-index: 2;
    overflow: hidden
}

    .video-player__inner:before {
        display: block;
        content: "";
        width: 100%;
        padding-top: 56.25%
    }

    .video-player__inner > * {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100%;
        height: 100%
    }

        .video-player__inner > * * {
            width: 100%;
            height: 100%
        }

.video-player__thumb {
    position: absolute;
    z-index: 1;
    max-height: 100%;
    background: #000;
    cursor: pointer;
    transition: opacity 1s ease,visibility 1s ease
}

.video-player__thumb--hidden {
    opacity: 0;
    pointer-events: none
}

.video-player__thumb:not(.video-player__thumb__hidden):hover .video-player__button {
    visibility: visible;
    opacity: 1;
    transform: scale(1.2);
    background: url(../svg/play-button.svg) no-repeat
}

.video-player__thumb:not(.video-player__thumb__hidden):hover .video-poster {
    opacity: .5
}

.video-player__button {
    border-radius: 0;
    box-shadow: none;
    cursor: pointer;
    padding: 0;
    border: none;
    width: 68px;
    height: 68px;
    background: url(../svg/play-button.svg) no-repeat;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-left: -33px;
    margin-top: -33px;
    opacity: 0;
    visibility: hidden;
    transform: scale(.8);
    z-index: 2;
    transition: transform .3s ease,opacity .3s ease,visibility .3s ease
}

.sense-container, .video-player__pointer {
    margin-left: auto;
    margin-right: auto
}

.video-player__embed {
    max-height: 100%;
    object-fit: cover
}

.video-player__pointer {
    position: absolute;
    bottom: 20px;
    right: 0;
    left: 0;
    width: 36px;
    height: 36px;
    z-index: 10;
    background: url(../svg/pointer-3.svg) no-repeat;
    background-size: 100% 100%;
    animation-duration: 2s;
    animation-iteration-count: infinite;
    animation-name: bounce;
    animation-timing-function: cubic-bezier(.28,.84,.42,1)
}

@keyframes bounce {
    0%,10%,100%,50%,64% {
        transform: translateY(0)
    }

    30% {
        transform: translateY(-100%)
    }

    57% {
        transform: translateY(-5%)
    }
}

@media screen and (max-width:959px) {
    .video-player__inner {
        height: 100vh
    }
}

@media screen and (max-width:767px) {
    .video-player__pointer {
        width: 26px;
        height: 26px
    }

    .video-player__embed {
        object-fit: initial
    }
}

.video-poster {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    transition: opacity 1s ease
}

.video-poster__bg {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    z-index: -1
}

.video-poster__stamp {
    position: absolute;
    top: 60px;
    left: 60px;
    width: 10%;
    max-width: 200px;
    height: 15%;
    max-height: 132px;
    object-fit: contain
}

.video-poster__text {
    position: absolute;
    top: 50%;
    right: 50%;
    transform: translate(50%,-50%);
    width: 28%;
    max-width: 520px;
    height: 72%;
    max-height: 640px;
    object-fit: contain
}

@media screen and (max-width:959px) {
    .video-poster__bg {
        object-position: 90% 0
    }

    .video-poster__stamp {
        height: 15%;
        width: 15%;
        left: 40px;
        top: 40px;
        object-position: top left
    }

    .video-poster__text {
        right: auto;
        left: 40px;
        top: calc(15% + 100px);
        transform: translate(0,0);
        object-position: top left;
        width: 50%;
        height: 50%
    }
}

@media screen and (max-width:767px) {
    .video-poster__bg {
        object-position: center bottom
    }

    .video-poster__stamp, .video-poster__text {
        left: 50%;
        transform: translateX(-50%);
        object-position: center center
    }

    .video-poster__stamp {
        width: 25%;
        height: 10%
    }

    .video-poster__text {
        width: 80%
    }
}

.contact-form {
    display: none;
    box-sizing: border-box
}

.contact-form__title {
    font-family: urw-din, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
    font-size: 30px;
    padding-bottom: 30px;
    line-height: 30px
}

    .contact-form__title:after {
        width: 110px;
        height: 2px;
        display: block;
        margin-top: 18px
    }

@media screen and (max-width:639px) {
    .card__title {
        font-size: 24px;
        line-height: 24px
    }
}

.content-slider {
    display: none
}

    .content-slider.slick-initialized {
        display: block;
        margin-right: -30px
    }

    .content-slider .slick-dots {
        margin-top: 30px;
        display: flex;
        align-items: center;
        justify-content: center;
        position: static
    }

        .content-slider .slick-dots li {
            margin: 0 27px 0 0;
            width: auto;
            height: auto;
            border-radius: 50%;
            overflow: hidden
        }

            .content-slider .slick-dots li:last-child {
                margin-right: 0
            }

            .content-slider .slick-dots li.slick-active button:before {
                background: #fff
            }

        .content-slider .slick-dots button {
            display: block;
            background: 0 0;
            padding: 0;
            position: relative;
            border-radius: 50%;
            width: 15px;
            height: 15px;
            border: none;
            font-size: 0;
            /*outline: 0;*/
            overflow: hidden;
            cursor: pointer
        }

            .content-slider .slick-dots button:before {
                content: "";
                width: 100%;
                height: 100%;
                border-radius: 50%;
                position: absolute;
                top: 0;
                left: 0;
                background: #248fcf;
                opacity: 1 !important;
                transition: background .3s ease
            }

    .content-slider .slick-arrow {
        font-size: 0;
        border: none;
        padding: 0;
        width: 30px;
        height: 30px;
        background: #248fcf;
        border-radius: 50%;
        box-shadow: 0 1px 3px rgba(0,0,0,.2);
        position: absolute;
        top: 50%;
        z-index: 1;
        margin-top: -15px;
        cursor: pointer;
        /*outline: 0;*/
        transition: opacity .3s ease
    }

        .content-slider .slick-arrow:before {
            content: "";
            width: 8px;
            height: 8px;
            border-top: 2px solid #fff;
            border-left: 2px solid #fff;
            position: absolute;
            top: 50%;
            left: 50%
        }

        .content-slider .slick-arrow.slick-disabled {
            opacity: .5
        }

        .content-slider .slick-arrow.slick-prev {
            left: 0
        }

            .content-slider .slick-arrow.slick-prev:before {
                transform: rotate(-45deg);
                margin-top: -5px;
                margin-left: -4px
            }

        .content-slider .slick-arrow.slick-next {
            right: 0
        }

            .content-slider .slick-arrow.slick-next:before {
                transform: rotate(135deg);
                margin-top: -5px;
                margin-left: -6px
            }

.fader-section {
    position: relative
}

.fader-section__inner {
    top: 0;
    left: 0;
    right: 0;
    width: 100%
}

.in-view .fader-section__inner {
    position: fixed
}

.fader-section__item {
    min-height: 100vh
}

    .fader-section__item ~ .fader-section__item {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        width: 100%;
        opacity: 0
    }

.form .mktoFormRow:first-child .mktoFieldWrap {
    margin-top: 0
}

.form .mktoFormCol {
    width: 100%
}

.form .mktoFieldWrap {
    width: 100%;
    float: none;
    margin-top: 15px
}

.form .mktoLabel {
    float: none !important;
    font-weight: 400 !important;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: .18px;
    line-height: 1 !important;
    padding: 0 10px 0 0 !important;
    display: inline;
    position: relative
}

    .form .mktoLabel .mktoAsterix {
        position: absolute;
        top: 0;
        right: 0;
        padding-right: 0 !important
    }

.form .mktoField:not([type=checkbox]) {
    padding: 5px 10px !important;
    height: auto;
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none;
    /*outline: 0;*/
    background: 0 0;
    margin-top: 5px !important;
    border: 1px solid #666;
    width: 100%;
    box-sizing: border-box;
    font-size: 14px;
    color: #666;
    font-weight: 400;
    line-height: 20px;
    letter-spacing: .14px
}

.form [type=checkbox].mktoField {
    margin-top: 10px !important;
    margin-bottom: 15px !important;
    width: 22px;
    height: 22px
}

    .form [type=checkbox].mktoField + label {
        width: auto;
        margin-top: 5px;
        margin-left: 38px;
        font-size: 14px;
        color: #666;
        font-weight: 400;
        margin-bottom: 20px;
        line-height: 20px;
        letter-spacing: .14px
    }

.form .mktoCheckboxList {
    padding: 0 !important
}

.form .mktoButton, .form .mktoButtonRow {
    width: 100%
}

.lightbox {
    background: rgba(45,61,71,.95);
    position: fixed;
    top: 0;
    left: 100%;
    width: 100%;
    height: 100%;
    padding-top: 20px;
    padding-bottom: 20px;
    box-sizing: border-box;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    z-index: 15;
    opacity: 0;
    visibility: hidden;
    overflow: scroll;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    backface-visibility: hidden;
    transition: opacity .3s ease,visibility 0s ease,left 0s ease;
    transition-delay: .3s,.6s,.6s
}

.lightbox--open {
    opacity: 1;
    visibility: visible;
    left: 0;
    transition-delay: 0s,0s,0s
}

.lightbox__inner {
    max-width: 480px;
    width: 100%;
    margin: auto;
    transform: translateY(-100%);
    opacity: 0;
    transition: opacity .3s ease-in-out,transform .3s ease-in-out;
    transition-delay: 0s,0s
}

.lightbox--video .lightbox__inner {
    max-width: 960px
}

.lightbox--open .lightbox__inner {
    opacity: 1;
    transform: translateY(0);
    transition-delay: .3s,.3s
}

.lightbox__body {
    background: #fff;
    clear: both
}

.lightbox--video .lightbox__body {
    padding: 0;
    position: relative
}

    .lightbox--video .lightbox__body:before {
        display: block;
        content: "";
        width: 100%;
        padding-top: 56.25%
    }

    .lightbox--video .lightbox__body > * {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        width: 100%;
        height: 100%
    }

        .lightbox--video .lightbox__body > * * {
            width: 100%;
            height: 100%
        }

.lightbox__body > * {
    display: block
}

.lightbox__close {
    background: 0 0;
    border: none;
    box-shadow: none;
    font-weight: 400;
    text-transform: uppercase;
    font-size: 22px;
    color: #fff;
    letter-spacing: .22px;
    line-height: 32px;
    text-shadow: 0 0 14px rgba(0,0,0,.69);
    float: right;
    margin-bottom: 20px;
    /*outline: 0;*/
    padding: 0;
    cursor: pointer;
    opacity: 0;
    transition: opacity .3s ease-in-out,color .3s ease-in-out;
    transition-delay: .6s,.6s
}

.lightbox--open .lightbox__close {
    opacity: 1
}

.lightbox__close:hover {
    background: 0 0;
    color: #248fcf;
    transition-delay: 0s,0s
}

.scroller__content, .scroller__title {
    font-weight: 400;
    text-transform: uppercase;
    color: #fff;
    text-shadow: 0 0 14px rgba(0,0,0,.69)
}

@media screen and (max-width:959px) {
    .lightbox__inner {
        padding: 0 20px;
        box-sizing: border-box
    }
}

@media screen and (max-width:767px) {
    .lightbox__inner {
        max-width: 568px
    }
}

@media screen and (max-width:639px) {
    .lightbox {
        background: rgba(102,102,102,.95);
        padding-top: 20px;
        padding-bottom: 40px
    }

    .lightbox__inner {
        max-width: 480px
    }

    .lightbox__body {
        padding: 20px 30px
    }
}

@media screen and (max-width:567px) {
    .lightbox__inner {
        max-width: 375px
    }
}

.scroller {
    position: relative;
    z-index: 1;
    background: #2d3d47;
    padding-bottom: 257px
}

.scroller__end, .scroller__end:after, .scroller__end:before {
    position: absolute;
    width: 100%;
    bottom: 0
}

.scroller__end {
    height: 540px;
    left: 0;
    z-index: -1
}

    .scroller__end:before {
        content: '';
        left: 0;
        height: 275px;
        background-image: linear-gradient(180deg,rgba(46,60,73,0) 0,#2e3c49 47%)
    }

    .scroller__end:after {
        content: '';
        left: 0;
        height: 540px;
        background-image: url(../png/footer-wave.png);
        background-repeat: repeat-x;
        background-position: top right;
        background-size: 100% 540px
    }

.scroller__bgs, .sign-off-section__bg {
    position: fixed;
    pointer-events: none;
    left: 0
}

.scroller__bgs {
    top: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    user-select: none
}

    .scroller__bgs img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: top center;
        position: absolute;
        top: 0;
        left: 0;
        opacity: 0;
        will-change: opacity;
        transition: opacity .6s ease
    }

        .scroller__bgs img.align-left {
            object-position: top left
        }

        .scroller__bgs img.align-right {
            object-position: top right
        }

        .scroller__bgs img.active {
            opacity: 1
        }

.scroller__section {
    padding-bottom: 16.5vh;
    padding-top: 16.5vh;
    box-sizing: border-box
}

.scroller__section-inner {
    position: relative;
    z-index: 1
}

.scroller__title {
    font-size: 70px;
    letter-spacing: .7px;
    line-height: 70px;
    margin-bottom: 50px
}

.scroller__content {
    font-size: 22px;
    letter-spacing: .22px;
    line-height: 32px
}

@media screen and (max-width:639px) {
    .scroller__title {
        font-size: 50px;
        line-height: 50px;
        margin-bottom: 30px
    }

        .scroller__title br {
            display: none
        }

    .scroller__content {
        font-size: 18px;
        line-height: 24px
    }
}

.card-list--push-bottom {
    margin-bottom: 20px
}

.card-list--row {
    display: flex
}

.card-list__item {
    padding-bottom: 16px;
    box-sizing: border-box
}

    .card-list__item:last-child {
        padding-bottom: 0
    }

.card-list--row .card-list__item {
    flex: 1;
    padding-right: 30px;
    padding-bottom: 0
}

    .card-list--row .card-list__item:last-child {
        padding-right: 0
    }

    .card-list--row .card-list__item .accordion, .card-list--row .card-list__item .card {
        height: 100%
    }

@media screen and (max-width:767px) {
    .card-list--break-at-medium {
        display: block
    }

        .card-list--break-at-medium .card-list__item {
            padding-right: 0;
            padding-bottom: 30px
        }

            .card-list--break-at-medium .card-list__item:last-child {
                padding-bottom: 0
            }
}

.sense-container {
    width: 100%;
    max-width: 960px;
    padding-left: 15px;
    padding-right: 15px;
    box-sizing: border-box
}

@media screen and (max-width:959px) {
    .sense-container {
        max-width: 768px
    }
}

@media screen and (max-width:767px) {
    .sense-container {
        max-width: 640px
    }
}

@media screen and (max-width:639px) {
    .sense-container {
        max-width: 568px
    }
}

@media screen and (max-width:567px) {
    .sense-container {
        max-width: 100%
    }
}

.intro-section__row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 35px
}

.intro-section__event-badge {
    flex: none;
    width: 140px;
    margin-left: 100px
}

.intro-section__title {
    flex: none;
    margin-bottom: 0
}

.intro-section__title--push-bottom {
    margin-bottom: 50px
}

.intro-section__content {
    max-width: 650px
}

@media screen and (max-width:959px) {
    .intro-section__title {
        flex: 1
    }

    .intro-section__event-badge {
        margin-left: 0
    }
}

@media screen and (max-width:767px) {
    .intro-section__row {
        display: block
    }

    .intro-section__event-badge {
        margin-left: auto;
        margin-right: auto;
        display: block;
        margin-top: 20px
    }
}

.perks-section__layout {
    display: flex;
    justify-content: flex-end
}

.perks-section__content {
    max-width: 450px
}

@media screen and (max-width:639px) {
    .intro-section__row, .intro-section__title--push-bottom {
        margin-bottom: 30px
    }

    .perks-section__layout {
        display: block
    }

    .perks-section__content {
        max-width: 100%
    }

    .recommended-section .scroller__title {
        text-align: center
    }

    .recommended-section .container--full-at-small {
        overflow: hidden;
        max-width: 100%;
        padding-left: 0;
        padding-right: 0
    }
}

.products-section__layout {
    display: flex;
    align-items: flex-start
}

.products-section__cards {
    flex: none;
    width: 370px;
    margin-right: 30px
}

@media screen and (max-width:767px) {
    .products-section__layout {
        display: block
    }

    .products-section__cards {
        width: 100%;
        margin-right: 0;
        margin-bottom: 40px
    }
}

.sign-off-section__bg {
    bottom: 0;
    width: 100%;
    height: 100vh;
    opacity: 0;
    transition: opacity .3s ease;
    mix-blend-mode: multiply;
    z-index: -1
}

    .sign-off-section__bg:after, .sign-off-section__bg:before {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%
    }

    .sign-off-section__bg:before {
        background-image: linear-gradient(180deg,rgba(102,102,102,0) 50%,#666 100%);
        mix-blend-mode: multiply
    }

    .sign-off-section__bg:after {
        background-image: linear-gradient(180deg,rgba(36,143,207,0) 50%,rgba(36,143,207,.5) 100%);
        mix-blend-mode: color
    }

.in-view .sign-off-section__bg {
    opacity: 1
}

.sign-off-section__content {
    max-width: 450px
}

    .form .sign-off-section__content .mktoButton, .sign-off-section__content .big-button, .sign-off-section__content .form .mktoButton {
        margin-top: 20px
    }

@media screen and (max-width:639px) {
    .sign-off-section__content {
        max-width: 100%
    }
}
