@font-face { font-family: 'DINRoundPro'; src: url("/assets/fonts/DINRoundPro-Bold.woff2") format("woff2"), url("/assets/fonts/DINRoundPro-Bold.woff") format("woff"); font-weight: bold; font-style: normal; font-display: swap; }

@font-face { font-family: 'DINRoundPro'; src: url("/assets/fonts/DINRoundPro.woff2") format("woff2"), url("/assets/fonts/DINRoundPro.woff") format("woff"); font-weight: normal; font-style: normal; font-display: swap; }

@font-face { font-family: 'DINRoundPro'; src: url("/assets/fonts/DINRoundPro-Medi.woff2") format("woff2"), url("/assets/fonts/DINRoundPro-Medi.woff") format("woff"); font-weight: 500; font-style: normal; font-display: swap; }

body { font-family: 'DINRoundPro', sans-serif; background: #fffdfc; font-size: 16px; min-width: 360px; max-width: 1800px; margin: 0 auto; color: #00215a; position: relative; }

main { position: relative; background: #fffdfc; z-index: 1; }

section { position: relative; margin-top: 0; }

h1, h2, h3, h4, h5 { font-weight: bold; line-height: 1em; text-transform: uppercase; color: #0059a7; }

h1 { font-size: 32px; }

h2 { font-size: 24px; margin: 0 0 0.5em; }

h3 { font-size: 18px; font-weight: 700; margin-top: 2em; }

h4 { font-size: 16px; font-weight: 700; }

@media screen and (min-width: 576px) { h1 { font-size: 40px; }
  h2 { font-size: 30px; }
  h3 { font-size: 22px; }
  h4 { font-size: 17px; } }

@media screen and (min-width: 758px) { h1 { font-size: 48px; }
  h2 { font-size: 38px; }
  h3 { font-size: 26px; }
  h4 { font-size: 18px; } }

li { font-weight: 400; }

p { font-size: 16px; line-height: 1.3em; font-weight: 400; }

a, a:link, a:visited, a:active, a:hover { color: inherit; text-decoration: none; }

a[href^='mailto:'] { text-decoration: underline; font-weight: 600; }

a.text-link { color: #000e27; text-decoration: underline; text-transform: uppercase; }

figure { margin: 0 0 1em; }

img { max-width: 100%; }

address { line-height: 1.2em; margin: 0 0 20px; }

.hidden { display: none !important; }

.underline { box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.3); }

::-moz-selection { color: inherit; background: rgba(0, 0, 0, 0.1); }

::selection { color: inherit; background: rgba(0, 0, 0, 0.1); }

header { background-color: #fffdfc; position: absolute; z-index: 1; top: 0; width: 100%; margin: 0; -webkit-transform-origin: top left; transform-origin: top left; -webkit-transform: skew(0deg, -3deg); transform: skew(0deg, -3deg); height: 130px; }

@media screen and (min-width: 576px) { header { height: 150px; } }

@media screen and (min-width: 768px) { header { height: 170px; } }

header h1 { margin: 0; }

header .logo { position: absolute; top: 0; left: 0; height: 100%; }

header .logo img { height: 100%; padding: 15px 20px; }

header nav { position: relative; top: 130px; }

@media screen and (min-width: 576px) { header nav { top: 150px; } }

@media screen and (min-width: 768px) { header nav { top: 170px; } }

header nav ul { margin: 0; padding: 0; }

header nav ul li { list-style: none; padding: 0; margin: 10px 0; }

header nav ul li > a { background-color: #fffdfc; line-height: 1em; display: inline-block; padding: 7px 10px 9px 30px; font-size: 21px; text-transform: uppercase; font-weight: 500; -webkit-transition: padding-left 75ms ease-out 0s; transition: padding-left 75ms ease-out 0s; }

@media screen and (min-width: 576px) { header nav ul li > a { font-size: 28px; padding: 6px 10px 8px 30px; } }

@media screen and (min-width: 768px) { header nav ul li > a { font-size: 36px; padding: 5px 10px 7px 30px; } }

header nav ul li > a:link, header nav ul li > a:visited, header nav ul li > a:active { color: #ff8e14; }

header nav ul li > a:hover { color: #0059a7; padding-left: calc(30px + 0.5em); -webkit-transition: padding-left 200ms ease 0s; transition: padding-left 200ms ease 0s; }

#hero { position: relative; height: 102vh; min-height: 495px; width: 100%; overflow: hidden; background-color: #ffece3; }

@media screen and (min-width: 576px) { #hero { min-height: 545px; } }

@media screen and (min-width: 768px) { #hero { min-height: 595px; } }

#hero:after { content: ' '; display: block; position: absolute; z-index: 1; bottom: calc(30px - 100vh); height: 100vh; width: 100%; -webkit-transform-origin: top right; transform-origin: top right; -webkit-transform: skew(0deg, 3deg); transform: skew(0deg, 3deg); background-color: #fffdfc; }

#hero > video { position: fixed; top: 50%; left: 50%; min-width: 100%; min-height: 100%; width: auto; height: auto; z-index: 0; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }

@media screen and (min-width: 1800px) { #hero > video { position: absolute; } }

@media screen and (max-width: 360px) { #hero > video { position: absolute; } }

footer { display: inline-block; position: relative; margin: 0; background-color: #0059a7; color: white; width: 100%; padding: 30px 30px 10px; }

footer p, footer address { text-align: center; }

footer .watusi { display: none; }

#backToTop { background-color: #0059a7; }

#backToTop a { display: block; font-size: 20px; text-transform: uppercase; font-weight: 500; line-height: 1em; text-align: center; white-space: nowrap; padding: 20px 8px 20px 8px; }

#backToTop a:before { content: "\25B2"; font-size: 70%; position: relative; top: -0.2em; }

#backToTop a:link, #backToTop a:visited, #backToTop a:active { color: #ff8e14; }

#backToTop a:hover { color: white; }

@media screen and (min-width: 576px) { footer p, footer address { text-align: right; }
  footer .watusi { display: block; opacity: 0.85; position: absolute; -webkit-transform: rotate(-10deg) translateY(-50%); transform: rotate(-10deg) translateY(-50%); font: 0/0 a; text-shadow: none; color: transparent; top: 50%; left: 60px; width: 110px; height: 110px; background-image: url("/assets/img/watusi400x400.png"); background-size: 105% 105%; background-position: center center; border: 3px solid white; border-radius: 50%; -webkit-transition: opacity 200ms, -webkit-transform 400ms; transition: opacity 200ms, -webkit-transform 400ms; transition: transform 400ms, opacity 200ms; transition: transform 400ms, opacity 200ms, -webkit-transform 400ms; }
  footer .watusi:hover { -webkit-transform: rotate(10deg) translateY(-50%); transform: rotate(10deg) translateY(-50%); }
  #backToTop { position: fixed; border-radius: 0 4px 4px 0; z-index: 10; top: 100%; }
  #backToTop a { -webkit-writing-mode: vertical-rl; -ms-writing-mode: tb-rl; writing-mode: vertical-rl; height: 200px; width: 36px; -webkit-transition: width 200ms; transition: width 200ms; }
  #backToTop a:hover { width: 50px; } }

@media screen and (max-width: 575px) { #backToTop { width: 100%; -webkit-transform: translateY(0) !important; transform: translateY(0) !important; }
  #backToTop a:before { left: -0.4em; } }

section { height: 0; overflow: hidden; }

section > .container { opacity: 0; -webkit-transition: opacity 0s linear 0s; transition: opacity 0s linear 0s; padding: 30px 35px 100px; }

section.displayed { height: auto; min-height: 30vh; }

section.displayed > .container { opacity: 1; -webkit-transition-duration: 200ms; transition-duration: 200ms; -webkit-transition-delay: 500ms; transition-delay: 500ms; }

#phoneNumber { z-index: 2; display: block; text-align: center; right: 0; position: -webkit-sticky; position: sticky; bottom: 0; background-color: #ff8e14; padding: 10px 15px; -webkit-transform-origin: top right; transform-origin: top right; cursor: default; }

@media screen and (min-width: 576px) { #phoneNumber { position: absolute; top: calc(101px - 5vw); bottom: auto; -webkit-transform: skew(0deg, -3deg); transform: skew(0deg, -3deg); padding: 10px 30px 10px 12px; } }

@media screen and (min-width: 768px) { #phoneNumber { top: calc(111px - 5vw); } }

@media screen and (min-width: 1800px) { #phoneNumber { top: 21px; } }

#phoneNumber > i { display: inline-block; vertical-align: text-top; margin-right: 5px; background-image: url("/assets/img/icon-phone.png"); background-size: contain; background-repeat: no-repeat; background-position: left center; width: 40px; height: 40px; }

@media screen and (min-width: 576px) { #phoneNumber > i { width: 30px; height: 30px; } }

@media screen and (min-width: 768px) { #phoneNumber > i { width: 40px; height: 40px; } }

#phoneNumber span { display: inline-block; position: relative; top: -0.05em; vertical-align: text-top; line-height: 1em; color: white; font-weight: 500; padding: 0; font-size: 40px; }

@media screen and (min-width: 576px) { #phoneNumber span { font-size: 30px; } }

@media screen and (min-width: 768px) { #phoneNumber span { font-size: 40px; } }

@-webkit-keyframes rotatePhone { from { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  to { -webkit-transform: rotate(90deg); transform: rotate(90deg); } }

@keyframes rotatePhone { from { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  to { -webkit-transform: rotate(90deg); transform: rotate(90deg); } }

@media screen and (max-width: 828px) { .touch #phoneNumber > i { -webkit-animation-duration: 250ms; animation-duration: 250ms; -webkit-animation-name: rotatePhone; animation-name: rotatePhone; -webkit-animation-timing-function: ease-in-out; animation-timing-function: ease-in-out; -webkit-animation-iteration-count: infinite; animation-iteration-count: infinite; -webkit-animation-direction: alternate; animation-direction: alternate; } }

.download-plan, .call-to-action { width: 100%; }

.download-plan a, .call-to-action a { position: relative; text-decoration: none; top: 0; width: 100%; display: block; background-color: white; border: 3px dashed #ff8e14; padding: 10px 15px; border-radius: 4px; -webkit-transition: background-color 300ms; transition: background-color 300ms; }

.download-plan a:hover, .call-to-action a:hover { border-color: #0059a7; }

.download-plan a > span, .call-to-action a > span { display: inline-block; position: relative; top: -0.05em; vertical-align: middle; line-height: 1em; color: #0059a7; font-weight: 700; padding: 0; font-size: calc(7px + 2vw); margin-left: 5px; }

@media screen and (min-width: 576px) { .download-plan a > span, .call-to-action a > span { font-size: 21px; margin-left: 10px; } }

.download-plan a > i, .call-to-action a > i { display: inline-block; vertical-align: middle; background-size: contain; background-repeat: no-repeat; background-position: left center; }

.download-plan a { max-width: 400px; margin-top: 40px; }

.download-plan a > i { width: 40px; height: 40px; background-image: url("/assets/img/icon-pdf.png"); }

.call-to-action a { margin: 40px auto 100px; }

.call-to-action a > i { width: 40px; height: 40px; background-image: url("/assets/img/icon-envelope.png"); }

.call-to-action a:after { content: ' '; display: block; position: absolute; top: calc(50% + 15px); right: 0; height: 200px; width: 200px; background-image: url("/assets/img/call-to-action.png"); background-size: cover; background-position: center center; }

@media screen and (min-width: 576px) { .call-to-action a:after { right: auto; left: 50%; } }

@media screen and (min-width: 768px) and (max-width: 991px) { .shift-up-md-150 { margin-top: -150px; } }

@media screen and (min-width: 992px) and (max-width: 1199px) { .shift-up-lg-150 { margin-top: -150px; } }

@media screen and (min-width: 1200px) { .shift-up-xl-150 { margin-top: -150px; } }
