/*
Theme Name: Insight Property Group
Theme URI: http://insightpropertygroupllc.com/
Version: 1.0
Description: Custom theme for Insight Property Group. Using the Beaver Builder framework.
Author: Yoko Co.
Author URI: https://www.yokoco.com
template: bb-theme
*/

/* Add your custom styles here... */ 


p {
	margin-bottom: 1.5em;
}

.clear {
	clear: both;
}

.text-col {
	max-width: 700px;
	margin: 0 auto;
}

a {
    -webkit-transition: all 400ms ease;
    -moz-transition: all 400ms ease;
    -o-transition: all 400ms ease;
    transition: all 400ms ease;
}

a:hover {
	text-decoration: none;
}

.invert, .invert h1, .invert h2, .invert h3, .invert h4, .invert h5, .invert h6 {
	color: #fff!important;
}

a.fl-button, a.fl-button:visited, .fl-builder-content a.fl-button, .fl-builder-content a.fl-button:visited, .cta-button {
	background: #7ac141;
	border: 0px;
	font-family: Montserrat, sans-serif;
	font-weight: 700;
	font-size: 18px;
	padding: 20px 46px!important;
	border-radius: 0px!important;
	-moz-border-radius: 0px!important;
	-webkit-border-radius: 0px!important;
}

a.fl-button:hover, .fl-builder-content a.fl-button:hover, .cta-button:hover {
	border: 0px;
	background: #00a3e4;
	color: #fff;
	text-decoration: none;
}

a.fl-button:hover span, .fl-builder-content a.fl-button:hover span, .cta-button {
	color: #fff;
}

.fl-page-content button, .fl-page-content input[type=button], .fl-page-content input[type=submit] {
	background: #7ac141;
	border: 0px;
	font-family: Montserrat, sans-serif;
	font-weight: 700;
	font-size: 18px;
	padding: 20px 46px;
	border-radius: 0px;
	-moz-border-radius: 0px;
	-webkit-border-radius: 0px;
}

.fl-page-content button:hover, .fl-page-content input[type=button]:hover, .fl-page-content input[type=submit]:hover {
	background: #00a3e4;
	border: 0px;
	color: #fff;
}

.post-edit-link {
	display: none;
}

/************************************* HOME STUFF **************************************/ 

.home .fl-page-header-primary {
	background: rgba(255,255,255,0);
	border: 0px;
	position: relative;
	z-index: 9999;
}

.home .fl-page-header .fl-page-header-wrap {
	border-bottom: 0px;
}

.home .fl-page-content {
	margin-top: -97px;
	z-index: 99;
}

.home-banner h1 {
	font-size: 72px;
	font-weight: 700;
}

.home-banner .fl-row-content-wrap {
	padding: 280px 20px 180px;
}

.home-banner img {
    -webkit-transition: all 400ms ease;
    -moz-transition: all 400ms ease;
    -o-transition: all 400ms ease;
    transition: all 400ms ease;

}
.home-banner img:hover {
opacity: 0.5;
}

.welcome-message .fl-row-content-wrap {
	padding: 60px 20px 100px;
}

.welcome-message h2 {
	font-size: 60px;
	color: #bbb;
	max-width: 960px;
	margin: 0 auto;
}

.welcome-message h2 strong {
	font-weight: 400;
}

.home-image-parallax .fl-row-content-wrap {
	padding: 270px 20px;
}

.home-bisect .fl-rich-text {
	max-width: 520px;
	margin: 0 auto;
}

.home-bisect .fl-module-content {
	padding: 160px 20px;
}

.home-our-work h2 {
	padding: 50px 20px;
	font-size: 60px;
	color: #bbb;
}

.home-our-work h2 strong {
	font-weight: 400;
}

.home-news {
	margin-bottom: 50px;
}

.home-news h2 {
	font-size: 60px;
}

body .fl-post-grid-title {
	font-size: 20px;
}

/************************************* PAGE STUFF **************************************/ 


h1.fl-post-title {
	font-size: 84px;
	font-weight: 700;
	text-align: center;
}

h1.fl-archive-title {
	font-size: 84px;
	font-weight: 700;
	text-align: center;
	padding-top: 60px;
	margin-top: 0px;
}

.archive .blog-title-header {
	display: none;
}

.search .blog-title-header {
	display: none;
}

.search .fl-archive-title {
	font-size: 36px;
}

.search .fl-sidebar {
	display: none;
}

.search .fl-content-left {
	border: 0px;
	float: none;
	margin: 0 auto;
}

.search .fl-post-title {
	font-size: 24px;
}

.search .fl-post-meta {
	display: none;
}

.fl-archive-nav  {
	margin-bottom: 50px;
	text-transform: uppercase;
	font-family: Montserrat, Lato, sans-serif;
	font-size: 14px;
	letter-spacing: 1px;
}

.restrict-width p {
	max-width: 700px;
	margin: 0 auto 1.5em;
	}

.restrict-width h1, .restrict-width h2, .restrict-width h3, .restrict-width h4, .restrict-width h5, .restrict-width h6 {
	max-width: 700px;
	margin: 0 auto 0.5em;
}

.page .fl-post-title, .blog .fl-post-title, .archive .fl-post-title {
	padding-top: 60px;
}

.page .has-custom-banner {
	background-position: center center;
	background-size: cover;
	background-color: #00a3e4;
}

.page .has-custom-banner h1.fl-post-title {
	color: #fff;
	padding: 180px 10px;
}

.tablepress thead th {
	background-color: #7ac141;
	color: #fff;
}

.tablepress tfoot th {
	background-color: #333;
	color: #fff;
}

#tablepress-Stats .column-1 {
	font-weight: bold;
}

.timeline-block h4 {
	margin-top: 0px;
	margin-bottom: 1em;
	font-size: 24px;
	color: #333;
}

.timeline-block strong {
	color: #bbb;
	font-weight: 400;
	font-family: Montserrat, sans-serif;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 2px;
}

.timeline-block h2 {
    color: #333;
}

.person-page-header {
	padding-top: 60px;
}

.person-item-container {
	width: 25%;
	float: left;
	padding: 0px 35px 40px;
}

.person-item {
	text-align: center;
	padding-bottom: 10px;
}

.person-item img {
	max-width: 100%;
	height: auto!important;
	opacity: 1;
}

.person-item-image {
	background: #00a3e4;
}

#people-grid .person-item img:hover {
	opacity: 0.8;
}

.person-item h5 {
	margin-bottom: 0px;
	font-size: 18px;
}

.person-item-job {
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 2px;
	color: #777;
	height: 44px;
}

h1.person-name {
	margin-bottom: 0px;
	font-size: 60px;
}

.person-job-title {
	text-align: center;
	margin-top: 5px;
	margin-bottom: 0px;
}

.person-headshot {
	text-align: center;
	margin-bottom: 15px;
	max-width: 250px;
	margin: 0 auto;
	border-radius: 128px;
	-moz-border-radius: 128px;
	-webkit-border-radius: 128px;
}

.person-headshot img {
	max-width: 250px;
	margin-bottom: 20px;
	height: auto;
	border-radius: 125px;
	-moz-border-radius: 125px;
	-webkit-border-radius: 125px;
}

.person-page-content .fl-content {
	margin-top: 10px;
}

.person-page-content {
	max-width: 900px;
	margin: 0 auto;
}

.person-page-sidebar h6 {
    text-transform: uppercase;
    font-size: 15px;
    margin-bottom: 0px;
}

.person-meta {
	margin-bottom: 30px;
	font-size: 14px;
	color: #999;
	}

.person-meta strong {
	display: block;
}

.team-cta {
	margin-bottom: 80px;
	margin-left: 15px;
}


/************************************* PROJECT STUFF **************************************/ 

.single-project h1.fl-post-title {
	padding-top: 100px;
	margin-bottom: 0px;
}

.single-project .fl-post-header {
	margin-bottom: 0px;
}


.project-subtitle h2 {
	color: #bbb;
	font-size: 36px;
	text-align: center;
	margin-top: 0px;
}

.project-subtitle .fl-row-content-wrap {
	padding-top: 0px;
}

.project-subtitle img.fl-photo-img {
	max-width: 50px;
	height: auto;
    -webkit-transition: all 400ms ease;
    -moz-transition: all 400ms ease;
    -o-transition: all 400ms ease;
    transition: all 400ms ease;
}


.project-subtitle img.fl-photo-img:hover {
	opacity: 0.6;
}

.project-images .fl-row-content-wrap {
	padding: 0px;
}

.project-large-subtitle h2 {
	text-align: center;
	color: #bbb;
	font-size: 60px;
	margin: 40px 0px 60px;
}

.project-large-subtitle strong {
	font-weight: 400;
}

.project-address {
	color: #555;
	font-family: Montserrat, sans-serif;
	text-transform: uppercase;
	font-size: 14px;
}

.project-address p {
	margin-bottom: 0px;
}

.project-details h6 {
	text-transform: uppercase;
	font-size: 14px;
	margin-bottom: 0px;
}

.project-details {
	color: #aaa;
}

.project-content-meta {
	padding-left: 70px;
}

.project-gallery {
	margin: 70px 0px 0px;
}

.project-gallery .fl-row-content-wrap {
	padding: 0px;
}

.project-gallery .fl-module-content {
	margin: 0px;
}

.project-gallery .fl-gallery-item {
	width: 25%;
	height: auto!important;
	position: relative!important;
	left: auto!important;
	top: auto!important;
	float: left;
    -webkit-transition: all 400ms linear;
    -moz-transition: all 400ms linear;
    -o-transition: all 400ms linear;
    transition: all 400ms linear;
}


.project-gallery .fl-gallery-item:hover {
	opacity: 0.7;
}

.project-gallery .fl-photo-content {
	width: 100%;
}

.project-gallery .fl-gallery-item img {
	width: 100%!important;
}

.project-related {
	padding-top: 50px;
	padding-bottom: 80px;
	background-color: #f4f4f4;
}

.project-related h2 {
	color: #bbb;
	margin-bottom: 80px;
}

.project-related img {
    -webkit-transition: all 400ms linear;
    -moz-transition: all 400ms linear;
    -o-transition: all 400ms linear;
    transition: all 400ms linear;
}

.project-related img:hover {
	opacity: 0.7;
}

.project-grid-item {
	width: 33.33%;
	padding-bottom: 33.33%;
	float: left;
	position: relative;
	background-size: cover;
	background-position: center center;
}

.project-grid-link {
	position: absolute;
	display: block;
	width: 100%;
	height: 100%;
	font-family: Montserrat, Arial, sans-serif;
	text-decoration: none;
	color: #fff;
    -webkit-transition: all 400ms linear;
    -moz-transition: all 400ms linear;
    -o-transition: all 400ms linear;
    transition: all 400ms linear;
}

.project-grid-link:hover {
	text-decoration: none;
	color: #fff;
	background: rgba(0,0,0,0.5);
}

.project-grid-content {
	opacity: 0;
	text-align: center;
    position: relative;
	padding: 20px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -webkit-transition: all 400ms linear;
    -moz-transition: all 400ms linear;
    -o-transition: all 400ms linear;
    transition: all 400ms linear;
}

.project-grid-content h3 {
	color: #fff;
}

.project-grid-item:hover .project-grid-content {
	opacity: 1;
}

.project-grid-button {
	display: inline;
	background: #7ac141;
	padding: 6px 12px;
	font-size: 16px;
}


.project-all-item-container {
	width: 33.3%;
	float: left;
	padding: 0px 35px 40px;
}

.project-all-item {
	text-align: center;
	padding-bottom: 10px;
}

.project-all-item img {
	max-width: 100%;
	height: auto!important;
    -webkit-transition: all 400ms ease;
    -moz-transition: all 400ms ease;
    -o-transition: all 400ms ease;
    transition: all 400ms ease;
  background-blend-mode: multiply;
}

.project-all-item-image {
	background: #fff;
}

.project-all-item img:hover {
	opacity: 0.8;
}

.project-all-item h5 {
	margin-bottom: 0px;
	font-size: 18px;
	height: 42px;
}

.project-all-item-job {
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 2px;
	color: #777;
	height: 44px;
}

.single-project .addthis_toolbox, .single-person .addthis_toolbox {
	display: none;
}

/************************************* BLOG **************************************/ 

.fl-post-meta  {
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 1px;
    font-family: "Montserrat", sans-serif;
    font-style: normal;
}

.fl-post .fl-post-thumb {
}

.fl-post-thumb {
	float: right;
	width: 25%;
}

.fl-post-thumb img {
	max-width: 100%;
	border-radius: 250px;
	-moz-border-radius: 250px;
	-webkit-border-radius: 250px;
	margin-left: 20px;
}

.single.single-format-standard .fl-post-title {
	text-align: left;
	font-size: 36px;
	color: #7ac141;
}

.single-person .fl-post-title {
	text-align: center;
}

.single-project .fl-post-title {
	text-align: center;
}

.blog .fl-post .fl-post-title, .archive .fl-post .fl-post-title {
	padding-top: 0px;
	font-size: 30px;
}

h3#reply-title {
	font-size: 20px;
	font-weight: 900;
}

h3.fl-comments-list-title {
	font-size: 20px;
	font-weight: 900;
}

.fl-post-feed-date {
    	font-family: "Montserrat", Lato, Arial, sans-serif;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 1px;
}

/************************************* SIDEBAR **************************************/ 

h4.fl-widget-title {
	text-transform: uppercase;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 1px;
}

.fl-widget ul li {
	border-top: 1px solid rgba(0,0,0,0.1);
	padding-top: 10px;
	margin-top: 10px;
}

.widget_recent_entries a {
	color: #aaa;
}

.widget_recent_entries a:hover {
	color: #7ac141;
}

#text-3 {
	border: 1px solid #7ac141;
	padding: 10px 20px 40px;
}


/************************************* CONTACT & FORMS **************************************/ 

.contact-details strong {
    	font-family: "Montserrat", Lato, Arial, sans-serif;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 1px;
}

.contact-details p {
	margin-bottom: 0px;
}

.contact-details h5 {
	margin-bottom: 20px;
}

.visual-form-builder fieldset {
	margin: 0px 0px 20px;
	border: 1px solid rgba(0,0,0,0.1);
	padding: 15px;
	background-color: #fff;
}

.visual-form-builder .vfb-legend {
	border-bottom: 0px;
	padding: 0px;
}

input.vfb-large, input[type="text"].vfb-large, input[type="tel"].vfb-large, input[type="email"].vfb-large, input[type="url"].vfb-large, select.vfb-large, textarea.vfb-textarea {
	padding: 8px;
}

.visual-form-builder label, label.vfb-desc {
    font-family: "Montserrat", Lato, Arial, sans-serif;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
	color: #555;
}

/************************************* FOOTER **************************************/ 

footer {
    	font-family: "Montserrat", sans-serif;
	font-size: 16px;
	line-height: 2.4em;
}

footer img {
	margin-bottom: 20px;
}

footer .fl-page-footer-container {

}

.fl-page-footer-container .fl-page-footer-text {
	text-align: left;
}

.fl-page-footer {
	border-top: 0px;
}

.fl-page-footer-widgets-container {
	padding-top: 70px;
}

#menu-footer-navigation {
	text-align: right;
	font-size: 24px;
}

#menu-footer-navigation a:hover {
	text-decoration: none;
}

/************************************* MEDIA QUERIES **************************************/ 





@media (min-width: 1100px) {
	.fl-page-nav-right .fl-page-header-container {
		width: 96%;
		max-width: 96%;
	}
	.fl-page-footer-widgets .fl-page-footer-widgets-container {
		width: 90%;
		max-width: 96%;
	}
	.fl-page-footer .fl-page-footer-container {
		width: 90%;
		max-width: 96%;
	}
}

@media (min-width: 992px) {
	.fl-page-nav-right .fl-page-header-row {
	    width: 100%;
	}
}


@media (max-width: 1440px) and (min-width: 992px) {
	.fl-page-nav .navbar-nav > li > a {
		padding: 15px 16px;
	}
	.fl-page-header .col-md-4 {
		width: 25%;
	}
	.fl-page-header .col-md-8 {
		width: 75%;
	}
	.fl-page-nav-right .fl-page-header-container {
		padding-left: 10px;
		padding-right: 10px;
	}


}


@media (max-width: 1200px) and (min-width: 992px) {
	.fl-page-nav .navbar-nav > li > a {
		padding: 15px 13px;
	}
}

@media (max-width: 1024px) {

	h1.fl-post-title, h1.fl-archive-title {
		font-size: 72px;
	}
	.single-person .fl-post-title {
		font-size: 48px;
	}

	.person-item-container {
		width: 33.3%;
		float: left;
		padding: 0px 20px 40px;
	}
	.home-banner h1 {
		font-size: 60px;
	}
	.home-banner .fl-row-content-wrap {
		padding: 180px 20px 80px;
	}
	.welcome-message h2 {
		font-size: 48px;
	}
	.home-bisect h3 {
		font-size: 24px;
	}
	.home-bisect .fl-module-content {
		padding: 100px 20px;
	}
	.home-our-work h2 {
		font-size: 48px;
	}
	.home-news h2 {
		font-size: 48px;
	}
}

@media (max-width: 991px) {
	.home .fl-page-content {
		margin-top: -130px;
	}
	.home .fl-page-nav-wrap {
		border: 0px;
	}
	.home .fl-page-header .fl-page-header-wrap {
		background: rgba(0,0,0,0.5);
	}
}


@media (max-width: 850px) {
	.fl-page-nav .navbar-nav > li > a {
		padding: 15px 16px;
	}
}

@media (max-width: 768px) {

	h1.fl-post-title, h1.fl-archive-title {
		font-size: 60px;
	}

	.person-item-container, .project-all-item-container {
		width: 50%;
		float: left;
		padding: 0px 10px 40px;
	}
	.project-subtitle h2 {
		font-size: 24px;
	}
	.project-large-subtitle h2 {
		font-size: 48px;
	}
	.project-gallery {
		margin: 10px 0px;
	}
	.project-related h2 {
		font-size: 36px;
		margin-bottom: 0px;
	}
	.home .fl-col-small {
		max-width: 100%;
	}
	.welcome-message h2 {
		font-size: 30px;
	}
	.home-our-work h2 {
		font-size: 30px;
	}
	.home-news h2 {
		font-size: 30px;
	}


}


@media (max-width: 767px) {
	.home .fl-page-header-primary {
    		border-color: #27c2ff;
    		background-color: #00a3e4;
	}
	.home .fl-page-header .fl-page-header-wrap {
		background: none;
	}
	.home .fl-page-content {
		margin: 0;
	}
	.fl-page-nav-toggle-icon.fl-page-nav-toggle-visible-mobile .fl-page-nav .navbar-toggle {
    		font-size: 30px;
    		line-height: 27px;
			top: 10px; 
	}
	.fl-page-header-primary .fl-logo-img {
		max-height: 42px;
		width: auto!important;
	}
	h1 {
		font-size: 40px;
	}
	h2 {
		font-size: 30px;
	}
	h3 {
		font-size: 24px;
	}

	h4 {
		font-size: 21px;
	}
	h5 {
		font-size: 18px;
	}
	h6 {
		font-size: 18px;
	}
	.timeline-block h4 {
		font-size: 18px;
	}
	.project-content-meta {
		padding: 0px 10px;
	}
	#menu-footer-navigation {
		text-align: center;
	}
	footer img {
		max-width: 180px!important;
	}
	.fl-page-footer-widgets-container {
		padding-top: 30px;
		text-align: center;
	}
	.fl-page-footer-container .fl-page-footer-text {
		text-align: center;
	}
}

@media (max-width: 719px) {

	h1.fl-post-title, h1.fl-archive-title {
		font-size: 40px;
	}
	.fl-post-header {
		margin-bottom: 0px;
	}
	
	.page .fl-post-title {
		margin-top: 0px;
	}

	.page .has-custom-banner h1.fl-post-title {
	padding: 80px 10px;
	}

	.person-item-container, .project-all-item-container {
		width: 50%;
		float: left;
		padding: 0px 10px 20px;
	}
	.project-subtitle h2 {
		font-size: 18px;
	}
	.project-large-subtitle h2 {
		font-size: 24px;
	}
	.project-gallery .fl-gallery-item {
		width: 33.3%;
	}
	.home-banner h1 {
		font-size: 36px;
	}
	.home-banner .fl-row-content-wrap {
		padding: 70px 20px 20px;
	}
	.home-bisect h3 {
		font-size: 21px;
	}
	.home-bisect .fl-module-content {
		padding: 50px 20px;
	}
	.project-grid-item {
		width: 100%;
		padding-bottom: 100%;
	}
	.project-grid-link {
   		 background: rgba(0,0,0,0.5);
	}
	.project-grid-content {
		opacity: 1;
	}

	.single .fl-post-title {
	font-size: 30px;
	}
	.blog .fl-post .fl-post-title, .archive .fl-post .fl-post-title {
	font-size: 24px;
	}
	.single-project h1.fl-post-title {
		padding-top: 50px;
	}
	.project-subtitle h2 {
		margin-bottom: 0px;
	}
	.project-large-subtitle h2 {
		margin: 10px 0px 20px;
	}
	.project-related {
		padding-top: 0px;
	}
	.project-related h2 {
		font-size: 24px;
	}

}


@media (max-width: 540px) {
	.fl-logo-img {
		max-width: 120px;
	}
	.home-image-parallax .fl-row-content-wrap {
		padding: 150px 20px;
	}
	.person-item-container, .project-all-item-container {
		width: 100%;
		float: left;
		padding: 0px 10px 20px;
	}
	.home-our-work h2 {
		padding: 20px;
	}
	.home-news h2 {
		margin-top: 0px;
	}
	.home-banner h1 {
		font-size: 24px;
	}
	.welcome-message h2 {
		font-size: 21px;
	}
	.welcome-message .fl-row-content-wrap {
		padding: 40px 20px 40px;
	}
	.contact-details h5 {
		font-size: 14px;
	}
	.single-person .fl-post-title {
		font-size: 24px;
	}
	.person-job-title {
		font-size: 18px;
	}
	.person-headshot img {
		max-width: 150px;
	}		
	.search .fl-archive-title {
		font-size: 21px;
	}	
	.search .fl-post-title {
		font-size: 18px;
	}
}