html {
  height: 100%;
  scroll-behavior: smooth;
}

/************************************************ Background ************************************************/
body {
	/*background:#F4F4D5;*/
	background:#fff;
}

input[type='submit']
{
   -webkit-appearance: none;
   -moz-appearance: none;
   appearance: none; 
}

/************************************************ Format ************************************************/

body, select, input, textarea {
	font-size:62.5%;
	font-family: "neue-haas-grotesk-text", Arial, Helvetica, sans-serif;
	color:#373f53;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1,h2,h3,h4 {
	display: block;
	width: 100%;
}

.titlefont {
	font-family: utopia-std-display, serif!important;
}

.title80 {
	font-size:80px!important;
	line-height: 1.2!important;
	margin: 0 0 25px!important;
}

.title60 {
	font-size:60px!important;
	line-height: 1.2!important;
	margin: 0 0 25px!important;
}

.title50 {
	font-size:50px!important;
	margin: 0 0 25px!important;
	line-height: 1.1em!important;
}

.title35 {
	font-size:35px!important;
	margin: 0 0 15px!important;
	line-height: 1.1em!important;
}

h1 {
	font-size:30px;
	font-weight: 700;
	font-style: normal;
}

h2.large {
	font-size:30px;
	font-weight: 700;
	font-style: normal;
	width: 100%;
}

h2 {
	font-size:28px;
	line-height: 1.5;
	margin: 0 0 10px;
}

h3 {
	font-size:26px;
	line-height: 1.5;
	margin: 0 0 10px;
}

h4 {
	font-size:24px;
	line-height: 1.5;
	margin: 0 0 10px;
}

h5 {
	font-size:13px;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-family: "neue-haas-grotesk-text", Arial, Helvetica, sans-serif;
	margin: 0 0 20px;
	font-weight: bold;
	line-height: 1.5;
}

h6 {
	font-size:10px;
}

p {
	font-size:21px;
	line-height:1.5;
	padding:0 0 1em;
	margin: 0;
}

p.large {
	font-size: 30px;
	font-weight: bold;
	line-height: 1.3;
	padding:0 0 15px;
}

a {
	color:#373f53;
	text-decoration:underline;
	transition: all 0.3s ease-out;
}

a:hover {
	color:#373f53;
	text-decoration:none;
}

a.btn {
	color:#373f53;
	border-bottom: 4px solid #ffd186;
	padding: .5em 0 .75em 0;
	margin: 10px 0 15px;
	font-size: 20px;
	display: inline-block;
	position: relative;
	font-weight: bold;
	text-decoration: none;
}
a.btn:hover {
	text-decoration:none;
	border-bottom: 4px solid #373f53;
}

a.btn.blue {
	border-bottom: 4px solid #373f53;
	color:#373f53;
}

a.btn.blue:hover {
	border-bottom: 4px solid #373f53;
	color:#373f53;
	opacity: .8;
}

a.btn i {
	margin-left:5px;
}

img, object, embed, video {
	max-width: 100%;
}

img {
	height:auto;	
}

strong {
	font-weight:bold;	
}

em {
	font-style:italic;	
}

hr {
  margin-top: 3rem;
  margin-bottom: 3.5rem;
  border-width: 0;
  border-top: 1px solid #E1E1E1;
 }

.clearfix:after {
	content:".";
	display:block;
	clear:both;
	height:0;
	visibility:hidden;	
}

a.openmenu {
	display:none;	
}

.overlay {
	height:0;
	opacity:0;
	position: fixed;
}

.video_wrapper {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	height: 0;
	margin: 0 0 20px;
}
.video_wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.mob_show {
	display: none!important;
}

.mob_hide {
	display: block!important;
}

.centeralign {
	text-align: center;
}

/* Grid
–––––––––––––––––––––––––––––––––––––––––––––––––– */

.row {
display: flex;
flex-wrap: wrap;
width: 100%;
margin-top: 10em;
}
.row.nomarg {
margin-top: 0;
}
.justify-content-between {
justify-content: space-between !important;
}
.justify-content-center {
justify-content: center !important;
}
.justify-content-end {
justify-content: end !important;
}
.align-items-center {
align-items: center !important;
}
.align-content-center {
align-content: center !important;
}

.col-1 {
flex:0 0 auto;
width:8.3333333333%
}
.col-2 {
flex:0 0 auto;
width:16.6666666667%
}
.col-3 {
flex:0 0 auto;
width:25%
}
.col-4 {
flex:0 0 auto;
width:33.3333333333%
}
.col-5 {
flex:0 0 auto;
width:41.6666666667%
}
.col-6 {
flex:0 0 auto;
width:50%
}
.col-7 {
flex:0 0 auto;
width:58.3333333333%
}
.col-8 {
flex:0 0 auto;
width:66.6666666667%
}
.col-9 {
flex:0 0 auto;
width:75%
}
.col-10 {
flex:0 0 auto;
width:83.3333333333%
}
.col-11 {
flex:0 0 auto;
width:91.6666666667%
}
.col-12 {
flex:0 0 auto;
width:100%
}

.col_marg1 {
margin-left:8.3333333333%
}
.col_marg2 {
margin-left:16.6666666667%
}
.col_marg3 {
margin-left:25%
}
.col_marg4 {
margin-left:33.3333333333%
}
.col_marg5 {
margin-left:41.6666666667%
}
.col_marg6 {
margin-left:50%
}

.blog_pic{
	width: 100%;
	margin: 20px 0 -180px;
}

.minusright5 {
	margin-right: -5%;
	position: relative;
}

/************************************************ Layout ************************************************/

section {
	width:100%;
	display: block;
	box-sizing: border-box;
	padding: 0 5%;
	position: relative;
}
section.nopaddleft {
	padding-left:0;
}
section.nopaddright {
	padding-right:0;
}
section.light {
	background:#f9e8cd;
}
section.blue {
	background:#D9E8ED;
}

.section_inner {
	margin: 0 auto;
	max-width: 1420px;
	width: 90%;
	position: relative;
	padding-top: 7vw;
	padding-bottom: 7vw;
}
.section_inner.full {
	max-width: 100%;
	width: 100%;
}
.section_inner.line {
	border-top: 2px solid #D9E8EF;
}

.section_inner.flex {
	display:flex;
	flex-flow:row wrap;
	justify-content: space-between;
	align-items: flex-start;
}

.section_inner.paddtop7 {
	padding-top:7em;
}
.section_inner.paddbottom7 {
	padding-bottom:7em;
}
.section_inner.paddtop15 {
	padding-top:15em;
}
.section_inner.paddbottom15 {
	padding-bottom:15em;
}

.section_inner.paddtop0 {
	padding-top: 0;
}
.section_inner.paddbottom0 {
	padding-bottom: 0;
}
.section_inner.nopaddtopbottom {
	padding-top: 0;
	padding-bottom: 0;
}
.section_inner.nopaddleft {
	margin-left: 0;
}

header {
	width:100%;
	float:left;
	box-sizing: border-box;
	position: relative;
	z-index: 4;
	padding-bottom: 6em;
}

.main_nav_surround {
	display: flex;
	max-width: 100%;
	min-width: 900px;
	flex-flow: row nowrap;
	justify-content: space-between;
	align-items: flex-start;
}

#logo {
	width:330px;
	margin:3em 5% 0;
}

#logo img {
	width:100%;
}

nav {
	width: 65%;
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	background:rgba(54,63,82,0.9);
	padding: 50px 5% 0;
	box-sizing: border-box;
}

nav ul {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	margin: 0;
}

nav ul li {
	font-size:16.5px;
	list-style-type: none;
	position: relative;
	padding: 0;
	margin: 0 15px;
}

nav ul li a {
	color:#fff;
	text-decoration: none;
	padding: 0 0 30px;
  	display: block;
}

nav ul li a:hover {
	text-decoration: none;
	color: #ffd186;
}

nav ul li.current-menu-item a,
nav ul li.current-menu-ancestor a,
nav ul li.current-menu-ancestor ul li a,
nav ul li.current-page-ancestor a {
	color:#fff;
}
nav ul li.current-menu-item a:after,
nav ul li.current-menu-ancestor a:after,
nav ul li.current-menu-ancestor ul li a:after,
nav ul li.current-page-ancestor a:after {
	color:#fff;
	position: absolute;
	height: 3px;
	background: #fff;
	width: 100%;
	bottom: 0;
	left: 0;content: '';
}

nav ul li.drop ul {
    display: none;
    position: absolute;
    background: rgba(54,63,82,0.9);
    width: 200px;
    z-index: 9999;
	margin:0px 0 0;
	padding:0;
	left: 50%;
  	transform: translateX(-50%);
	transition: all 0.3s ease-out;
}

nav ul li.drop:hover ul {
    display: table;
	table-layout:fixed;
}

nav ul li.drop ul li {
	width:100%;
	float:left;
	text-align:center;
	margin: 0;
	padding: 0;
}

nav ul li.drop ul li a {
	width:100%;
	color:#fff;
	padding:15px 10px 13px;
	float:left;
	font-size:15px;
	letter-spacing:normal;
	box-sizing:border-box;
	border-bottom:1px solid #A6A6A8;
}

nav ul li.drop ul li:last-child a {
	border-bottom:none;
}

nav ul li.drop ul li a:hover,
nav ul li.drop ul li.selected a,
nav ul li.drop ul li.current_page_item a {
	color:#ffd186;
}

nav ul li.drop ul li.selected a,
nav ul li.drop ul li.current_page_item a {
	font-weight:400;
}

nav ul li.drop ul li a:hover:after {
	width:0;
}

nav ul li.current-menu-item ul li a:after,
nav ul li.current-menu-ancestor ul li a:after,
nav ul li.current-menu-ancestor ul li.current_page_item a:after {
	width:0;
}

/************************************************ Homepage ************************************************/

.hero {
	width:100%;
	padding: 0;
	box-sizing: border-box;
	text-align: left;
	min-height: 684px;
	background-size:cover!important;
	background-repeat: no-repeat!important;
	background-position: center!important;
}
.hero.large {
	min-height: 960px;
	background-position: bottom!important;
}
.hero.blog {
	min-height: 700px;
	padding-bottom: 5em;
	background-position: bottom!important;
}
.hero.blog.small {
	min-height: 300px;
}
.hero.large .hero_content {
	margin-left: 10%;
  	padding: 10vw 0 0;
}
.hero_content {
	width: 80%;
	position: relative;
	z-index: 2;
	display: flex;
	flex-flow: row wrap;
	color: #fff;
	align-items: center;
	margin-left: 10%;
  	padding: 10em 0 0;
}
.hero_grad {
	background: rgba(5,16,50,0.25);
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}
.hero_content h2 {
	font-size:80px;
	margin: 0 0 0.2em;
}
.hero_content h1 {
	font-size:21px;
	font-family: "neue-haas-grotesk-text", Arial, Helvetica, sans-serif;
	font-weight: normal;
	margin: 0 0 .5em;
	line-height: 1.5;
}
.hero_content a.btn:hover {
	text-decoration:none;
	border-bottom: 4px solid #fff;
}
.hero_content a.btn {
	color:#fff;
	border-bottom: 4px solid #fff;
}
.hero_content a.btn:hover {
	text-decoration:none;
	border-bottom: 4px solid #fff;
}

.hp_blog {
	width: 70%;
	background:#D9E8ED;
	padding: 2.5em 4em;
	box-sizing: border-box;
	position: absolute;
	bottom: -11em;
	right: 5%;
	z-index: 2;
	animation: fadein 1s;
	display: flex;
	flex-flow: wrap;
	justify-content: space-between;
	align-items: center;
}
.hp_blog p.small {
	font-size: 1.4em;
	text-transform: uppercase;
	font-weight: bold;
	margin: 0 0 2em;
	padding: 0 0 1em;
	border-bottom: 2px solid #fff;
	width: 100%;
}
.hp_blog p.large {
	font-size: 2.8em;
	font-weight: 500;
	margin: 0;
	width: 75%;
}
.hp_blog a.btn {
	color:#373f53;
	border-bottom: 2px solid #373f53;
	padding: 0 0 0.25em;
	margin: 0;
	font-size: 1.8em;
	display: inline-block;
	position: relative;
	font-weight: bold;
	text-decoration: none;
	transition: all 0.3s ease-out;
}
.hp_blog a.btn:hover {
	color:#373f53;
	border-bottom: 2px solid #373f53;
}
.hp_blog a.btn .far {
	padding: 0;
	transition: all 0.3s ease-out;
}
.hp_blog a.btn:hover .far {
	padding: 0 0 0 .25em;
	transition: all 0.3s ease-out;
}

.hero .slick-track {
    display: flex !important;
}

.hero .slick-slide{
    height: auto !important;
}
.hero .slide{
    height: 100% !important;
}
.hero .slick-slide > div{
    height: 100% !important;
}


/************************************************ Main Content ************************************************/

.services_slider {
	margin: 0 0 3em;
}

.services_slider .service_block {
	width:100%;
	padding: 0;
	border: none;
	box-sizing: border-box;
	margin-bottom: 0;
}
.services_slider .slick-slide {
	margin-left: 60px;
}
.services_slider .slick-list {
    margin-left:-60px;
}

.services_slider .service_block:hover {
	border: none;
}

.services_container {
	margin:3em 0 0;
	width: 100%;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
}
.services_container::after {
	content: "";
	width:31%;
}
.service_block {
	width:31%;
	padding: 20px;
	border: 5px solid transparent;
	box-sizing: border-box;
	margin-bottom: 2em;
	position: relative;
	transition: all 0.3s ease-out;
}
.service_block a {
	width:100%;
	height: 100%;
	top: 0;
	left: 0;
	position: absolute;
}
.service_block a:hover {
	background-color: rgba(255,255,255,0.15);
}
.service_block:hover {
	border: 5px solid #ffd186;
}
.service_block p.small{
	font-size:16px;
	padding: 0 0 10px;
}
.service_block p{
	font-size:17px;
}
.service_block img {
	height:93px;
	padding: 0 0 3em;
}

.number_list {
	display:flex;
	flex-flow: row wrap;
	justify-content: space-between;
	margin: 0 0 0 5%;
}
.number_area {
	width:42%;
	margin: 0 0 5em;
}
.number_area h6 {
	position: relative;
}
.number_area h6:after {
	position: absolute;
	content: '';
	width:80px;
	height: 80px;
	border: 3px solid #fee3b8;
	top: -40%;
	border-radius: 50%;
	left: -13%;
	z-index: -1;
}
.number_area h4 {
	font-size:1.6em;
	margin: 0 0 10px;
	font-weight: bold;
}
.number_area p {
	font-size:1.5em;
}

.title_surround {
	width:100%;
	display: flex;
	flex-flow: row wrap;
	padding: 0 0 3em;
	margin: 0 0 7em;
	border-bottom: 2px solid #D9E8EF;
}

.title_surround h3 {
}

img.full_pic {
	width:100%;
}

aside.orange_large {
	width:100%;
	padding: 12% 13% 10%;
	background: #ffd186;
	box-sizing: border-box;
	position: absolute;
	z-index: 3;
	bottom: -13vw;
}
aside.orange_large.static {
	bottom: inherit;
	position: relative;
	margin-left:-10%;
}
aside.orange_large ul {
	width:100%;
	list-style-type: none;
}
aside.orange_large ul li {
	width:100%;
	font-size: 34px;
	margin: 0 0 20px;
}
aside.orange_large p {
	font-size: 34px;
	margin: 0 0 20px;
	padding: 0;
}
aside.blue {
	width:100%;
	padding: 50px 30px;
	background: #d9e8ed;
	box-sizing: border-box;
	position: relative;
	z-index: 3;
}
aside.blue h5 {
	border-bottom:2px solid #fff;
	padding: 0 0 10px;
}
.share_buttons {
	width: 100%;
	margin: 0 0 30px;
	padding: 0 0 15px;
	border-bottom:2px solid #D9E8EF;
}

.people_area {
	width: 100%;
	line-height: 0;
	margin-bottom: -1px;
}

.people_area img {
	width: 100%;
}

.heading {
	width:100%;
	padding: 6em 5% 0;
	box-sizing: border-box;
	text-align: left;
	display: flex;
	justify-content: space-between;
}

.heading_surround {
	display: flex;
	justify-content: space-between;
}

.heading_surround.full {
	display: flex;
	justify-content: center;
	flex-flow: row wrap;
}

.heading_left {
	width: 40%;
	margin: 5% 0 50px 10%;
}

.heading_left.long {
	width: 90%;
	margin: 5% 0 50px 0;
}

.heading_right {
	width:40%;
	margin-bottom: -8%;
	align-items: end;
	display: flex;
}

.heading_right.large {
	width:44%;
}

img.rounded {
	border-radius:10px;
}

.heading h1 {
	font-size:55px;
	color:#812E6E;
	margin: 0 0 20px;
}

.single-post .heading h1 {
	font-size: 40px;
	color: #812E6E;
	margin: 0 0 20px;
}

.heading h2 {
	font-size:22px;
	color:#812E6E;
	margin: 0 0 30px;
	font-weight: 500;
}

.heading h4.uppercase {
	font-size:13px;
	text-transform: uppercase;
	font-weight: bold;
	margin: 10px 0 20px;
}

.heading p {
	font-size:22px;
	margin: 0;
}

.heading_sub_links {
	width:80%;
	background: #A4338A;
	color:#F4F4D5;
	border-radius:3em;
	font-size: 20px;
	padding: 14px 25px;
	display: flex;
	flex-flow: row wrap;
	position: relative;
	font-weight: bold;
	border: 3px solid #fff;
	line-height: 1.5em;
}

.heading_sub_links strong {
	margin: 0 10px 5px 0;
}

.heading_sub_links ul {
	width:auto;
	display: flex;
	flex-flow: row wrap;
	margin: 0;
}

.heading_sub_links ul li {
	list-style-type:none;
	margin: 0 10px 0 0;
	font-size: 18px;
}

.heading_sub_links ul li a {
	text-decoration: underline;
	color: #fff;
	font-weight: normal;
}

.heading_sub_links ul li a:hover {
	text-decoration: none;
	color: #fff;
}

.section_title {
	width:100%;
	float: left;
	margin: 0 0 30px;
}

.section_title.center {
	text-align: center;
}

.section_title.white {
	color:#fff;
}
.section_title.blue {
	color:#55C2E4;
}
.section_title.green {
	color:#CDD500;
}

.section_title h2,
.section_title h3 {
	font-size:5em;
	font-family: "roboto-slab", serif;
	margin: 0 0 10px;
}

.fee_table {
	border:4px solid #ffd186;
	border-bottom: none;
	width: 100%;
	display: flex;
	flex-flow: row wrap;
	margin: -50px 0 10em;
	box-sizing: border-box;
}
.fee_level {
	width:100%;
	padding: 5em 5%;
	box-sizing: border-box;
	border-bottom: 4px solid #ffd186;
	display: flex;
	flex-flow: row;
	justify-content: space-between;
	align-items: center;
}
.fee_level p {
	font-size:36px;
	font-weight: normal;
	padding: 0;
}
.fee_block:first-child {
	width:35%;
}
.fee_block:nth-child(2) {
	width:10%;
	text-align: center;
}
.fee_block:nth-child(3) {
	width:35%;
}


/************************************************ Contact ************************************************/

.heading_left ul.footer_social_icons {
	margin: 0;
	justify-content: flex-start;
}

.contact_form {
	width:100%;
	padding: 60px 30px 30px;
	border-radius:10px;
	background: #fff;
	box-sizing: border-box;
}

.contact_form.border {
	border:5px solid #A4338A;
}


/************************************************ News ************************************************/

.news_list {
	width:100%;
	margin:0;
	float:left;	
}

ul.articles {
	width:100%;
	float:left;
	display:flex;
	flex-wrap:wrap;
	align-items:flex-start;
	justify-content: space-between;
	margin:0 0 100px;
	list-style-type: none;
}

ul.articles li {
	width:48%;
	margin:0 0 3%;
	position:relative;
	line-height:0;
	overflow:hidden;
}

ul.articles li a.over {
	z-index:3;
	position:absolute;
	top:0;
	left:0;
	height:100%;
	width:100%;
}

ul.articles li .info_block {
	width:100%;
	position:absolute;
	bottom:0;
	left:0;
	background:rgba(57,57,65,0.75);
	padding:15px 8%;
	box-sizing:border-box;
	z-index:2;
	line-height:1.5em;
	color:#fff;
	transition: all 0.3s ease-out;
}

ul.articles li img {
	z-index:1;
	width: 100%;
}

ul.articles li:hover .info_block {
	padding:30px 8%;
	background:rgba(57,57,65,0.9);
}

ul.articles li .info_block p {
	font-weight:400;
	font-size:21px;
	padding:0;
	float:left;
	width:100%;
}

img.service_icon {
	width: 100px;
	margin: 0 0 30px;
}



/************************************************ About ************************************************/

.team_area {
	width:100%;
	display:flex;
	flex-flow: row wrap;
	margin: 4em 0 5em;
	justify-content: space-between;
}
.team_area:after {
	content: "";
	width: 31%;
}

.team_item {
	width:31%;
	position: relative;
	margin-right: 0;
	margin-bottom: 2.3%;
}

.team_item a {
	width:100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
}

.team_item a:hover {
	background: rgba(255,255,255,.3);
}

.team_item img {
	width:100%;
	margin: 0 0 10px;
}

.team_detail {
	width: 100%;
	padding: 3em 2em 2em;
	background: linear-gradient(0deg, rgb(0, 0, 0) 0%, rgba(0, 0, 0, 0) 100%);
	position: absolute;
	bottom: 0;
	left: 0;
	box-sizing: border-box;
	color: #fff;
}

.team_item p {
	font-size:2.1em;
	font-weight: normal;
	padding: 0;
	width: 100%;
}

.team_item span {
	font-size:1.8em;
	line-height: 1.5em;
	width: 100%;
	display: block;
	font-weight: bold;
}


/************************************************ People Modal ************************************************/


.modal {
  display: none;
}
.team_member_surround {
	width:100%;
	padding: 0;
}
.modal_left {
	width:100%;
	float: left;
	display: flex;
}
.modal_right {
	width:50%;
	float: left;
	position: relative;
}
.modal .no-gutters > .col,
.modal .no-gutters > [class*=col-] {
  padding: 0;
}
.modal.team-member {
	padding: 0 !important;
	width: 100%;
	max-width: 1200px;
}
.modal.team-member .team-image {
  position: relative;
  object-fit: cover;
  object-position: top;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 35%;
}
.modal.team-member .modal-header,
.modal.team-member .modal-body {
  padding: 30px 5%;
	width: 65%;
}
.modal.team-member p.large {
	font-size: 36px;
	font-weight: normal;
}
.modal.team-member p.large strong {
	font-size: 32px;
	font-weight: bold;
}
.modal.team-member .modal-header {
  background-color:#CDD500;
  border: none;
  border-radius: 0;
	color: #fff;
  display: block;
}
.modal.team-member .modal-header * {
  margin: 0;
}
.modal.team-member .modal-body {
  background-color: #fff;
}
.fancybox-button :hover,
button.fancybox-button:hover{
	text-decoration:none;
	background:none;
	color:#ffd186; 
}

/*.fancybox-button[data-fancybox-close] {
  width: 60px;
  height: 60px;
}*/

@media only screen and (max-width: 667px) {
  .modal.team-member .modal-header,
.modal.team-member .modal-body {
    padding: 1.5rem;
  }
}
.popup {
  display: none;
  width: 50%;
  max-width: 600px;
}

@media only screen and (max-width: 1024px) {
  .popup {
    max-width: none;
    width: 90%;
  }
}




/************************************************ Form Elements and General Styling ************************************************/

/* Buttons
–––––––––––––––––––––––––––––––––––––––––––––––––– */
.button,
button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
	background:none;
	font-size:24px;
	text-transform:uppercase;
	color:#373f53;
	border: none;
	border-bottom: 4px solid #ffd186;
	padding: .5em 0 .75em 0;
	margin: 10px 0 15px;
	display: inline-block;
	position: relative;
	font-weight: bold;
	text-decoration: none;
	cursor: pointer;
	transition: all 0.3s ease-out;
}

.button:hover,
button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover{
	text-decoration:none;
	border-color:#373f53;
	color:#373f53; 
}


/* Forms
–––––––––––––––––––––––––––––––––––––––––––––––––– */
input[type="email"],
input[type="number"],
input[type="search"],
input[type="text"],
input[type="tel"],
input[type="url"],
input[type="password"],
textarea,
select {
	height: 68px;
	padding: 10px 20px;
	background-color: #fff;
	border: none;
	box-shadow: none;
	box-sizing: border-box;
	width: 100%;
	border-radius:10px;
	font-size: 20px; 
}
/* Removes awkward default styles on some inputs for iOS */
input[type="email"],
input[type="number"],
input[type="search"],
input[type="text"],
input[type="tel"],
input[type="url"],
input[type="password"],
textarea {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none; }
textarea {
	height: 200px;
	padding: 10px 20px;
	background-color: #fff;
	border: none;
	box-shadow: none;
	box-sizing: border-box;
	width: 100%;
	border-radius:10px;
	font-size: 20px; 
}
input[type="email"]:focus,
input[type="number"]:focus,
input[type="search"]:focus,
input[type="text"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
  border: 2px solid #33C3F0;
  outline: 0; }
label,
legend {
  display: block;
  margin-bottom: .5rem;
text-transform: uppercase;
font-weight: bold;
font-size: 13px;}
fieldset {
  padding: 0;
  border-width: 0; }
input[type="checkbox"],
input[type="radio"] {
  display: inline; }
label > .label-body {
  display: inline-block;
  margin-left: .5rem;
  font-weight: normal; }


/* Lists
–––––––––––––––––––––––––––––––––––––––––––––––––– */
ul {
  list-style: disc inside; }
ol {
  list-style: decimal inside; }
ol, ul {
  padding-left: 0;
  margin-top: 0; }
ul ul,
ul ol,
ol ol,
ol ul {
  margin: 1.5rem 0 1.5rem 3rem;
  font-size: 90%; }
li {
margin-bottom: 0.5rem;
font-size:20px;
line-height: 1.5em;
margin-left: 20px;
list-style-position: outside;}

ol {
  counter-reset: number-list-counter;
  list-style: none;
  margin-left: 0;
  padding-left: 0;
}
ol li {
  counter-increment: number-list-counter;
  position: relative;
  padding-left: 25px;
  margin-bottom: 1rem;
  font-weight: 500;
	font-size: 20px;
}
ol li:before {
  content: counter(number-list-counter) ".";
  position: absolute;
  left: 0;
  top: 0;
}


/* Code
–––––––––––––––––––––––––––––––––––––––––––––––––– */
code {
  padding: .2rem .5rem;
  margin: 0 .2rem;
  font-size: 90%;
  white-space: nowrap;
  background: #F1F1F1;
  border: 1px solid #E1E1E1;
  border-radius: 4px; }
pre > code {
  display: block;
  padding: 1rem 1.5rem;
  white-space: pre; }

blockquote {
  position: relative;
  background-color: #ffd186;
  padding: 30px;
  margin: 0 0 40px 0;
	color: #373f53;
font-size: 20px;
	line-height: 1.5em;
}
blockquote p {
  font-size:20px;
}
@media only screen and (max-width: 768px) {
  blockquote p {
    font-size: 18px;
  }
}

cite {
  display: block;
  font-style: normal;
  font-weight: 700;
  color: #fff;
  font-size: 18px;
}
cite:before {
  content: "- ";
}
@media only screen and (max-width: 768px) {
  cite {
    font-size: 16px;
  }
}


/* Tables
–––––––––––––––––––––––––––––––––––––––––––––––––– */
th,
td {
  padding: 12px 15px;
  text-align: left;
  border-bottom: 1px solid #E1E1E1; }
th:first-child,
td:first-child {
  padding-left: 0; }
th:last-child,
td:last-child {
  padding-right: 0; }
  tr:nth-child(odd) {
	background:#f4f4f4;  
  }


/* Spacing
–––––––––––––––––––––––––––––––––––––––––––––––––– */
input,
textarea,
select,
fieldset {
  margin-bottom: 1.5rem; }
pre,
blockquote,
dl,
figure,
table,
ul,
ol,
form {
  margin-bottom: 1.5rem; }


/************************************************ Contact Form Elements ************************************************/


.form_item {
    display: inline-block;
    margin:0;
    vertical-align: top;
    width: 100%;
}

.form_item label,
.form_item_message label{
   display:block;
   font-size:16px;
   margin:0 0 7px;
}

.form_item input {
    border:2px solid #373f53;
	box-sizing: border-box;
	background: #fff;
    color: #040507;
    float: left;
    font-size: 16px;
    height: 50px;
    margin: 0 0 20px;
    padding: 12px 0 10px 10px;
    width: 100%;
	border-radius:0;
}

.form_item_message textarea {
	font-size: 16px;
	border:2px solid #373f53;
	height:120px;
	width:100%;
	padding: 12px 0 10px 10px;
	box-sizing: border-box;
	border-radius:3px;
	margin:0 0 20px;
	background: #fff;
}

.form_item.select {
	width:100%;
	position:relative;
}

.form_item.select select {
	-webkit-appearance: none; 
	-moz-appearance: none;
	appearance: none;/* remove default arrow */
	width:100%;
	height:60px;
	border:2px solid #eaf0f2;
	border-radius:3px;
	box-sizing:border-box;
	font-size:16px;
	padding:8px 15px 8px 15px;
	position:relative;
	box-shadow:none;
	background:url(../images/downarrow.png) no-repeat center right #fff;
	background-size:30px;
}

/* Customize the label (the container) */
.form_item .labelcontainer {
  display: inline-block;
  position: relative;
  margin-left: -22px;
  margin-bottom: 10px;
  cursor: pointer;
  font-size: 22px;
  padding-bottom:0;
  margin:0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.form_item .labelcontainer label.error {
    margin: 5px 0 0 36px;
}

/* Hide the browser's default checkbox */
.labelcontainer input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: auto;
    padding: 0;
    margin: 0;
}

/* Create a custom checkbox */
.checkmark {
  position: absolute;
  top: 5px;
  left: 0;
  height: 20px;
  width: 20px;
  background-color: #4b6d50;
  border:none;
  border-radius:3px;
}

/* On mouse-over, add a grey background color */
.labelcontainer:hover input ~ .checkmark {
  background-color: #4b6d50;
}

/* When the checkbox is checked, add a blue background */
.labelcontainer input:checked ~ .checkmark {
  background-color: #f6e2a3;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

/* Show the checkmark when checked */
.labelcontainer input:checked ~ .checkmark:after {
  display: block;
}

/* Style the checkmark/indicator */
.labelcontainer .checkmark:after {
  left: 6px;
  top: 2px;
  width: 5px;
  height: 10px;
  border: solid #464e78;
  border-width: 0 3px 3px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
} 

.form_item input:focus,
.form_item_message textarea:focus {
	border:1px solid #7bcef2!important;
}

.form_item label.warning,
.form_item_message label.warning {
	color:#F00;	
}

.submit_surround {
	width:100%;
	float:left;
}

.submit {
	background:none;
	font-size:24px;
	text-transform:uppercase;
	cursor:pointer;
	border:3px solid #f6e2a3;
	color:#373f53;
	border-bottom: 4px solid #ffd186;
	padding: .5em 0 .75em 0;
	margin: 10px 0 15px;
	display: inline-block;
	position: relative;
	font-weight: bold;
	text-decoration: none;
}
.submit:hover {
	text-decoration:none;
	border-bottom: 4px solid #373f53;
}

.form_submit {
	float:left;
	width:100%;
}

#mapholder {
	width: 100%;
	float: left;
	height: 400px;
	position: relative;
	right: 0;
	top: -20px;
	z-index: 100;
}

#mapholder img, #mapholder object, #mapholder embed, #mapholder video {
	max-width:none;
	width:auto;
}

#mapholder img {
	height:auto;	
}

#mapholder p {
	color:#000;	
	font-size:14px;
	padding:0;
}

#mapholder p strong {
	font-weight:bold;
}

.honey {
	display:none;	
}

/************************************************ CTA ************************************************/

.cta_bottom {
	display: flex;
	width: 100%;
	padding: 0;
	background:#d9e8ed;
}

.cta_bottom_inner {
	display: flex;
	width: 100%;
	align-items: center;
}
.home .cta_bottom_inner,
.page-id-8 .cta_bottom_inner {
	background:#fff;
}
.home .cta_bottom_inner a.btn,
.page-id-8 .cta_bottom_inner a.btn {
	color:#373f53;
	border-bottom: 4px solid #ffd186;
}
.home .cta_bottom_inner a.btn:hover,
.page-id-8 .cta_bottom_inner a.btn:hover {
	text-decoration:none;
	border-bottom: 4px solid #373f53;
}
.cta_bottom_inner a.btn {
	border-bottom: 4px solid #373f53;
	color:#373f53;
}
.cta_bottom_inner a.btn:hover {
	border-bottom: 4px solid #373f53;
	color:#373f53;
	opacity: .8;
}

.pic_block {
	background: none;
	width:60%;
	box-sizing: border-box;
	margin:-3em 0;
	position: relative;
	text-align: center;
	overflow: hidden;
}

.testimonials_block {
	background: #ffd186;
	width:60%;
	box-sizing: border-box;
	padding: 10em 10%;
	margin:-3em 0;
	position: relative;
	text-align: center;
	overflow: hidden;
}
.testimonials_block.full {
	width:100%;
	margin:0;
}

.testimonials_block:before {
	height: 103px;
	width: 103px;
	position: absolute;
	content: '';
	top: 5em;
	left: 10%;
	background: url("../images/quotemarks.png") no-repeat top left;
	background-size: 100%;
}

.testimonials_block .person {
	width:170px;
	height: 170px;
	border-radius: 50%;
	border:7px solid #F9E6C5;
	overflow: hidden;
	margin: 0 auto 2em;
}

.testimonials_block p {
	font-size:2em;
}

.testimonials_block p i {
	font-style: italic;
}

.testimonials_block p.small {
	font-size:17px;
	font-weight: bold;
	padding: 0;
	margin: 0
}

.cta {
	width: 40%;
	padding: 5em 5%;
	align-items: center;
}

.cta.full {
	width: 100%;
	padding: 5em 5%;
	align-items: center;
	text-align: center;
}

aside.orange_large ul.social_icons {
	width: 100%;
	display: flex;
	flex-flow: row nowrap;
	list-style-type: none;
	justify-content:flex-start;
	align-items: center;
	margin: 0;
}

aside.orange_large ul.social_icons li {
	font-size:20px;
	margin: 0 10px 0 0;
	width: auto;
}

aside.orange_large ul.social_icons li a {
	color:#373f53;
	width: 42px;
	height: 42px;
	border-radius:50%;
	border: 2px solid #373f53;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

aside.orange_large ul.social_icons li a:hover {
	color:#ffd186;
	background: #373f53;
	border-color: #373f53;
}


/************************************************ Footer ************************************************/

.mailing_surround {
	background: #A4338A;
	border-radius:10px;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	padding: 80px 5% 50px;
	box-sizing: border-box;
	color: #fff;
	max-width: 1420px;
	margin: 0 auto -80px;
	text-align: center;
	position: relative;
}

.mailing_surround .person {
	width:285px;
	position: absolute;
	right: 2%;
	top: -200px;
}

.mailing_surround h6 {
	font-family: "roboto-slab", serif;
	font-size:50px;
	margin: 0 0 10px;
	width: 100%;
}

.mailing_surround p {
	margin: 0;
	font-weight: 500;
}

.mailing_surround .frm_message p {
	color: #101010;
	padding: 0;
}

.frm_error_style {
	color: red;
	font-size: 13px;
}

.mail_signup {
	width:75%;
	background: #fff;
	padding: 15px;
	border-radius: 30em;
	margin: 20px 0 0;
}

.mail_signup .frm_combo_inputs_container, .mail_signup .frm_grid_container, .mail_signup .frm_form_fields .frm_section_heading, .mail_signup .frm_form_fields .frm_fields_container {
	display: inherit!important;
}

.mail_signup form,
.mail_signup fieldset {
	margin: 0!important;
}

.mail_signup input {
	width: 69%;
	border-radius: 3em;
	background: #fff;
	float: left;
	font-size: 20px;
	color: #010101;
	font-weight: 500;
	padding: 24px 30px;
	box-sizing: border-box;
	line-height: 1.5em;
	margin: 0;
	height: auto;
	border: 1px solid transparent;
}

.mail_signup button {
	float: right;
	border-radius: 3em;
	font-size: 17px;
	line-height: 1.5em;
	padding: 24px 20px;
	display: inline-block;
	height: auto;
	margin: 0;
	font-weight: bold;
	vertical-align: top;
	color: #fff;
	position: relative;
	border: none;
	cursor: pointer;
	width: 30%;
	box-sizing: border-box;
	background: #CDD500;
	transition: all 0.3s ease-out;
	text-transform: uppercase;
}

.mail_signup button i {
	margin-right:5px;
}

.mail_signup button:hover {
	background: #A4338A;
}

footer {
	width:100%;
	float:left;
	padding: 15em 5% 5em;
	box-sizing: border-box;
	background: #373f53;
	color: #fff;
}

footer a {
	color: #fff;
	text-decoration: underline;
}

footer a:hover {
	color: #fff;
	text-decoration: none;
}

footer img {
	width:196px;
}

footer p.uppercase {
	font-size:1.3em;
	font-weight: bold;
	letter-spacing: 1px;
	padding: 0;
	text-transform: uppercase;
}
footer p {
	font-size:1.8em;
}

.footer_inner {
	margin: 0 auto;
	max-width: 1420px;
	width: 90%;
	position: relative;
}

.footer_cols {
	display: flex;
	justify-content: space-between;
	flex-flow:row wrap;
}

.footer_col {
	flex-grow: 1;
   flex-shrink: 0;
   flex-basis: 30%;
}

.footer_col:last-child {
	flex-basis: 10%;
}

ul.footer_links {
	display: flex;
	flex-flow: row wrap;
	list-style-type: none;
	align-items: center;
}

ul.footer_links li {
	font-size:1.8em;
	margin: 0 0 0.5em 0;
	width: 100%;
}

ul.footer_links li a {
	color:#fff;
	text-decoration: none;
}

ul.footer_links li a:hover {
	color:#ffd186;
}

ul.footer_social_icons {
	width: 100%;
	display: flex;
	flex-flow: row nowrap;
	list-style-type: none;
	justify-content: flex-start;
	align-items: center;
	margin: 0 10% 0 0;
}

ul.footer_social_icons li {
	font-size:2em;
	margin: 0 10px 0 0;
}

ul.footer_social_icons li a {
	color:#fff;
	width: 42px;
	height: 42px;
	border-radius:50%;
	border: 2px solid #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

ul.footer_social_icons li a:hover {
	color:#373f53;
	background: #ffd186;
	border-color: #ffd186;
}

.footer_bottom {
	display: flex;
	flex-flow: nowrap;
	border-top: 2px solid #A6A6A8;
	padding: 4em 0 0;
	margin: 3em 0;
	align-items: center;
}

.footer_bottom a,
.copyright a {
	color: #B4B4B2;
	text-decoration: underline;
}
.footer_bottom a:hover,
.copyright a:hover{
	color: #B4B4B2;
	text-decoration: none;
}

.footer_left {
	width:82.5px;
	margin-right: 4em;
}

.footer_right {
	width:80%;
	color: #B4B4B2;
}

.footer_right p {
	font-size:1.4em;
}

.copyright {
	width:100%;
	font-size:1.3em;
	line-height: 1.5em;
	color: #B4B4B2;
}

.copyright a.small {
	font-size:13px;
}


/************************************************ Smaller screens ************************************************/

@media only screen and (max-width: 1300px) {

nav {
  width: 67%;
  padding: 50px 2% 15px;
}
	
#logo {
  width: 330px;
  margin: 3em 3% 0;
}
	
}

@media only screen and (max-width: 1250px) {

.section_inner {
	margin: 0 auto;
	width: 100%;
}
	
.hero.large .hero_content {
  margin-left: 5%;
  padding: 7vw 0 0;
}
	
.footer_inner {
	width: 100%;
}
	
.footer_col {
	margin-right: 3%;
}
	
}

@media only screen and (max-width: 1170px) {

/* Mobile menu */

a.openmenu {
	position:absolute;
	right:3%;
	font-size:22px;
	color:#fff;
	z-index:100;
	top:30px;
	display:block;
	width: 56px;
	height: 56px;
}

a.openmenu.fixed {
	position:fixed;
	font-size:22px;
	color:#fff;
	z-index:100;
}

#nav-icon1, #nav-icon2, #nav-icon3, #nav-icon4 {
  width: 50px;
  height: 30px;
  position: relative;
  margin: 0 auto;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  -o-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  cursor: pointer;
	margin-top: 15px;
}

#nav-icon1 span, #nav-icon3 span, #nav-icon4 span {
  display: block;
  position: absolute;
  height: 1.5px;
  width: 100%;
  background: #fff;
  border-radius: 0;
  opacity: 1;
  left: 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .25s ease-in-out;
  -moz-transition: .25s ease-in-out;
  -o-transition: .25s ease-in-out;
  transition: .25s ease-in-out;
}

#nav-icon1 span:nth-child(1) {
  top: 0px;
}

#nav-icon1 span:nth-child(2) {
  top: 13px;
}

#nav-icon1 span:nth-child(3) {
  top: 20px;
}

#nav-icon1.openstate span:nth-child(1) {
  top: 10px;
  -webkit-transform: rotate(135deg);
  -moz-transform: rotate(135deg);
  -o-transform: rotate(135deg);
  transform: rotate(135deg);
}

#nav-icon1.openstate span:nth-child(3) {
  opacity: 0;
  left: -60px;
}

#nav-icon1.openstate span:nth-child(2) {
  top: 10px;
  -webkit-transform: rotate(-135deg);
  -moz-transform: rotate(-135deg);
  -o-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index:99;
	background:#373f53;
	overflow-y: auto;
	overflow-x: hidden;
	padding: 80px 0;
	box-sizing: border-box;
}

/* Overlay closing cross */
.overlay .overlay-close {
	width: 80px;
	height: 80px;
	position: absolute;
	right: 20px;
	top: 20px;
	overflow: hidden;
	border: none;
	background: url(../img/cross.png) no-repeat center center;
	text-indent: 200%;
	color: transparent;
	outline: none;
	z-index: 100;
}

/* Menu style */
.overlay .nav_surround {
	width:100%;
	text-align:center;
	float:left;
	padding:20px 0;;
	height:auto;
	overflow-y:auto;
	box-sizing:border-box;
}

.overlay ul {
	list-style: none;
	padding: 0;
	margin: 0 auto;
	display: inline-block;
	height: 100%;
	position: relative;
	width:100%;
}
.overlay ul li {
	display: block;
	/*height: 20%;
	height: calc(100% / 5);*/
	line-height:1.7;
	font-size:32px;
	width:100%;
	float:left;
	margin: 0;
}
.overlay ul li ul {
	display: none;
	margin: 0 0 8px;
	float: left;
	width: 100%;
}
.overlay ul li a {
	display: block;
	color: #fff;
	-webkit-transition: color 0.2s;
	transition: color 0.2s;
	float:left;
	width:100%;
	text-decoration: none;
	padding: 0 5%;
	box-sizing: border-box;
	text-align: left;
}
.overlay ul li ul li {
	font-size:26px;
}

.overlay ul li a:hover,
.overlay ul li a:focus {
	color: #ffd186;
}
.overlay ul li.current-menu-item a,
.overlay ul li.current-menu-ancestor a,
.overlay ul li.current-page-ancestor a {
	color: #ffd186;
	text-decoration:none;
	font-weight: bold;
}

.overlay ul li.current-menu-item ul.sub-menu li a,
.overlay ul li.current-menu-ancestor ul.sub-menu li a,
.overlay ul li.current-page-ancestor ul.sub-menu li a {
	color: #ffd186;
	text-decoration:none;
}
	
.overlay ul li ul.sub-menu li a:hover,
.overlay ul li ul.sub-menu li.selected a,
.overlay ul li ul.sub-menu li.current_page_item a {
	color:#ffd186;
}

.overlay ul li ul.sub-menu li.selected a,
.overlay ul li ul.sub-menu li.current_page_item a {
	font-weight:400;
}

/* Effects */
.overlay {
	opacity: 0;
	visibility: hidden;
	-webkit-transition: opacity 0.5s, visibility 0s 0.5s;
	transition: opacity 0.5s, visibility 0s 0.5s;
}

.overlay.open {
	opacity: 1;
	visibility: visible;
	-webkit-transition: opacity 0.5s;
	transition: opacity 0.5s;
}

.overlay .nav_surround {
	-webkit-perspective: 1200px;
	perspective: 1200px;
}

.overlay ul {
	opacity: 0.4;
	-webkit-transform: translateY(-25%) rotateX(35deg);
	transform: translateY(-25%) rotateX(35deg);
	-webkit-transition: -webkit-transform 0.5s, opacity 0.5s;
	transition: transform 0.5s, opacity 0.5s;
}

.overlay.open ul {
	opacity: 1;
	-webkit-transform: rotateX(0deg);
	transform: rotateX(0deg);
}

.overlay.close ul {
	-webkit-transform: translateY(25%) rotateX(-35deg);
	transform: translateY(25%) rotateX(-35deg);
}
	
.overlay_links {
	width:100%;
	float: left;
	padding: 20px 5%;
	color: #fff;
}
	
.overlay_links a {
	color:#fff;
}
	
.overlay_links p {
	font-size:21px;
}

.overlay_social {
	width: 100px;
	display: flex;
	flex-flow: row nowrap;
	list-style-type: none;
	align-items: center;
	float: left;
}

.overlay_social a {
	font-size: 24px;
	margin: 0 20px 0 0;
	color:#fff;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

.overlay_social a:hover {
	color:#F4F4D5;
}
	
/*Menu*/	
.main_nav_surround {
	min-width: 0;
	width: 100%;
}
	
nav {
	display: none;
}	
	
.row {
	margin-top: 80px;
}	
	
p {
	font-size: 18px;
}
	
li {
font-size:18px;}
	
.hero_content {
	width: 90%;
	margin-left: 5%;
	padding: 5em 0 0;
}

.hero {
  min-height: 484px;
}
.hero.large {
  min-height: 860px;
}
	
aside.orange_large {
  width: 100%;
  padding: 12% 9% 10%;	
}
aside.orange_large p {
  font-size: 28px;
}

@media only screen and (max-width: 1023px) {

.hp_blog{
  width: 90%;
	bottom: -5em;
}
	
.home .team_item:nth-child(3) {
	display: none;
}
	
.mob_hide {
	display: none!important;
}

section.nopaddleft,
section.nopaddright {
	padding-left: 5%;
	padding-right: 5%;
}	
	
.col-1,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-10,.col-11,.col-12 {
	width:100%;
}
.col_marg1,.col_marg2,.col_marg3,.col_marg4,.col_marg5,.col_marg6 {
	margin-left:0;
}
	
img.full_pic{
  width: 100%;
  margin: 0 0 50px;
}

.blog_pic {
	width:100%;
	margin: -15em 0 80px;
}

.minusright5 {
	margin-right: -5%;
	position: relative;
}
	
.cta_bottom_inner{
  flex-flow: row wrap;
}
	
.testimonials_block {
	width: 100%;
	margin: 0;
}
	
.cta {
  width: 100%;
  padding: 5em 5%;
  text-align: center;
}
	
.team_area {
	justify-content: space-between;
}	
	
.team_item {
  width: 48%;
  position: relative;
  margin-bottom: 3%;
	margin-right: 0;
}
	
aside.orange_large{
	width: 100%;
	padding: 12% 9% 10%;
	position: relative;
	bottom: 0;
	margin: 20px 0;
}
	
.service_block{
  width: 48%;
}
	
.hero_content h1 br {
	display: none;
}
#mapholder{
	width: 100%;
	float: left;
	height: 300px;
	position: relative;
	right: 0;
	bottom: 0;
	top: -40px;
	z-index: 3;
}
	
.mail_signup {
	width: 100%;
}
	
footer {
  padding: 10em 5% 5em;
}
	
.footer_cols {
	flex-flow: row wrap;
}
	
.footer_col {
	margin-right: 0;
	width: 100%;
	margin-bottom: 20px;
}
	
.copyright {
	margin: 20px 0 0;
	text-align: center;
}
	
.mob_show {
	display: block!important;
}

.mob_hide {
	display: none!important;
}
	
}


/************************************************ Mobile ************************************************/

@media handheld, only screen and (max-width: 767px) {

#logo {
	width: 245px;
	margin: 0;
}
	
.row {
  margin-top: 40px;
}	

.hero {
  width: 100%;
  padding: 3em 5% 0;
}
 .hero_content{
	width: 100%;
	margin-left: 0;
	padding: 5em 0 0;
}
.blog_pic {
	width: 100%;
	margin: 0;
}
	
.hero.large .hero_content{
    margin-left: 0;
    padding: 7vw 0 0;
}
	
.hero.blog {
  min-height: 400px;
  padding-bottom: 30px;
}
	
.team_item span {
  font-size: 1.2em;
}
	
footer {
  padding: 50px 5% 50px;
}

.footer_col{
	margin-right: 0;
	width: 100%;
	margin-bottom: 20px;
	flex-basis: 100%;
	text-align: center;
}	
	
ul.footer_social_icons {
	width: 100%;
	display: flex;
	flex-flow: row nowrap;
	list-style-type: none;
	justify-content: center;
	align-items: center;
	margin: 0 10% 0 0;
}
h1, h2, h3, h4, h5 {
  margin: 0 0 15px;
}

}

@media handheld, only screen and (max-width: 600px) {

.title80 {
  font-size: 50px !important;
}
.title60 {
	font-size:42px!important;
}
.title50 {
	font-size:36px!important;
}
.title35 {
	font-size:30px!important;
}
h1 {
	font-size:28px;
	line-height: 1.3;
}
h2.large {
	font-size:28px;
}
h2 {
	font-size:24px;
}
h3 {
	font-size:22px;
}
h4 {
	font-size:20px;
}
h5 {
	font-size:13px;
	margin: 0;
}
h6 {
	font-size:10px;
}
p {
	font-size:18px;
}
p.large {
	font-size: 26px;
}
.testimonials_block p{
  font-size: 18px;
}
.services_slider{
	margin: 0 0 40px !important;
}
.hp_blog {
  padding: 2.5em 3em;
}
	
.hero {
	min-height: 384px;
}
.hero.large{
	min-height: 860px;
	margin: 0 0 5em;
}
aside.orange_large ul li {
  font-size: 28px;
}
	
.modal_left {
	flex-flow: row wrap;
}	
.modal.team-member .team-image{
  width: 100%;
}
.modal.team-member .modal-header, .modal.team-member .modal-body {
  padding: 30px 5%;
  width: 100%;
}
.service_block{
	width: 100%;
}
.hp_blog p.large
{
  font-size: 24px;
  font-weight: 500;
  margin: 0;
  width: 100%;
}

.fee_table {
	flex-flow: row wrap;
	margin: 0 0 30px;
}
.fee_level{
	width: 100%;
	padding: 3em 5%;
	box-sizing: border-box;
	border-bottom: 4px solid #ffd186;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: center;
	text-align: center;
}
.fee_block:first-child,
.fee_block:nth-child(2),
.fee_block:nth-child(3) {
	width: 100%;
	text-align: center;
}
.fee_level p{
	font-size: 24px;
	font-weight: normal;
}
	
.team_item {
  width: 48%;
  position: relative;
  margin-bottom: 10px;
}
	
.contact_form {
  width: 100%;
  padding: 40px 20px 20px;
}
	
ul.articles {
    justify-content: space-between;
	margin: 0 0 30px;
}

ul.articles li {
    width: 100%;
    margin: 0 0 30px 0;
	box-shadow:none;
	overflow:inherit;
}

ul.articles li img {
	box-shadow: none;
	border-radius:0;
}


ul.articles li .info_block {
    width: 100%;
    position: relative;
    bottom: 0;
    left: 0;
    background: none;
    padding: 15px 0;
    box-sizing: border-box;
    z-index: 2;
    line-height: 1.5em;
    transition: all 0.3s ease-out;
    color: #373f53;
}

.article_surround {
    width: 100%;
    float: left;
    margin: 0;
}

.article_surround .news_side {
    width: 24%;
    float: left;
    position: relative;
    padding: 10px 0;
    margin: 10% 0 0 0%;
}

.article_text {
    width: 100%;
    margin: 0 auto;
}
	
ul.articles li:hover .info_block {
	padding:15px 0;
	background:none;
}

ul.articles li .info_block p {
    font-size: 19px;
    line-height: 1.3em;
}
	
.number_area{
	width: 100%;
	margin: 0 0 35px;
}

.footer_bottom {
	display: flex;
	flex-flow: wrap;
	align-items: center;
	text-align: center;
	justify-content: center;
}
.footer_left{
	width: 82.5px;
	margin-right: 0;
	margin-bottom: 20px;
}
	
}

/* ========================================== */
/* ! Provide higher res assets for iPhone 4   */
/* ========================================== */

@media only screen and (-webkit-min-device-pixel-ratio: 2) { 


}