@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/* Table of Content
==================================================
	#Site Variables
	#Site Styles
	#UIKit Styles
	#Page Styles
	#Media Queries
	#Font-Face */
	

/* #Site Variables
================================================== 
:root {
  --primary: #242936;
  --secondary: #333F49;
  --light: #EFEFEF;
  --dark: #1C202B;
  --white: #ffffff;
  --gray: #C1C1C1;
  --text: #000000;
  --navigation: #ffffff;
  
  --primary-font: 'Lato', 'Arial', sans-serif;
  --secondary-font: 'Optima', serif;
}
*/



/* #Site Styles
================================================== */
*				{ outline:none; }
html, body		{ color:var(--text); font-size:16px; font-weight:400; font-family:var(--primary-font); line-height:1.5rem; }

.aligncenter 	{ text-align:center; }
.alignleft		{ text-align:left; }
.alignright		{ text-align:right; }
	img.aligncenter { float:none; display:block; margin:0 auto 15px; }
	img.alignleft	{ float:left; margin-right:15px; }
	img.alignright	{ float:right; margin-left:15px; }

.w900 			{ font-weight:900; }
.w800			{ font-weight:800; }
.w700			{ font-weight:700; }
.w600			{ font-weight:600; }
.w500			{ font-weight:500; }
.w400			{ font-weight:400; }
.w300			{ font-weight:300; }
.w200			{ font-weight:200; }
.w100			{ font-weight:100; }

.font6			{ font-size:0.6rem; }
.font7			{ font-size:0.7rem; }
.font8			{ font-size:0.8rem; }
.font9			{ font-size:0.9rem; }
.font10			{ font-size:1.0rem; }
.font11			{ font-size:1.1rem; }
.font12			{ font-size:1.2rem; }
.font13			{ font-size:1.3rem; }
.font15			{ font-size:1.5rem; }
.font18			{ font-size:1.8rem; }
.font20			{ font-size:2.0rem; }
.font25			{ font-size:2.5rem; }
.font30			{ font-size:3.0rem; }
.font35			{ font-size:3.5rem; }
.font40			{ font-size:4.0rem; }
.font45			{ font-size:4.5rem; }

.s1				{ letter-spacing:.1em; }
.s2				{ letter-spacing:.2em; }
.s3				{ letter-spacing:.3em; }
.s4				{ letter-spacing:.4em; }
.s5				{ letter-spacing:.5em; }
.s6				{ letter-spacing:.6em; }
.s7				{ letter-spacing:.7em; }
.s8				{ letter-spacing:.8em; }

.lh0			{ line-height:1.0em; }
.lh1			{ line-height:1.1em; }
.lh2			{ line-height:1.2em; }
.lh3			{ line-height:1.3em; }
.lh4			{ line-height:1.4em; }
.lh5			{ line-height:1.5em; }
.lh8			{ line-height:1.8em; }
.lh20			{ line-height:2.0em; }
.lh25			{ line-height:2.5em; }

.br5 			{ border-radius:5px; }
.br10 			{ border-radius:10px; }
.br15 			{ border-radius:15px; }
.br20 			{ border-radius:20px; }
.br25 			{ border-radius:25px; }

h1, h2, h3, h4, .uk-h1, .uk-h2, .uk-h3, .uk-h4	{ font-family:var(--secondary-font); font-weight:300; color:inherit; line-height:1.2em; }

h1, .uk-h1 		{ font-size:5.000rem; }
h2, .uk-h2 		{ font-size:2.250rem; }
h3, .uk-h3 		{ font-size:1.500rem; }
h4, .uk-h4 		{ font-size:1.250rem; }

p				{ font-size:1.00rem; line-height:1.5em; }

b, 
strong, 
.uk-text-bold	{ font-weight:700; }

a, .uk-link		{ color:var(--primary); text-decoration:none; }
	a:hover, .uk-link:hover { color:inherit; text-decoration:underline; }

em 				{ color:inherit; }

blockquote	{ font-weight:300; color:inherit; line-height:1.8em; position:relative; }
	blockquote cite { font-style:normal; font-weight:800; font-size:.875rem; text-transform:uppercase; }
	blockquote::before { content:'“'; font-family:'Arial', sans-serif; font-size:3em; font-style:normal; display:block; position:absolute; top:0; left:0; }

.font-primary { font-family:var(--primary-font); }
.font-secondary { font-family:var(--secondary-font); }


/* #UIKit Styles
================================================== */
.uk-background-primary, .uk-section-primary { color:var(--white); }
.uk-background-secondary, .uk-section-secondary { color:var(--primary); }
.uk-background-dark, .uk-section-dark { background:var(--dark); color:var(--white); }
.uk-background-gray { background:#E2E2E2 }

.uk-container-expand-left.uk-container-large, .uk-container-expand-right.uk-container-large { padding-right:0; max-width: calc(50% + (1400px / 2) - 0px); }

.uk-text-contrast { color:var(--white); }
.uk-text-default { color:var(--text); }
.uk-text-tertiary { color:var(--tertiary); }

.uk-button { border-radius:5px; padding:10px 20px 8px; font-weight:700; letter-spacing:.05em; font-size:.8rem; line-height:1em; }
.uk-button-secondary { color:var(--primary); }
.uk-button-contrast { background:var(--white); color:var(--primary); }
.uk-button-contrast:hover { background:var(--dark); color:var(--white); }

.uk-padding-xsmall { padding:10px; }

.uk-card { color:inherit; }
.uk-card-xsmall { padding:10px; }

/* #Page Styles
================================================== */
.alert-text { padding:3px 0; }
.alert-text p { margin-bottom:0; }

.alert-graphic { padding:0; }
.alert-graphic img { width:100%; }

.utl { background:var(--dark); color:var(--white); }

.header { padding:10px 0; z-index:981; }
	.header .logo { width:225px; }
	
	.header .uk-navbar-nav>li>a { font-family:var(--primary-font); color:var(--navigation); text-transform:inherit; font-weight:600; font-size:1rem; }
	
	.home .header { position:absolute; top:0; left:0; width:100%; background:none; }
	
.border { border:1px solid #C3C3C3; }
	
.quick-contact { background:var(--secondary); padding:5px 15px; display:flex; align-items:center; color:var(--primary); }
	.quick-contact ul { list-style:none; display:flex; gap:10px; margin:0 0 0 15px; padding:0; }
	.quick-contact ul li { font-size:.8em; }
	.quick-contact ul li a { color:var(--primary); text-transform:uppercase; text-decoration:underline; }
	
.quick-nav { display:flex; background:var(--white); border:1px solid var(--light); font-size:.875em; font-weight:700; color:var(--primary); padding:0 10px; }
	.quick-nav a { text-decoration:none; }
	.quick-nav .uk-subnav { margin:0 0 0 5px; }
	.quick-nav .uk-subnav>* { padding:0; }
	.quick-nav .uk-subnav>*>:first-child { text-transform:inherit; padding:0 10px; color:var(--primary); }
	.quick-nav .uk-subnav>*.uk-active>:first-child { background:var(--primary); color:var(--white) !important; }
	.quick-nav ul li a:hover { background:#ddd; color:var(--primary) !important; }
	
.show-hide-nav { background:#edf2f7 !important; border-radius:30px !important; padding:10px !important; margin:25px auto !important; display:inline-block !important; text-align:center !important; }
	.show-hide-nav ul { background:rgba(255,255,255,.4); border-radius:30px; padding:0 30px; margin:0; list-style:none; }
	.show-hide-nav ul li { display:inline-block; margin:0; border-right:2px solid var(--light); }
	.show-hide-nav ul li a { display: flex; align-items: center; justify-content: center; padding:10px 30px; color:var(--secondary); font-weight:700; text-transform:uppercase; font-size:.875em; border:0 !important; }
	.show-hide-nav ul li.uk-active a { text-decoration:none; background:var(--secondary); color:var(--white); }
	.show-hide-nav ul li a span { display:inline-block; margin:0 10px; }
	.show-hide-nav ul li:last-child { border-right:0; }
	.show-hide-nav .uk-tab::before { border:0; }
	
	.show-hide-sub-nav { display: flex; justify-content: center; flex-wrap: wrap; list-style: none; margin: 0; padding: 0; }
	.show-hide-sub-nav li { margin: 0 5px; }
	.show-hide-sub-nav a { display: inline-block; padding: 8px 15px; text-decoration: none; background: #fff; color: #999; }
	.show-hide-sub-nav li.uk-active a { background: var(--primary); color: #fff; }
	.show-hide-sub-nav a:hover { background: var(--primary); color: #fff; }

.toggle-btn { background:var(--secondary); color:var(--white); text-transform:uppercase; text-decoration:none; font-size:.85em; font-weight:600; border-radius:10px; padding:8px 10px; letter-spacing:.05em; width:100%; box-sizing:border-box; text-align:center; display:block; }
	.toggle-btn::after { display:inline-block; margin-left:15px; font-style:normal; font-variant:normal; text-rendering:auto; -webkit-font-smoothing:antialiased; font-family:"Font Awesome 5 Pro"; font-weight:900; content:"\f107"; }
	.toggle-btn:hover { color:var(--white); text-decoration:none; }
	
.comm-nav { padding:0; margin:0; background:var(--primary); }
	.comm-nav .uk-subnav>*>:first-child { color:var(--white); font-size:.875em; font-weight:600; padding:8px 15px; }
	.comm-nav .uk-subnav-divider>:nth-child(n+2):not(.uk-first-column)::before { border-color:rgba(255,255,255,0.2); margin:0; }
	.comm-nav .uk-subnav>*>:first-child::after { display:inline-block; margin-left:3px; font-style:normal; font-variant:normal; text-rendering:auto; -webkit-font-smoothing:antialiased; font-family:"Font Awesome 5 Pro"; font-weight:900; content:"\f105"; }
	.comm-nav.uk-active .uk-subnav>*>:first-child { padding:8px 10px; }
	.comm-nav .uk-subnav>* { padding-left: 0px; }
	
.featured-block { margin:25px 0; background:var(--light); }

.featured-communities { position:relative; background:var(--light); border-top:1px solid #ddd; border-bottom:1px solid #ddd; }
	.featured-communities:before { content:''; position:absolute; bottom:-1px; left:0; width:100%; height:30%; border-top:1px solid #ddd; background:var(--white); }
	.featured-communities > * { position:relative; }

.featured-homes { position:relative; }
	.featured-homes:before { content:''; position:absolute; bottom:0; left:0; width:100%; height:18%; background:var(--white); }
	.featured-homes > * { position:relative; }
	
.embed-container { 	position: relative; padding-bottom: 56.25%; overflow: hidden; max-width: 100%; height: auto;} 
	.embed-container iframe,
	.embed-container object,
	.embed-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
	
.grecaptcha-badge { display:none !important; }

.footer {}


#breadcrumbs { font-size:.875em; opacity:.8; }

.full-bleed {  width: 100vw;  margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.editor-styles-wrapper .full-bleed { width: auto; max-width: 100%; margin-left: 0; margin-right: 0; }

.custom-popup-modal { position: fixed; inset: 0; display: none; z-index: 99999; }
.custom-popup-modal.is-open { display: flex; align-items: center; justify-content: center; padding: 24px; }
.custom-popup-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.6); }
.custom-popup-dialog { position: relative; width: 100%; max-width: 960px; max-height: 90vh; overflow: auto; background:var(--white); padding: 20px; border-radius: 6px; box-shadow: 0 10px 30px rgba(0,0,0,.25); z-index: 1; }
.custom-popup-close { position: absolute; top: 10px; right: 10px; border: 0; background: transparent; font-size: 22px; line-height: 1; cursor: pointer; }

.custom-sticky { position: fixed; left: 0; right: 0; z-index: 99998; transform: translateY(110%); opacity: 0; pointer-events: none; transition: transform 250ms ease, opacity 250ms ease; }
.custom-sticky.is-visible { transform: translateY(0); opacity: 1; pointer-events: auto; }
.custom-sticky-inner { background: #fff; border-top: 1px solid rgba(0,0,0,.12); box-shadow: 0 -10px 30px rgba(0,0,0,.12); padding: 14px 16px; }
.custom-sticky-close { float: right; border: 0; background: transparent; font-size: 20px; cursor: pointer; }

html.has-custom-popup-open, html.has-custom-popup-open body { overflow: hidden; }


/* #Media Queries
================================================== */
	@media only screen and (max-width: 1220px) { }

	/* Smaller than standard 960 (devices and browsers) */
	@media only screen and (max-width: 959px) { }

	/* Tablet Portrait size to standard 960 (devices and browsers) */
	@media only screen and (min-width: 768px) and (max-width: 959px) {}

	/* All Mobile Sizes (devices and browser) */
	@media only screen and (max-width: 767px) { }

	/* Mobile Landscape Size to Tablet Portrait (devices and browsers) */
	@media only screen and (min-width: 480px) and (max-width: 767px) {}

	/* Mobile Portrait Size to Mobile Landscape Size (devices and browsers) */
	@media only screen and (max-width: 479px) {}


/* #Font-Face
================================================== */
		
/*	@font-face {
		font-family: 'FontName';
		src: url('../fonts/FontName.eot');
		src: url('../fonts/FontName.eot?iefix') format('eot'),
			 url('../fonts/FontName.woff') format('woff'),
			 url('../fonts/FontName.ttf') format('truetype'),
			 url('../fonts/FontName.svg#webfontZam02nTh') format('svg');
		font-weight: normal;
		font-style: normal; }
*/