/* Basic */
html, body {
  overflow-x: hidden;
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

section {
  margin-bottom: 120px; }
  section:last-of-type {
    margin-bottom: 0; }

html {
  scroll-behavior: smooth; }

/* Fonts */
h1, h2 {
  font-family: "Vollkorn", serif;
  color: #02066E;
  font-weight: 700;
  margin: 0; }

h1 {
  font-size: 58px;
  line-height: 64px; }

h2 {
  font-size: 38px;
  line-height: 44px; }

h3 {
  font-family: "Open Sans", sans-serif;
  font-size: 20px;
  color: #02066E;
  letter-spacing: 0;
  line-height: 28px;
  margin: 0; }

p {
  font-family: "Open Sans", sans-serif;
  font-size: 18px;
  color: #131415;
  line-height: 32px;
  font-weight: 400;
  margin: 15px 0 0 0; }
  p strong {
    font-weight: 700; }

/* Buttons / Links */
a {
  text-decoration: none;
  color: #055FFB;
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  transition: all .3s ease-in-out; }
  a:hover {
    color: #02066E; }

.btn {
  background: #055FFB;
  border: 1px solid #055FFB;
  border-radius: 4px;
  font-size: 16px;
  color: #FFFFFF;
  text-align: center;
  line-height: 16px;
  padding: 21px;
  transition: all .3s ease-in-out;
  margin: 40px 0 0 0;
  width: 197px;
  font-weight: 700; }
  .btn:hover {
    background-color: #02066E;
    border-color: #02066E;
    color: #FFFFFF; }

.btn-link {
  background: none;
  border-radius: 4px;
  font-size: 16px;
  text-align: center;
  line-height: 16px;
  padding: 21px;
  transition: all .3s ease-in-out;
  margin: 40px 0 0 30px;
  font-weight: 700; }

/* Hero */
#hero {
  background-color: #F4F9FE;
  padding: 140px 0; }
  #hero .keyvisual {
    position: absolute;
    top: 0;
    right: 0;
    width: 44vw;
    height: auto; }
    @media (max-width: 1600px) {
      #hero .keyvisual {
        width: 54vw !important; } }
    @media (max-width: 1200px) {
      #hero .keyvisual {
        width: 65vw !important;
        right: -150px; } }
    @media (max-width: 992px) {
      #hero .keyvisual {
        display: none; } }
  #hero .keyvisual-mobile {
    margin: -200px -130px 0 0;
    width: 100%;
    float: right; }
    @media (max-width: 576px) {
      #hero .keyvisual-mobile {
        margin: -200px -60px 0 0 !important; } }

@media (min-width: 992px) {
  .hide-row {
    display: none; } }

/* Cards */
.cards {
  margin-top: 30px; }
  .cards .card {
    background: #F4F9FE;
    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.08);
    border-radius: 10px;
    padding: 40px;
    margin: 30px 0 0 0; }
    .cards .card p {
      font-size: 16px;
      line-height: 26px; }

/* Formats */
#formats {
  background-color: #F4F9FE;
  padding: 120px 0;
  text-align: center; }
  #formats p {
    font-size: 14px;
    line-height: 20px; }
  #formats .icon {
    margin: 80px 0 20px -30px; }
  #formats .btn {
    margin: 80px 0 0 0; }

/* Contact */
#contact h2 {
  text-align: center;
  margin-bottom: 40px; }

#contact p {
  font-size: 14px;
  line-height: 20px; }
  #contact p a {
    font-size: 14px;
    line-height: 20px; }

#contact .required {
  float: right; }

#contact .btn {
  margin-top: 80px; }

#contact .privacy {
  margin: 30px 0 0 0; }

#contact .form-error,
#contact .form-success {
  display: none; }

/* Input */
input[type=text], textarea {
  background: #E7EFFF;
  border: none;
  border-radius: 4px;
  width: 100%;
  height: 58px;
  font-family: "Open Sans", sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: #02066E;
  padding: 21px 18px;
  margin: 30px 0 0 0; }

textarea {
  height: 180px; }

input[type='checkbox'] {
  -webkit-appearance: none;
  border: 0;
  background-color: #E7EFFF;
  border-radius: 4px;
  height: 30px;
  width: 30px;
  margin: 10px 10px 0 0; }
  input[type='checkbox']:checked {
    background-image: url(/assets/img/icons/icon-checkmark.svg);
    background-size: 24px 18px;
    background-position: center center;
    background-repeat: no-repeat; }

::placeholder {
  color: #131415;
  opacity: 1; }

:-ms-input-placeholder {
  color: #131415; }

::-ms-input-placeholder {
  color: #131415; }

.form-success, form-error {
  margin: 60px 0 0 0; }
  .form-success h3, form-error h3 {
    text-align: center; }

.form-error h3 {
  color: #FF2327;
  text-align: center; }

.hidden-fields {
  opacity: 0;
  height: 1px;
  overflow: hidden; }
  .hidden-fields input {
    font-size: 1px;
    line-height: 1px;
    height: 1px; }

/* Address */
#address {
  background-color: #055FFB;
  padding: 50px 0; }
  #address p {
    font-size: 14px;
    color: #F4F9FE;
    line-height: 20px; }
  #address a[href*="mailto"] {
    color: inherit;
    font-size: inherit; }

/* Footer */
footer {
  padding: 20px 0; }
  footer p {
    margin: 0;
    font-size: 14px;
    line-height: 20px; }
  footer a {
    text-align: center;
    margin-left: 50px; }
  @media (max-width: 992px) {
    footer p {
      text-align: center;
      margin: 20px 0; }
    footer a {
      display: block;
      margin: 20px 0; } }
