@import url('https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,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; }

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; text-transform:inherit; }

h1, .uk-h1 		{ font-size:2.750rem; }
h2, .uk-h2 		{ font-size:2.250rem; }
h3, .uk-h3 		{ font-size:1.750rem; }
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-background-secondary { color:var(--white); }

.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-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:200x; }
	
	.header .uk-navbar-nav>li>a { font-family:var(--primary-font); color:var(--navigation); }
	
.quick-contact { background:var(--secondary); padding:5px 15px; display:flex; align-items:center; color:var(--white); }
	.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(--white); 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(--secondary); 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(--secondary); }
	.quick-nav .uk-subnav>*.uk-active>:first-child { background:var(--secondary); color:var(--white) !important; }
	.quick-nav ul li a:hover { background:#ddd; color:var(--secondary) !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(--secondary); color: #fff; }
	.show-hide-sub-nav a:hover { background: var(--secondary); 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(--secondary); }
	.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); }
	
.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; }
*/


/* Reserve at Knapp Bluff layout
================================================== */
:root {
  --reserve-blue: #35434f;
  --reserve-taupe: #a28b76;
  --reserve-ink: #272727;
  --reserve-muted: #707070;
  --reserve-soft: #f4f4f4;
  --reserve-line: #d3d3d3;
  --reserve-sans: "Open Sans", Arial, sans-serif;
  --reserve-serif: "Playfair Display", Georgia, serif;
}

html {
  scroll-behavior: smooth;
}

body {
  color: var(--reserve-blue);
  font-family: var(--reserve-sans);
  font-size: 16px;
  line-height: 1.5;
}

img {
  max-width: 100%;
}

.reserve-home h1,
.reserve-home h2,
.reserve-home h3,
.site-footer h1,
.site-footer h2,
.site-footer h3 {
  color: var(--reserve-blue);
  font-family: var(--reserve-serif);
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
}

.reserve-home h1 {
  font-size: 4.5em;
  line-height: 1;
  margin: 0 0 22px;
}

.reserve-home h2 {
  font-size: 3em;
  line-height: 1em;
  margin: 0;
}

.reserve-home h3 {
  font-size: 2em;
  line-height: 1em;
}

.site-header {
  box-shadow: 0 1px 0 rgba(53, 67, 79, 0.12);
  position: relative;
  z-index: 5;
}

.site-header .uk-navbar-container {
  min-height: 110px;
}

.site-header .uk-logo img {
  height: auto;
  max-height: 65px;
  object-fit: contain;
  width: min(376px, 54vw);
}

.site-header .uk-navbar-nav > li > a {
  color: var(--reserve-blue);
  font-family: var(--reserve-sans);
  font-size: .875em;
  font-weight: 800;
  min-height: 50px;
  padding: 0 10px;
  text-transform: uppercase;
}

.site-header .uk-navbar-nav {
  gap: 10px;
}

.site-header .uk-navbar-nav > li > a:hover,
.footer-nav a:hover,
.text-link:hover {
  color: var(--reserve-taupe);
}

.social-tools {
  gap: 18px;
}

.social-tools a {
  color: var(--reserve-blue);
}

.brand-outline,
.brand-button {
  border-radius: 30px;
  font-size: .875em;
  font-weight: 700;
  line-height: 40px;
  min-height: 40px;
  padding: 0 30px;
  text-transform: uppercase;
}

.brand-outline {
  border: 2px solid var(--reserve-blue);
  color: var(--reserve-blue);
}

.brand-outline:hover {
  border-color: var(--reserve-taupe);
  color: var(--reserve-taupe);
}

.brand-button,
.uk-button-primary.brand-button {
  background: var(--reserve-blue);
  color: #fff;
}

.brand-button:hover,
.uk-button-primary.brand-button:hover {
  background: #25313b;
  color: #fff;
}

.hero {
  background: var(--reserve-soft);
}

.hero-media {
  height: clamp(360px, 40vw, 500px);
  overflow: hidden;
}

.hero-media img,
.feature-image,
.wide-feature,
.area-media img,
.gallery-strip img {
  background: linear-gradient(135deg, #f3f1ee, #d8d1c9);
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.intro-section {
  overflow: hidden;
  padding-bottom: 72px;
  padding-top: 72px;
}

.eyebrow {
  color: var(--reserve-taupe);
  font-size: 22px;
  font-weight: 800;
  letter-spacing: 0.1em;
  margin: 0 0 12px;
  text-transform: uppercase;
}

.subhead {
  color: var(--reserve-taupe);
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 800;
  letter-spacing: 0.04em;
  margin-bottom: 28px;
  text-transform: uppercase;
}

.lead-copy {
  color: var(--reserve-ink);
  font-size: 1.2em;
  line-height: 1.45;
}

.feature-image {
  aspect-ratio: 1.24;
}

.signup-band {
  background: var(--reserve-soft);
}

.signup-band h2 {
  margin-bottom: 8px;
}

.signup-band p {
  color: var(--reserve-ink);
  margin: 0;
}

.signup-mark {
  height: 90px;
  width: 90px;
}

.reserve-home .uk-input {
  border: 1px solid var(--reserve-muted);
  color: var(--reserve-ink);
  height: 40px;
}

.reserve-home .uk-input:focus {
  border-color: var(--reserve-blue);
}

.gallery-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:2px;
  margin:2px 0;
}

.gallery-strip img {
  aspect-ratio: 3 / 2;
}

.community-section {
  background: var(--reserve-soft);
  padding: 0;
}

.community-section .uk-container {
  padding-bottom: 60px;
  padding-top: 60px;
}

.feature-list {
  color: var(--reserve-ink);
  font-size: 1.2em;
  font-weight: 500;
  margin: 34px 0;
}

.feature-list li {
  align-items: flex-start;
  display: flex;
  gap: 18px;
}

.feature-list .uk-icon {
  color: var(--reserve-taupe);
  flex: 0 0 auto;
  margin-top: 4px;
}

.wide-feature {
  aspect-ratio: 2.24;
}

.action-card {
  border: 1px solid #aaa;
  box-shadow: none;
  min-height: 201px;
  padding: 28px 26px;
}

.action-card h3 {
  margin: 8px 0 14px;
}

.action-card p {
  color: var(--reserve-ink);
  line-height: 1.35;
  margin-bottom: 18px;
}

.card-icon {
  color: var(--reserve-taupe);
}

.text-link {
  align-items: center;
  color: var(--reserve-blue);
  display: inline-flex;
  font-size: 16px;
  font-weight: 800;
  gap: 8px;
  text-transform: uppercase;
}

.area-section {
  background: var(--reserve-blue);
  overflow: hidden;
  position: relative;
}



.area-layout {
  display: flex;
  flex-wrap: wrap;      /* lets them stack on mobile */
}
.area-map {
  flex: 1 1 50% !important;
  width: 50% !important;
  min-width: 0 !important;
  min-height: 260px;
  position: relative;
  overflow: hidden;
}

.area-map iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.area-media {
  flex: 1 1 50% !important;
  width: 50% !important;
  min-width: 0 !important;
  min-height: 260px;
  display: flex;
  align-items: center;
  overflow: hidden;
  position: relative;
}

.area-media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}
.area-media .area-content {
  position: relative;
  z-index: 2;
}

.area-content {
  box-sizing: border-box;
  padding-left: max(30px, calc((100vw - 1400px) / 2 + 30px));
  position: relative;
  z-index: 1;
}

.area-layout {
  align-items: stretch;
  display: flex;
}

/* map now on the LEFT */
.area-map {
  order: 1;
  flex: 1 1 auto;
  min-height: 260px;
  position: relative;
  overflow: hidden;
}
.area-map iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.area-content h2,
.area-content p {
  color: #fff;
  max-width: 680px;
}

.area-content p {
  font-size: 24px;
  line-height: 1.35;
  margin-top: 26px;
}

.builder-section {
  background: var(--reserve-soft);
}

.builder-card {
  border: 1px solid var(--reserve-line);
  box-shadow: 0 3px 25px rgba(0, 0, 0, 0.16);
  padding: clamp(28px, 4vw, 54px);
}

.builder-card p:not(.eyebrow) {
  color: var(--reserve-ink);
  font-size: 1.1em;
  line-height: 1.5;
}

.site-footer {
  background: var(--reserve-blue);
  color: #fff;
}

.footer-nav a {
  color: #fff;
  font-size: 1em;
  font-weight: 500;
  text-transform: uppercase;
}

.footer-logo {
  max-height: 185px;
  object-fit: contain;
}

address {
  font-style: normal;
  line-height: 1.75;
}

.site-footer hr {
  border-color: rgba(255, 255, 255, 0.29);
}

.copyright {
  font-size: 15px;
  margin-bottom: 0;
}

@media (max-width: 1199px) {
  .site-header .uk-navbar-container {
    min-height: 100px;
  }

  .site-header .uk-navbar-nav > li > a {
    font-size: 14px;
    padding: 0 8px;
  }
}

@media (max-width: 959px) {
  body {
    font-size: 17px;
  }

  .site-header .uk-navbar-container {
    min-height: 90px;
  }

  .gallery-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .community-section .uk-container {
    padding-left: 30px;
    padding-right: 30px;
  }

  .area-layout {
    display: block;
  }

  .area-media {
    clip-path: none;
    flex-basis: auto;
    margin-right: 0;
  }

  .area-media::after {
    background: rgba(53, 67, 79, 0.72);
  }

  .area-content {
    max-width: calc(100% - 60px);
    padding-left: 30px;
    padding-right: 0;
  }

    .area-map,
  .area-media {
    flex: 1 1 100% !important;
    width: 100% !important;
  }
}

@media (max-width: 639px) {
  .reserve-home h1 {
    font-size: 48px;
  }

  .brand-outline,
  .brand-button {
    padding: 0 22px;
  }

  .intro-section {
    padding-top: 48px;
  }

  .gallery-strip {
    grid-template-columns: 1fr;
  }

  .footer-nav,
  .site-footer address {
    text-align: center;
  }
}
