html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}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}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-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,
body {
    background-color: #EEE;font-family: 'Poppins', sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: #fff;
    background-color: #111;
}

* {
    box-sizing: border-box;
    outline: none;
}

.spring {
    position: relative;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0;
}

.header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 33px 50px 23px 120px;
}

.logo picture,
.logo img {
    display: block;
}

.top-nav {
    display: flex;
    justify-content: center;
    align-items: center;
}

.top-nav > a {
    color: #fff;
    padding: 20px 15px;
    margin: 0 5px;
    font-size: 14px;
    text-decoration: none;
}

.top-nav > a:hover {
    text-decoration: underline;
}

.social-nav {
    display: flex;
    justify-content: center;
    align-items: center;
}

.social-nav > a {
    padding: 5px 3px;
    margin: 0 2px;
}

.social-nav > a > picture > img {
    display: block;
}

.menu-btn {
    display: none;
}

.close-menu-btn {
    display: none;
}

.banner {
    position: relative;
    padding: 0 102px 0 120px;
}

.banner > div {
    position: relative;
    padding: 109px 0 71px;
    z-index: 2000;
    width: 727px;
}

.banner > div > h1 {
    font-size: 48px;
    line-height: 65px;
    margin: 0 0 16px;
}

.banner > div > h6,
.form > h6 {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
    color: rgba(255, 255, 255, 0.58);
    margin: 0 0 16px;
}

.banner > img {
    position: absolute;
    top: 0;
    right: 102px;
    height: 100%;
    z-index: 1000;
}

.h2 {
    font-size: 40px;
    font-weight: 400;
    line-height: 52px;
    margin: 0 0 16px;
}

.txt--lrg {
    font-size: 18px;
    line-height: 32px;
    margin: 0;
}

.txt--center {
    text-align: center;
}

.philosophy {
    padding: 64px 88px 0;
}

.philosophy__cards {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 30px 0 0;
}

.philosophy__cards > li {
    padding: 0 8px;
    width: 33.3333%;
}

.philosophy__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    background-color: #889996;
    padding: 39px 28px 28px;
    border-radius: 20px;
}

.philosophy__card > img {
    display: block;
    margin: 0 0 21px;
}

.philosophy__card > h4 {
    font-size: 20px;
    font-weight: 600;
    line-height: 28px;
    margin: 0 0 8px;
}

.philosophy__card > p {
    font-size: 16px;
    font-weight: 400;
    line-height: 28px;
    margin: 0;
    text-align: center;
}

.form {
    display: flex;
    flex-direction: column;
}

.form__row {
    display: flex;
    align-items: flex-end;
}

.form__row > input[type="text"] {
    background-color: transparent;
    border: none;
    border-bottom: 1px solid #fff;
    border-radius: 0;
    width: 250px;
    padding: 16px 0;
    margin: 0 0 32px;
    font-size: 16px;
    line-height: 19px;
    color: #fff;
}

.form__row > input[type="text"]::placeholder {
    font-size: 16px;
    line-height: 19px;
    color: #fff;
}

.form__row > input[type="text"]:first-child {
    margin-right: 48px;
}

.form__row > input[type="submit"] {
    background: #889996;
    border-radius: 48px;
    padding: 15px 32px;
    border: none;
    color: #fff;
    font-weight: 500;
    margin: 0 32px 0 0;
}

.form__row > p {
    margin: 0;
    font-size: 12px;
    line-height: 18px;
    color: rgba(255, 255, 255, 0.81);
}

.form__row > p > a {
    font-weight: 700;
    font-size: 12px;
    line-height: 18px;
    color: rgba(255, 255, 255, 0.81);
}

.cost {
    padding: 64px 102.5px 0;
}

.cost__cards {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 37px 0 0 0;
}

.cost__cards > li {
    padding: 0 7.5px;
    width: 25%;
}

.cost__card {
    border-radius: 20px;
    border: 1px solid #d8d8d8;
    padding: 29px 25px 22px;
}

.cost__card > h5 {
    font-weight: 300;
    font-size: 14px;
    line-height: 31px;
    margin: 0;
}

.cost__card > h3 {
    font-weight: 700;
    font-size: 48px;
    line-height: 65px;
    margin: 0;
}

.cost__card > h3 > span {
    font-weight: 400;
    font-size: 14px;
}

.cost__card > h4 {
    font-weight: 700;
    font-size: 16px;
    line-height: 26px;
    margin: 0;
}

.time {
    padding: 64px 116px 0;
}

.time__table {
    background: #1b1b1b;
    border-radius: 20px;
    width: 100%;
    padding: 47px 72px;
    margin: 32px 0;
    display: flex;
    align-items: stretch;
}

.time__table ul {
    list-style: none;
    margin: 0;
    padding: 0 0 18px;
    width: 16.666%;
    border-right: 1px solid #889996;
}

.time__table ul:last-child {
    border-right: none;
}

.time__table li {
    padding: 10px 0;
    text-align: center;
}

.time__table li:first-child {
    border-bottom: 1px solid #889996;
    padding: 0 0 18px;
}

.fifty-fifty {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 64px 116px 0;
}

.fifty-fifty > li {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.fifty-fifty > li > img {
    display: block;
}

.fifty-fifty > li > h2 {
    font-size: 48px;
    font-weight: 700;
    line-height: 65px;
    margin: 0 0 16px;
}

.fifty-fifty > li > p {
    color: rgba(255, 255, 255, 0.58);
    font-size: 14px;
    font-weight: 400;
    line-height: 28px;
    margin: 0 0 32px;
}

.fifty-fifty > li > a {
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    line-height: 21px;
    padding: 17px 36px;
    text-decoration: none;
    border: 1px solid #fff;
    border-radius: 48px;
    margin: 32px 0 0;
}

.bg--grey {
    margin-top: 60px;
    padding: 50px 90px 55px 135px;
    background-color: #889996;
}

.in-touch {
    display: flex;
    justify-content: space-between;
    list-style: none;
    margin: 0;
    padding: 0;
}

.in-touch > li > h4 {
    font-weight: 500;
    margin: 0 0 10px;
}

.in-touch > li > h1 {
    font-size: 40px;
    margin: 0 0 24px;  
}

.in-touch__card {
    background-color: #5c696c;
    padding: 28px 32px;
    border-radius: 20px;
}

.in-touch__card > h2 {
    font-size: 29px;
    line-height: 44px;
    margin: 0 0 22px;
}

.in-touch__card > p,
.in-touch__card > a {
    display: block;
    color: #fff;
    text-decoration: none;
    font-size: 20px;
    margin: 0 0 22px;
}

.in-touch__card > p:last-child {
    margin: 0;
}

input[type="submit"].form__btn--white {
    background-color: #fff;
    color: #889996;
    font-size: 14px;
    line-height: 21px;
}

.footer {
    display: flex;
    align-items: center;
    padding: 32px 56px 37px 116px;
}

.footer > img {
    display: block;
    margin: 0 30px 0 0;
}

.footer > nav {
    display: flex;
}

.footer > nav > a {
    margin: 15px;
    color: #fff;
    text-decoration: none;
}

.footer__social {
    align-self: flex-end;
    margin-left: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.footer__social > nav {
    display: flex;
    align-items: center;
    margin: 0 0 12px;
}

.footer__social > nav > a {
    padding: 10px 6px;
    margin: 2px;
    text-decoration: none;
}

.footer__social > nav > a > img {
    display: block;
}

.footer__social > p {
    font-size: 14px;
    line-height: 17px;
    margin: 0 8px 0 0;
}

.terms,
.privacy {
    padding: 54px 123px;
}

.terms > h1 {
    font-size: 48px;
    font-weight: 700;
    line-height: 65px;
    margin: 0 0 45px;
}

.terms > h2 {
    font-size: 40px;
    font-weight: 400;
    line-height: 52px;
    margin: 32px 0 16px;
}

.terms > p,
.terms ul {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
    margin: 0 0 16px;
    color: rgba(255, 255, 255, 0.58);
}

.terms > h6 {
    font-size: 16px;
    font-weight: 700;
    line-height: 18px;
    color: rgba(255, 255, 255, 0.58);
    margin: 0 0 16px;
}

.terms a,
.privacy a {
    font-weight: 700;
    color: #fff;
}

.privacy > h1 {
    font-size: 48px;
    font-weight: 700;
    line-height: 65px;
    margin: 0 0 32px;
}

.privacy > h2 {
    font-size: 16px;
    font-weight: 700;
    line-height: 18px;
    margin: 0 0 16px;
}

.privacy > p,
.privacy ul {
    font-size: 14px;
    font-weight: 400;
    line-height: 18px;
    color: rgba(255, 255, 255, 0.8);
    margin: 0 0 16px;
}

.desktop {
    display: block;
}

.mobile,
.mobile--inline {
    display: none;
}

.error {
    color: #ff4242 !important;
}

.success {
    color: #00ef60 !important;
}

.mrg-btm--0 {
    margin-bottom: 0 !important;
}

@media (max-width: 768px) {
    .header {
        position: relative;
        padding: 30px 30px 35px;
    }   

    .menu-btn {
        display: block;
        cursor: pointer;
    }

    .close-menu-btn {
        position: absolute;
        top: 37px;
        right: 32px;
        display: block;
        cursor: pointer;
    }

    .top-nav,
    .social-nav {
        display: none;
        position: absolute;
        top: 0;
        right: -1000px;
        z-index: 9000;
        width: 100%;
        max-width: 250px;
        background-color: #889996;
    }

    .top-nav {
        flex-direction: column;
        align-items: stretch;
        padding: 73px 19px 25px 19px;
    }

    .top-nav > a {
        text-align: right;
        padding: 16px 16px 12px 16px;
        margin: 0 0 4px 0;
    }

    .social-nav {
        top: 416px;
        padding-bottom: 265px;
        border-bottom-left-radius: 12px;
        border-bottom-right-radius: 12px;
    }

    .social-nav > a {  
        padding: 7.5px 5px;
        margin: 0 2.5px;
    }

    .banner {
        padding: 0 31px;
    }

    .banner > div {
        padding: 0;
        width: 100%;
    }

    .banner > div > h1 {
        font-size: 24px;
        line-height: 30px;
    }

    .banner > img {
        display: none;
    }

    .form__row {
        align-items: flex-start;
        flex-direction: column;
    }
    
    .form__row > input[type="text"],
    .form__row > input[type="text"]:first-child {
        margin: 0 0 32px;
        width: 100%;
    }

    .form__row > input[type="submit"] {
        margin: 0 0 24px;
        width: 100%;
    }

    .h2 {
        font-size: 20px;
        line-height: 52px;
    }
    
    .txt--lrg {
        font-size: 14px;
        line-height: 16px;
    }

    .philosophy {
        padding: 32px 34px 0;
    }

    .philosophy__cards,
    .cost__cards {
        flex-direction: column;
    }

    .philosophy__cards > li,
    .cost__cards > li {
        width: 100%;
        padding: 0 0 16px;
    }

    .cost {
        padding: 16px 40px 0;
    }

    .time {
        padding: 16px 34px 0;
        flex-direction: column;
    }

    .time__table {
        flex-direction: column;
        padding: 48px 22px;
    }

    .time__table > ul {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid #889996;
    }

    .time__table > ul:last-child {
        border-bottom: none;
    }

    .time__table li:first-child { 
        padding-top: 12px;
    }

    .fifty-fifty {
        flex-direction: column;
        padding: 32px 23px 0;
    }

    .fifty-fifty > li > img {
        width: 100%;
        margin: 0 0 16px;
    }

    .fifty-fifty > li > a {
        margin: 0;
    }

    .fifty-fifty--mobile-invert {
        flex-direction: column-reverse;
    }

    .mobile {
        display: block;
    }

    .mobile--inline {
        display: inline-block;
    }

    .desktop {
        display: none;
    }

    .bg--grey {
        padding: 32px 28px;
        margin-top: 32px;
    }

    .in-touch {
        flex-direction: column;
    }

    .in-touch > li > h1 {
        font-size: 20px;
        line-height: 30px;
    }

    .in-touch__card > h2 {
        font-size: 20px;
        line-height: 30px;
    }

    .in-touch__card > p,
    .in-touch__card > a {
        font-size: 14px;
        line-height: 21px;
    }

    .footer {
        padding: 22px 29px 32px;
        justify-content: space-between;
        flex-wrap: wrap;
    }

    .footer > nav {
        flex-direction: column;
    }

    .footer > nav > a {
        margin: 4px 0;
        text-align: right;
    }

    .footer__social {
        width: 100%;
        margin: 0;
        align-items: center;
        text-align: center;
    }

    .terms {
        padding: 0 16px 32px;
    }

    .terms > h1 {
        font-size: 24px;
        line-height: 65px;
        margin: 0;
    }

    .terms > h2 {
        font-size: 20px;
        line-height: 52px;
        margin: 8px 0;
    }
}