/* ========================================================================
   127 The View - Styles
   ======================================================================== */

/* Reset & Base
   ======================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { line-height: 1.15; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { margin: 0; background-color: #FFFFFF; color: #000; font-weight: 400; font-size: 16px; font-family: 'Lora', serif; line-height: 1.6; }
article, aside, footer, header, nav, section { display: block; }
figure { margin: 0; }
img { max-width: 100%; height: auto; border: 0; vertical-align: middle; }
a { color: #0074D9; text-decoration: none; transition: all 0.2s ease; }
a:hover { color: #004b8d; text-decoration: none; }
a:focus, button:focus { transition: none; outline: 2px solid #306EAB; color: inherit; }
button { border: 0; margin: 0; padding: 0; text-align: inherit; text-transform: inherit; font: inherit; letter-spacing: inherit; background: none; cursor: pointer; overflow: visible; transition: all 0.2s ease; }
strong { font-weight: bold; }
p { margin: 25px 0; font-size: 16px; }
p:last-child { margin-bottom: 0; }
h1, h2, h3, h4, h5, h6 { display: block; margin: 50px 0 30px 0; color: #ffffff; font-weight: 400; text-transform: uppercase; font-family: 'Lora', serif; line-height: 1.25; }
h1, .h1 { font-size: 1.8em; line-height: 1.1em; font-weight: 400; }
@media (min-width: 576px) { h1, .h1 { font-size: 2em; } }
@media (min-width: 768px) { h1, .h1 { font-size: 3em; line-height: 1.4em; } }
h2, .h2 { font-size: 1.75em; color: #306EAB; }
@media (min-width: 768px) { h2, .h2 { font-size: 48px; } }
h3, .h3 { font-size: 1.5em; }
@media (min-width: 768px) { h3, .h3 { font-size: 2.25em; } }
h4, .h4 { font-size: 1.25em; color: #003466; }
@media (min-width: 768px) { h4, .h4 { font-size: 28px; } }
h5, .h5 { font-size: 1.125em; color: #003466; text-transform: uppercase; }
@media (min-width: 768px) { h5, .h5 { font-size: 1.25em; } }
h6, .h6 { font-size: 1em; }
h1:last-child, h2:last-child, h3:last-child, h4:last-child, h5:last-child, h6:last-child { margin-bottom: 0; }
ul { list-style: none; padding: 0; margin: 0; }

/* Utility Classes
   ======================================================================== */
.hide { display: none !important; }
.skip-link { position: absolute; top: -40px; left: 0; background: #000; color: #fff; padding: 8px; z-index: 1000; }
.skip-link:focus { top: 0; }
.overflow-hidden { overflow: hidden; }
.type-center { text-align: center; }
.text-link { position: relative; display: inline-block; color: #306EAB; font-size: 1em; text-decoration: underline; }
.text-link:hover { text-decoration: underline; opacity: 0.5; color: inherit; }
.text-link--white { color: #fff !important; }
.text-link--white:hover { color: #ccc !important; }

@media (min-width: 992px) {
	.mobile-only { display: none !important; }
}
@media (max-width: 991px) {
	.desktop-only { display: none !important; }
}

/* Container & Grid System
   ======================================================================== */
.container { max-width: 1224px; margin: 0 auto; padding: 0 15px; }
@media (min-width: 576px) { .container { max-width: 540px; } }
@media (min-width: 768px) { .container { max-width: 720px; } }
@media (min-width: 992px) { .container { max-width: 1140px; } }
.container--fluid { max-width: 1400px; margin: 0 auto; padding: 0 15px; }
.container--small { max-width: 1024px; margin: 0 auto; padding: 0 15px; }
.container--large { max-width: 1400px; margin: 0 auto; padding: 0 15px; }

.grid { display: flex; flex-wrap: wrap; margin: 0 -15px; }
.grid--no-padding { margin: 0; }
.grid--no-padding > .grid__column { padding: 0; }
.grid__column { padding: 0 15px; width: 100%; }
.padding-nulled { padding: 0 !important; }

.grid__column--1 { width: 8.333%; }
.grid__column--2 { width: 16.667%; }
.grid__column--3 { width: 25%; }
.grid__column--4 { width: 33.333%; }
.grid__column--5 { width: 41.667%; }
.grid__column--6 { width: 50%; }
.grid__column--7 { width: 58.333%; }
.grid__column--8 { width: 66.667%; }
.grid__column--9 { width: 75%; }
.grid__column--10 { width: 83.333%; }
.grid__column--11 { width: 91.667%; }
.grid__column--12 { width: 100%; }

@media (min-width: 576px) {
	.grid__column--1--sm { width: 8.333%; }
	.grid__column--2--sm { width: 16.667%; }
	.grid__column--3--sm { width: 25%; }
	.grid__column--4--sm { width: 33.333%; }
	.grid__column--5--sm { width: 41.667%; }
	.grid__column--6--sm { width: 50%; }
	.grid__column--7--sm { width: 58.333%; }
	.grid__column--8--sm { width: 66.667%; }
	.grid__column--9--sm { width: 75%; }
	.grid__column--10--sm { width: 83.333%; }
	.grid__column--11--sm { width: 91.667%; }
	.grid__column--12--sm { width: 100%; }
}
@media (min-width: 768px) {
	.grid__column--1--md { width: 8.333%; }
	.grid__column--2--md { width: 16.667%; }
	.grid__column--3--md { width: 25%; }
	.grid__column--4--md { width: 33.333%; }
	.grid__column--5--md { width: 41.667%; }
	.grid__column--6--md { width: 50%; }
	.grid__column--7--md { width: 58.333%; }
	.grid__column--8--md { width: 66.667%; }
	.grid__column--9--md { width: 75%; }
	.grid__column--10--md { width: 83.333%; }
	.grid__column--11--md { width: 91.667%; }
	.grid__column--12--md { width: 100%; }
}
@media (min-width: 992px) {
	.grid__column--1--lg { width: 8.333%; }
	.grid__column--2--lg { width: 16.667%; }
	.grid__column--3--lg { width: 25%; }
	.grid__column--4--lg { width: 33.333%; }
	.grid__column--5--lg { width: 41.667%; }
	.grid__column--6--lg { width: 50%; }
	.grid__column--7--lg { width: 58.333%; }
	.grid__column--8--lg { width: 66.667%; }
	.grid__column--9--lg { width: 75%; }
	.grid__column--10--lg { width: 83.333%; }
	.grid__column--11--lg { width: 91.667%; }
	.grid__column--12--lg { width: 100%; }
}

/* Typography
   ======================================================================== */
p.lead { font-size: 1.125em; }
@media (min-width: 768px) { p.lead { font-size: 1.5em; } }
.lead { font-weight: 500; font-size: 1.25em; }
@media (min-width: 768px) { .lead { font-size: 20px; } }
.alpha { margin-top: 0 !important; }
.preheadline { margin-top: 0; margin-bottom: 10px; font-size: 1.25rem; opacity: 0.75; color: #000; text-transform: uppercase; font-weight: 400; }

/* About intro - centered welcome section */
.about-intro { text-align: center; max-width: 760px; margin: 0 auto; }
.subheadline { margin-top: -20px; font-size: 20px; margin-bottom: 20px !important; color: #000; }
@media (min-width: 768px) { .subheadline { font-size: 28px; } }

/* Lists
   ======================================================================== */
.list__item { line-height: 1.25em; font-size: 1.15rem !important; margin-bottom: 15px !important; position: relative; }
@media (min-width: 576px) { .list__item { padding-right: 10px; } }
.list--inline { padding-left: 0; }
.list--inline .list__item { display: inline-block; }
.list--inline .list__item:not(:last-child) { padding-right: 0; }
@media (min-width: 576px) { .list--inline .list__item:not(:last-child) { padding-right: 25px; } }
.list--two-column { column-count: 1; }
@media (min-width: 992px) { .list--two-column { column-count: 2; } }
.list--dashes li { padding-left: 20px; }
.list--dashes li::before { content: '\f068'; font-family: 'FontAwesome'; font-size: 12px; position: absolute; left: 0; }

/* Buttons
   ======================================================================== */
.btn { position: relative; padding: 15px 25px; border-radius: 0px; border: 0; display: inline-block; color: #ffffff; font-size: 0.85em; font-family: 'Lora', serif; font-weight: 400; line-height: 21px; text-align: center; text-transform: uppercase; white-space: normal; transition: all 0.2s ease; cursor: pointer; }
@media (min-width: 576px) { .btn { font-size: 1em; } }
.btn:hover, .btn:focus, .btn:active { box-shadow: 0px 5px 20px 2px rgba(0,0,0,0.1); transform: translateY(-2px); transition: all 0.2s ease; color: #fff; }
.btn--blue { background-color: #306EAB; color: #ffffff; }
.btn--blue:hover { background-color: #003466; color: #ffffff; }
.btn--orange { background-color: #003466; color: #ffffff; }
.btn--orange:hover { background-color: #306EAB; color: #ffffff; }
.btn--white { background-color: #ffffff; color: #000; }
.btn--white:hover { background-color: #ffffff; color: #000; }

/* Header & Navigation
   ======================================================================== */
.header { background-color: #fff; box-shadow: 0 0 10px rgba(48,110,171,0.6); position: fixed; top: 0; width: 100%; z-index: 99; overflow: visible; padding: 15px 0; }
@media (min-width: 992px) { .header { padding: 0; } }

.nav { margin-bottom: 0; }
@media (min-width: 992px) { .nav { display: flex; align-items: center; } }
.nav__item { display: block; margin-bottom: 0; text-align: center; }
@media (min-width: 992px) { .nav__item { text-align: left; } }
.nav__link { position: relative; display: inline-block; padding: 10px; margin: 0; text-transform: uppercase; font-weight: 700; font-size: 1.125em; color: #fff; white-space: nowrap; }
.nav__link:hover { color: #fff; text-decoration: underline; }
@media (min-width: 992px) {
	.nav__link { font-size: 0.875em; color: #003466; padding: 11px 10px; }
	.nav__link:hover { color: #000; text-decoration: none; }
}
@media (min-width: 1200px) { .nav__link { padding: 11px 20px; } }
.nav__link--callout { background-color: #306eab; color: #fff !important; padding: 15px 35px; min-width: 235px; margin-bottom: 20px; }
@media (min-width: 992px) { .nav__link--callout { padding: 11px 15px; min-width: 0; margin-bottom: 0; } }
.nav__link--callout:hover { background-color: #003466; }
.nav__link--callout--trans { background-color: transparent; border: 2px solid #fff; }
.nav__link--phone { display: none; }
@media (min-width: 992px) { .nav__link--phone { display: block; } }

.navbar { display: flex; padding: 0; align-items: center; justify-content: space-between; }
.navbar__logo { padding: 0; display: block; width: 200px; }
.navbar__logo h4 { font-family: 'Lora', serif; font-size: 1.5em; font-weight: 700; color: #003466; margin: 0; }

.navbar__nav { position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 998; overflow-y: scroll; background-color: #000; display: block; padding: 50px 15px 0; opacity: 0; visibility: hidden; transition: all 0.3s ease; }
.navbar__nav--is-open { opacity: 1; visibility: visible; overflow: hidden; }
@media (min-width: 992px) {
	.navbar__nav { position: relative; top: auto; left: auto; right: auto; bottom: auto; z-index: 998; opacity: 1; overflow: visible; visibility: visible; background-color: transparent; display: inline-block; padding: 0; }
}
@media (min-width: 992px) { .navbar__mobile-buttons { display: none; } }
.navbar__phone-icon { display: inline-block; font-size: 21px; line-height: 18px; padding: 10px 13px; }
.navbar__phone-icon a { color: #003466; }

.navicon { position: relative; z-index: 999; border: none; background-color: transparent; padding: 10px 8px; outline: none; display: inline-block; }
.navicon__holder { display: block; cursor: pointer; }
.navicon__line { position: relative; width: 26px; height: 3px; margin-bottom: 5px; display: block; border-radius: 5px; background-color: #003466; transition: all 0.25s cubic-bezier(0.57, 0.28, 0.25, 0.69); }
.navicon__line:last-of-type { margin-bottom: -1px; }
.navicon--toggle .navicon__line { background-color: #fff; }
.navicon--toggle .navicon__line:first-of-type { transform: rotate(45deg) translateY(6px) translateX(6px); }
.navicon--toggle .navicon__line:nth-of-type(2) { opacity: 0; transform: scale(0); }
.navicon--toggle .navicon__line:last-of-type { transform: rotate(-45deg) translateY(-5px) translateX(5px); }

/* Dropdown */
.dropdown { position: relative; display: inline-block; width: 100%; margin-bottom: 20px !important; }
@media (min-width: 576px) { .dropdown { width: auto; } }
@media (min-width: 992px) { .dropdown { margin-bottom: 0 !important; } }
@media (min-width: 1200px) { .dropdown { min-width: 124px; } }
.dropdown__toggle { cursor: pointer; display: inline-block !important; }
@media (min-width: 992px) { .dropdown__toggle { line-height: 76px; } }
.dropdown__toggle-icon { margin-left: 5px; transition: all 0.3s ease; }
.dropdown--is-open .dropdown__toggle-icon { transform: rotate(-180deg); }
.dropdown__nav { display: none; position: relative; transition: all 0.3s ease; padding: 0; margin: 0; }
@media (min-width: 992px) {
	.dropdown__nav { position: absolute; display: block; opacity: 0; visibility: hidden; border-radius: 0 0 5px 5px; overflow: hidden; background-color: #fff; box-shadow: 0 10px 25px rgba(0,0,0,0.35); transform: translateY(-20px); width: 225px; z-index: 100; }
}
.dropdown--is-open .dropdown__nav { display: block; opacity: 1; visibility: visible; transform: translateY(0px); }
.dropdown__item { display: block; padding: 0; list-style-type: none; }
@media (min-width: 992px) { .dropdown__item { margin: 0; border-bottom: 1px solid rgba(255,255,255,0.1); } .dropdown__item:last-of-type { border-bottom: 0; } }
.dropdown__link { display: block; padding: 5px 10px; color: #fff; font-weight: 700; text-transform: uppercase; font-size: 0.875em; }
.dropdown__link:hover, .dropdown__link:focus { color: #fff; opacity: 0.5; }
@media (min-width: 992px) {
	.dropdown__link { margin: 0; padding: 12px 15px; font-size: 0.835em; color: #000; }
	.dropdown__link:hover, .dropdown__link:focus, .dropdown__link:active { background-color: #003466; opacity: 1; color: #fff; }
}

/* Banner / Hero
   ======================================================================== */
.banner { position: relative; z-index: 10; background-color: #000; padding: 50px 0; margin-top: 80px; }
@media (min-width: 768px) { .banner { height: 60vh; min-height: 500px; } }
@media (min-width: 992px) { .banner { height: 70vh; margin-top: 100px; } }
@media (min-width: 1200px) { .banner { height: 90vh; } }

.banner__content { position: relative; padding: 0 15px; text-align: center; animation: moveDown 1s forwards; }
@media (min-width: 768px) {
	.banner__content { height: 100%; display: flex; flex-wrap: wrap; flex-direction: column; justify-content: space-between; }
}
.banner__content .subheadline { font-family: 'Lora', serif; font-size: 1em; font-weight: 400; padding-bottom: 10px; opacity: 1; margin-top: 20px; }
@media (min-width: 992px) { .banner__content .subheadline { font-size: 1.5em; } }

.banner__background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; transition: all ease 0.25s; background-position: center center; background-repeat: no-repeat; background-size: cover; }
@media (min-width: 992px) { .banner__background { animation: blur 1s forwards; } }

.banner__heading { margin-top: 0; margin-bottom: 25px !important; color: #fff; font-family: 'Lora', serif; }


.banner__buttons { text-align: center; }
.banner__btn { align-self: center; width: 100%; max-width: 400px; margin: 5px; }
@media (min-width: 992px) { .banner__btn { font-size: 26px !important; padding: 23px !important; } }

@keyframes moveDown { 0% { transform: translateY(-10px); opacity: 0; } 100% { transform: translateY(0px); opacity: 1; } }
@keyframes blur { 0% { opacity: 0; } 50% { opacity: 0.3; } 100% { opacity: 0.8; } }

/* Sections
   ======================================================================== */
.section { position: relative; padding-top: 40px; padding-bottom: 40px; color: #000; }
.section h2 { color: #306EAB; }
.section p { color: #000; }
@media (min-width: 768px) { .section { padding-top: 60px; padding-bottom: 60px; } }
.section--small { padding-top: 30px; padding-bottom: 30px; }
@media (min-width: 768px) { .section--small { padding-top: 50px; padding-bottom: 50px; } }
.section--light-gray { background-color: #efefef; }
.section--light-gray h2, .section--light-gray h3 { color: #306EAB; }
.section--light-gray p, .section--light-gray li { color: #000; }
.section--blue { background-color: #003466; }
.section--color { background-color: #003466; }
.section--color h1, .section--color h2, .section--color h3, .section--color h4, .section--color h5, .section--color h6, .section--color p, .section--color ul li, .section--color a { color: #fff; }
.section--blue h1, .section--blue h2, .section--blue h3, .section--blue h4, .section--blue h5, .section--blue h6, .section--blue p, .section--blue ul li, .section--blue a { color: #fff; }

.anchor { position: relative; top: -70px; display: block; }

/* Accordion (Floor Plans)
   ======================================================================== */
.ac { margin-top: 10px; border: 1px solid #ddd; background-color: #fff; }
.ac-q { font: bold 15px Arial, sans-serif; color: #111; padding: 10px 30px 10px 10px; margin: 0; text-decoration: none; display: block; cursor: pointer; position: relative; }
.ac-q::after { content: '+'; text-align: center; width: 15px; right: 10px; top: 50%; transform: translate(0, -50%); position: absolute; font-size: 1.2em; }
.ac.is-active > .ac-q::after { content: '\2013'; }
.ac .ac-a { max-height: 0; overflow: hidden; transition: max-height 0.4s ease; }
.ac.is-active .ac-a { max-height: 10000px; }
.accordion-container .ac-q { color: #003466; background-color: rgba(0, 52, 102, 0.1); transition: all ease 0.25s; }
.accordion-container .ac.is-active .ac-q { background-color: rgba(0, 52, 102, 1); color: #fff; }
.accordion-container .ac.is-active .ac-a { margin-top: 30px; margin-bottom: 30px; }

/* Floor Plans
   ======================================================================== */
.floorplan { padding: 0px; margin-bottom: 50px; }
@media (min-width: 992px) { .floorplan { padding: 20px; margin-bottom: 0; } }
.floorplan__list.list { margin-top: 20px; }
@media (min-width: 992px) { .floorplan__list.list { margin-top: 0; } }
.floorplan__list.list li { font-size: 0.95em !important; padding: 3px 0; color: #000; margin-bottom: 5px !important; list-style-type: none; }
.floorplan__list.list li i { font-size: 2em; }
.floorplan__view-image { display: block; height: 300px; text-align: center; transition: opacity ease 0.25s; }
.floorplan__view-image.hide { opacity: 0; display: inline-block; visibility: hidden; position: absolute; }
.floorplan__view-image img { object-fit: contain; height: 100%; object-position: top; }
.floorplan__switcher { display: flex; margin-top: 20px; }
.floorplan__switcher__btn { width: 50%; padding: 10px; text-align: center; font-weight: bold; background-color: rgba(48,110,171, 0.1); cursor: pointer; text-decoration: none; color: #333; transition: all ease 0.25s; }
.floorplan__switcher__btn.active { background-color: rgba(48,110,171, 1); color: #fff; }
.floorplans-page { overflow: hidden; }

/* Image Gallery
   ======================================================================== */
.image-gallery__image { height: 200px; display: block; position: relative; overflow: hidden; }
.image-gallery__image::after { content: '\f002'; font-family: 'FontAwesome'; position: absolute; width: 100%; height: 100%; top: 0; left: 0; background-color: #306EAB; opacity: 0; transition: all ease 0.25s; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 30px; }
.image-gallery__image:hover::after { opacity: 0.8; }
.image-gallery__image img { object-fit: cover; width: 100%; height: 100%; transition: transform 0.4s ease; }
.image-gallery__image:hover img { transform: scale(1.05); }
@media (min-width: 992px) { .image-gallery__image { height: 350px; } }

/* Lightbox
   ======================================================================== */
.lightbox { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.9); z-index: 9999; align-items: center; justify-content: center; }
.lightbox--active { display: flex; }
.lightbox__image { max-width: 90%; max-height: 90vh; object-fit: contain; }
.lightbox__close { position: absolute; top: 15px; right: 25px; color: #fff; font-size: 40px; cursor: pointer; background: none; border: none; z-index: 10000; }
.lightbox__prev, .lightbox__next { position: absolute; top: 50%; transform: translateY(-50%); color: #fff; font-size: 50px; cursor: pointer; background: none; border: none; padding: 20px; z-index: 10000; }
.lightbox__prev { left: 10px; }
.lightbox__next { right: 10px; }
.lightbox__prev:hover, .lightbox__next:hover, .lightbox__close:hover { color: #306EAB; }

/* Contact Form
   ======================================================================== */
.control { margin-bottom: 20px; }
.control:last-of-type { margin-bottom: 0; }
.control__label { color: #000; display: block; margin-bottom: 5px; font-weight: 500; font-size: 0.9em; }
.control__label--is-required::after { content: " *"; color: #c00; }
.control__input { display: block; width: 100%; padding: 0.5rem 1rem; border: 1px solid #E0E0E0; border-radius: 0; font-family: inherit; font-size: 1rem; transition: border-color 0.2s ease; background-color: #fff; color: #000; appearance: none; }
.control__input:focus { border-color: #306EAB; outline: none; box-shadow: 0 0 0 2px rgba(48,110,171,0.2); }
.control__textarea { resize: vertical; min-height: 120px; }
.form .control__label { font-weight: normal; font-size: 18px; padding-bottom: 0; margin-bottom: 2px; }
.form .control__input { border: 2px solid rgba(48,110,171,.5); font-family: 'Lora', serif; font-size: 18px; padding: 15px; height: 55px; transition: all ease 0.25s; }
.form .control__input:focus { border: 2px solid rgba(0,52,102,1); outline: none; box-shadow: none; }
.form .control__textarea { height: 125px; }
.form-status { margin-top: 15px; display: none; }
.form-status--success { display: block; }
.form-status--error { display: block; padding: 10px; background-color: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; border-radius: 2px; }
.form-status__banner { background-color: #003466; color: #fff; font-family: 'Lora', serif; font-size: 24px; padding: 15px 20px; }
.form-status__thanks { font-size: 16px; color: #333; margin-top: 12px; }

/* Footer
   ======================================================================== */
.footer { padding: 0 !important; text-align: center; }
.footer__top { padding: 50px 0; }
.footer__contacts li { font-size: 1em !important; text-transform: uppercase; font-weight: 300; font-family: 'Lora', serif; color: #fff; }
.footer__contacts li a { color: #fff; }
.footer__contacts li a:hover { text-decoration: underline; }
.footer__bottom { padding: 15px 0; background-color: #000; }
.footer__bottom p { margin: 10px 0; font-size: 13px; color: #fff; }
.footer__copyright { text-align: center; }
@media (min-width: 992px) { .footer__copyright { text-align: left; } }
.footer__copyright .list { margin-top: 10px; margin-bottom: 10px; }
.footer__copyright .list__item { display: inline-block; margin-bottom: 0 !important; font-size: 13px !important; opacity: 0.85 !important; font-weight: 300; color: #fff; }
.footer__copyright .list__item a { color: #ffffff; font-size: 0.95em; opacity: 0.85; font-weight: 300; text-transform: uppercase; font-family: 'Lora', serif; }
.footer__copyright .list__item a::before { content: ""; padding-right: 10px; padding-left: 10px; }
@media (min-width: 576px) { .footer__copyright .list__item a::before { content: "|"; } }
.footer__copyright .list__item a:hover { text-decoration: underline; }
.footer__developer { text-align: center; }
@media (min-width: 992px) { .footer__developer { text-align: right; } }
.footer__developer p { color: rgba(255,255,255,0.7); }

/* Scroll to Top
   ======================================================================== */
#to-top { position: fixed; bottom: 65px; right: 10px; cursor: pointer; display: none; padding: 0; z-index: 999; opacity: 0.6; }
@media (min-width: 576px) { #to-top { bottom: 20px; } }
@media (min-width: 768px) { #to-top { bottom: 15px; right: 15px; } }
#to-top:hover { opacity: 1; }
#to-top .fa { color: #fff; background: #306EAB; font-size: 2.5em; padding: 5px 12px; line-height: 36px; width: 50px; height: 50px; border-radius: 50%; transition: all 0.25s ease; }
#to-top .fa:hover { background: #003466; }

/* Cookie Warning
   ======================================================================== */
.cookie-warning { position: fixed; z-index: 9999; bottom: 15px; left: 15px; right: 15px; padding: 30px; background-color: #003466; color: #ffffff; transition: opacity 0.3s ease; }
.cookie-warning--is-hidden { display: none !important; }
.cookie-warning__container { display: flex; flex-direction: column; }
@media (min-width: 768px) { .cookie-warning__container { flex-direction: row; } }
.cookie-warning__content { flex: 1; }
.cookie-warning__notice { color: #fff; font-size: 13px; margin: 0; max-width: 880px; line-height: 1.5; }
.cookie-warning__link { color: #fff; text-decoration: underline; }
.cookie-warning__link:hover { color: #003466; text-decoration: underline; }
.cookie-warning__action { margin-top: 20px; }
@media (min-width: 768px) { .cookie-warning__action { margin-top: 0; padding-left: 30px; flex: 0 0 300px; max-width: 300px; text-align: right; } }
.btn.cookie-warning__button { background-color: #fff; color: #000 !important; min-width: 150px; padding: 8px 25px; white-space: nowrap; font-size: 0.85em; }
.btn.cookie-warning__button:hover { background-color: #306EAB; }

/* FAQ Section
   ======================================================================== */
.faq-section .lead { margin-bottom: 30px; }
.faq-list { max-width: 900px; }
.faq-item { border-bottom: 1px solid #ddd; }
.faq-item:first-child { border-top: 1px solid #ddd; }
.faq-question { padding: 18px 40px 18px 0; font-family: 'Lora', serif; font-size: 1.1em; font-weight: 600; color: #003466; cursor: pointer; position: relative; list-style: none; }
.faq-question::-webkit-details-marker { display: none; }
.faq-question::after { content: '+'; position: absolute; right: 15px; top: 50%; transform: translateY(-50%); font-size: 1.4em; font-weight: 400; color: #306EAB; transition: transform 0.2s ease; }
.faq-item[open] .faq-question::after { content: '\2013'; }
.faq-question:hover { color: #306EAB; }
.faq-answer { padding: 0 0 20px 0; }
.faq-answer p { margin-top: 0; font-size: 0.95em; line-height: 1.7; color: #333; }
.faq-answer a { color: #306EAB; text-decoration: underline; }
.faq-answer a:hover { color: #003466; }

/* Inner Page Banner */
.banner--inner { background-color: #596273; min-height: 250px; height: 30vh; display: flex; align-items: center; justify-content: center; margin-top: 80px; }
@media (min-width: 992px) { .banner--inner { margin-top: 100px; } }
.banner--inner .banner__heading { margin-bottom: 0 !important; }

/* Active Nav Link
   ======================================================================== */
@media (min-width: 992px) {
	.nav__link--active { color: #306EAB !important; }
	.nav__link--active::after { content: ''; position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%); width: 30px; height: 2px; background-color: #306EAB; }
}

/* Promotional Banner
   ======================================================================== */
.promo-banner { background-color: #1a5c2a; position: fixed; top: 0; left: 0; right: 0; z-index: 100; }
.promo-banner__inner { display: flex; align-items: center; justify-content: center; padding: 12px 15px; max-width: none; }
.promo-banner__content { display: flex; align-items: center; justify-content: center; gap: 8px; flex-wrap: wrap; flex: 1; }
.promo-banner__star { color: #D4A847; font-size: 1em; }
.promo-banner__text { color: #fff; font-family: 'Lora', serif; font-size: 1em; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
@media (min-width: 768px) { .promo-banner__text { font-size: 1.15em; } }
.promo-banner__link { color: #D4A847; font-family: 'Lora', serif; font-size: 0.85em; font-weight: 700; text-decoration: underline; text-transform: uppercase; white-space: nowrap; }
.promo-banner__link:hover { color: #fff; }
.promo-banner__close { color: rgba(255,255,255,0.7); font-size: 1.4em; line-height: 1; padding: 5px 8px; flex-shrink: 0; }
.promo-banner__close:hover { color: #fff; }

/* Push page down when promo banner is visible */
body.has-promo .header { top: var(--promo-height, 40px); }
body.has-promo .banner { margin-top: calc(80px + var(--promo-height, 40px)); }
@media (min-width: 992px) { body.has-promo .banner { margin-top: calc(100px + var(--promo-height, 40px)); } }
body.has-promo .banner--inner { margin-top: calc(80px + var(--promo-height, 40px)); }
@media (min-width: 992px) { body.has-promo .banner--inner { margin-top: calc(100px + var(--promo-height, 40px)); } }

/* Available Units - Filter Bar
   ======================================================================== */
.section--filters { padding-top: 25px; padding-bottom: 25px; }
@media (min-width: 768px) { .section--filters { padding-top: 30px; padding-bottom: 30px; } }

.units-filter { align-items: center; }
.units-filter__count { font-family: 'Lora', serif; font-size: 1.1em; font-weight: 600; color: #003466; margin: 0 0 15px 0; }
@media (min-width: 768px) { .units-filter__count { margin-bottom: 0; } }

.units-filter__controls { display: flex; flex-wrap: wrap; gap: 12px; }
@media (min-width: 768px) { .units-filter__controls { justify-content: flex-end; } }

.units-filter__control { display: flex; flex-direction: column; flex: 1; min-width: 120px; }
@media (min-width: 768px) { .units-filter__control { flex: 0 0 auto; min-width: 150px; } }

.units-filter__label { font-size: 0.75em; font-weight: 600; text-transform: uppercase; color: #666; margin-bottom: 4px; letter-spacing: 0.5px; }

.units-filter__select { appearance: none; -webkit-appearance: none; background-color: #fff; border: 2px solid rgba(48,110,171,0.3); border-radius: 0; padding: 8px 32px 8px 12px; font-family: 'Lora', serif; font-size: 0.9em; color: #003466; cursor: pointer; transition: border-color 0.2s ease; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23003466' d='M6 8L0 0h12z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; }
.units-filter__select:focus { border-color: #003466; outline: none; box-shadow: 0 0 0 2px rgba(48,110,171,0.2); }

/* Available Units - Unit Cards
   ======================================================================== */
.unit-card { background-color: #fff; border: 1px solid #e8e8e8; margin-bottom: 25px; transition: box-shadow 0.3s ease; }
@media (min-width: 768px) { .unit-card__grid { gap: 30px; } }
.unit-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }

.unit-card__image-col { position: relative; }

.unit-card__image { display: block; height: 250px; text-align: center; background-color: #f9f9f9; padding: 15px; transition: opacity ease 0.25s; }
.unit-card__image.hide { opacity: 0; display: inline-block; visibility: hidden; position: absolute; }
.unit-card__image img { object-fit: contain; height: 100%; width: 100%; object-position: center; }
@media (min-width: 768px) { .unit-card__image { height: 280px; } }

.unit-card__switcher { display: flex; }
.unit-card__switcher-btn { width: 50%; padding: 8px; text-align: center; font-weight: bold; font-size: 0.85em; background-color: rgba(48,110,171,0.1); cursor: pointer; text-decoration: none; color: #333; transition: all ease 0.25s; }
.unit-card__switcher-btn.active { background-color: rgba(48,110,171,1); color: #fff; }
.unit-card__switcher-btn:hover { color: #003466; }

.unit-card__details { padding: 25px 20px; display: flex; flex-direction: column; justify-content: center; }
@media (min-width: 768px) { .unit-card__details { padding: 30px; } }

.unit-card__header { margin-bottom: 15px; }
.unit-card__title { margin: 0; font-size: 1.5em; color: #003466; text-transform: uppercase; font-weight: 700; }
.unit-card__meta { font-size: 0.9em; color: #888; text-transform: uppercase; letter-spacing: 0.5px; }

.unit-card__specs { display: flex; flex-wrap: wrap; gap: 20px; margin: 0 0 20px 0; padding: 15px 0; border-top: 1px solid #eee; border-bottom: 1px solid #eee; }
.unit-card__spec { font-size: 0.95em; color: #333; white-space: nowrap; margin-bottom: 0 !important; }
.unit-card__spec i { color: #306EAB; margin-right: 5px; }

.unit-card__pricing { margin-bottom: 15px; }
.unit-card__rent { display: block; font-family: 'Lora', serif; font-size: 1.6em; font-weight: 700; color: #003466; margin-bottom: 5px; }
.unit-card__available { display: block; font-size: 0.9em; color: #555; }
.unit-card__available i { margin-right: 4px; color: #306EAB; }

.unit-card__promo { background-color: rgba(26,92,42,0.08); border-left: 3px solid #1a5c2a; padding: 10px 15px; margin-bottom: 20px; font-size: 0.85em; font-weight: 600; color: #1a5c2a; }
.unit-card__promo i { color: #D4A847; margin-right: 5px; }

.unit-card__actions { display: flex; flex-wrap: wrap; gap: 10px; }
.unit-card__btn { flex: 1; min-width: 140px; font-size: 0.8em !important; padding: 12px 15px !important; text-align: center; }
@media (min-width: 768px) { .unit-card__btn { flex: 0 0 auto; } }

/* Available Units - Empty State
   ======================================================================== */
.units-empty { text-align: center; padding: 60px 20px; }
.units-empty__icon { font-size: 3em; color: #ccc; display: block; margin-bottom: 20px; }
.units-empty__heading { color: #003466; margin-top: 0; font-size: 1.5em; }
.units-empty__text { max-width: 500px; margin: 0 auto 30px auto; color: #666; font-size: 1em; line-height: 1.6; }
