body {
    color: #000;
}

h1,h2 {
    font-weight: 800;
}

.h3 {
    font-size: 22px;
    line-height: 1.5;
}

.text-weight-heavy {
    font-weight: 800;
}

.text-weight-light {
    font-weight: 300;
}

.text-weight-normal {
    font-weight: 500 !important;
}

.text-medium,
.text-large {
    margin: 6% 0;
}

.text-medium {
    font-size: 30px;
}

.text-xl {
    font-size: 95px;
}

.fg-white {
    color: #fff;
}

.fg-text-light {
    color: #d8d8d8;
}

.fg-black {
    color: #000;
}

.fg-blue {
    color: #5c85b3;
}

.fg-purple {
    color: #6441ff;
}

.fg-text-dark {
    color: #444343;
}

.bg-black {
    background: #000;
}

.bg-gray {
    background: #f2f3f8;
}

.bg-purple {
    background: #6441ff;
}

.bg-blue {
    background: #689ED4;
}

.bg-white {
    background: #fff;
}

.bg-pink {
    background: #DF3AFF;
}

.fg-pink {
    color: #DF3AFF;
}

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

.no-margin-all {
    margin: 0 !important;
}

.no-margin-top {
    margin-top: 0 !important;
}

.no-margin-bottom {
    margin-bottom: 0 !important;
}

.no-padding-all {
    padding: 0 !important;
}

.no-padding-top {
    padding-top: 0 !important;
}

.no-padding-bottom {
    padding-bottom: 0 !important;
}

.no-padding-vertical {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.no-padding-horizontal {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.no-padding-top {
    padding-top: 0 !important;
}

.margin-vertical-medium {
    margin: 5% 0;
}

.margin-vertical-large {
    margin: 8% 0;
}

.margin-top-large {
    margin-top: 8%;
}


.margin-bottom-small {
    margin-bottom: 7.5% !important;
}

.cp-wrap {
    display: block;
    position: relative;
    margin-top: 70px;
    background: #f2f3f8;
    font-family: "Open Sans", Arial, Helvetica, sans-serif;
}

.cp-wrap strong {
    font-weight: 900;
}

.cp-wrap .content-block h2 {
    font-size: 25px;
    line-height: 32px;
}

.cp-wrap .content-block .cp-graphic-wrap h2 {
    font-size: 20px;
    line-height: 28px;
}

.cp-wrap .cp-branding .content-block h2.subtitle {
    font-size: 20px;
    line-height: 28px;
}

.cp-wrap h1,
.cp-wrap h2,
.cp-wrap h3,
.cp-wrap p {
    font-family: inherit;
}

.content-block {
    margin: 0 auto;
    max-width: 1300px;
    padding: 7.5%;
    overflow: hidden;
}

.inner-content-block {
    margin: 0 auto 15%;
    padding: 0;
    max-width: 760px;
}

.content-block.header {
    max-width: 1300px;
}

.content-block p {
    font-size: 18px;
    line-height: 36px;
}

.content-block p small {
    line-height: 26px;
}

.content-block p.info {
    font-size: 27px;
    line-height: 38px;
}

.content-block.fg-text-light p a {
    text-decoration: underline;
    color: #d8d8d8;
}

.content-block.fg-text-light p a:hover {
    color: #d8d8d8;
}

.content-block-graphic {
    margin: 0 auto;
}

.content-block-graphic img {
    max-width: 100%;
    height: auto;
}

.content-block-graphic h3 {
    font-size: 18px;
    margin: 35px 0 25px;
}

.auto-charge .content-block p {
    color: #282828;
}

.cp-graphic-wrap + .cp-graphic-wrap {
    margin-top: 15%;
}

.content-block-graphic + .content-block-graphic {
    margin-top: 15%;
}

.cp-icon-wrap {
    padding-bottom: 7.5%;
}

.cp-header h3 {
    margin-bottom: 7.5%;
    font-weight: 300;
    font-size: 17px;
    line-height: 1.5;
}

.cp-header h3 span {
    font-style: italic;
    color: #5c85b3;
    font-weight: 900;
}

.button-wrap a.btn:active,
.button-wrap a.btn:focus,
.button-wrap a.btn:hover {
    text-decoration: none;
    color: #fff;
    background: #0096C0;
}

.cp-intro .btn-wrap,
.auto-charge .btn-wrap {
    margin: 15% auto;
    width: 300px;
}

.cp-intro .btn-wrap .btn {
    display: block;
    padding: 18px 0;
    border: 5px solid #fff;
    color: #fff;
    width: 100%;
    border-radius: 9999px;
    font-weight: 600;
    font-size: 18px;
}

.auto-charge .btn-wrap .btn {
    display: block;
    padding: 18px 0;
    border: 5px solid #699ed4;
    color: #fff;
    width: 100%;
    border-radius: 9999px;
    font-weight: 600;
    font-size: 18px;
    background: #699ed4;
}

.content-block p.smaller {
    font-size: 14px;
    line-height: 24px;
}

.subtitle + p {
    margin-top: 5%;
}

.image-wrap {
    margin: 0 auto;
    width: 75%;
}

.image-wrap img {
    width: 100%;
    height: auto;
}

.image-wrap.has-max-width {
    max-width: 20%;
}

.image-wrap + .image-wrap {
    padding-top: 45px;
}

.image-wrap.device {
    margin: 8% auto;
}

@media only screen and (max-width: 767px) {
    .hidden-xs {
        display: none !important;
    }
}

@media only screen and (min-width: 768px) {
    .cp-header h3 {
        font-size: 32px;
    }

    .text-medium {
        font-size: 39px;
    }

    .text-large {
        font-size: 52px !important;
        line-height: 65px !important;
    }

    .text-xl {
        font-size: 40px !important;
    }

    .hidden-sm-up {
        display: none !important;
    }

    .content-block-graphic h3 {
        font-size: 28px;
    }
}

@media only screen and (min-width: 1099px) {
    .content-block  {
        padding: 7.5% 0;
    }
}

@media only screen and (min-width: 1024px) {
    .cp-wrap .content-block h2 {
        font-size: 40px;
        line-height: 55px;
    }

    .content-block-graphic p {
        margin: 0 auto;
        max-width: 75%;
    }

    .cp-wrap .content-block .cp-graphic-wrap h2 {
        font-size: 30px;
        line-height: 42px;
    }

    .cp-wrap {
        margin-top: 80px;
    }
}

@media only screen and (min-width: 1300px) {
    .text-xl {
        font-size: 70px !important;
    }

    .content-block-graphic p {
        margin: 0 auto;
        max-width: 50%;
    }
}

