/* DEFAULT */
html,
body {
	margin: 0;
	padding: 0;
	color: #0b5394;
	font-family: 'Lato', sans-serif;
}

h1, 
h2, 
h3, 
h4, 
h5 {
	font-family: 'Ubuntu', sans-serif;
	margin: 0;
}

p:first-child {
	margin-top: 0;
}

p:last-child {
	margin-bottom: 0;
}

a {
	color: #0b5394;
}

/* STRUCTURE */
.wrapper,
.build-details {
	width: 100%;
	font-size: 18px;
}

.module,
.module .inner{
	width: 100%;
	max-width: 1366px;
	margin: 0 auto;
}

.module.full {
	max-width: none;
}

.flex-row {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.flex-row .flex-col {
	flex: 1;
}

/* COMMON STYLES */
.mobile-only {
	display: none;
}

.button {
	display: inline-block;
	color: #00124a;
	text-decoration: none;
	font-size: 16px;
	background-color: #f4cf03;
	border-radius: 25px;
	padding: 10px 20px;
}

/* HOME - HERO MODULE */
.module.hero {
	position: relative;
}
		
.module.hero img {
	width: 100%;
}
		
.module.hero .headline {
	position: absolute;
	left: 10%;
	top: 8%;
	color: #ffffff;
}
		
.module.hero .headline h1 {
	font-size: 72px;
	width: 60%;
	margin: 0;
}
		
.module.hero .headline h2 {
	font-family: 'Lato', sans-serif;
	font-size: 27px;
	width: 41%;
	margin: 0;
}
		
.module.hero .callout {
	position: absolute;
	z-index: 5;
	left: 10%;
	bottom: 20%;
	width: 285px;
	color: #00124a;
	font-weight: bold;
	font-size: 24px;
}

.module.hero .callout p {
	font-weight: 900;
}

.module.hero .callout p:first-child {
	margin-top: 0;
}

/* HOME - SIMPLE TEXT MODULE */
.module.simple-text {
	font-family: 'Ubuntu', sans-serif;
	text-align: center;
	color: #0b5394;
	font-size: 42px;
	line-height: 52px;
}

.module.simple-text .inner {
	padding: 50px 20%;
	width: 60%;
	max-width: 820px;
}

/* HOME - ICONS 4 MODULE */
.module.icons-4 {
	background-color: #f0f8fe;
	color: #0b5394;
}

.module.icons-4 .inner {
	padding: 50px 20%;
	width: 60%;
	max-width: 860px;
}

.module.icons-4 h3 {
	font-family: 'Lato', sans-serif;
	font-size: 30px;
	text-align: center;
	font-weight: normal;
	margin-bottom: 50px
}

.module.icons-4 h5 {
	font-size: 24px;
	margin: 20px 0 10px 0;
}

.module.icons-4 .flex-row {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	justify-content: space-between;
}

.module.icons-4 .flex-row .flex-col {
	flex: 1;
	text-align: center;
}

.module.icons-4 .flex-row .flex-col img {
	width: 80%;
}

/* HOME - 1 COLUMN AND 2 COLUMN MODULE */
.module.one-and-two {
	background-color: #f4cf03;
	color: #0b5394;
}

.module.one-and-two .inner {
	padding: 80px 10%;
	width: 80%;
	max-width: 1060px;
}

.module.one-and-two h3 {
	font-size: 72px;
	text-align: center;
	margin: 0 auto 30px 0;
}

.module.one-and-two .col-1 {
	flex-basis: calc(33.33% - 60px);
	padding-right: 60px;
}

.module.one-and-two .col-2 {
	flex-basis: calc(66.66% - 63px);
	padding-left: 60px;
	border-left: 3px solid #0b5394;
}

.module.one-and-two h4 {
	font-size: 24px;
	font-family: 'Lato', sans-serif;
	margin-bottom: 34px;
}

.module.one-and-two .items {
	display: flex;
	flex-wrap: wrap;
}

.module.one-and-two .items .item {
	flex: 1;
	flex-basis: 50%;
}

.module.one-and-two .items .item:nth-child(odd) {
	flex-basis: calc(50% - 10px);
	padding-right: 10px;
	padding-bottom: 20px;
}

.module.one-and-two .items .item:nth-child(even) {
	flex-basis: calc(50% - 10px);
	padding-left: 10px;
}

/* HOME - MAP MODULE */
.module.map {
	background: url("images/map-bg.png") no-repeat center center;
	background-size: cover;
}

.module.map .inner {
	padding: 85px 6% 100px 6%;
	width: 78%;
	max-width: 1060px;
}

.module.map .map-container {
	max-width: 666px;
	margin: 0 auto;
}

.module.map h3 {
	color: #ffffff;
	font-size: 48px;
	text-align: center;
	margin-bottom: 78px;
}

/* HOME - TWO BOX MODULE */
.module.two-box {
	background: linear-gradient(to right, #ffffff 0%,#ffffff 60%,#f0f8fe 60%,#f0f8fe 100%);
}

.module.two-box .inner {
	padding: 0;
	width: 78%;
	max-width: 1060px;
}

.module.two-box h3 {
	font-size: 48px;
	margin-bottom: 45px;
}

.module.two-box h4 {
	font-size: 24px;
	font-family: 'Lato', sans-serif;
}

.module.two-box .flex-row .flex-col {
	padding-top: 100px;
	padding-bottom: 110px;
	
}

.module.two-box .flex-row .flex-col.col-1 {
	flex-basis: calc(60% - 60px);
	padding-right: 60px;

}

.module.two-box .flex-row .flex-col.col-2 {
	padding-left: 130px;
	background-color: #f0f8fe;
	flex-basis: calc(40% - 130px);
}

.module.two-box .quote {
	position: relative;
}

.module.two-box .quote::before {
	content: '';
	position: absolute;
	top: -8px;
	left: -47px;
	width: 32px;
	height: 31px;
	background: url("images/quote-open.png") no-repeat top left;
}

.module.two-box .quote::after {
	content: '';
	position: absolute;
	bottom: -14px;
	right: -34px;
	width: 31px;
	height: 31px;
	background: url("images/quote-close.png") no-repeat top left;
}

.module.two-box .quote + cite {
	display: block;
	padding-top: 30px;
	font-style: normal;
}

/* HOME - FORM MODULE */
.module.form {
	position: relative;
	z-index: 10;
	margin-top: -90px;
	background: url("images/form-bg.png") no-repeat top center;
	background-size: cover;
	
}

.module.form .inner {
	padding: 150px 10% 80px 10%;
	width: 80%;
	max-width: 800px;
}

.module.form h3 {
	color: #f4cf03;
	font-size: 60px;
	text-align: center;
	margin-bottom: 50px;
}

.module.form .form-container {
	width: calc(100% - 180px);
	max-width: 480px;
	padding: 38px 90px;
	margin: 0 auto;
	background-color: #05326e;
	border-radius: 25px;
}

.module.form .form-container .form-intro {
	color: #ffffff;
	font-size: 30px;
	font-weight: 900;
}

.module.faq {
	font-size: 24px;
	font-weight: bold;
}

.module.simple-text.faq .inner {
	padding-top: 38px;
	padding-bottom: 38px;
}

@media only screen and (max-width: 1200px) {
	.module.hero .headline h1 {
		font-size: 50px;
		width: 70%;
	}

	.module.hero .headline h2 {
		font-size: 18px;
		width: 41%;
	}
			
	.module.hero .callout {
		font-size: 18px;
		width: 200px;
		bottom: 20%;
	}
}
		
@media only screen and (max-width: 1024px) {
	.module.two-box {
		background: none #ffffff;
	}
	
	.module.two-box .flex-row {
		display: block;
	}
	
	.module.two-box .flex-row .flex-col {
		flex: none;
		width: 100%;
	}
	
	.module.two-box .inner {
		padding-top: 50px;
		padding-left: 0;
		padding-right: 0;
		width: 100%;
	}
	
	.module.two-box .flex-row .flex-col.col-1 {
		padding: 50px 15px;
		width: calc(100% - 30px);
	}
	
	.module.two-box .flex-row .flex-col.col-2 {
		padding: 50px 62px;
		width: calc(100% - 124px);
	}
	
	.module.two-box .flex-row .flex-col.col-2 .quote {
		width: 100%;
	}
	
	.module.form {
		margin-top: -45px;
	}
	
	.module.form .inner {
		padding-top: 100px;
		padding-left: 0;
		padding-right: 0;
		width: 100%;
	}
}
		
@media only screen 
  and (min-device-width: 320px) 
  and (max-device-width: 480px)
  and (-webkit-min-device-pixel-ratio: 2),
(min-device-width: 320px) 
  and (max-device-width: 568px)
  and (-webkit-min-device-pixel-ratio: 2),
(min-device-width: 375px) 
  and (max-device-width: 667px) 
  and (-webkit-min-device-pixel-ratio: 2), 
(min-device-width: 414px) 
  and (max-device-width: 736px) 
  and (-webkit-min-device-pixel-ratio: 3),
(min-device-width: 375px) 
  and (max-device-width: 667px) 
  and (-webkit-min-device-pixel-ratio: 2),
(max-width: 768px) {
	.mobile-only {
		display: block;
	}
	.desktop-only {
		display: none;
	}
	
	.module.hero .headline {
		left: 15px;
	}
	
	.module.hero .headline h1 {
		font-size: 40px;
		width: 100%;
	}
	
	.module.simple-text:not(.faq) .inner {
		font-size: 30px;
		line-height: 40px;
	}

	.module.hero .headline h2 {
		font-size: 18px;
		width: 70%;
	}
	
	.module.hero .callout {
		position: relative;
		left: auto;
		bottom: auto;
		padding: 15px;
		width: calc(100% - 30px);
		text-align: center;
		background-color: #5fa2d4;
	}
	
	.module.simple-text .inner,
	.module.icons-4 .inner,
	.module.one-and-two .inner,
	.module.map .inner,
	.module.form .inner {
		padding-top: 50px;
		padding-left: 15px;
		padding-right: 15px;
		width: calc(100% - 30px);
		max-width: none;
	}
	
	
	.module.icons-4 .flex-row {
		flex-wrap: wrap;
	}
	
	.module.icons-4 .flex-row .flex-col {
		flex-basis: 50%;
		text-align: center;
	}

	.module.icons-4 .flex-row .flex-col img {
		width: auto;
	}

	.module.one-and-two .col-1 {
		flex-basis: 100%;
		padding-right: 0;
		padding-bottom: 24px;
	}

	.module.one-and-two .col-2 {
		flex-basis: 100%;
		border-left: none;
		padding-left: 0;
	}
	
	.module.one-and-two h4 {
		margin-bottom: 16px;
	}
	
	.module.one-and-two .items .item {
		flex-basis: 100%;
		padding-bottom: 16px;
	}
	
	.module.one-and-two .items .item:nth-child(odd),
	.module.one-and-two .items .item:nth-child(even) {
		padding-left: 0;
		padding-right: 0;
		flex-basis: 100%
	}
}