html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
a {
	text-decoration: none; 
}
em { 
	font-style: italic;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
a, input, textarea , .button {
	transition: all 0.1s;
	-moz-transition: all 0.1s;
	-webkit-transition: all 0.1s;
	-o-transition: all 0.1s;
}

body { font-family: 'Roboto'; }
#navigation { position: fixed; top: 80px; right: 80px; z-index: 9999; transition: top 0.3s; -moz-transition: top 0.3s; -webkit-transition: top 0.3s; -o-transition: top 0.3s; }
#navigation > ul { height: 60px; border-radius: 4px; overflow: hidden; }
#navigation > ul > li { display: block; float: left; }
#navigation > ul > li > a { display: block; height: 60px; font-family: 'Roboto'; font-size: 20px; line-height: 60px; color: #ffffff; padding: 0px 30px; background-color: #0047ba; }
#navigation > ul > li > a:hover { background-color: #ffffff; color: #0047ba;}
.onedge { top: 10px !important;}

#container { width: 100%; position: relative;}
#container > .section { width: 100%; height: 780px; position: relative; box-sizing: border-box; -moz-box-sizing: border-box; background-size: cover; background-repeat: no-repeat; background-position: center center; }
#container > .section > h1 { height: 80px; padding-left: 11%; font-size: 38px; line-height: 80px; color: #ffffff; background-color: #0047ba;}

#home {}
#home > #logo { width: 155px; height: 60px; position: absolute; top: 80px; left: 80px; background: url('../gfx/logo.png') no-repeat center center; }
#home > p { position: absolute; width: 60%; left: 7%; top: 35%; font-size: 48px; line-height: 64px; color: #ffffff; border-left: 21px solid #f04e6c; padding-left: 42px; font-weight: lighter;}
#home > #service-link { display: block; width: 200px; height: 60px; text-align: center; background-color: #0047ba; border: 0 none; border-radius: 4px; position: absolute; left: 11%; bottom: 27%; font-size: 20px; line-height: 60px; color: #ffffff;  }
#home > #service-link:hover { background-color: #ffffff; color: #0047ba;}

#about {}
#about > p { position: absolute; width: 45%; left: 7%; top: 26%; font-size: 30px; line-height: 40px; color: #0047ba; border-left: 21px solid #0047ba; padding-left: 42px; font-weight: lighter;}

#services { background-color: #ccdaf1; }
#services > .service-holder { width: 100%; height: 700px; }
#services > .service-holder > .service { width: 50%; height: 50%; box-sizing: border-box; -moz-box-sizing: border-box; float: left; position: relative; background-position: center center; background-size: cover; background-repeat: no-repeat;}
#services .service > h3 { font-size: 30px; line-height: 30px; color: #f04e6c; position: absolute; width: 50%; left: 44%; top: 5%; font-weight: normal;}
#services .service > p { font-size: 20px; line-height: 26px; font-weight: lighter; color: #0047ba; position: absolute; width: 50%; left: 44%; top: 25%;}

#container > #contact.section { height: 1100px; }
#contact > .form-holder { width: 50%; padding-top: 30px; padding-bottom: 30px; float: left; overflow: auto;}
#contact > .form-holder > form { display: block; width: 80%; margin: 0 auto;}
#contact input, #contact textarea { display: block; width: 100%; padding: 10px 20px; box-sizing: border-box; -moz-box-sizing: border-box; margin-bottom: 10px; border: 1px solid #bfd1ee; border-radius: 4px; outline: none; background-color: #ffffff; font-size: 20px; line-height: 20px; color: #bfd1ee; resize: none;}
#contact input:focus, #contact textarea:focus { background-color: #e5ecf8; color: #2a51a3; }
#contact .button { width: 20%; height: 75px; font-size: 20px; line-height: 20px; color: #ffffff; background-color: #f04e6c; border: 0 none; border-radius: 4px; position: absolute; left: 30%; bottom: 618px; margin-top: 0px; cursor: pointer;}
#contact .button:hover { background-color: #f47a91;}
#contact > .info-holder { width: 50%; padding-top: 50px; padding-bottom: 50px; float: left; overflow: auto;}
#contact > .info-holder > ul { display: block; width: 80%; margin: 0 auto;}
#contact > .info-holder > ul > li { font-size: 20px; line-height: 26px; color: #2a51a3; padding-left: 50px; padding-bottom: 60px; background-repeat: no-repeat; }
#contact > .info-holder > ul > li.email { background-image: url('assets/gfx/email.png'); background-position: 0px 0px;}
#contact > .info-holder > ul > li.tel { background-image: url('assets/gfx/tel.png'); background-position: 0px 0px;}
#contact > .info-holder > ul > li.address { background-image: url('assets/gfx/address.png'); background-position: 6px 0px;}
#contact #map_canvas { width: 100%; height: 500px; box-sizing: border-box; -moz-box-sizing: border-box; position: absolute; bottom: 80px;}
#contact > .footer-band { width: 100%; height: 80px; box-sizing: border-box; -moz-box-sizing: border-box; position: absolute; bottom: 0px; }
#contact > .footer-band > p { padding-left: 12%; font-size: 14px; line-height: 80px; color: #0047ba; font-weight: lighter;}

.g-recaptcha {
	width: 100%;
}

#form-result {
    position: fixed;
    top: 0px;
    left: 0px;
    right: 0px;
    bottom: 0px;
    z-index: 9999;
    background-color: rgba(0, 0, 0, 0.7);
    display: none; }
#form-result .alert-holder {
    width: 400px;
    height: 200px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -200px;
    margin-top: -100px;
    background-color: #ffffff;
    display: table;
    padding: 20px; }
#form-result .alert-holder p {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
    font-size: 20px;
    line-height: 28px;
    color: #004d8d; }
@media only screen and (min-width: 961px) and (max-width: 1200px){
	#home > p { font-size: 44px; width: 70%; }
	#about > p { font-size: 24px; line-height: 32px; }
	#services .service > p { font-size: 17px; line-height: 26px;}
	#services .service > h3 { font-size: 24px; line-height: 30px;}

	#container > #contact.section { height: 1184px;}

}

@media only screen and (max-width: 960px){
	#container { width: 960px;}
	#navigation { right: 10px;}
	#home > p { font-size: 34px; width: 70%; }
	#about > p { font-size: 20px; line-height: 30px;}
	#services .service > p { font-size: 16px; line-height: 24px; }
	#services .service > h3 { font-size: 20px; line-height: 26px;}
	#contact > .info-holder > ul > li { font-size: 18px;}
	

}




















