@charset "UTF-8";
@keyframes spin {
  100% {
    transform: rotate(360deg);
  }
}
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

*,
::before,
::after {
  flex: 0 1 auto;
  box-sizing: inherit;
}

html {
  box-sizing: border-box;
  word-wrap: break-word;
}

body {
  color: #20272c;
  font-family: "merriweather sans", sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
}

button,
[type=submit] {
  cursor: pointer;
}

iframe {
  border: 0;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

svg {
  fill: currentColor;
}

[type=search] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

[data-whatintent=mouse] :focus,
[data-whatintent=touch] :focus {
  outline: 0;
}

table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

th,
td {
  padding: 0.5rem 1rem;
  text-align: left;
}

th {
  background: #141b4d;
  color: #fff;
}

tr:nth-child(odd) td {
  background: #f5f5f5;
}

h3 {
  font-size: 1.5em;
  font-weight: normal;
}

input,
button,
select,
textarea {
  font-family: inherit;
}

.svgstore {
  display: block;
  position: relative;
}
.svgstore::before {
  display: block;
  content: "";
}
.svgstore svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.svgstore--amazon::before {
  padding-bottom: 30.2325581395%;
}

.svgstore--angle-down::before {
  padding-bottom: 100%;
}

.svgstore--angle-up::before {
  padding-bottom: 100%;
}

.svgstore--bars::before {
  padding-bottom: 100%;
}

.svgstore--chevron-left::before {
  padding-bottom: 100%;
}

.svgstore--chevron-right::before {
  padding-bottom: 100%;
}

.svgstore--comment-o::before {
  padding-bottom: 100%;
}

.svgstore--envelope-o::before {
  padding-bottom: 100%;
}

.svgstore--facebook-f::before {
  padding-bottom: 100%;
}

.svgstore--facebook::before {
  padding-bottom: 19.5211786372%;
}

.svgstore--google::before {
  padding-bottom: 32.962962963%;
}

.svgstore--hand-o-right::before {
  padding-bottom: 100%;
}

.svgstore--instagram::before {
  padding-bottom: 100%;
}

.svgstore--long-arrow-up::before {
  padding-bottom: 100%;
}

.svgstore--microsoft::before {
  padding-bottom: 21.3733075435%;
}

.svgstore--redfin::before {
  padding-bottom: 26.4%;
}

.svgstore--refresh::before {
  padding-bottom: 100%;
}

.svgstore--search::before {
  padding-bottom: 100%;
}

.svgstore--skyline-bg::before {
  padding-bottom: 354.7619047619%;
}

.svgstore--skyline::before {
  padding-bottom: 28.8720538721%;
}

.svgstore--twitter::before {
  padding-bottom: 100%;
}

.svgstore--uw::before {
  padding-bottom: 49.1071428571%;
}

.svgstore--x::before {
  padding-bottom: 100%;
}

.svgstore--yelp::before {
  padding-bottom: 48.9420935412%;
}

.svgstore--zillow::before {
  padding-bottom: 24.6878901373%;
}

.clear::before, .clear::after {
  display: table;
  content: "";
}
.clear::after {
  clear: both;
}

.flush > :first-child {
  margin-top: 0;
}
.flush > :last-child {
  margin-bottom: 0;
}

.secheading,
.building h2:not(.gform_submission_error),
.feed h2 {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-block: 4rem 2rem;
  color: #141b4d;
  font-size: 1rem;
  font-weight: bold;
  text-transform: uppercase;
}
.secheading::after,
.building h2:not(.gform_submission_error)::after,
.feed h2::after {
  content: "";
  flex-grow: 1;
  border-top: 0.125rem solid #cdd0cf;
}

.scope a:not([class]) {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

@media (min-width: 32em) {
  .category-children {
    -moz-column-count: 2;
         column-count: 2;
    -moz-column-gap: 2rem;
         column-gap: 2rem;
  }
}
@media (min-width: 48em) {
  .category-children {
    -moz-column-count: 3;
         column-count: 3;
  }
}

body #wpadminbar {
  position: fixed;
}

.wp-caption {
  max-width: 100%;
}

.gform_wrapper {
  margin-top: 1rem;
}
.post__content .gform_wrapper {
  margin-bottom: 1rem;
}

.gform_fields {
  margin: 0;
  padding: 0;
  list-style: none;
}
.gform_fields fieldset {
  margin-right: 0;
  margin-left: 0;
  padding: 0;
  border: 0;
}

.gform_required_legend {
  display: none;
}

.hide-label .gfield_label {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.field_sublabel_below .ginput_complex label {
  padding-left: 0.5rem;
  font-size: 75%;
}

.gfield {
  margin-bottom: 1rem;
}
.gfield [type=tel],
.gfield [type=text],
.gfield [type=email],
.gfield select,
.gfield textarea {
  display: block;
  width: 100%;
  padding: 0.75rem 1rem;
  border: 0.0625rem solid #141b4d;
  border-radius: 0.25rem;
  background: #fff;
}
.gfield.inline-checkboxes {
  display: flex;
  flex-wrap: wrap;
  padding: 0 1rem;
}
.gfield.inline-checkboxes .gfield_label {
  padding-right: 1rem;
}
.gfield.inline-checkboxes .gfield_checkbox {
  display: flex;
  padding: 0;
  list-style: none;
}
.gfield.inline-checkboxes .gfield_checkbox li {
  padding-right: 1rem;
}

.gform_button {
  width: 100%;
}

.gform_confirmation_message {
  margin-top: 1rem;
  padding: 0 1rem;
}

.gfield_required {
  color: #2c8d95;
}

.gfield_consent_description {
  margin-bottom: 0;
  color: gray;
  font-size: 0.75rem;
}

.gfield_visibility_hidden {
  display: none;
}

.gform_validation_container {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.validation_error {
  margin-bottom: 1rem;
  font-weight: bold;
}

.validation_error,
.validation_message {
  width: 100%;
  padding: 0 1rem;
  color: red;
}
.inline-checkboxes .validation_error,
.inline-checkboxes .validation_message {
  padding: 0;
}

h2.gform_submission_error {
  color: #2c8d95;
}

.ihf-container .lazy {
  opacity: 1;
}

#ihf-board-detail-disclaimer,
#ihf-board-disclaimers .ihf-board-disclaimer-text,
.ihf-board-disclaimers p {
  display: none !important;
}

.mce-content-body {
  margin-right: 1rem;
  margin-left: 1rem;
}

.post__content figure {
  margin: 0;
}

.post__content iframe {
  max-width: 100%;
}

.minimodal {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
}

.minimodal__overlay {
  position: absolute;
  top: -8rem;
  left: 0;
  width: 100%;
  height: calc(100% + 16rem);
  background: rgba(0, 0, 0, 0.9);
}

.minimodal__viewport {
  position: relative;
  height: 100%;
  pointer-events: none;
}

.minimodal__item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.minimodal__status {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  text-align: center;
}

.minimodal__content {
  height: 100%;
}

.minimodal__element {
  display: block;
  position: relative;
  top: 50%;
  max-width: 100%;
  max-height: 100%;
  margin: auto;
  transform: translateY(-50%);
  pointer-events: auto;
}

.minimodal__element--map {
  background: white;
}

.minimodal__element--video {
  max-width: 177.7777777778vh;
}

.minimodal__element--video::before {
  display: block;
  padding-bottom: 56.25%;
  background: black;
  content: "";
}

.minimodal__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.minimodal__caption {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  color: white;
  pointer-events: auto;
}

.minimodal__close {
  position: absolute;
  top: 0;
  right: 0;
}

.minimodal__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.minimodal__nav--previous {
  left: 0;
}

.minimodal__nav--next {
  right: 0;
}

.minimodal,
.minimodal__status,
.minimodal__content,
.minimodal__item--added,
.minimodal__item--removed {
  transition: opacity 300ms ease-in-out;
  opacity: 0;
}

.minimodal--active,
.minimodal__item--loading .minimodal__status,
.minimodal__item--loaded .minimodal__content {
  opacity: 1;
}

.minimodal__item--added--previous,
.minimodal__item--removed--next {
  transform: translateX(-100%);
}

.minimodal__item--added--next,
.minimodal__item--removed--previous {
  transform: translateX(100%);
}

.minimodal {
  z-index: 2147483648;
  /* one greater than intercom */
}

.minimodal__overlay {
  background: rgba(32, 39, 44, 0.95);
}

.minimodal__item {
  transition: transform 300ms ease-in-out, opacity 300ms ease-in-out;
}

.minimodal__content {
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
}

.minimodal__nav,
.minimodal__close {
  width: 2.875rem;
  padding: 1rem;
  border: 0;
  background-color: transparent;
  color: #fff;
}

.minimodal__nav {
  padding: 0.5rem;
}

.minimodal__nav--previous {
  transform: translateY(-50%) rotate(-90deg);
}

.minimodal__nav--next {
  transform: translateY(-50%) rotate(90deg);
}

.ads {
  padding-top: 1rem;
  padding-bottom: 1rem;
  border-top: 0.125rem solid #cdd0cf;
  border-bottom: 0.125rem solid #cdd0cf;
}

.ads__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  padding: 0;
}
@media (min-width: 48em) {
  .ads__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .ads__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.ads__item {
  display: block;
  margin: 1rem;
}
.ads__item img {
  width: 100%;
}

article.author {
  margin: 2rem 0;
}

article.author--small {
  font-size: 0.875rem;
  overflow: hidden;
}

.author__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .author__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .author__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.author__header {
  display: flex;
  flex-direction: column;
  margin: 2rem 0;
  font-size: 0.875rem;
}
@media (min-width: 48em) {
  .author__header {
    display: block;
    overflow: hidden;
  }
}

@media (min-width: 48em) {
  .author__image {
    width: calc(50% - 1rem);
    margin-right: 2rem;
    float: left;
  }
}

@media (min-width: 32em) {
  .author__image--small {
    width: calc(33.333% - 1rem);
    margin-right: 2rem;
    float: left;
  }
}
@media (min-width: 48em) {
  .author__image--small {
    width: calc(33.333% - 1.333rem);
  }
}

.author__meta {
  order: -1;
  padding-bottom: 1rem;
  overflow: hidden;
}
@media (min-width: 48em) {
  .author__meta {
    margin-bottom: 0.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 0.0625rem solid #cdd0cf;
  }
}

.author__meta__title {
  margin: 0;
  color: #2c8d95;
  font-weight: bold;
}

.author__meta__name {
  margin: 0;
  font-size: 1.75rem;
}

.author__meta__org {
  margin: 0;
  color: #66676c;
}

.author__info {
  overflow: hidden;
}
.author__info p {
  margin: 1rem 0;
}

.author__info--small {
  clear: both;
}
@media (min-width: 48em) {
  .author__info--small {
    width: calc(33.333% - 1.333rem);
    float: left;
    clear: none;
  }
}
.author__info--small :last-child {
  margin-bottom: 0;
}

.author__info__email {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

.author__button {
  width: 100%;
  margin-top: 1rem;
}
@media (min-width: 48em) {
  .author__button {
    width: auto;
  }
}
@media (min-width: 48em) {
  .author__button:first-child {
    margin-top: 1.5rem;
  }
}
.author__info--small .author__button {
  width: 100%;
  margin-top: 0;
}

.author__bio {
  margin: 2rem 0;
}

@media (min-width: 32em) {
  .author__bio--small {
    width: calc(66.666% - 1rem);
    margin-top: 0;
    float: left;
  }
}
@media (min-width: 48em) {
  .author__bio--small {
    width: calc(33.333% - 1.333rem);
    margin-right: 2rem;
    margin-bottom: 0;
  }
}
.author__bio--small :first-child {
  margin-top: 0;
}
.author__bio--small :last-child {
  margin-bottom: 0;
}

.author__contact--small {
  text-align: center;
}
@media (min-width: 48em) {
  .author__contact--small {
    padding-left: 2rem;
    text-align: left;
  }
}

.breadcrumbs {
  padding: 1.25rem 0;
  background-color: #141b4d;
  color: #fff;
}
@media (min-width: 48em) {
  .breadcrumbs {
    font-size: 1.5em;
  }
}
.breadcrumbs a {
  color: inherit;
  text-decoration: none;
}
.breadcrumbs .breadcrumb_separator {
  margin: 0 0.5rem;
  color: #1b365d;
}
@media (min-width: 48em) {
  .breadcrumbs .breadcrumb_separator {
    margin: 0 1rem;
  }
}
.breadcrumbs .breadcrumb_last {
  font-weight: bold;
}

.breadcrumbs__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .breadcrumbs__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .breadcrumbs__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

@media (min-width: 48em) {
  .post__content .building {
    margin-inline: -2rem;
  }
}
@media (min-width: 80em) {
  .post__content .building {
    margin-inline: -3rem;
  }
}

.building__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .building__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .building__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}
.post__content .building__container {
  padding: 0;
}

.building__overview {
  border-top: 0.0625rem solid #cdd0cf;
}
@media (min-width: 48em) {
  .building__overview {
    display: flex;
    justify-content: space-between;
  }
}

.building__stats {
  display: flex;
  justify-content: space-between;
  margin: 2rem 0;
  padding: 0;
  list-style: none;
}
@media (min-width: 48em) {
  .building__stats {
    flex-grow: 1;
    margin-right: 4rem;
  }
}

.building__stats__label {
  display: block;
}

.building__stats__value {
  display: block;
  font-size: 1.25rem;
  font-weight: bold;
}
@media (min-width: 32em) {
  .building__stats__value {
    font-size: 2rem;
  }
}
@media (min-width: 64em) {
  .building__stats__value {
    font-size: 2.5rem;
  }
}

.building__credit {
  margin: 2rem 0;
  padding: 0;
  list-style: none;
}

.building__credit__item {
  margin-top: 0.5rem;
}
.building__credit__item:first-child {
  margin-top: 0;
}

.building__credit__value {
  font-weight: bold;
}

.building__detail {
  margin: 2rem 0;
}

.building__address a {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

.building__address__neighborhood {
  color: #66676c;
}

@media (min-width: 32em) {
  .building__amenities ul {
    -moz-column-count: 2;
         column-count: 2;
    -moz-column-gap: 2rem;
         column-gap: 2rem;
  }
}
@media (min-width: 48em) {
  .building__amenities ul {
    -moz-column-count: 3;
         column-count: 3;
  }
}

.building__contact {
  margin: 2rem -1rem;
}
@media (min-width: 48em) {
  .building__contact {
    margin-right: 0;
    margin-left: 0;
  }
}

.building__map__embed {
  height: 20rem;
  margin-top: 2rem;
}

.building__faq {
  margin: 2rem 0;
  padding: 0 1rem;
}
@media (min-width: 48em) {
  .building__faq {
    padding: 0;
  }
}

.building__form {
  margin-top: 2rem;
  padding: 2rem;
  background-color: #f5f5f5;
}
.building__form textarea {
  height: 8rem;
}
.building__form [type=submit] {
  max-width: 18.875rem;
}

.building__form__heading {
  margin: 0;
  color: #141b4d;
}

.building__section {
  margin: 4rem 0;
}

.building__image {
  margin-bottom: 1rem;
}
@media (width >= 48em) {
  .building__image {
    width: calc(50% - 1rem);
    margin-right: 2rem;
    margin-bottom: 0;
    float: left;
  }
}

.building__image + .building__content {
  overflow: hidden;
}

.buildings {
  margin: 2rem 0;
}

.buildings__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .buildings__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .buildings__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.buildings__item {
  display: flex;
  flex-direction: column;
}
@media (min-width: 48em) {
  .buildings__item {
    flex-direction: row;
    align-items: center;
  }
}
.buildings__item + .buildings__item {
  margin-top: 2rem;
}

.buildings__detail {
  display: block;
  position: relative;
  width: 100%;
  padding: 0.5rem 0.5rem 1rem 0.5rem;
  color: inherit;
  text-align: center;
  text-decoration: none;
  box-shadow: 0 0 1rem rgba(32, 39, 44, 0.25);
  z-index: 1;
}

.buildings__image {
  position: relative;
  overflow: hidden;
}
.buildings__image::before {
  content: "";
  display: block;
  padding-top: 66.667%;
}
.buildings__image img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
}

.buildings__title {
  display: block;
  margin: 1rem 0 0.5rem;
  font-size: 1.25rem;
  font-weight: bold;
}

.buildings__address {
  display: block;
}

.buildings__neighborhood {
  display: block;
  color: #66676c;
}

.buildings__map {
  width: 100%;
}

.buildings__map__embed {
  height: 20rem;
}

.button {
  display: inline-block;
  padding: 0.5rem 1.5rem;
  border: 0;
  border-radius: 0.25rem;
  background: #2c8d95;
  color: #fff;
  font-size: 1.25rem;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
}

.comments {
  padding-top: 2rem;
  padding-bottom: 2rem;
}
.post + .comments, .feed + .comments {
  border-top: 0.125rem solid #cdd0cf;
}
.comments iframe {
  display: block;
}

.comments__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .comments__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .comments__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.expand {
  border-bottom: 0.0625rem solid #cdd0cf;
}

.expand__toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 1rem 0;
  border: 0;
  background-color: transparent;
  font-weight: bold;
}

.expand__icon {
  flex-shrink: 0;
  width: 1.25rem;
}
[aria-expanded=true] > .expand__icon {
  transform: rotate(180deg);
}

.expand__content {
  display: none;
  margin-top: -1rem;
}
[aria-expanded=true] + .expand__content {
  display: block;
}

.feature {
  position: relative;
  margin: 0 0 2rem;
}

.feature--empty {
  margin: 0 0 1.3125rem 1rem;
}

.feature__image {
  position: relative;
  overflow: hidden;
}
.feature--empty .feature__image {
  display: none;
}
.feature__image::before {
  display: block;
  padding-bottom: 66.666%;
  content: "";
}
.feature__image img {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateY(-50%);
  -o-object-fit: cover;
     object-fit: cover;
}

.feature__caption {
  position: absolute;
  bottom: -0.6875rem;
  left: 1rem;
  padding: 0.125rem 0.375rem;
  background: #2c8d95;
  color: #fff;
  font-size: 0.75rem;
}
.feature--empty .feature__caption {
  display: inline-block;
  position: static;
}
.feature__caption a {
  color: inherit;
  text-decoration: none;
}

.featured-post {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-block: 4rem;
}
@media (min-width: 48em) {
  .featured-post {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .featured-post {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.featured-post__item {
  display: grid;
  gap: 2rem;
}
@media (min-width: 48em) {
  .featured-post__item {
    grid-template-columns: 1fr 1fr;
  }
}

.featured-post__text {
  align-self: center;
}
.featured-post__text h3 {
  margin-bottom: 0.5rem;
}

.feed {
  margin: 2rem 0;
}

.feed--alt {
  padding: 2rem 0;
  border-top: 0.125rem solid #cdd0cf;
  border-bottom: 0.125rem solid #cdd0cf;
  background: #f5f5f5;
}

.feed__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .feed__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .feed__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.feed__heading {
  display: flex;
  align-items: center;
  margin: 0 0 1rem;
  color: #66676c;
  font-size: inherit;
}

.feed__heading__icon {
  width: 1rem;
  margin-right: 0.75rem;
}

.feed__scroll {
  display: flex;
  align-items: flex-start;
  margin: 0 -1rem;
  overflow-x: auto;
  overflow-y: hidden;
}
@media (min-width: 48em) {
  .feed__scroll {
    margin-right: -2rem;
    margin-left: -2rem;
  }
}
@media (min-width: 48em) {
  .feed__scroll::before, .feed__scroll::after {
    display: block;
    flex-shrink: 0;
    align-self: stretch;
    width: 1rem;
    content: "";
  }
}

@media (min-width: 64em) {
  .feed__scroll--alt {
    flex-wrap: wrap;
    padding: 0 1rem;
  }
}
@media (min-width: 64em) {
  .feed__scroll--alt::before, .feed__scroll--alt::after {
    display: none;
  }
}

.feed__scroll--simple {
  flex-wrap: wrap;
  align-items: center;
}
@media (min-width: 48em) {
  .feed__scroll--simple {
    margin-right: -1rem;
    margin-left: -1rem;
  }
}
.feed__scroll--simple::before, .feed__scroll--simple::after {
  display: none;
}

.feed__item {
  flex-shrink: 0;
  width: 18.666rem;
  padding: 0 1rem;
  color: #66676c;
}
@media (min-width: 64em) {
  .feed__item {
    width: 33.333%;
  }
}
.feed__item * {
  box-sizing: border-box;
}
.feed__item :last-child {
  margin-bottom: 0;
}
@media (min-width: 64em) {
  .feed__scroll--alt .feed__item:nth-child(n+4) {
    margin-top: 2rem;
  }
}
.feed__scroll--simple .feed__item {
  width: 50%;
  margin-top: 2rem;
  padding: 0 2rem;
}
@media (min-width: 48em) {
  .feed__scroll--simple .feed__item {
    width: 33.333%;
  }
}
.feed__scroll--simple .feed__item:nth-child(n+3) {
  margin-top: 4rem;
}
@media (min-width: 48em) {
  .feed__scroll--simple .feed__item:nth-child(n+3) {
    margin-top: 2rem;
  }
}
@media (min-width: 48em) {
  .feed__scroll--simple .feed__item:nth-child(n+4) {
    margin-top: 4rem;
  }
}

.feed__item--video {
  padding-bottom: 1rem;
}

.feed__image {
  display: block;
  position: relative;
}
.feed__item--alt .feed__image {
  margin-bottom: 1.25rem;
}

.feed__image__link {
  display: block;
  position: relative;
  background: #141b4d;
}
.feed__image__link::before {
  display: block;
  padding-bottom: 50%;
  content: "";
}
.feed__image__link img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.feed__image__link--team::before {
  padding-bottom: 75%;
}

.feed__status {
  position: absolute;
  bottom: -0.6875rem;
  left: 1rem;
  padding: 0.125rem 0.375rem;
  color: #fff;
  font-size: 0.75rem;
  font-weight: bold;
  text-decoration: none;
}

.feed__status--for-sale,
.feed__status--category {
  background: #2c8d95;
}

.feed__status--for-rent {
  background: #2c8d95;
}

.feed__status--pending {
  background: #141b4d;
}

.feed__status--sold {
  background: #66676c;
}

.feed__title {
  margin: 0.5rem 0;
  color: #20272c;
  font-size: inherit;
  font-weight: bold;
}
.feed__title a {
  color: inherit;
  text-decoration: none;
}
.feed__item--alt .feed__title {
  padding: 0 1rem;
}

.feed__date,
.feed__price {
  margin: 0.5rem 0;
}
.feed__item--alt .feed__date,
.feed__item--alt .feed__price {
  padding: 0 1rem;
}

.feed__price {
  color: #2c8d95;
}

.feed__role {
  margin-bottom: 0;
  color: #2c8d95;
  font-weight: bold;
}

.feed__name {
  margin: 0;
  color: #20272c;
  font-size: 1.375rem;
  font-weight: bold;
}
.feed__name a {
  color: inherit;
  text-decoration: none;
}

.feed__map {
  margin-bottom: 2rem;
}

.footer {
  padding-block: 4rem;
  background: #141b4d;
  color: #fff;
}
.footer a {
  color: inherit;
  text-decoration: none;
}
.footer p:not([class]) {
  font-size: 0.75rem;
}

.footer__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  display: grid;
  gap: 2rem 4rem;
  align-items: center;
}
@media (min-width: 48em) {
  .footer__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .footer__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}
@media (min-width: 64em) {
  .footer__container {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

.footer__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin: 0;
  padding: 0;
  font-size: 0.75rem;
  list-style: none;
  text-align: center;
}

.footer__bottom {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-top: 4rem;
  text-align: center;
}
@media (min-width: 48em) {
  .footer__bottom {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .footer__bottom {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}
.footer__bottom p {
  margin: 0;
}

.footer__legal {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin: 0;
  padding: 0;
  font-size: 0.75rem;
  list-style: none;
  text-align: center;
}

.gallery {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.gallery__link {
  display: block;
  position: relative;
  width: 100%;
  margin-top: 1rem;
  overflow: hidden;
}
@media (min-width: 48em) {
  .gallery__link {
    width: calc(50% - 0.5rem);
  }
}
.gallery__link:first-child, .gallery__link:last-child:nth-child(even) {
  width: 100%;
}
.gallery__link::before {
  display: block;
  padding-bottom: 66.666%;
  content: "";
}
.gallery__link img {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateY(-50%);
  -o-object-fit: cover;
     object-fit: cover;
}

.header {
  position: relative;
  border-top: 0.75rem solid #bbd771;
  border-bottom: 0.125rem solid #cdd0cf;
}

.header__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .header__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .header__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.header__main {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header__title {
  position: relative;
  margin: 1rem auto;
  color: #141b4d;
}
@media (min-width: 64em) {
  .header__title {
    margin: 1rem 0;
  }
}

.header__toggle {
  position: relative;
  width: 2.25rem;
  padding: 0.625rem;
  border: 0.0625rem solid #cdd0cf;
  border-radius: 50%;
  background: none;
  color: #66676c;
}

.header__toggle--nav {
  order: -1;
}
@media (min-width: 64em) {
  .header__toggle--nav {
    display: none;
  }
}

.header__contact {
  margin: 0 -1rem;
  padding: 1rem;
  border-top: 0.125rem solid #cdd0cf;
  background: #f5f5f5;
  font-size: 0.875rem;
  text-align: center;
  pointer-events: none;
}
@media (max-width: 63.999em) {
  .header__contact {
    display: none;
  }
}
@media (min-width: 48em) {
  .header__contact {
    margin: 0 -2rem;
  }
}
@media (min-width: 64em) {
  .header__contact {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    max-width: 80rem;
    margin: 0;
    padding: 0 5.25rem 0 0;
    transform: translate(-50%, -50%);
    border-top: 0;
    background: transparent;
    text-align: right;
  }
}
@media (min-width: 80rem) {
  .header__contact {
    padding-right: 6.25rem;
  }
}
.header__contact * {
  pointer-events: auto;
}

.header__contact__heading {
  margin: 0;
  font-size: inherit;
}

.header__contact__link {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

.header__contact__link--alt {
  color: inherit;
  font-weight: normal;
}

.hero {
  padding: 4rem 0;
  background-position: center;
  background-size: cover;
}
@media (min-width: 48em) {
  .hero {
    padding: 6rem 0;
  }
}
@media (min-width: 64em) {
  .hero {
    padding: 8rem 0;
  }
}

.hero--simple {
  color: #fff;
  text-shadow: 0 0.125rem 0.25rem #20272c;
}

.hero__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .hero__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .hero__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}
.hero--simple .hero__container {
  max-width: 52rem;
}

.hero__overlay {
  padding: 2rem;
  background-color: rgba(255, 255, 255, 0.95);
  font-size: 1.5rem;
  text-align: center;
}
@media (min-width: 48em) {
  .hero__overlay {
    padding: 2rem 4rem;
  }
}
@media (min-width: 64em) {
  .hero__overlay {
    padding: 2rem 8rem;
  }
}
.hero--simple .hero__overlay {
  background-color: transparent;
}

.hero__heading {
  margin-bottom: 0;
  font-size: 2rem;
}
.hero__heading::after {
  display: block;
  max-width: 12rem;
  height: 0.125rem;
  margin: 1.5rem auto;
  background-color: #cdd0cf;
  content: "";
}
.hero--simple .hero__heading::after {
  display: none;
}

.lifestyles {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-top: 2rem;
  margin-bottom: 2rem;
}
@media (min-width: 48em) {
  .lifestyles {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .lifestyles {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.lifestyles__desc {
  margin: 0;
  font-weight: normal;
  text-align: center;
}

.lifestyles__grid {
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 0 -1rem;
}

.lifestyles__item {
  width: calc(100% - 1rem);
  margin: 1rem 0 0 1rem;
}
@media (min-width: 48em) {
  .lifestyles__item {
    width: calc(50% - 1rem);
  }
}

.lifestyles__link {
  display: block;
  position: relative;
  color: inherit;
}

.lifestyles__title {
  position: absolute;
  top: 50%;
  left: 50%;
  padding: 0.5rem 1rem;
  transform: translate(-50%, -50%);
  background-color: rgba(255, 255, 255, 0.95);
  font-weight: bold;
}

.list {
  margin: 2rem 0;
}

.list__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .list__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .list__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.list__item {
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  border-bottom: 0.125rem solid #e9e9e9;
}
@media (min-width: 48em) {
  .list__item {
    display: flex;
  }
}

.list__image {
  width: 16.666rem;
  margin-bottom: 1rem;
}
@media (min-width: 48em) {
  .list__image {
    flex-shrink: 0;
    margin: 0 2rem 0 0;
  }
}
@media (min-width: 80em) {
  .list__image {
    width: 16rem;
  }
}

.list__content > :first-child {
  margin-top: 0;
}
.list__content > :last-child {
  margin-bottom: 0;
}
.list__content a {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

.list__meta {
  margin-bottom: 0;
  color: #66676c;
}

.list__title {
  margin: 0;
}

.list__title--alt a {
  color: inherit;
}

.list__source {
  display: flex;
  align-items: center;
  color: #66676c;
  font-style: italic;
}

.list__source__logo {
  width: 6rem;
  margin-left: 1rem;
}

.load {
  margin: 2rem 0;
  text-align: center;
}
.feed__scroll--auto + .load {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.load__button {
  padding: 0.5rem 1rem;
  border: 0.0625rem solid #cdd0cf;
  border-radius: 0.25rem;
  background: #fff;
  color: #66676c;
}

.load__button__container {
  display: flex;
}

.load__button__icon {
  width: 0.75rem;
  margin-left: 0.5rem;
}
.load__button--loading .load__button__icon {
  animation: spin 600ms linear;
  animation-iteration-count: infinite;
}

.logo {
  color: inherit;
  line-height: 1;
  text-align: left;
  text-decoration: none;
}

.logo__name {
  display: block;
  font-size: 2rem;
  font-weight: bold;
}

.logo__description {
  display: block;
  color: #2c8d95;
  font-size: 1.25rem;
  font-weight: normal;
}

.meta {
  display: flex;
  flex-direction: column;
  margin-bottom: 1rem;
  color: #66676c;
}
@media (min-width: 48em) {
  .meta {
    flex-direction: row;
    align-items: center;
  }
}
.meta :last-child {
  margin-bottom: 0;
}

.meta__post {
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
  line-height: 1.25;
}
@media (min-width: 48em) {
  .meta__post {
    margin-bottom: 0;
  }
}
.meta__post a {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

.meta__user {
  margin-right: 0.5rem;
  border-radius: 50%;
}

.meta__detail {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
}
.meta__detail span {
  display: block;
}

.meta__detail__date::before {
  content: " • ";
}

.meta__share {
  display: flex;
  align-items: center;
  font-weight: bold;
}
@media (min-width: 48em) {
  .meta__share {
    margin-left: auto;
  }
}

.meta__share__link {
  display: block;
  width: 2rem;
  margin-left: 1rem;
  color: #141b4d;
}

.nav {
  position: absolute;
  top: -0.75rem;
  left: 0;
  width: 100%;
  transform: translateY(-100%);
  transition: transform 300ms ease-in-out;
  border-bottom: 0.125rem solid #cdd0cf;
  background: #fff;
  color: #141b4d;
  z-index: 3;
}
@media (min-width: 64em) {
  .nav {
    position: static;
    align-self: flex-end;
    width: auto;
    margin-right: auto;
    transform: none;
    transition: none;
    border: 0;
    background: transparent;
    z-index: auto;
  }
}

.nav--active {
  transform: none;
}

.nav__close {
  width: 100%;
  padding: 1rem;
  border: 0;
  border-bottom: 0.0625rem solid #fff;
  background: #141b4d;
  color: #fff;
}
@media (min-width: 64em) {
  .nav__close {
    display: none;
  }
}

.nav__close__container {
  display: flex;
  align-items: center;
  justify-content: center;
}

.nav__close__icon {
  display: block;
  width: 0.75rem;
  margin-right: 0.5rem;
}

.nav__list {
  margin: 0;
  padding: 1rem 0;
  background: #141b4d;
  color: #fff;
  list-style: none;
}
@media (min-width: 64em) {
  .nav__list {
    display: flex;
    gap: 1.5rem;
    margin-left: 3rem;
    padding: 0;
    background: none;
    color: #66676c;
  }
}
@media (min-width: 64em) {
  .nav__list > li:has(> [aria-expanded=true]) > a,
.nav__list > li:has(> [aria-expanded=true]) > button {
    color: #141b4d;
  }
}
.nav__list li {
  display: flex;
  flex-wrap: wrap;
  position: relative;
}
.nav__list a {
  display: block;
  max-width: calc(100% - 3.25rem);
  padding: 1rem;
  color: inherit;
  text-decoration: none;
}
@media (min-width: 64em) {
  .nav__list a {
    max-width: none;
    padding-inline: 0;
  }
}
.nav__list ul {
  display: none;
  width: 100%;
  margin: 0;
  padding: 0 0 0 1rem;
  list-style: none;
}
@media (min-width: 64em) {
  .nav__list ul {
    position: absolute;
    top: 100%;
    left: -1.5rem;
    width: 20rem;
    padding: 1rem 1.5rem;
    background: #141b4d;
    color: #fff;
    z-index: 1;
  }
}
.nav__list ul a {
  padding-block: 0.5rem;
}
@media (min-width: 64em) {
  .nav__list ul a {
    max-width: calc(100% - 3.25rem);
  }
}
@media (min-width: 64em) {
  .nav__list ul ul {
    position: static;
    width: 100%;
    padding-block: 0;
    background: none;
  }
}
.nav__list [aria-expanded=true] + ul {
  display: block;
}

.nav__toggle {
  flex-shrink: 0;
  width: 3.25rem;
  margin-left: auto;
  padding: 0 1rem;
  border: 0;
  background: none;
  color: inherit;
}
@media (min-width: 64em) {
  .nav__toggle {
    width: 1.25rem;
    padding: 0;
  }
}
.nav__toggle[aria-expanded=true] svg {
  transform: rotate(180deg);
}

.nav__block__list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 0 -1rem;
  padding: 0;
  list-style: none;
}

.nav__block__item {
  width: 50%;
  padding: 0 0 1rem 1rem;
  text-align: center;
}
@media (min-width: 48em) {
  .nav__block__item {
    width: 33.333%;
  }
}
@media (min-width: 64em) {
  .nav__block__item {
    width: 25%;
  }
}
@media (min-width: 72em) {
  .nav__block__item {
    width: 20%;
  }
}
@media (min-width: 80rem) {
  .nav__block__item {
    width: 16.666%;
  }
}
@media (min-width: 48em) {
  .nav__block__list--inline .nav__block__item {
    width: 25%;
  }
}

.nav__block__item--alt {
  width: auto;
  padding: 0 1rem 1rem 2rem;
  text-align: left;
}

.nav__block__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 11.5rem;
  padding: 1rem;
  border-radius: 0.25rem;
  background-color: #141b4d;
  background-position: center;
  background-size: cover;
  color: #fff;
  font-size: 0.75rem;
  text-align: center;
  text-decoration: none;
}

.nav__block__label {
  display: block;
  max-width: 100%;
  padding: 0.125rem 0.375rem;
  background: #2c8d95;
}

.nav__block__name {
  display: block;
  margin-top: 1rem;
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

.newsletter-container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-top: 2rem;
  margin-bottom: 2rem;
}
@media (min-width: 48em) {
  .newsletter-container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .newsletter-container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.newsletter {
  position: relative;
  width: 100%;
  padding-bottom: 2.25rem;
  text-align: center;
}
@media (min-width: 48em) {
  .newsletter {
    font-size: 1.25rem;
  }
}
@media (min-width: 64em) {
  .newsletter {
    font-size: 1.5rem;
  }
}
.post__content .newsletter {
  margin-top: 2rem;
  margin-bottom: 2rem;
}
@media (min-width: 64em) {
  .newsletter-container .newsletter {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
}

.newsletter__header {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.post__content .newsletter__header {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}
.newsletter-container .newsletter__header {
  flex-direction: row;
  align-items: flex-start;
  text-align: left;
}
@media (min-width: 64em) {
  .newsletter-container .newsletter__header {
    margin-right: 4rem;
  }
}

.newsletter__icon {
  width: 2rem;
  margin-bottom: 0.5rem;
}
@media (min-width: 48em) {
  .newsletter__icon {
    width: 2.5rem;
  }
}
@media (min-width: 64em) {
  .newsletter__icon {
    width: 3rem;
  }
}
.newsletter-container .newsletter__icon {
  flex-shrink: 0;
  margin: 0 1rem 0 0;
}
@media (min-width: 48em) {
  .newsletter-container .newsletter__icon {
    margin-right: 2rem;
  }
}

.newsletter__text {
  margin-bottom: 1rem;
}
@media (min-width: 48em) {
  .newsletter__text {
    margin-bottom: 2rem;
  }
}
@media (min-width: 64em) {
  .newsletter-container .newsletter__text {
    margin: 0;
  }
}
.footer .newsletter__text {
  font-size: 1rem;
}

.newsletter__heading {
  margin: 0;
  font-size: inherit;
}

.newsletter__description {
  margin: 0;
}

.newsletter__form {
  display: flex;
  width: 100%;
  font-size: 1rem;
}
@media (min-width: 64em) {
  .newsletter-container .newsletter__form {
    flex: 1 1 auto;
    width: auto;
  }
}
.newsletter__form iframe {
  width: 100%;
}

.newsletter__label {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.newsletter__input {
  flex: 1 1 auto;
  width: 0;
  min-width: 0;
  margin-right: 0.375rem;
  padding: 0.5rem 1rem;
  border: 0;
  background: transparent;
  color: #66676c;
}
.newsletter__input::-moz-placeholder {
  opacity: 1;
}
.newsletter__input:-ms-input-placeholder {
  opacity: 1;
}
.newsletter__input::placeholder {
  opacity: 1;
}
.footer .newsletter__input {
  color: #fff;
}
.footer .newsletter__input::-moz-placeholder {
  color: #fff;
}
.footer .newsletter__input:-ms-input-placeholder {
  color: #fff;
}
.footer .newsletter__input::placeholder {
  color: #fff;
}

.newsletter__locations {
  display: flex;
  justify-content: center;
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0;
}

.newsletter__checkbox {
  margin: 0 0.5rem;
}
.newsletter__checkbox input {
  margin-right: 0.25rem;
}

.newsletter__button {
  padding: 0.5rem 1rem;
  border: 0;
  border-radius: 0.25rem;
  background: #2c8d95;
  color: #fff;
}

.pagination {
  padding: 2rem 0;
}
.post + .pagination {
  border-top: 0.125rem solid #cdd0cf;
}
.pagination a {
  display: block;
  padding: 0.5rem 1rem;
  border: 0.0625rem solid #cdd0cf;
  border-radius: 0.25rem;
  color: #66676c;
  text-decoration: none;
}

.pagination__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  display: flex;
}
@media (min-width: 48em) {
  .pagination__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .pagination__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.pagination__previous {
  margin-left: auto;
}

.popup {
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  align-items: center;
  justify-content: center;
  width: 100%;
  transition: opacity 300ms ease-in-out, visibility 300ms ease-in-out;
  background: rgba(32, 39, 44, 0.25);
  opacity: 0;
  visibility: hidden;
  z-index: 4;
}
.admin-bar .popup {
  top: 32px;
}
@media (max-width: 782px) {
  .admin-bar .popup {
    top: 46px;
  }
}

.popup--active {
  opacity: 1;
  visibility: visible;
}

.popup__scroll {
  width: 100%;
  max-height: 100%;
  padding: 1rem 0;
  overflow: auto;
}
@media (min-width: 48em) {
  .popup__scroll {
    padding: 2rem 0;
  }
}
@media (min-width: 80em) {
  .popup__scroll {
    padding: 3rem 0;
  }
}

.popup__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .popup__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .popup__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.popup__main {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  padding: 1rem;
  border-radius: 0.25rem;
  background: #fff;
  color: #141b4d;
  box-shadow: 0.25rem 0.25rem 0.5rem rgba(32, 39, 44, 0.25);
}
@media (min-width: 48em) {
  .popup__main {
    padding: 2rem;
  }
}
@media (min-width: 64em) {
  .popup__main {
    padding: 3rem;
  }
}
.popup--contact .popup__main, .popup--question .popup__main {
  align-items: stretch;
}

.popup__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 2.25rem;
  padding: 0.625rem;
  border: 0.0625rem solid #cdd0cf;
  border-radius: 50%;
  background: transparent;
  color: #66676c;
}

.popup__heading {
  margin: 0;
  padding: 0 3rem 0 1rem;
  font-size: 1rem;
}
@media (min-width: 48em) {
  .popup__heading {
    font-size: 1.5rem;
  }
}

.popup__description {
  margin: 0;
  padding: 0 3rem 0 1rem;
}
@media (min-width: 48em) {
  .popup__description {
    font-size: 1.25rem;
  }
}

.post {
  margin: 2rem 0;
}
.post + .post {
  padding-top: 1rem;
  border-top: 0.125rem solid #cdd0cf;
}

.post__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .post__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .post__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.post__container--wide {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .post__container--wide {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .post__container--wide {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.post__breadcrumbs {
  color: #66676c;
  font-size: 0.75rem;
}
.post__breadcrumbs a {
  color: inherit;
  text-decoration: none;
}
.post__breadcrumbs .breadcrumb_separator {
  margin: 0 0.5rem;
  color: #e9e9e9;
}
.post__breadcrumbs .breadcrumb_last {
  font-weight: bold;
}

.post__title {
  margin: 1rem 0 0.5rem;
  font-size: 1.5em;
}
.post__title a {
  color: inherit;
  text-decoration: none;
}

.post__content {
  position: relative;
  z-index: 0;
}
@media (min-width: 48em) {
  .post__content {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .post__content {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}
.post__content a:not([class]) {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}
.post__content blockquote {
  margin-right: 0;
  margin-left: 0;
  padding: 1rem;
  background: #f5f5f5;
}
@media (min-width: 48em) {
  .post__content blockquote {
    padding: 2rem;
  }
}
.post__content blockquote :first-child {
  margin-top: 0;
}
.post__content blockquote :last-child {
  margin-bottom: 0;
}

.post__footer {
  display: flex;
  flex-direction: row;
}

.post__more {
  color: #2c8d95;
  font-weight: bold;
  text-decoration: none;
}

.post__comments {
  display: flex;
  align-items: center;
  margin-left: auto;
  color: #66676c;
  text-decoration: none;
}

.post__comments__icon {
  width: 1rem;
  margin-right: 0.5rem;
}

.posts {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-block: 4rem;
}
@media (min-width: 48em) {
  .posts {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .posts {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.posts__grid {
  display: grid;
  align-items: start;
  gap: 2rem;
}
@media (min-width: 32em) {
  .posts__grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 64em) {
  .posts__grid {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}
.posts__grid img {
  margin-bottom: 1rem;
}

.reviews {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin: 2rem auto;
}
@media (min-width: 48em) {
  .reviews {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .reviews {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.router {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-block: 4rem;
}
@media (min-width: 48em) {
  .router {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .router {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.router--nested {
  padding: 0;
}

.router__wrap {
  display: grid;
  align-items: start;
  gap: 2rem;
}
@media (min-width: 48em) {
  .router__wrap {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 64em) {
  .router__wrap {
    grid-template-columns: 2fr 3fr;
  }
}

.router__featured {
  display: grid;
  align-items: start;
  align-self: start;
  gap: 2rem;
}

.router__grid {
  display: grid;
  align-items: start;
  gap: 2rem;
}
@media (min-width: 32em) {
  .router__grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 64em) {
  .router__grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media (min-width: 64em) {
  .router__wrap .router__grid {
    grid-template-columns: 1fr 1fr;
  }
}
.router__grid img {
  margin-bottom: 1rem;
}

.router__cta {
  margin-top: 2rem;
  text-align: center;
}

body .search {
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  align-items: center;
  width: 100%;
  transition: opacity 300ms ease-in-out, visibility 300ms ease-in-out;
  background: rgba(255, 255, 255, 0.95);
  opacity: 0;
  visibility: hidden;
  z-index: 3;
}

body.admin-bar .search {
  top: 32px;
}
@media (max-width: 782px) {
  body.admin-bar .search {
    top: 46px;
  }
}

body .search--active {
  opacity: 1;
  visibility: visible;
}

.search__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
}
@media (min-width: 48em) {
  .search__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .search__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.search__label {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.search__input {
  width: 100%;
  border: 0;
  background: transparent;
  font-size: 2rem;
}
@media (min-width: 48em) {
  .search__input {
    font-size: 3rem;
  }
}
@media (min-width: 64em) {
  .search__input {
    font-size: 4rem;
  }
}
@media (min-width: 80em) {
  .search__input {
    font-size: 5rem;
  }
}
.search__input::-moz-placeholder {
  opacity: 1;
}
.search__input:-ms-input-placeholder {
  opacity: 1;
}
.search__input::placeholder {
  opacity: 1;
}

.search__button {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.search__close {
  position: absolute;
  top: 0;
  right: 0;
  width: 2.875rem;
  padding: 1rem;
  border: 0;
  background: transparent;
}

.skyline {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns:rdf=%22http://www.w3.org/1999/02/22-rdf-syntax-ns%23%22 xmlns=%22http://www.w3.org/2000/svg%22 height=%2278.807mm%22 width=%2222.343mm%22 version=%221.1%22 xmlns:cc=%22http://creativecommons.org/ns%23%22 xmlns:dc=%22http://purl.org/dc/elements/1.1/%22 viewBox=%220 0 79.168132 279.23748%22%3E %3Cg fill=%22%23f5f5f5%22 transform=%22matrix%28-1 0 0 -1 -802.59 693.23%29%22%3E %3Cpath fill=%22%23f5f5f5%22 d=%22m-802.59 431.36c-19.785 0-19.785-17.365-39.571-17.365-19.798 0-19.798 17.365-39.597 17.365v261.87h79.168%22/%3E %3C/g%3E %3C/svg%3E ");
  background-repeat: repeat-x;
  background-position: center 38%;
  background-size: auto 41%;
}

.skyline__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  max-width: none;
}
@media (min-width: 48em) {
  .skyline__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .skyline__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.slideshow__main {
  position: relative;
}

.slideshow__full {
  display: none;
  position: relative;
  width: 100%;
  max-height: 34rem;
  margin-bottom: 1rem;
  overflow: hidden;
  aspect-ratio: 1440/600;
}
@media (min-width: 48em) {
  .slideshow__full {
    display: block;
  }
}
.slideshow__full::before {
  display: block;
  padding-top: 66.666%;
  content: "";
}

.slideshow__full__image {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateY(-50%);
  transition: opacity 300ms ease-in-out;
  -o-object-fit: cover;
     object-fit: cover;
}

.slideshow__full__image--preload {
  opacity: 0;
}

.slideshow__prev,
.slideshow__next {
  display: none;
  position: absolute;
  top: 50%;
  width: 3rem;
  padding: 0;
  border: 0;
  border-radius: 0.25rem;
  transform: translateY(-50%);
  transition: opacity 300ms ease-in-out, visibility 300ms ease-in-out;
  background: #2c8d95;
  color: #fff;
  opacity: 0;
  visibility: hidden;
}
@media (min-width: 48em) {
  .slideshow__prev,
.slideshow__next {
    display: block;
  }
}
.slideshow__main:hover .slideshow__prev,
.slideshow__main:hover .slideshow__next {
  opacity: 1;
  visibility: visible;
}

.slideshow__prev {
  left: 1rem;
}

.slideshow__next {
  right: 1rem;
}

.slideshow__nav {
  display: flex;
  align-items: flex-start;
  padding-inline: 1rem;
  overflow-x: auto;
  overflow-y: hidden;
}

.slideshow__nav__item {
  display: block;
  position: relative;
  flex-shrink: 0;
  width: 20.25rem;
  max-width: calc(100% - 2rem);
  margin-left: 1rem;
  background-color: #141b4d;
  overflow: hidden;
}
@media (min-width: 48em) {
  .slideshow__nav__item {
    width: 13.5rem;
  }
}
.slideshow__nav__item::before {
  display: block;
  padding-top: 66.666%;
  content: "";
}
.slideshow__nav__item:first-child {
  margin-left: 0;
}

.slideshow__nav__item--active::after {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0.5rem solid #bbd771;
  content: "";
  pointer-events: none;
}
@media (min-width: 48em) {
  .slideshow__nav__item--active::after {
    display: block;
  }
}

.slideshow__nav__image {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateY(-50%);
  -o-object-fit: cover;
     object-fit: cover;
}

.social {
  display: flex;
  justify-content: center;
  margin: 0 0 2rem;
  padding: 0;
  list-style: none;
}
.social:last-child {
  margin-bottom: 0;
}
@media (min-width: 64em) {
  .nav .social {
    display: none;
  }
}

.social__item {
  margin: 0 0.25rem;
}

.social__link {
  display: block;
  width: 4rem;
  padding: 0.375rem 1rem;
  border: 0.0625rem solid;
  border-radius: 0.25rem;
  color: inherit;
}

.split {
  margin: 2rem 0;
}
.split h4 {
  margin-bottom: 0;
  color: #141b4d;
}
.split h4 + p {
  margin-top: 0;
}
.split ul,
.split ol {
  padding-left: 1.125rem;
}
.split .gform_fields {
  padding-left: 0;
}

.split__container {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}
@media (min-width: 48em) {
  .split__container {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .split__container {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.split__item {
  width: 100%;
}
@media (min-width: 48em) {
  .split__item {
    width: calc(50% - 1rem);
    margin-top: 2rem;
  }
}
.split__item > :first-child {
  margin-top: 0;
}
.split__item > :last-child {
  margin-bottom: 0;
}
.split__item + .split__item {
  margin-top: 2rem;
}
@media (min-width: 48em) {
  .split__item + .split__item {
    margin-top: 0;
  }
}

.split__item--gray-light {
  flex-grow: 1;
  margin-right: -1rem;
  margin-left: -1rem;
  padding: 2rem 1rem;
  background: #f5f5f5;
}
@media (min-width: 48em) {
  .split__item--gray-light {
    flex-grow: 0;
    margin-right: 0;
    margin-left: 0;
    padding: 2rem;
  }
}

.title {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin: 2rem auto;
}
@media (min-width: 48em) {
  .title {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .title {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.title__breadcrumbs {
  color: #66676c;
  font-size: 0.75rem;
}
.title__breadcrumbs a {
  color: inherit;
  text-decoration: none;
}
.title__breadcrumbs .breadcrumb_separator {
  margin: 0 0.5rem;
  color: #e9e9e9;
}
.title__breadcrumbs .breadcrumb_last {
  font-weight: bold;
}

.title__text {
  padding-top: 0.5rem;
  border-top: 0.125rem solid #cdd0cf;
  font-size: 1.25rem;
  font-weight: bold;
}

.video {
  position: relative;
}
.video::before {
  display: block;
  padding-bottom: 56.25%;
  content: "";
}
.video > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.visual-editor {
  width: 100%;
  max-width: 80rem;
  margin-right: auto;
  margin-left: auto;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-block: 4rem;
}
@media (min-width: 48em) {
  .visual-editor {
    padding-right: 2rem;
    padding-left: 2rem;
  }
}
@media (min-width: 80em) {
  .visual-editor {
    padding-right: 3rem;
    padding-left: 3rem;
  }
}

.visual-editor__cta {
  margin-top: 2rem;
  text-align: center;
}
/*# sourceMappingURL=style.css.map */
