/*
 * Reboot v4.5.0
 */

*,::after,::before{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-size:1rem;font-weight:400;line-height:1.5;color:#212529;text-align:left;background-color:#fff}[tabindex="-1"]:focus:not(:focus-visible){outline:0!important}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem}p{margin-top:0;margin-bottom:1rem}abbr[data-original-title],abbr[title]{text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;border-bottom:0;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#007bff;text-decoration:none;background-color:transparent}a:hover{color:#0056b3;text-decoration:underline}a:not([href]){color:inherit;text-decoration:none}a:not([href]):hover{color:inherit;text-decoration:none}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em}pre{margin-top:0;margin-bottom:1rem;overflow:auto;-ms-overflow-style:scrollbar}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg{overflow:hidden;vertical-align:middle}table{border-collapse:collapse}caption{padding-top:.75rem;padding-bottom:.75rem;color:#6c757d;text-align:left;caption-side:bottom}th{text-align:inherit}label{display:inline-block;margin-bottom:.5rem}button{border-radius:0}button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}[role=button]{cursor:pointer}select{word-wrap:normal}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none!important}

/*
 * jQuery UI v1.12.1
 * Includes: core.css, slider.css
 */

.ui-helper-hidden{display:none}.ui-helper-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.ui-helper-reset{margin:0;padding:0;border:0;outline:0;line-height:1.3;text-decoration:none;font-size:100%;list-style:none}.ui-helper-clearfix:before,.ui-helper-clearfix:after{content:"";display:table;border-collapse:collapse}.ui-helper-clearfix:after{clear:both}.ui-helper-zfix{width:100%;height:100%;top:0;left:0;position:absolute;opacity:0;filter:Alpha(Opacity=0)}.ui-front{z-index:100}.ui-state-disabled{cursor:default!important;pointer-events:none}.ui-icon{display:inline-block;vertical-align:middle;margin-top:-.25em;position:relative;text-indent:-99999px;overflow:hidden;background-repeat:no-repeat}.ui-widget-icon-block{left:50%;margin-left:-8px;display:block}.ui-widget-overlay{position:fixed;top:0;left:0;width:100%;height:100%}.ui-slider{position:relative;text-align:left}.ui-slider .ui-slider-handle{position:absolute;z-index:2;width:1.2em;height:1.2em;cursor:default;-ms-touch-action:none;touch-action:none}.ui-slider .ui-slider-range{position:absolute;z-index:1;font-size:.7em;display:block;border:0;background-position:0 0}.ui-slider.ui-state-disabled .ui-slider-handle,.ui-slider.ui-state-disabled .ui-slider-range{filter:inherit}.ui-slider-horizontal{height:.8em}.ui-slider-horizontal .ui-slider-handle{top:-.3em;margin-left:-.6em}.ui-slider-horizontal .ui-slider-range{top:0;height:100%}.ui-slider-horizontal .ui-slider-range-min{left:0}.ui-slider-horizontal .ui-slider-range-max{right:0}.ui-slider-vertical{width:.8em;height:100px}.ui-slider-vertical .ui-slider-handle{left:-.3em;margin-left:0;margin-bottom:-.6em}.ui-slider-vertical .ui-slider-range{left:0;width:100%}.ui-slider-vertical .ui-slider-range-min{bottom:0}.ui-slider-vertical .ui-slider-range-max{top:0}


/* global
---------------------------------------- */

html {
    --black: #1a2d35;
    --gray: #a6aaac;
    --lightgray: #e7e7e8;
    --white: #fff;
    --blue: #2491eb;
    --lightblue: #92c8f5;
    --darkblue: #2888d7;
    --pink: #fd6cb3;
}

body {
    font-family: "Kanit", sans-serif;
    font-weight: 300;
    color: var(--black);
    margin: 0;
}

h1, h2, h3, h4, h5, h6, b, strong {
    font-weight: 900;
}

h1, h2, h3, h4, h5, h6 {
    line-height: 1.05;
}

h1, h2, h3 {
    text-transform: uppercase;
}

h1 {
    font-size: 2.25rem;
}

h2 {
    font-size: 2rem;
}

h3 {
    font-size: 1.5rem;
}

a {
    color: var(--blue);
    transition: color .2s, background-color .2s;
}

a:hover {
    color: var(--darkblue);
}

img {
    max-width: 100%;
    height: auto;
}

ul {
    list-style: none;
    padding-left: 0;
}

::-webkit-search-cancel-button,
::-webkit-search-decoration {
    -webkit-appearance: none;
}

@media (min-width: 992px) {

    html {
        font-size: 1.25vw;
    }

    body {
        font-size: 1.25rem;
    }

    h1 {
        font-size: 3.75rem;
    }

    h2 {
        font-size: 3rem;
    }

    h3 {
        font-size: 2rem;
    }

}

/* accessbility
---------------------------------------- */

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* table
---------------------------------------- */

.table-helper {
    width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
}

.table {
    width: 100%;
    max-width: 50rem;
    margin-left: auto;
    margin-right: auto;
    font-size: .9375rem;
    text-align: left;
    line-height: 1.25;
    padding-bottom: 1rem;
}

.table th,
.table td {
    padding: .5rem;
}

.table th {
    border-bottom: 1px solid var(--lightgray);
    padding-bottom: 1rem;
}

.table tbody tr:first-child td {
    padding-top: 1rem;
}

.table-striped tbody tr:nth-child(even) td {
    position: relative;
}

.table-striped tbody tr:nth-child(even) td:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: .25em;
    bottom: .25em;
    background-color: rgba(36,145,235,.085);
    pointer-events: none;
}

@media (min-width: 992px) {

    .table {
        font-size: 1rem;
    }

    .table th,
    .table td {
        padding: .8125rem .5rem;
    }

}

/* cta
---------------------------------------- */

.cta {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    vertical-align: middle;
    font-weight: 900;
    text-transform: uppercase;
    white-space: nowrap;
    text-decoration: none;
    background-color: var(--blue);
    color: var(--white);
    padding: .625rem;
    width: 15rem;
    height: 3rem;
}

.cta:hover {
    text-decoration: none;
    background-color: var(--darkblue);
    color: var(--white);
}

.cta-outline {
    border: 1px solid var(--lightgray);
}

.cta-outline:hover {
    background-color: var(--white);
    color: var(--blue);
}

/* forms
---------------------------------------- */

.form {
    width: 31.25rem;
    max-width: 100%;
}

.form p {
    margin-bottom: 1.5rem;
}

.textbox-primary {
    width: 100%;
    padding: .5rem;
    margin: 0;
    border: 1px solid var(--lightblue);
    border-radius: 0;
    box-shadow: none;
    outline: none;
    transition: border-color .2s;
    -webkit-appearance: none;
}

.textbox-primary:focus {
    border-color: var(--blue);
}

.button-primary {
    font-weight: 900;
    text-transform: uppercase;
    background-color: var(--blue);
    color: var(--white);
    padding: .625rem 1.875rem;
    margin: 0;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    outline: none;
    transition: background-color .2s;
    -webkit-appearance: none;
}

.button-primary:hover {
    background-color: var(--darkblue);
}

.textbox-secondary {
    width: 100%;
    padding: .5rem 0;
    margin: 0;
    border: 0;
    border-bottom: 1px solid;
    border-radius: 0;
    box-shadow: none;
    outline: none;
    background-color: transparent;
    -webkit-appearance: none;
}

.textbox-secondary:focus {
    border-bottom-color: var(--blue);
}

.select-primary {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24' viewBox='0 0 24 24' width='24'%3E%3Cpath d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
    background-position: right center;
    background-repeat: no-repeat;
    background-size: 1.5rem 1.5rem;
    padding: .5rem;
    padding-right: 1.5rem;
    margin: 0;
    border: 1px solid var(--lightblue);
    border-radius: 0;
    box-shadow: none;
    outline: none;
    transition: border-color .2s;
    -webkit-appearance: none;
}

.select-primary:focus {
    border-color: var(--blue);
}

.button-secondary {
    font-weight: 900;
    text-transform: uppercase;
    background-color: transparent;
    color: var(--blue);
    padding: .5rem 0;
    margin: 0;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    outline: none;
    transition: color .2s;
    -webkit-appearance: none;
}

.button-secondary:hover {
    color: var(--darkblue);
}

.output {
    font-size: 1rem;
}

.output.success {
    color: #28a745;
}

.output.error {
    color: #dc3545;
}

/* grid
---------------------------------------- */

@media (min-width: 992px) {

    .row {
        display: flex;
    }

    .col {
        flex: 1;
    }

}

/* modal
---------------------------------------- */

.modal {
    position: fixed;
    z-index: 9;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,.5);
}

.modal-wrapper,
.modal-content {
    max-width: calc(100vw - 2.5rem);
    max-height: calc(100vh - 5rem);
}

.modal-wrapper {
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 50rem;
    height: auto;
    background-color: #fff;
    box-shadow: 0 0 1rem rgba(0,0,0,.3);
}

.modal-content {
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.modal-body {
    padding: 2.5rem;
}

.modal-body table {
    width: 100%;
    max-width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    font-size: 1rem;
    margin-bottom: 1.5rem;
}

.modal-body th,
.modal-body td {
    border: 1px solid var(--lightgray);
    padding: .5rem .75rem;
    text-align: left;
    font-weight: normal;
}

.modal-body tr:nth-child(even) th,
.modal-body tr:nth-child(even) td {
    background-color: rgba(36,145,235,.085);
}

.modal-close,
.disclosure-close,
.disclosure-back {
    position: absolute;
    right: .5rem;
    top: .5rem;
    width: 2.125rem;
    height: 2.125rem;
    text-decoration: none;
    cursor: pointer;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24' viewBox='0 0 24 24' width='24'%3E%3Cpath d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z'/%3E%3C/svg%3E") center / contain no-repeat;
    transition: opacity .2s;
}

.modal-close:hover,
.disclosure-close:hover,
.disclosure-back:hover {
    opacity: .7;
}

.modal-visible {
    overflow: hidden;
}

.youtube-video {
    position: relative;
}

.youtube-video:before {
    content: "";
    display: block;
    padding-bottom: 56.25%;
}

.youtube-video iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.disclosure-content {
    font-size: 1rem;
}

.disclosure-content * {
    font-family: inherit !important;
    font-size: inherit !important;
    line-height: inherit !important;
    color: inherit !important;
}

.disclosure-title {
    font-size: 2rem !important;
}

/* header/footer
---------------------------------------- */

.header,
.footer {
    padding: 1rem;
}

.header {
    position: fixed;
    z-index: 9;
    left: 0;
    right: 0;
    top: 0;
    transition: .2s;
}

.header.tiny {
    box-shadow: 0 .25rem .5rem rgba(26,45,53,.125);
    background-color: var(--white);
    padding-top: .5rem;
    padding-bottom: .5rem;
}

.masthead {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.masthead p {
    margin-bottom: 0;
}

.logo {
    position: relative;
    z-index: 9;
    width: 10rem;
}

.logo a {
    display: block;
}

.hamburger {
    position: relative;
    z-index: 9;
    display: block;
    width: 2.25rem;
    height: 2.25rem;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Crect x='.559' y='7.136' width='35.441' height='3.6' rx='1.8' fill='%231a2d35'/%3E%3Crect x='.28' y='16.2' width='35.441' height='3.6' rx='1.8' fill='%231a2d35'/%3E%3Crect y='25.264' width='35.441' height='3.6' rx='1.8' fill='%231a2d35'/%3E%3C/svg%3E%0A") center / 1.75rem 1.75rem no-repeat;
}

.menu {
    position: fixed;
    z-index: 8;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: var(--white);
    display: none;
}

.menu ul {
    list-style: none;
    padding: 0;
    margin-top: 4rem;
}

.menu a {
    display: block;
    padding: .75rem 1rem;
    color: inherit;
    text-decoration: none;
}

.menu a:hover {
    color: var(--blue);
}

.mm {
    overflow: hidden;
}

.mm .hamburger {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36'%3E%3Crect x='-6.428' y='15.519' width='48.856' height='4.963' rx='2.481' transform='rotate(-45 18 18)' fill='%231a2d35'/%3E%3Crect x='15.519' y='-6.428' width='4.963' height='48.856' rx='2.481' transform='rotate(-45 18 18)' fill='%231a2d35'/%3E%3C/svg%3E%0A") center / 1.25rem 1.25rem no-repeat;
}

.footer {
    background-color: var(--lightgray);
    padding-top: 3.5rem;
    padding-bottom: 1rem;
}

.colophon h2 {
    text-align: center;
}

.metainfo {
    display: flex;
    flex-direction: column;
    margin-bottom: 4rem;
}

.brand {
    display: none;
}

.links {
    order: 1;
}

.links ul {
    font-size: .75rem;
    display: flex;
    justify-content: center;
    margin-bottom: 0;
}

.links li {
    padding: 0 .25rem;
}

.links a {
    color: inherit;
}

.mailing {
    padding: 3rem 2rem;
}

.mailing h3 {
    text-align: center;
    text-transform: none;
    font-size: 1.5rem;
    margin-bottom: 2rem;
}

.mailing .form {
    width: 22.5rem;
    margin: 0 auto;
}

.mailing p {
    position: relative;
    font-size: .875rem;
    margin-bottom: .5rem;
}

.mailing .textbox-secondary {
    font-size: .8125rem;
    padding-right: 2rem;
}

.mailing .button-secondary {
    font-size: .75rem;
    position: absolute;
    right: 0;
    top: 0;
    padding: 0;
    height: 100%;
}

.social ul {
    display: flex;
    justify-content: center;
}

.social li {
    padding: 2rem .625rem;
}

.social svg {
    width: 2rem;
    height: auto;
}

.legalinfo {
    font-size: .75rem;
    text-align: center;
}

.legalinfo a {
    color: inherit;
    text-decoration: underline;
}

.securities {
    font-size: .875rem;
}

@media (min-width: 992px) {

    .header,
    .footer {
        padding: 2rem 5rem;
    }

    .hamburger {
        display: none;
    }

    .logo {
        width: 12.5rem;
    }

    .menu {
        position: static;
        background-color: transparent;
        font-size: 1.125rem;
        display: block !important;
    }

    .menu ul {
        display: flex;
        flex-direction: row;
        justify-content: flex-end;
        align-items: center;
        padding: 0;
        margin: 0;
    }

    .menu li:not(:last-child) {
        margin-right: 1.25rem;
    }

    .menu a {
        padding: .5rem;
        transition: background-size .2s;
        background-image: linear-gradient(to right, var(--blue), var(--blue));
        background-position: center bottom;
        background-repeat: no-repeat;
        background-size: 0 0;
    }

    .menu a:hover,
    .menu a.active {
        background-size: 50% 1.05px;
    }

    .colophon {
        padding: 4rem 0;
    }

    .colophon h2 {
        margin-bottom: 4rem;
    }

    .metainfo {
        flex-direction: row;
    }

    .brand {
        flex: 0 0 40%;
    }

    .links {
        flex: 0 0 30%;
    }

    .mailing {
        flex: 0 0 30%;
    }

    /*
    .brand {
        flex: 0 0 35%;
    }

    .links {
        flex: 0 0 15%;
    }

    .mailing {
        flex: 0 0 30%;
    }

    .social {
        flex: 0 0 20%;
    }
    */

    .brand {
        display: block;
    }

    .brand img {
        width: 13rem;
        margin-bottom: .5rem;
    }

    .brand p {
        font-size: .75rem;
        padding-right: 4rem;
    }

    .links {
        order: initial;
    }

    .links ul {
        flex-direction: column;
    }

    .links li {
        margin-bottom: .25rem;
    }

    .mailing {
        padding: 0;
        margin-top: 1rem;
    }

    .mailing h3 {
        text-align: left;
        margin-bottom: .5rem;
    }

    .mailing .form {
        width: 100%;
        padding-right: 2rem;
    }

    .social ul {
        justify-content: flex-end;
    }

    .securities {
        font-size: 1rem;
    }

}

@media (min-width: 1200px) {

    .logo {
        width: 10rem;
    }

    .menu {
        font-size: 1rem;
    }

}

/* module
---------------------------------------- */

.module {
    padding: 3.125rem 1rem;
}

.module:first-child {
    padding-top: 10rem;
}

.module h1,
.module h2 {
    margin-bottom: 2rem;
}

.module h3 {
    margin-bottom: 1rem;
}

@media (min-width: 992px) {

    .module {
        padding: 7.5rem 5rem;
    }

    .module:first-child {
        padding-top: 13.75rem;
    }

}

/* hero
---------------------------------------- */

.hero {
    background-color: var(--lightgray);
    padding-bottom: 1.5rem;
}

.hero .title {
    margin-bottom: 1rem;
}

.hero .media {
    margin-top: 2.5rem;
    margin-left: -1rem;
    margin-right: -1rem;
}

.in-view .a-1 {
    position: relative;
    display: block;
    bottom: -2rem;
    animation-name: hero;
    animation-duration: 1s;
    animation-fill-mode: forwards;
}

@keyframes hero {
    0% {
        bottom: -2rem;
    }
    100% {
        bottom: 0;
    }
}

@media (min-width: 992px) {

    .main .hero {
        padding-top: 15rem;
        padding-bottom: 0;
        margin-bottom: 2rem;
    }

    .hero .media {
        margin: -7rem -5rem -7rem -18rem;
        pointer-events: none;
    }

    .hero .media img {
        min-width: 100%;
    }

}

/* features
---------------------------------------- */

.features {
    text-align: center;
}

.features li {
    padding: 0 1.5rem;
}

.features li:not(:last-child) {
    padding-bottom: 2.5rem;
}

.features h2 {
    margin-bottom: 2.75rem;
}

.features h3 {
    font-size: 1.375rem;
    font-weight: 500;
    text-transform: none;
    margin-top: 1rem;
}

.features h3 span {
    color: var(--blue);
}

.features svg {
    width: 5.625rem;
    height: auto;
}

@media (min-width: 992px) {

    .features {
        padding-bottom: 4rem;
    }

    .features h2 {
        margin-bottom: 4rem;
    }

    .features h3 {
        font-size: 2rem;
    }

    .features .icon {
        display: block;
    }

    .features .icon:before {
        content: "";
        display: inline-block;
        vertical-align: bottom;
        height: 7rem;
    }

    .features svg {
        width: 7rem;
        height: auto;
    }

    .features .row .col {
        padding-bottom: 0;
    }

}

/* benefits
---------------------------------------- */

.benefits {
    text-align: center;
    background-color: var(--blue);
    color: var(--white);
}

.benefits ul {
    font-size: 1.125rem;
    line-height: 1.3;
    padding: 1.5rem;
    margin-bottom: 2rem;
    display: flex;
    flex-direction: column;
}

.benefits li {
    position: relative;
    margin: 1.75rem 0;
}

.benefits .before {
    position: absolute;
    left: 50%;
    transform: translate(-50%, .5rem);
    bottom: -.25rem;
    width: 5rem;
    border-bottom: 1px solid;
}

.benefits .after {
    display: none;
}

.benefits a {
    color: inherit;
}

.benefits .learn-d {
    display: none;
}

.in-view .a-2 {
    opacity: .5;
    animation-name: benefitsI;
    animation-duration: .2s;
    animation-fill-mode: forwards;
}

@keyframes benefitsI {
    0% {
        opacity: .5;
    }
    100% {
        opacity: 1;
    }
}

.a-2a {
    animation-delay: .5s;
}

.a-2b {
    animation-delay: 1.5s;
}

.a-2c {
    animation-delay: 2.5s;
}

.a-2d {
    animation-delay: 3.5s;
}

.in-view .a-2 .before {
    width: 0;
    animation-name: benefitsII;
    animation-duration: .2s;
    animation-fill-mode: forwards;
}

@keyframes benefitsII {
    0% {
        width: 0;
    }
    100% {
        width: 5rem;
    }
}

.a-2a .before {
    animation-delay: .5s;
}

.a-2b .before {
    animation-delay: 1.5s;
}

.a-2c .before {
    animation-delay: 2.5s;
}

.a-2d .before {
    animation-delay: 3.5s;
}

@media (min-width: 992px) {

    .main .benefits {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .benefits {
        text-align: left;
    }

    .benefits .row {
        align-items: center;
    }

    .benefits .col:last-child {
        display: flex;
        justify-content: flex-end;
    }

    .benefits h2 {
        margin-bottom: 1.25rem;
    }

    .benefits ul {
        font-size: 1.75rem;
        margin: 0;
    }

    .benefits .learn-m {
        display: none;
    }

    .benefits .learn-d {
        display: block;
        margin-top: 2rem;
        margin-bottom: 0;
    }

    .benefits .before {
        display: none;
    }

    .benefits .after {
        display: block;
        position: absolute;
        left: -2rem;
        top: .5rem;
        height: 3.75rem;
        border-left: 3px solid;
    }

    .in-view .after {
        height: 0;
        animation-name: benefitsIII;
        animation-duration: .2s;
        animation-fill-mode: forwards;
    }

    @keyframes benefitsIII {
        0% {
            height: 0;
        }
        100% {
            height: 3.75rem;
        }
    }

    .a-2a .after {
        animation-delay: .5s;
    }

    .a-2b .after {
        animation-delay: 1.5s;
    }

    .a-2c .after {
        animation-delay: 2.5s;
    }

    .a-2d .after {
        animation-delay: 3.5s;
    }

}

/* products
---------------------------------------- */

.products {
    position: relative;
    text-align: center;
}

.pro-menu {
    display: inline-flex;
    font-size: .9375rem;
    font-weight: 900;
    text-transform: uppercase;
    padding-left: 0;
    cursor: pointer;
}

.pro-menu li {
    margin: 0 .5rem;
}

.pro-menu a {
    text-decoration: none;
    color: inherit;
    opacity: .5;
    transition: opacity .2s;
}

.pro-menu a:hover,
.pro-menu .active a {
    opacity: 1;
}

.pro-content {
    text-align: left;
    padding: 2.5rem 0 1rem;
}

.products .cta {
    position: absolute;
    right: 0;
    bottom: 0;
    transform: translateY(50%);
    font-size: .875rem;
    border-top-left-radius: 2rem;
    border-bottom-left-radius: 2rem;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 12.5rem;
}

.products .cta svg {
    width: 2rem;
    height: auto;
    margin-right: .5rem;
}

@media (min-width: 992px) {

    .products {
        text-align: left;
        padding-bottom: 8rem;
    }

    .products .row {
        flex-direction: row-reverse;
    }

    .products .col:first-child p {
        text-align: center;
        padding-left: 3rem;
    }

    .products .web img {
        margin: -9rem 0;
    }

    .products .mobile img {
        margin: -10rem 0;
        max-width: 12rem;
    }

    .pro-menu {
        font-size: 1.5rem;
    }

    .pro-menu li {
        margin: 0 1.5rem 0 0;
    }

    .pro-content {
        padding: 1.5rem 0;
    }

    .products .cta {
        font-size: 1.25rem;
        width: 17rem;
        height: 4.375rem;
        border-top-left-radius: 3rem;
        border-bottom-left-radius: 3rem;
    }

    .products .cta svg {
        width: 2.85rem;
        height: auto;
        margin-left: .125rem;
    }

}

/* clients
---------------------------------------- */

.clients {
    padding-top: 8.75rem;
    background-color: var(--lightgray);
}

.clients h2 {
    font-size: 3.25rem;
}

.clients p:last-child {
    padding: 2.75rem 0;
}

@media (min-width: 992px) {

    .clients {
        text-align: center;
        padding-bottom: 2.5rem;
    }

    .clients h2 {
        max-width: 38rem;
        margin-left: auto;
        margin-right: auto;
    }

    .clients p {
        max-width: 57rem;
        margin-left: auto;
        margin-right: auto;
    }

}

/* charities
---------------------------------------- */

.charities {
    text-align: center;
}

.charities ul {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 3rem;
}

.charities li {
    flex: 0 0 50%;
    max-width: 50%;
    padding: 1.5rem;
    display: flex;
    justify-content: center;
    align-items: center;
}

.in-view .a-3 {
    position: relative;
    bottom: -2rem;
    animation-name: charities;
    animation-duration: 1s;
    animation-fill-mode: forwards;
}

@keyframes charities {
    0% {
        bottom: -2rem;
    }
    100% {
        bottom: 0;
    }
}

@media (min-width: 768px) {

    .charities li {
        flex: 0 0 25%;
        max-width: 25%;
    }

}

@media (min-width: 992px) {

    .charities {
        padding-top: 4.5rem;
        padding-bottom: 3.5rem;
    }

    .charities ul {
        max-width: 60rem;
        margin-left: auto;
        margin-right: auto;
    }

    .charities li {
        padding: 1rem;
    }

    .charities img {
        width: auto;
        height: auto;
        max-width: 9rem;
        max-height: 6rem;
    }

}

/* partners
---------------------------------------- */

.partners {
    background-color: var(--lightgray);
}

.partners img {
    pointer-events: none;
}

@media (min-width: 992px) {

    .main .partners {
        padding-top: 15rem;
        margin-bottom: 2rem;
    }

    .partners .row {
        align-items: center;
    }

    .partners .col:first-child {
        padding-right: 1.5rem;
    }

    .partners .col:last-child {
        padding-left: 1.5rem;
    }

}

/* faq
---------------------------------------- */

.faq-back {
    font-size: .875rem;
    display: none;
}

.faq-back a {
    color: inherit;
}

.faq-head {
    margin-bottom: 3rem;
}

.faq-q li {
    margin-bottom: 1rem;
}

.faq-q li a {
    color: inherit;
}

.faq-a h2 {
    font-size: 1.25rem;
    font-weight: 400;
    text-transform: none;
    margin-bottom: 1.5rem;
}

.faq-content table {
    width: 100%;
    max-width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    font-size: 1rem;
    margin-bottom: 1.5rem;
}

.faq-content th,
.faq-content td {
    border: 1px solid var(--lightgray);
    padding: .5rem .75rem;
    text-align: left;
    font-weight: normal;
}

.faq-content tr:nth-child(even) th,
.faq-content tr:nth-child(even) td {
    background-color: rgba(36,145,235,.085);
}

.faq-content ul {
    list-style: disc;
    padding-left: 2rem;
}

@media (max-width: 991.98px) {

    .faq-back {
        display: none !important;
    }

    .faq-head .search {
        display: none;
    }

    .faq-q {
        display: none;
    }

    .faq-a .faq-content {
        display: block !important;
        margin-bottom: 3rem;
    }

    .faq-a .faq-content:last-child {
        margin-bottom: 0;
    }

}

@media (min-width: 992px) {

    .main .faq {
        padding-bottom: 2.5rem;
    }

    .faq-ui-1 .faq-menu {
        display: flex;
        flex-wrap: wrap;
    }

    .faq-ui-1 .faq-menu li {
        flex: 0 0 33.333333%;
    }

    .faq-ui-2 .faq-body {
        display: flex;
    }

    .faq-ui-2 .faq-body .faq-q {
        flex: 0 0 40%;
    }

    .faq-ui-2 .faq-body .faq-a {
        flex: 0 0 60%;
    }

    .faq-head {
        display: flex;
        align-items: center;
    }

    .faq-head > div {
        flex: 1;
    }

    .faq-head h1 span {
        display: block;
    }

    .faq-head .textbox-secondary {
        position: relative;
        bottom: -1rem;
        padding: .75rem 0 .75rem 2.5rem;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='48' height='48' viewBox='0 0 48 48'%3E%3Cpath d='M47.479,44.965l-12.9-12.9a19.587,19.587,0,1,0-2.514,2.514L44.965,47.479a1.778,1.778,0,0,0,2.514-2.514ZM3.556,19.555a16,16,0,1,1,16,16,16.017,16.017,0,0,1-16-16Z' fill='%231a2d35'/%3E%3C/svg%3E");
        background-position: left center;
        background-size: 1.5rem 1.5rem;
        background-repeat: no-repeat;
    }

    .faq-q {
        font-size: 1.125rem;
    }

    .faq-q li {
        padding-right: 2rem;
    }

    .faq-ui-2 .faq-q li {
        margin-bottom: 3rem;
    }

    .faq-q li > a {
        display: block;
    }

    .faq-q li.active > a {
        position: relative;
        display: block;
        font-weight: 900;
        padding-left: .625rem;
    }

    .faq-q li.active > a:before {
        content: "";
        position: absolute;
        left: 0;
        top: .45rem;
        bottom: .45rem;
        border-left: 2px solid var(--blue);
    }

    .faq-a {
        font-size: 1.25rem;
    }

    .faq-a h2 {
        font-size: 2.25rem;
        font-weight: 900;
    }

}

/* join
---------------------------------------- */

.join {
    text-align: center;
}

.join h2 {
    margin-bottom: 2.25rem;
}

.join h2 + p {
    max-width: 33.5rem;
    margin-left: auto;
    margin-right: auto;
}

.join a {
    color: inherit;
}

.join .form {
    width: 100%;
    max-width: 39.75rem;
    margin: 3rem auto;
}

.join .form p {
    position: relative;
    margin-bottom: 1rem;
}

.join .textbox-primary {
    padding: .625rem;
    padding-right: 6.5rem;
}

.join .button-primary {
    position: absolute;
    right: 0;
    top: 0;
    width: 6rem;
    height: 100%;
    padding: 0;
}

@media (min-width: 992px) {

    .join {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .join .textbox-primary {
        font-size: 1.125rem;
        padding: 1rem;
        padding-right: 8.5rem;
    }

    .join .button-primary {
        width: 7.5rem;
    }

}

/* interests
---------------------------------------- */

@media (min-width: 992px) {

    .interests {
        max-width: 60rem;
        margin: 0 auto;
        text-align: center;
    }

}

/* members
---------------------------------------- */

.members {
    background-color: var(--lightgray);
}

.members p {
    margin-bottom: 2rem;
}

.members img {
    margin-bottom: .625rem;
}

@media (min-width: 992px) {

    .members img {
        width: 3.75rem;
        height: auto;
    }

    .members .row {
        align-items: center;
    }

    .members .row .col:last-child {
        padding-left: 4rem;
    }

}

/* community
---------------------------------------- */

.community p {
    margin-bottom: 2rem;
}

@media (min-width: 992px) {

    .community {
        max-width: 60rem;
        margin: 0 auto;
        text-align: center;
    }

    .community p {
        margin-top: 3rem;
    }

}

/* commission
---------------------------------------- */

.commission {
    padding-bottom: 1rem;
}

.commission p {
    margin-bottom: 2rem;
}

.commission img {
    pointer-events: none;
    width: 35rem;
}

@media (min-width: 992px) {

    .main .commission {
        padding-top: 15rem;
    }

    .commission .col:first-child {
        flex: 0 0 55%;
    }

    .commission img {
        width: 100%;
        margin-top: -5rem;
    }

}

/* payment
---------------------------------------- */

.payment {
    text-align: center;
    background-color: var(--lightgray);
}

.payment p {
    width: 47rem;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2rem;
}

.payment img {
    width: 35rem;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.payment ul {
    text-align: left;
}

.payment li {
    display: flex;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.payment li:last-child {
    margin-bottom: 0;
}

.payment li:before {
    content: "";
    border-left: 2px solid var(--blue);
    min-height: 2.3rem;
    margin-top: .4rem;
    padding-right: .75rem;
}

@media (min-width: 992px) {

    .payment {
        padding-top: 5rem;
        padding-bottom: 2.5rem;
    }

    .payment ul {
        padding: 1rem;
        margin-top: 3rem;
        background-color: rgba(255,255,255,.4);
    }

}

@media (min-width: 1200px) {

    .payment ul {
        display: flex;
        font-size: 1rem;
    }

    .payment li {
        margin-bottom: 0;
    }

    .payment li:first-child {
        flex-basis: 40rem;
        padding-right: 1rem;
    }

}

/* pricing
---------------------------------------- */

.pricing {
    text-align: center;
    padding-bottom: 0;
}

.pricing h3 {
    margin-top: 2rem;
}

.pricing p {
    width: 47rem;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 2rem;
}

.pricing img {
    width: 35rem;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
}

.pricing small {
    font-weight: 400;
}

.account-related-fees {
    text-align: center;
    padding-bottom: 0;
}

.other-fees {
    text-align: center;
}

@media (min-width: 992px) {

    .pricing {
        padding-top: 5rem;
    }

    .pricing h3 {
        margin-top: 4rem;
        margin-bottom: 2rem;
    }

    .pricing thead {
        font-size: inherit;
    }

    .pricing td:nth-child(1) {
        width: 17rem;
    }

    .pricing td:nth-child(2) {
        width: 12rem;
    }

    .pricing td:nth-child(3) {
        width: 12rem;
    }

    .pricing td:nth-child(4) {
        width: 9rem;
    }

}

/* calculator
---------------------------------------- */

.calculator {
    text-align: center;
    padding-bottom: 0;
}

.calculator .form {
    width: 100%;
    max-width: 31.25rem;
    margin-left: auto;
    margin-right: auto;
    font-size: 1rem;
}

.calculator .input {
    margin-bottom: 2rem;
}

.calculator .input label {
    display: block;
    text-transform: uppercase;
}

.calculator .lever {
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
}

.calculator .lever .val {
    flex: 1;
    padding: 0 1rem;
}

.calculator .lever .min,
.calculator .lever .max {
    font-size: .9375rem;
}

.calculator .ui-slider {
    border: 1px solid var(--lightblue);
    border-radius: .5rem;
}

.calculator .ui-slider-range {
    background-color: var(--blue);
    border-radius: inherit;
}

.calculator .ui-slider-handle {
    width: 1.25rem;
    height: 1.25rem;
    background-color: var(--blue);
    border: .25rem solid var(--white);
    border-radius: 50%;
    box-shadow: 0 0 .1875rem var(--blue);
    outline: none;
}

.calculator .return {
    font-weight: 900;
}

.calculator .return .title {
    text-transform: uppercase;
}

.calculator .return .value {
    font-size: 1.75rem;
}

.calculator .select-primary {
    background-size: 1.25rem 1.25rem;
    border-color: rgba(0,0,0,.15);
    padding-top: .125rem;
    padding-bottom: .125rem;
    padding-right: 1.125rem;
    border-radius: .25rem;
    font-size: .9375rem;
    text-align: center;
}

.calculator .select-primary:focus {
    border-color: var(--lightblue);
}

@media (min-width: 992px) {

    .calculator {
        padding-top: 4rem;
    }

}

/* theme <body class="theme-pink">
---------------------------------------- */

.theme-pink .theme-color {
    color: var(--pink);
}

.theme-pink .theme-border {
    border-color: var(--pink);
}

.theme-pink .theme-fill {
    fill: var(--pink);
}
