/* CSS Document - use this a starting template for respsonsive */
/* updated to common sized Nov 2017 */
/************************************************************************************
	max width 1680 - desktop
*************************************************************************************/
@media screen and (max-width: 1680px) {
	
.contact_sticky_btn .midline {
    font-size: 1.4em;
}	
	
.hp-tagline2 {
    font-size: 2.4em;
}	
	
.page_container .page_wrap {
    padding: 2% 8% 2% 2%;
}
	
}

/************************************************************************************
	max width 1440 - desktop
*************************************************************************************/
@media screen and (max-width: 1440px) {

.hp-titlebox {
    width: 70vw;
    left: 15vw;
}

.contact_sticky_btn .bottomline {
    font-size: 0.8em;
}	
	
.header .navbar {
    width: 60%;
}	
	
.header .contactside {
    width: 20%;
}	

.services_wrap {
    margin: 20vh 10vw 0px 10%;
}	
	
.form-block-nb {
    flex-direction: column;
}	
	
.form-block-nb input[type="submit"] {
    width: 62%;
}	
	
	
}

/************************************************************************************
	max width 1440 x max height 900 laptop / tablet
*************************************************************************************/
@media screen and (max-width: 1440px) and (max-height: 900px) {

	
}

/************************************************************************************
	max width 1366 - desktop / laptop
*************************************************************************************/
@media screen and (max-width: 1366px) {
	
.form-block-nb input[type="submit"] {
    width: 100%;
	margin-top: 5px;
}
	
}

/************************************************************************************
	max width 1366 x max height 1024 laptop / tablet
*************************************************************************************/
@media screen and (max-width: 1366px) and (max-height: 1024px) {

	
}

/************************************************************************************
	max width 1366 x max height 768 laptop / tablet
*************************************************************************************/
@media screen and (max-width: 1366px) and (max-height: 768px) {

.contact_sticky_btn .midline {
    font-size: 1.2em;
}
	
}

/************************************************************************************
	max width 1280 - desktop / laptop
*************************************************************************************/
@media screen and (max-width: 1280px) {

.contact_sticky_btn .topline {
	display: none;
}	
	
.contact_sticky_btn .bottomline {
	display: none;
}	
	
.contact_sticky_btn .midline {
    font-size: 1.2em;
}	
	
.contact_sticky_btn {
    top: calc(100vh - 95px);
    height: 95px;
}
	
}
	
/************************************************************************************
	max width 1280 x 1024 - desktop / laptop
*************************************************************************************/
@media screen and (max-width: 1280px) and (max-height: 1024px) {

	
}

/************************************************************************************
	max width 1280 x 800 - desktop / laptop
*************************************************************************************/
@media screen and (max-width: 1280px) and (max-height: 800px) {

}

/************************************************************************************
	max width 1140 - desktop / laptop
*************************************************************************************/
@media screen and (max-width: 1140px) {

.header .contactside {
    width: 23%;
}	
	
.form_wrap {
    width: 60%;
}
	
.contact_wrap .address_block {
    width: 37%;
}	

.contact_wrap .address_block .title {
	line-height: 1em;
}	

.contact_sticky_btn {
    padding: 12px 11px 10px;
}
	
}

/************************************************************************************
	max width 1024 x max height 900 laptop / tablet
*************************************************************************************/
@media screen and (max-width: 1140px) and (max-height: 900px) {

	
}

/************************************************************************************
	max width 1024 - laptop / tablet
*************************************************************************************/
@media screen and (max-width: 1024px) {

.hp-titlebox {
    width: 80vw;
    left: 10vw;
}	
	
.contact_wrap {
	flex-direction: column;
}	
	
.form_wrap {
    width: 100%;
	margin-bottom: 15px;
}	
	
.form-block .form-row .form-input {
    width: 65%;
}	
	
.form-block .form-row .form-label {
    width: 34%;
    padding-right: 4%;
}	
	
.form-block-nb .g-recaptcha {
    width: 50%;
	padding-left: 25%;
}	
	
.contact_wrap .address_block {
    width: 100%;
	text-align: center;
}	
	
.contact_wrap .address_block .socialline {
    justify-content: center;
}	
	
}

/************************************************************************************
	max width 1024 x max height 1366 - iPad
*************************************************************************************/
@media screen and (max-width: 1024px) and (max-height: 1366px) {
	
}

/************************************************************************************
	max width 1024 x max height 768 laptop / tablet
*************************************************************************************/
@media screen and (max-width: 1024px) and (max-height: 768px) {

.page_container {
    padding: 60px 10% 10% 10%;
}	
	
	
}

/************************************************************************************
	max width 1024 x max height 640 laptop / tablet
*************************************************************************************/
@media screen and (max-width: 1024px) and (max-height: 640px) {

	
}


/************************************************************************************
	max width 812 x max height 375 - iPhone X 
*************************************************************************************/
@media screen and (max-width: 812px) and (max-height: 375px) {

.header .navbar {
	display: none;
}

.header .mobile_nav {
	display: block;
}
	
.header {
    height: 70px;
}

.hbg {
    height: 70px;
}	
	
.header .toplogo {
    width: 32%;
	margin-left: 6%;
}	
	
.header .contactside {
    width: 40%;
}	
	
.contact_sticky_btn {
    display: none;
}	

.hp_logo {
    top: 25vh;
    width: 80vw;
    left: 10vw;
    height: 32vh;
}

.hp-tagline2 {
    font-size: 1.8em;
}	
	
#scroll_down_btn {
    font-size: 1em;
}	
	
.section_header_text {
    font-size: 1.2em;
}	

.section_top-logo {
    height: 130px;
}	
	
.cta_wrap .page_text {
    font-size: 1em;
}	

.contentblock .page_wrap .page_text {
    font-size: 1em;
}	

.services_wrap .service_line .service_name {
    font-size: 1em;
}	
	
.services_wrap {
    margin: 8vh 10vw 0px 10%;
}	
	
.page_container .page_wrap .page_text {
    font-size: 1em;
}	
	
}

/************************************************************************************
	max width 800 - laptop / tablet
*************************************************************************************/
@media screen and (max-width: 800px) {

}

/************************************************************************************
	max width 768 - laptop / tablet
*************************************************************************************/
@media screen and (max-width: 768px) {

	
}

/************************************************************************************
	max width 768 x max height 1024 - iPad
*************************************************************************************/
@media screen and (max-width: 768px) and (max-height: 1024px) {

.header .navbar {
	display: none;
}

.header .mobile_nav {
	display: block;
}
	
.header {
    height: 70px;
}

.hbg {
    height: 70px;
}	
	
.header .toplogo {
    width: 32%;
	margin-left: 6%;
}	
	
.header .contactside {
    width: 40%;
}	
	
.contact_sticky_btn {
    display: none;
}	

.hp_logo {
    top: 25vh;
    width: 80vw;
    left: 10vw;
    height: 32vh;
}

.hp-tagline2 {
    font-size: 1.8em;
}	
	
#scroll_down_btn {
    font-size: 1em;
}	
	
.section_header_text {
    font-size: 1.2em;
}	

.section_top-logo {
    height: 130px;
}	
	
.cta_wrap .page_text {
    font-size: 1em;
}	

.contentblock .page_wrap .page_text {
    font-size: 1em;
}	

.services_wrap .service_line .service_name {
    font-size: 1em;
}	
	
.services_wrap {
    margin: 8vh 10vw 0px 10%;
}	
	
.page_container .page_wrap .page_text {
    font-size: 1em;
}		
	
.page_container {
    padding: 48px 3% 10% 3%;
}	
	
}

/************************************************************************************
	max width 740 x max height 360 - S8
*************************************************************************************/
@media screen and (max-width: 740px) and (max-height: 360px) {

.page-grid-half {
    display: flex;
	flex-direction: column;
}

.page-grid-thirds {
    display: flex;
	flex-direction: column;
}
	
.page-row-container {
    display: flex;
	flex-direction: column;
}
	
.page-grid-firstthird {
    display: flex;
	flex-direction: column;
}

.page-grid-lastthird {
    display: flex;
	flex-direction: column;
}
	
	
}

/************************************************************************************
	max width 720 - laptop / tablet
*************************************************************************************/
@media screen and (max-width: 720px) {

}

/************************************************************************************
	max width 667 x max height 375 - phone
*************************************************************************************/
@media screen and (max-width: 667px) and (max-height: 375px) {

.page-grid-half {
    display: flex;
	flex-direction: column;
}

.page-grid-thirds {
    display: flex;
	flex-direction: column;
}
	
.page-row-container {
    display: flex;
	flex-direction: column;
}
	
.page-grid-firstthird {
    display: flex;
	flex-direction: column;
}

.page-grid-lastthird {
    display: flex;
	flex-direction: column;
}
	
	
}

/************************************************************************************
	max width 640 x max height 360 - S5 / S7
*************************************************************************************/
@media screen and (max-width: 640px) and (max-height: 360px) {

	
}

/************************************************************************************
	max width 600 - laptop / tablet
*************************************************************************************/
@media screen and (max-width: 600px) {

}

/************************************************************************************
	max width 568 x max height 320 - phone
*************************************************************************************/
@media screen and (max-width: 568px) and (max-height: 320px) {

.header .toplogo {
    margin-left: 9%;
}	
	
.header .contactside {
    width: 50%;
}	
	
.cta_wrap {
    padding: 20px 10%;
}

.contentblock {
    padding: 20px 10%;
}
	
.services_wrap {
    margin: 4vh 2% 0px 2%;
}	
	
.form-block-nb .g-recaptcha {
    padding-left: 15%;
}	
	
}

/************************************************************************************
	max width 480 - tablet / phone
*************************************************************************************/
@media screen and (max-width: 480px) {

.page-grid-half {
    display: flex;
	flex-direction: column;
}

.page-grid-thirds {
    display: flex;
	flex-direction: column;
}
	
.page-row-container {
    display: flex;
	flex-direction: column;
}
	
.page-grid-firstthird {
    display: flex;
	flex-direction: column;
}

.page-grid-lastthird {
    display: flex;
	flex-direction: column;
}
	
.header .toplogo {
    width: 50%;
    margin-left: 9%;
}

.header .contactside .fas {
    display: none;
}	
	
.header .contactside {	
    font-size: 1.2em;
	letter-spacing: -1px;
}	
	
.cta_wrap {
    padding: 80px 4%;
}
	
.contentblock {
    padding: 80px 6% 50px 4%;
}
		
.contentblock .page_wrap {
	flex-direction: column;
}	
	
.contentblock .page_wrap .page_text {
    width: 100%;
}	
	
.contentblock .page_wrap .page_image {
    width: 40%;
	margin-left: 30%;
    height: 336px;
}	
	
.services_wrap .service_line .service_name {
    height: 1.8em;
	margin-bottom: 15px;
}	
	
.form-block .form-row {
    flex-direction: column;
}	
	
.form-block .form-row .form-label {
    width: 100%;
	text-align: left;
	margin-bottom: 5px;
}	

.form-block .form-row .form-input {
    width: 100%;
}	

.form-block-nb .g-recaptcha {
	padding-left: 9%;
}	
	
}

/************************************************************************************
	max width 414 - phone
*************************************************************************************/
@media screen and (max-width: 414px) {

.home_contact_wrap {
    padding: 10px 0px 0px 0%;
}	

.form-block-nb .g-recaptcha {
    padding-left: 0%;
}	

.home_contact_wrap {
    text-align: center;
}	

.home_contact_wrap .socialline {
    justify-content: center;
}	

.header .mobile_nav .fas {
    font-size: 2.2em;
}	

.section_top-logo {
    display: none;
}	

.section_header {
    width: 100%;
}	
	
.cta_wrap .page_text {
    padding: 0px 0px 0px 0%;
}	
	
.contentblock .page_wrap .page_text {
    padding: 0px 0px 0px 0%;
}	

.page_container .page_wrap {
    padding: 10% 2% 2% 2%;
}	
	
.page_container .page_wrap .page_text {
    padding: 0px 0px 30px 0%;
}	
	
.contact_wrap {
    padding: 0px 0px 0px 0%;
}	
	
.form-block-nb .g-recaptcha {
    padding-left: 9%;
}	
	
#gmap {
    width: 100%;
}	
	
.overlay .message_box .message_paragraph {
    font-size: 1em;
}
	
.overlay .message_box {
    width: 90%;
}	

}

/************************************************************************************
	max width 400 - phone
*************************************************************************************/
@media screen and (max-width: 400px) {

}

/************************************************************************************
	max width 390 - phone
*************************************************************************************/
@media screen and (max-width: 390px) {

}

/************************************************************************************
	max width 375 - phone
*************************************************************************************/
@media screen and (max-width: 375px) {

.header {
    height: 110px;
	flex-direction: column;
}	
	
.hbg {
    height: 110px;
}	
	
.header .toplogo {
    width: 80%;
	margin-top: 5px;
	margin-left: 20px;
}	
	
.header .contactside {
    width: 100%;
}	

.header .contactside .phone{
    width: 100%;
	text-align: center;
	height: 30px;
	margin-top: -10px;
}	
	
	
.header .mobile_nav .fas {
    margin-top: 11px;
}	

.page_container {
    padding: 90px 2% 10% 2%;
}	

.page_container .page_wrap {
    padding: 10% 4% 2% 4%;
}	
	
.form-block-nb .g-recaptcha {
    padding-left: 5%;
}	
	
}

/************************************************************************************
	max width 375 x max height 812 - iPhone X 
*************************************************************************************/
@media screen and (max-width: 375px) and (max-height: 812px) {

	
}

/************************************************************************************
	max width 375 x max height 667 - phone
*************************************************************************************/
@media screen and (max-width: 375px) and (max-height: 667px) {

}

/************************************************************************************
	max width 360 - phone
*************************************************************************************/
@media screen and (max-width: 360px) {

.home_contact_wrap .title {
    font-size: 1.8em;
	letter-spacing: -1px;
}	
	
.home_contact_wrap .address_label {
    line-height: 1.4em;
	letter-spacing: -1px;
}

.form-block-nb .g-recaptcha {
    padding-left: 3%;
}	
	
.services_wrap .service_line .service_name {
    margin-bottom: 31px;
	width: 85%;
}	
	
.form-block-nb .g-recaptcha {
    padding-left: 0%;
}	
	
}

/************************************************************************************
	max width 360 x max height 740 - S8
*************************************************************************************/
@media screen and (max-width: 360px) and (max-height: 740px) {

}

/************************************************************************************
	max width 360 x max height 640 - S5 / S7
*************************************************************************************/
@media screen and (max-width: 360px) and (max-height: 640px) {

	
}

/************************************************************************************
	max width 320 - phone
*************************************************************************************/
@media screen and (max-width: 320px) {

.overlay .message_box .message_paragraph {
    font-size: 0.8em;
}
	
	
}

/************************************************************************************
	max width 320 x max height 568 - phone
*************************************************************************************/
@media screen and (max-width: 320px) and (max-height: 568px) {

	
}