* { margin: 0 auto; box-sizing: inherit; -webkit-font-smoothing: antialiased; }
body { position: relative; overflow-x: hidden;  color: #ffffff; font-size: 22px; background-color: #1a114a; background-image: url('images/Graphene-icon.svg'); background-size: 100% 100%; background-repeat: no-repeat; background-blend-mode: screen; }
body.thank-you { background-position: bottom left; background-repeat: no-repeat; background-size: 100% auto; height: 100vh; }
body:before { position: absolute; content: ''; width: 100%; height: 100%; background-color: rgba(27, 17, 74, 0.8); }

/* Fonts */
/* @font-face { font-family: 'Roobert'; src: url('fonts/roobert-regular.woff2') format('woff2'), url('fonts/roobert-regular.woff') format('woff'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'PP Hatton'; src: url('fonts/pp_hatton_medium.woff2') format('woff2'), url('fonts/pp_hatton_medium.woff') format('woff'); font-weight: 500; font-style: normal; font-display: swap; } */

/* Typography */
h1, h2, h3, h4, h5, h6 { font-family: Calibri, sans-serif; font-weight: 500; margin: 0 0 20px; color: #1b114a; }
p { color: #1b114a; font-family: Calibri, sans-serif; font-weight: 400; margin: 0 0 20px; letter-spacing: -0.44px; line-height: 1.3; }
h2 { font-size: 46px; letter-spacing: -0.92px; line-height: 1.4; }
h3 { font-size: 32px; letter-spacing: -0.92px; line-height: 1.3; }


/* Wrapper */
.o-wrapper { max-width: 1100px; margin: 0 auto; }
.o-wrapper--narrow { max-width: 850px; }
.c-main { padding: 0 0 150px 0; position: relative;  z-index: 1; }

/* Logo */
.c-logo { width: 50%; margin-bottom: 3.5rem; }
.c-logo__wrapper { display: flex; flex-flow: column; align-items: center; justify-content: flex-end; height: 30vh; position: relative; z-index: 1; }

/* Button */
.c-button { background-color: #4952A3; color: #fff; font-family: "Calibri", sans-serif; font-size: 22px; line-height: 1; font-weight: 400; letter-spacing: -0.44px; border: none; padding: 18px 64px 22px; display: inline-block; cursor: pointer; transition: .2s; border-radius: 6px; }
.c-button:hover { background-color: #1b114a; }

/* Form */
.c-contact-form__wrapper { background-color: #fff; border-radius: 10px; padding: 65px 50px 50px 50px; margin: 0 auto; border: 2px solid #CBD0D4; }
.c-contact-form__title { margin: 0 0 5px; }
.c-contact-form__content { margin: 0 0 50px; text-align: center; }
.c-contact-form__content p { margin-bottom: 0; }
.c-contact-form__form { padding: 0 60px; }
.c-contact-form__bottom { text-align: center; margin: 40px auto 0; }

/* Form Fields */
.o-input { border-radius: 6px; border: 2px solid #72889A; color: #72889A; padding: 18px 16px 20px 16px; display: block; background-color: #fff; font-family: "Calibri", sans-serif; font-size: 18px; line-height: 1; width: calc(100% - 32px); }
.o-input:focus { border-color: #4952A3; outline: 0; }
.o-input::placeholder { color: #CBD0D4; }
.o-input.error { border-color: #DF0000; }
.o-input--textarea { height: 80px; }
#contact_honeypot { display: none; }
.o-label { display: block; font-family: "Calibri",sans-serif; font-size: 16px; color: #72889A; padding: 1rem; position: absolute; display: none; }
.o-field { position: relative; margin: 0 0 20px; }

/* Form Errors */
span.error { display: none !important; }

/* Thank You */
.c-thank-you__wrapper { height: 100%; display: flex; align-items: center; justify-content: center; position: relative; }
.c-thank-you { background-color: #fff; border-radius: 10px; padding: 65px 50px 50px 50px; text-align: center; }
.c-thank-you__title { margin: 0 auto; }
.c-thank-you p { margin-bottom: 0; }

/* Responsive */

@media (max-width: 900px) {
    .o-wrapper--narrow { margin: 0 30px; }
}

@media (max-width: 700px) {
    .c-contact-form__form { padding: 0; }
    .c-logo { width: 80%; }
    .c-logo__wrapper { height: 20vh; }
}

@media (max-width: 560px) {
    h2 { font-size: 28px; line-height: 1.2; }
    body, p, .c-button { font-size: 18px; }
    .c-contact-form__wrapper { padding: 40px 30px; }
    .c-main { padding-bottom: 50px; }
    .o-field { margin-bottom: 15px; }
    .c-contact-form__content { margin-bottom: 30px; }
    .c-contact-form__bottom { margin-top: 30px; }
    .o-wrapper--narrow { margin: 0 20px; }
    .o-input { padding: 14px 14px 16px; font-size: 17px; }
    .c-thank-you { padding: 40px 30px; }
}