:root {
  --black: black;
  --red: #e90000;
  --black-70: #000000b3;
  --white: white;
  --dark-khaki: #7b8a53;
  --dark-red: #b40000;
  --black-10: #0000001a;
  --dark-olive-green: #344e23;
  --black-04: #0000000a;
  --black-40: #0006;
  --white-smoke: #f0efed;
  --black-60: #0009;
  --black-20: #0003;
  --white-20: #fff3;
  --white-40: #fff6;
  --white-60: #fff9;
}

.w-layout-blockcontainer {
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.w-embed-youtubevideo {
  background-image: url('https://d3e54v103j8qbb.cloudfront.net/static/youtube-placeholder.2b05e7d68d.svg');
  background-position: 50%;
  background-size: cover;
  width: 100%;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  position: relative;
}

.w-embed-youtubevideo:empty {
  min-height: 75px;
  padding-bottom: 56.25%;
}

@media screen and (max-width: 991px) {
  .w-layout-blockcontainer {
    max-width: 728px;
  }
}

@media screen and (max-width: 767px) {
  .w-layout-blockcontainer {
    max-width: none;
  }
}

body {
  color: #000;
  font-family: Inter, sans-serif;
  font-size: 16px;
  font-weight: 300;
  line-height: 180%;
}

h1 {
  letter-spacing: -5px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 96px;
  font-weight: 600;
  line-height: 100%;
}

h2 {
  letter-spacing: -2px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 64px;
  font-weight: 600;
  line-height: 110%;
}

h3 {
  letter-spacing: -1px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 32px;
  font-weight: 200;
  line-height: 120%;
}

h4 {
  letter-spacing: -.5px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 24px;
  font-weight: 500;
  line-height: 120%;
}

h5 {
  letter-spacing: -.5px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 20px;
  font-weight: 500;
  line-height: 120%;
}

h6 {
  letter-spacing: 0;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 140%;
}

p {
  margin-bottom: 0;
}

a {
  color: var(--black);
  font-weight: 400;
  text-decoration: none;
}

ul, ol {
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 40px;
}

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

strong {
  font-weight: 600;
}

em {
  font-style: italic;
}

blockquote {
  border-left: 2px solid var(--red);
  margin-top: 64px;
  margin-bottom: 64px;
  margin-left: 32px;
  padding: 0 32px 0 24px;
  font-size: 24px;
  font-weight: 500;
  line-height: 140%;
}

figure {
  margin-bottom: 10px;
}

figcaption {
  text-align: center;
  margin-top: 5px;
}

.rich-text h1, .rich-text h2 {
  letter-spacing: -1px;
  margin-top: 48px;
  margin-bottom: 20px;
  font-size: 32px;
  font-weight: 500;
  line-height: 120%;
}

.rich-text h3 {
  letter-spacing: -.5px;
  margin-top: 24px;
  margin-bottom: 16px;
  font-size: 24px;
  font-weight: 500;
  line-height: 120%;
}

.rich-text h4 {
  letter-spacing: -.5px;
  margin-top: 24px;
  margin-bottom: 16px;
  font-size: 20px;
  line-height: 120%;
}

.rich-text h5 {
  letter-spacing: -.5px;
  margin-top: 24px;
  margin-bottom: 16px;
  font-size: 18px;
  line-height: 120%;
}

.rich-text h6 {
  margin-top: 16px;
  margin-bottom: 12px;
  font-size: 16px;
  font-weight: 600;
  line-height: 140%;
}

.rich-text p {
  margin-bottom: 24px;
  font-size: 16px;
  line-height: 180%;
}

.rich-text a {
  color: var(--red);
  font-weight: 400;
  text-decoration: underline;
}

.rich-text strong {
  font-weight: 500;
}

.rich-text li {
  font-size: 16px;
  line-height: 180%;
}

.rich-text ul, .rich-text ol {
  margin-bottom: 24px;
  padding-left: 24px;
}

.rich-text figcaption {
  margin-top: 12px;
  font-size: 12px;
  font-weight: 400;
  line-height: 170%;
}

.rich-text figure {
  margin-top: 48px;
  margin-bottom: 48px;
}

.rich-text blockquote {
  border-left: 2px solid var(--red);
  margin-top: 64px;
  margin-bottom: 64px;
  margin-left: 32px;
  padding: 4px 32px 4px 24px;
  font-size: 24px;
  line-height: 140%;
}

.text-uppercase {
  color: var(--black-70);
  text-transform: uppercase;
  font-family: Vollkorn, serif;
  font-size: 12px;
  font-weight: 400;
  line-height: 120%;
}

.text-uppercase.is-red {
  color: var(--red);
}

.container {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
  padding-right: 0;
}

.information-nav {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 96px;
  display: flex;
}

.heading-huge {
  letter-spacing: -5px;
  font-family: Vollkorn, serif;
  font-size: 96px;
  font-weight: 700;
  line-height: 100%;
}

.heading-huge.is-white {
  color: var(--white);
  font-family: Vollkorn, serif;
  font-weight: 700;
}

.heading-huge.is-white.portfolio {
  letter-spacing: -.4px;
  font-size: 30px;
  font-weight: 700;
}

.heading-small {
  color: var(--black);
  letter-spacing: -.5px;
  font-family: PT Serif, serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 120%;
}

.heading-large {
  letter-spacing: -2px;
  font-family: Vollkorn, serif;
  font-size: 64px;
  font-weight: 700;
  line-height: 110%;
}

.heading-large.is-center {
  text-align: center;
}

.information-bottom {
  border-top: 1px solid #0000001a;
  flex-direction: column;
  justify-content: center;
  display: flex;
}

.text-large {
  letter-spacing: -.5px;
  font-family: Vollkorn, serif;
  font-size: 24px;
  font-weight: 400;
  line-height: 160%;
}

.brand-image {
  width: 100%;
  display: block;
}

.heading-medium {
  letter-spacing: -1px;
  font-size: 32px;
  font-weight: 200;
  line-height: 120%;
}

.text-regular {
  color: var(--black-70);
  font-family: PT Serif, serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 180%;
}

.text-regular.is-white {
  color: var(--white);
}

.text-regular.is-center {
  text-align: center;
}

.style-guide-links {
  grid-column-gap: 32px;
  align-items: center;
  display: flex;
}

.brand-link {
  flex: none;
  align-items: center;
  width: 128px;
  display: flex;
}

.brand-link.w--current {
  flex-direction: row;
  flex: none;
  justify-content: flex-start;
  align-items: center;
}

.text-link {
  color: var(--dark-khaki);
  font-family: PT Serif, serif;
  font-weight: 400;
  text-decoration: underline;
  transition: color .2s cubic-bezier(.39, .575, .565, 1);
  display: inline-block;
}

.text-link:hover {
  color: var(--dark-red);
  text-decoration: underline;
}

.text-link.is-blue {
  color: #2151f5;
  font-weight: 500;
}

.text-small {
  font-family: Vollkorn, serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 170%;
}

.text-tiny {
  text-transform: uppercase;
  font-family: minion-pro, sans-serif;
  font-size: 12px;
  font-weight: 400;
  line-height: 170%;
}

.text-tiny.for-newsletter {
  color: var(--dark-khaki);
  text-transform: none;
  font-family: Vollkorn, serif;
  text-decoration: underline;
}

.text-tiny.is-red {
  color: var(--dark-khaki);
  font-weight: 400;
}

.text-tiny.for-post-author {
  font-weight: 600;
}

.text-tiny.is-white {
  color: var(--white);
}

.text-tiny.is-hidden-mobile {
  text-transform: none;
}

.text-xlarge {
  letter-spacing: -1px;
  font-family: Vollkorn, serif;
  font-size: 32px;
  font-style: normal;
  font-weight: 700;
  line-height: 120%;
}

.page-wrapper {
  overflow: hidden;
}

.header {
  justify-content: center;
  align-items: center;
  padding-left: 0;
  padding-right: 0;
  display: block;
}

.main {
  min-height: 40vh;
  display: flex;
}

.footer-old {
  z-index: 20;
  background-color: var(--white);
  position: relative;
}

.navi-bar {
  z-index: 100;
  background-color: #0000;
  width: 100%;
  position: fixed;
  inset: 0 0 auto;
}

.nav {
  border-bottom: 1px solid var(--black-10);
  background-color: #0000;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-width: 100%;
  min-height: 0;
  padding-top: 16px;
  padding-bottom: 16px;
  display: block;
  position: relative;
  overflow: visible;
}

.menu-button {
  grid-column-gap: 8px;
  cursor: pointer;
  justify-content: center;
  align-items: center;
  display: flex;
}

.side-menu {
  justify-content: flex-end;
  width: 100%;
  height: 100vh;
  display: none;
  position: fixed;
  inset: 0%;
}

.blurry-layer {
  background-color: var(--black-70);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.side-menu-items {
  z-index: 10;
  background-color: #fff;
  flex-direction: column;
  width: 30%;
  min-width: 480px;
  height: auto;
  display: flex;
  position: relative;
}

.side-menu-top {
  grid-column-gap: 8px;
  border-bottom: 1px solid var(--black-10);
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  min-height: 128px;
  padding-right: 48px;
  display: flex;
}

.side-menu-social {
  background-color: var(--white);
  margin-top: 48px;
  padding: 48px;
}

.close-button {
  background-color: var(--dark-olive-green);
  cursor: pointer;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  font-family: Vollkorn, serif;
  display: flex;
}

.side-menu-link {
  border-bottom: 1px solid var(--black-10);
  background-color: var(--white);
  width: 100%;
  padding: 16px 64px 16px 48px;
  transition: background-color .2s cubic-bezier(.39, .575, .565, 1);
}

.side-menu-link:hover {
  background-color: var(--black-04);
}

.social-link {
  background-color: var(--black-04);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  display: flex;
}

.social-link.for-side-menu {
  border: 1px solid var(--black-10);
  background-color: #0000;
  width: 80px;
  height: 80px;
}

.social-image {
  width: 20px;
}

.social-links {
  grid-column-gap: 12px;
  display: flex;
}

.hero-full-page {
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  height: 100vh;
  padding-top: 144px;
  padding-bottom: 64px;
  display: flex;
  position: relative;
}

.project-desktop-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.title-wrapper {
  z-index: 10;
  position: relative;
}

.spacer-huge {
  width: 100%;
  height: 190px;
}

.narrow-container {
  max-width: 1184px;
  margin-left: auto;
  margin-right: auto;
}

.spacer-regular {
  width: 100%;
  height: 128px;
}

.cms-link {
  width: 100%;
  height: 100%;
}

.thumb-image {
  border-radius: 20px;
  overflow: hidden;
}

.thumbnail {
  mix-blend-mode: normal;
  border: 1px #000;
  border-radius: 20px;
  width: 100%;
  max-width: 100%;
  display: inline-block;
  overflow: visible;
}

.thumb-info {
  grid-row-gap: 8px;
  border-bottom: 1px solid var(--black-10);
  flex-direction: column;
  justify-content: flex-start;
  min-height: 80px;
  margin-bottom: 40px;
  padding-top: 16px;
  padding-bottom: 16px;
  padding-right: 32px;
  display: flex;
  position: relative;
}

.thumb-info.for-news {
  justify-content: flex-start;
  min-height: 230px;
}

.green-line {
  background-color: var(--dark-khaki);
  width: 0%;
  height: 1px;
  position: absolute;
  inset: auto 0% -1px;
}

.intro-bar {
  border-bottom: 1px none var(--black-10);
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 32px;
  padding-bottom: 16px;
  display: flex;
}

.news-wrapper {
  position: relative;
}

.news-list {
  grid-column-gap: 32px;
  grid-row-gap: 32px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.news-item {
  position: relative;
}

.cta {
  grid-column-gap: 16px;
  justify-content: flex-end;
  align-items: center;
  padding: 100px 64px;
  display: none;
}

.cta-text {
  letter-spacing: -4px;
  text-transform: uppercase;
  font-size: 64px;
  font-weight: 400;
  line-height: 120%;
}

.cta-link {
  position: relative;
}

.cta-line {
  background-color: var(--black);
  width: 100%;
  height: 4px;
}

.footer-items {
  border-top: 1px solid var(--black-10);
  justify-content: space-between;
  align-items: center;
  padding-top: 32px;
  padding-bottom: 32px;
  display: flex;
}

.footer-legal {
  grid-column-gap: 16px;
  align-items: center;
  display: flex;
}

.footer-info, .nav-buttons {
  grid-column-gap: 32px;
  align-items: center;
  display: flex;
}

.outline-button-small {
  border: 1px solid var(--black);
  border-radius: 6px;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  min-width: 80px;
  min-height: 32px;
  padding: 4px 8px;
  display: flex;
}

.oveview-intro {
  grid-column-gap: 64px;
  grid-row-gap: 64px;
  grid-template-rows: auto;
  grid-template-columns: minmax(96px, 420px) minmax(200px, 572px);
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: flex-start;
  display: grid;
}

.oveview-intro.for-work-case {
  grid-template-rows: auto;
  width: 100%;
  max-width: 1184px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
}

.flexbox-paragraphs {
  grid-row-gap: 24px;
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.flexbox-paragraphs.for-work-case {
  max-width: 736px;
}

.news-redirect-link {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.section-post {
  padding-top: 184px;
}

.post-wrapper {
  max-width: 736px;
  margin-left: auto;
  margin-right: auto;
}

.post-intro {
  grid-row-gap: 16px;
  flex-direction: column;
  margin-bottom: 64px;
  display: flex;
}

.post-author-date {
  border-top: 1px solid var(--black-10);
  border-bottom: 1px solid var(--black-10);
  justify-content: space-between;
  align-items: center;
  min-height: 48px;
  padding-top: 12px;
  padding-bottom: 12px;
  display: flex;
}

.post-author, .post-date {
  grid-column-gap: 4px;
  display: flex;
}

.project-details {
  grid-column-gap: 16px;
  grid-row-gap: 0px;
  grid-template-rows: auto auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.project-details-item {
  border-top: 1px solid var(--black-10);
  border-bottom: 1px solid var(--black-10);
  padding-top: 16px;
  padding-bottom: 16px;
}

.project-details-item._3, .project-details-item._4 {
  border-top-style: none;
  border-bottom-style: none;
}

.first-group-images {
  grid-column-gap: 32px;
  grid-row-gap: 32px;
  grid-template-rows: auto auto auto auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.work-case-content {
  grid-row-gap: 192px;
  flex-direction: column;
  align-items: center;
  max-width: 1184px;
  margin-top: 192px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.work-case-image {
  object-fit: cover;
  border-radius: 20px;
  width: 100%;
  height: 100%;
}

.second-group-images {
  grid-column-gap: 32px;
  grid-row-gap: 32px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

._404-content {
  grid-row-gap: 48px;
  flex-direction: column;
  align-items: center;
  max-width: 642px;
  margin-top: -8vh;
  display: flex;
}

.tag-404 {
  border: 1px solid var(--red);
  border-radius: 100px;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  display: flex;
}

.tag-404.top {
  margin-left: auto;
  margin-right: auto;
  position: absolute;
  inset: 32px 0% auto;
}

.tag-404.bottom {
  position: absolute;
  inset: auto auto 32px;
}

.ghost-item {
  width: 100%;
  height: 1px;
}

.section-404 {
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  min-height: 100vh;
  padding-left: 4%;
  padding-right: 4%;
  display: flex;
  position: relative;
}

.link-404 {
  background-color: var(--red);
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  min-width: 192px;
  min-height: 64px;
  padding: 8px 16px;
  display: flex;
}

.pop-up {
  z-index: 200;
  background-color: var(--black-70);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 100vh;
  padding-left: 7.5%;
  padding-right: 7.5%;
  display: none;
  position: fixed;
}

.pop-newsletter {
  background-color: var(--white);
  justify-content: center;
  align-items: center;
  min-width: 652px;
  min-height: 420px;
  padding: 128px;
  display: flex;
}

.newsletter-content {
  grid-row-gap: 32px;
  flex-direction: column;
  align-items: center;
  width: 100%;
  display: flex;
}

.newsletter-texts {
  grid-row-gap: 8px;
  flex-direction: column;
  align-items: center;
  display: flex;
}

.form-block {
  width: 100%;
  margin-bottom: 0;
  font-size: 16px;
}

.newsletter-form {
  grid-row-gap: 8px;
  flex-direction: column;
  display: flex;
}

.text-field {
  border: 1px solid var(--black-10);
  border-radius: 90px;
  min-height: 64px;
  margin-bottom: 0;
  padding-left: 24px;
  padding-right: 24px;
  font-size: 16px;
}

.text-field:active {
  font-size: 16px;
}

.text-field:focus {
  color: var(--black);
  border-color: #e9000033;
  font-size: 16px;
}

.text-field::placeholder {
  color: var(--black-40);
}

.submit-button {
  background-color: var(--dark-khaki);
  border-radius: 90px;
  flex: none;
  min-width: 192px;
  min-height: 64px;
  padding: 16px;
  font-weight: 400;
}

.close-fixed {
  grid-column-gap: 8px;
  align-items: center;
  display: flex;
  position: fixed;
  inset: 64px 64px auto auto;
}

.project-mobile-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: none;
  position: absolute;
  inset: 0%;
}

.burger {
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 32px;
  display: flex;
}

.side-menu-overflow {
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  display: flex;
  overflow: auto;
}

.top-gradient {
  background-image: linear-gradient(#0009, #0000);
  width: 100%;
  height: 40%;
  position: absolute;
  inset: 0% 0% auto;
}

.open-newsletter {
  cursor: pointer;
}

.success-messege {
  border: 1px solid var(--red);
  background-color: var(--white);
  border-radius: 100px;
}

.hero-section {
  background-image: linear-gradient(#00000054, #00000054), url('../images/KennyHeights_LinearGarden03.webp');
  background-position: 0 0, 0 0;
  background-size: auto, cover;
  background-attachment: scroll, fixed;
  height: auto;
  margin-left: 0;
  margin-right: 0;
  padding-left: 8vw;
  padding-right: 8vw;
  display: block;
  position: static;
}

.hero-content {
  align-items: stretch;
  height: 100vh;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  position: static;
}

.hero-content.ctr {
  height: auto;
}

.hero-content-container {
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  width: auto;
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
  padding: 30vh 0 0;
  display: flex;
}

.hero-content-container.no-top-padding {
  padding-top: 0;
}

.hero-content-container.vertical {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
}

.hero-details {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 40vw;
  margin-top: 0;
  padding-right: 0;
  display: flex;
}

.big-title-h1 {
  color: #fff;
  letter-spacing: .1437rem;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 5vh;
  padding-left: 0;
  padding-right: 0;
  font-family: minion-pro-display, sans-serif;
  font-size: 2.78rem;
  font-weight: 700;
  line-height: 3.25rem;
}

.big-paragraph {
  color: #fff;
  text-align: left;
  letter-spacing: .08rem;
  padding-right: 8vw;
  font-family: minion-pro, sans-serif;
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1.75rem;
  position: relative;
}

.content-photo {
  border-radius: 0;
  width: 80%;
  position: relative;
  box-shadow: 8px 14px 16px 4px #00000030;
}

.content-photo.smaller {
  width: 60%;
}

.content-photo.bigger {
  width: 100%;
}

.content-h-container {
  z-index: 2;
  grid-column-gap: 5vw;
  grid-row-gap: 5vw;
  flex-direction: row;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 0;
  margin-bottom: 15vh;
  display: grid;
  position: relative;
}

.content-h-container.no-bottom-padding {
  flex-direction: row-reverse;
  margin-top: 0;
  margin-bottom: 0;
}

.content-h-container.smaller-gap {
  grid-column-gap: 2vw;
  grid-row-gap: 2vw;
  margin-bottom: 0;
}

.small-paragraph {
  z-index: 2;
  color: #303030;
  text-align: center;
  letter-spacing: .08rem;
  padding-right: 10vw;
  font-family: minion-pro, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4rem;
  position: relative;
}

.small-paragraph.reverse {
  z-index: 2;
  text-align: center;
  padding-left: 10vw;
  padding-right: 0;
}

.small-paragraph.reverse.with-small-title {
  margin-bottom: 1.3vh;
}

.small-paragraph.grouping-paragraph {
  text-align: center;
  padding-bottom: 6vh;
  padding-left: 2vw;
  padding-right: 2vw;
}

.small-paragraph.no-right-padding {
  text-align: center;
  padding-right: 0;
}

.small-paragraph.white {
  color: #fff;
  padding-left: 0;
}

.small-paragraph.white.top-padding {
  margin-top: 5vh;
}

.small-paragraph.white.reverse {
  padding-left: 7vw;
}

.small-paragraph.white.with-small-title {
  padding-right: 0;
  font-size: .8rem;
  line-height: 1.2rem;
}

.small-paragraph.white.with-small-title.right-aligned {
  text-align: right;
  padding-right: 0;
}

.small-paragraph.with-small-title {
  margin-bottom: 3vh;
}

.content-details {
  text-align: left;
  width: 100%;
  max-width: 40vw;
  padding-left: 4vw;
  position: relative;
}

.content-details.reverse {
  padding-left: 0;
  padding-right: 4vw;
}

.content-details.bottom-tanked {
  flex-direction: column;
  justify-content: flex-end;
  max-width: 20vw;
  display: flex;
}

.section {
  background-color: #fff;
  height: auto;
  margin-left: 0;
  margin-right: 0;
  padding: 20vh 8vw;
  position: relative;
}

.section.green-bg {
  background-color: var(--white);
  background-image: none;
  margin-top: 0;
}

.section.green-bg.hide {
  display: none;
}

.section.no-top-padding {
  padding-top: 0;
  padding-bottom: 15vh;
}

.section.no-top-padding.white-smoke-bg {
  background-color: #f0efed;
}

.section.mobile-no-padding {
  padding-top: 15vh;
  padding-bottom: 15vh;
}

.section.mobile-no-padding.light-bg {
  background-color: #e5e3e0;
}

.section.photo-section {
  background-image: linear-gradient(#00000054, #00000054), url('../images/the-mansions-linear-garden.webp');
  background-position: 0 0, 50%;
  background-size: auto, auto;
  background-attachment: scroll, fixed;
  height: 100vh;
  padding-top: 5vh;
  padding-bottom: 5vh;
}

.section.photo-section.breaker {
  background-image: linear-gradient(#0000, #0000), url('../images/the-mansions-balcony.webp');
  background-position: 0 0, 50% 100%;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  background-attachment: scroll, scroll;
  height: 80vh;
}

.section.photo-section.breaker.hide {
  display: none;
}

.section.grey-bg {
  background-color: var(--white);
  background-image: linear-gradient(#bcb8b1, #bcb8b1);
  margin-top: 0;
}

.content-description {
  text-align: left;
  align-self: auto;
  padding-left: 0;
  position: relative;
}

.section-content {
  text-align: center;
  width: 100%;
  padding-top: 0;
  padding-left: 0;
  padding-right: 0;
  display: block;
  position: relative;
}

.section-content.top-padding {
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  margin-top: 0;
  padding: 40vh 0 0;
  display: flex;
}

.section-content.white-smoke-bg {
  background-color: var(--white-smoke);
  opacity: 1;
  padding: 15vh 8vw;
}

.big-title-h3 {
  z-index: 2;
  color: #030303;
  text-align: center;
  letter-spacing: .125rem;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 3vh;
  padding-right: 10vw;
  font-family: minion-pro-display, sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.76rem;
  position: relative;
}

.big-title-h3.reverse {
  z-index: 2;
  text-align: center;
  margin-bottom: 3vh;
  padding-left: 10vw;
  padding-right: 0;
}

.big-title-h3.reverse.white {
  margin-bottom: 5vh;
  padding-left: 3vw;
}

.big-title-h3.reverse.with-small-title {
  text-align: center;
  margin-bottom: 1.3vh;
}

.big-title-h3.white {
  color: #fff;
  padding-left: 0;
}

.big-title-h3.white.with-small-title {
  padding-right: 0;
  font-size: 1.2rem;
  line-height: 1.4rem;
}

.big-title-h3.white.with-small-title.right-aligned {
  text-align: right;
  padding-right: 0;
}

.big-title-h3.no-right-padding {
  text-align: center;
  padding-right: 0;
}

.big-title-h3.no-right-padding.bigger {
  margin-bottom: .4vh;
  font-size: 1.8rem;
}

.big-title-h3.with-small-title {
  margin-bottom: 1.3vh;
}

.content-image {
  border-radius: 0;
  width: auto;
  min-width: 0;
  height: auto;
  position: relative;
}

.content-image.for-intro-to-mansions {
  margin-top: 20vh;
  margin-bottom: 10vh;
}

.navi-link {
  color: #fff;
  letter-spacing: .15rem;
  -webkit-text-stroke-color: #fff0;
  text-transform: none;
  background-color: #1e1e1e;
  padding: 3vh 8vw;
  font-family: minion-pro-display, sans-serif;
  font-size: .95rem;
  font-weight: 400;
  line-height: 1.25rem;
}

.navi-link.w--current {
  color: #fff;
  text-shadow: 1px 2px 4px #00000082;
}

.navi-link.no-right-padding {
  padding-right: 0;
}

.navi-link.hide {
  display: none;
}

.township-logo {
  z-index: 2;
  height: 10vh;
  margin-bottom: 5vh;
  padding-bottom: 0;
  position: relative;
}

.semi-transparent-image {
  z-index: 1;
  opacity: .28;
  text-align: center;
  margin-bottom: 0;
  margin-left: auto;
  margin-right: auto;
  display: block;
  position: relative;
  inset: -60px auto auto;
}

.ctr-section {
  background-image: linear-gradient(#00000054, #00000054), url('../images/ms3.webp');
  background-position: 0 0, 50% 100%;
  background-size: auto, cover;
  height: 80vh;
  margin-left: 0;
  margin-right: 0;
  padding: 15vh 8vw;
  display: block;
  position: static;
}

.button-primary {
  color: #fff;
  letter-spacing: .05rem;
  text-transform: uppercase;
  background-color: #344e236b;
  border: 3px solid #fff;
  border-radius: 0;
  margin-top: 6vh;
  padding: 2vh 2vw;
  font-family: minion-pro-display, sans-serif;
  font-size: .75rem;
  font-weight: 700;
  line-height: .8rem;
  transition: background-color .8s;
}

.button-primary:hover {
  background-color: #344e23eb;
}

.button-primary.solid-color {
  background-color: #344e23eb;
  border-color: #303030;
  margin-top: 0;
  transition: background-color .8s;
}

.button-primary.solid-color:hover {
  color: #000;
  background-color: #344e236b;
}

.footer-contact-link {
  color: #fff;
  text-align: left;
  letter-spacing: .125rem;
  font-size: .9rem;
  line-height: 1.25rem;
}

.logo-image {
  margin-right: 0;
}

.footer-small-title {
  color: #fbd784;
  letter-spacing: 3px;
  margin-bottom: 5vh;
  font-family: minion-pro-display, sans-serif;
  font-size: .6rem;
  font-weight: 700;
  line-height: .9rem;
}

.logo-container {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.links-container {
  align-items: flex-start;
  display: flex;
}

.footer {
  text-align: center;
  background-color: #1e1e1e;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 10vh 8vw 5vh;
  display: flex;
}

.social {
  margin-bottom: 3vh;
}

.socials-column {
  flex-direction: column;
  align-items: center;
  display: flex;
}

.footer-text {
  color: #fff;
  letter-spacing: .125rem;
  margin-bottom: 0;
  font-size: .7rem;
  font-weight: 400;
  line-height: 1.25rem;
  text-decoration: underline;
  display: block;
}

.footer-text:hover {
  text-decoration: underline;
}

.footer-text.copyright-no-link {
  letter-spacing: .125rem;
  text-transform: none;
  margin-bottom: 0;
  font-family: minion-pro-display, sans-serif;
  font-size: .7rem;
  font-weight: 400;
  line-height: .8rem;
  text-decoration: none;
}

.footer-text.copyright-no-link:hover {
  text-decoration: none;
}

.footer-copyright-container {
  justify-content: space-between;
  align-items: center;
  padding-top: 2vh;
  display: flex;
}

.footer-block {
  color: #fff;
  text-align: left;
  letter-spacing: .125rem;
  font-family: minion-pro, sans-serif;
  font-size: .7rem;
  font-weight: 400;
  line-height: 1.25rem;
}

.links-column {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 25vw;
  margin-right: 2vw;
  display: flex;
}

.footer-container {
  border-bottom: 1px solid #c4c4c4;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: 10vh;
  display: flex;
}

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

.body {
  font-family: minion-pro, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.25rem;
}

.container-2 {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  background-color: #0000;
  flex-flow: row;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  place-content: space-between;
  align-self: auto;
  align-items: center;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  display: flex;
}

.nav-menu {
  align-self: center;
}

.navbar {
  background-color: #0000;
  flex: 0 auto;
  order: 0;
  justify-content: space-between;
  align-self: auto;
  align-items: stretch;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
}

.nav-link {
  color: var(--white);
}

.brand-logo {
  width: 7rem;
  padding-left: 0;
}

.navi-bar-container {
  background-color: #0000;
  border-bottom: 1px solid #ffffff1a;
  flex-flow: column wrap;
  justify-content: center;
  align-items: stretch;
  padding: 2vh 8vw;
  display: flex;
}

.content-grouping-logo {
  width: 15vw;
  margin-bottom: 5vh;
}

.content-grouping-image {
  width: auto;
  height: auto;
  padding-bottom: 0;
}

.content-grouping {
  flex-direction: column;
  flex: 0 auto;
  justify-content: center;
  align-self: center;
  align-items: center;
  padding-left: 0;
  padding-right: 0;
  display: flex;
}

.content-grouping-details {
  width: auto;
  margin-top: 5vh;
}

.navi-bar-div {
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.content-v-container {
  z-index: 2;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  flex-direction: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-content: stretch center;
  place-items: center;
  width: 100%;
  margin-top: 0;
  margin-bottom: 10vh;
  display: flex;
  position: relative;
}

.content-v-container.no-bottom-padding {
  margin-bottom: 0;
}

.content-intro {
  width: 100%;
  max-width: none;
  position: relative;
}

.navi-menu {
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  display: block;
}

.small-title-h2 {
  color: #030303;
  text-align: center;
  letter-spacing: .25rem;
  text-transform: none;
  margin-top: 0;
  margin-bottom: 1vh;
  font-family: minion-pro-display, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.25rem;
  position: relative;
}

.small-title-h2.bottom-margin {
  margin-bottom: 5vh;
}

.big-title-h2 {
  color: #030303;
  text-align: center;
  letter-spacing: .3125rem;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 5vh;
  font-family: minion-pro-display, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2rem;
  position: relative;
}

.content-bg-image-container {
  position: absolute;
  inset: 5vh 0% 0%;
}

.content-paragraph {
  text-align: center;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 60vw;
  display: block;
}

.content-paragraph.small-padding {
  margin-bottom: 5vh;
}

.content-intro-paragraph {
  color: #303030;
  text-align: center;
  letter-spacing: .08rem;
  padding-right: 0;
  font-family: minion-pro, sans-serif;
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1.75rem;
  position: relative;
}

.content-intro-paragraph.side-padding {
  padding-left: 15vw;
  padding-right: 15vw;
}

.content-grouping-button.top-padding {
  margin-top: 40px;
}

.content-h3-container {
  z-index: 2;
  grid-column-gap: 1vw;
  grid-row-gap: 1vw;
  flex-direction: row;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 0;
  margin-bottom: 15vh;
  display: grid;
  position: relative;
}

.content-h3-container.no-bottom-padding {
  flex-direction: row-reverse;
  margin-top: 0;
  margin-bottom: 0;
}

.small-title-h3 {
  z-index: 2;
  color: #030303;
  text-align: center;
  letter-spacing: .25rem;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 5vh;
  padding-right: 0;
  font-family: minion-pro-display, sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 2rem;
  position: relative;
}

.bold-text {
  text-transform: uppercase;
  font-size: .9rem;
  font-weight: 700;
}

.icon {
  color: #fff;
}

.mobile-menu.w--open {
  background-color: #c8c8c800;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

.utility-page-form {
  flex-direction: column;
  align-items: stretch;
  display: flex;
}

.div-form {
  flex-direction: column;
  justify-content: center;
  display: flex;
}

.container-form {
  justify-content: center;
  align-items: center;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.body-form {
  background-color: #3a2121d6;
}

.privacy-paragraph {
  text-align: center;
  width: 100%;
  max-width: none;
}

.privacy-intro-paragraph {
  color: #303030;
  text-align: justify;
  letter-spacing: .08rem;
  padding-right: 0;
  font-family: minion-pro, sans-serif;
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1.75rem;
  position: relative;
}

.privacy-points {
  margin-top: 5vh;
  margin-bottom: 5vh;
  padding-left: 5vw;
}

.privacy-points-paragraph {
  color: #303030;
  text-align: justify;
  padding-bottom: 2vh;
  font-size: 1.1rem;
  line-height: 1.75rem;
}

.content-v-policy-container {
  z-index: 2;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  flex-direction: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-content: stretch center;
  place-items: center;
  width: 100%;
  margin-top: 0;
  margin-bottom: 10vh;
  display: block;
  position: relative;
}

.big-title-h2-small {
  color: #030303;
  text-align: center;
  letter-spacing: .3125rem;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 1vh;
  font-family: minion-pro-display, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2rem;
  position: relative;
}

.big-title-h2-small.side-padding {
  padding-left: 10vw;
  padding-right: 10vw;
}

.sub-hero-section {
  background-image: linear-gradient(#00000054, #00000054), url('../images/this-is-parkcity.webp');
  background-position: 0 0, 50%;
  background-size: auto, cover;
  background-attachment: scroll, scroll;
  height: 80vh;
  margin-left: 0;
  margin-right: 0;
  padding-left: 8vw;
  padding-right: 8vw;
  display: block;
  position: static;
}

.sub-hero-section._2 {
  background-image: linear-gradient(#00000054, #00000054), url('../images/the-mansions-guardhouse.webp');
}

.hero-details2 {
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  width: 40vw;
  margin-top: 0;
  padding-right: 0;
  display: flex;
}

.small-description {
  color: #fff;
  text-align: left;
  letter-spacing: .08rem;
  padding-right: 0;
  font-family: minion-pro, sans-serif;
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1.75rem;
  position: relative;
}

.sub-hero-content {
  justify-content: center;
  align-items: stretch;
  height: auto;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  position: static;
}

.sub-hero-content.ctr {
  height: auto;
}

.sub-hero-content-container {
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  width: auto;
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
  padding: 30vh 0 0;
  display: flex;
}

.sub-hero-content-container.no-top-padding {
  padding-top: 0;
}

.sub-hero-details {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 40vw;
  margin-top: 0;
  padding-right: 0;
  display: flex;
}

.big-title-h1-for-sub {
  color: #fff;
  text-align: center;
  letter-spacing: .1437rem;
  text-transform: uppercase;
  align-self: auto;
  margin-top: 0;
  margin-bottom: 5vh;
  padding-left: 0;
  padding-right: 0;
  font-family: minion-pro-display, sans-serif;
  font-size: 2.78rem;
  font-weight: 700;
  line-height: 3.25rem;
}

.small-title {
  z-index: 2;
  color: #303030;
  text-align: center;
  letter-spacing: .08rem;
  margin-bottom: 1.3vh;
  padding-right: 10vw;
  font-family: minion-pro, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4rem;
  position: relative;
}

.small-title.reverse {
  z-index: 2;
  text-align: center;
  padding-left: 10vw;
  padding-right: 0;
}

.small-title.reverse.with-small-title {
  text-align: center;
  margin-bottom: 3vh;
}

.small-title.grouping-paragraph {
  text-align: center;
  padding-bottom: 6vh;
  padding-left: 2vw;
  padding-right: 2vw;
}

.small-title.no-right-padding {
  text-align: center;
  padding-right: 0;
}

.small-title.white {
  color: #fff;
  padding-left: 0;
  padding-right: 0;
  font-size: .8rem;
  line-height: 1.2rem;
}

.small-title.white.top-padding {
  margin-top: 5vh;
}

.small-title.white.reverse {
  padding-left: 7vw;
}

.small-title.white.right-aligned {
  text-align: right;
  padding-right: 0;
}

.small-title.with-small-title {
  margin-bottom: 3vh;
}

.photo-hero-content {
  justify-content: flex-end;
  align-items: stretch;
  height: 100%;
  padding-left: 0;
  padding-right: 0;
  display: flex;
  position: static;
}

.photo-hero-content.ctr {
  height: auto;
}

.photo-hero-content-container {
  flex-direction: row;
  justify-content: center;
  align-items: flex-end;
  width: auto;
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
  padding: 0;
  display: flex;
}

.photo-hero-content-container.no-top-padding {
  padding-top: 0;
}

.site-plan-map {
  border-radius: 0;
  width: 80%;
  padding-top: 40px;
  position: relative;
}

.small-paragraph-floor-plan {
  z-index: 2;
  color: #303030;
  text-align: center;
  letter-spacing: .08rem;
  margin-bottom: 3vh;
  padding-right: 0;
  font-family: minion-pro, sans-serif;
  font-size: 1rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.4rem;
  position: relative;
}

.small-paragraph-floor-plan.reverse {
  z-index: 2;
  text-align: center;
  padding-left: 10vw;
  padding-right: 0;
}

.small-paragraph-floor-plan.reverse.with-small-title {
  margin-bottom: 1.3vh;
}

.small-paragraph-floor-plan.grouping-paragraph {
  text-align: center;
  padding-bottom: 6vh;
  padding-left: 2vw;
  padding-right: 2vw;
}

.small-paragraph-floor-plan.no-right-padding {
  text-align: center;
  padding-right: 0;
}

.small-paragraph-floor-plan.white {
  color: #fff;
  padding-left: 0;
}

.small-paragraph-floor-plan.white.top-padding {
  margin-top: 5vh;
}

.small-paragraph-floor-plan.white.reverse {
  padding-left: 7vw;
}

.small-paragraph-floor-plan.white.with-small-title {
  padding-right: 0;
  font-size: .8rem;
  line-height: 1.2rem;
}

.small-paragraph-floor-plan.white.with-small-title.right-aligned {
  text-align: right;
  padding-right: 0;
}

.small-paragraph-floor-plan.with-small-title {
  margin-bottom: 3vh;
}

@media screen and (min-width: 1280px) {
  .section.green-bg, .section.no-top-padding {
    padding-bottom: 15vh;
  }

  .section.mobile-no-padding {
    padding-top: 15vh;
    padding-bottom: 15vh;
  }

  .section.grey-bg {
    padding-bottom: 15vh;
  }
}

@media screen and (min-width: 1440px) {
  .content-h-container.smaller-gap {
    margin-bottom: 0;
  }

  .section.green-bg, .section.no-top-padding {
    padding-bottom: 15vh;
  }

  .section.mobile-no-padding {
    padding-top: 15vh;
    padding-bottom: 15vh;
  }

  .section.grey-bg {
    padding-bottom: 15vh;
  }

  .ctr-section {
    padding-top: 15vh;
    padding-bottom: 15vh;
  }

  .footer {
    padding-top: 10vh;
    padding-bottom: 5vh;
  }
}

@media screen and (min-width: 1920px) {
  .section.green-bg, .section.no-top-padding {
    padding-bottom: 15vh;
  }

  .section.mobile-no-padding {
    padding-top: 15vh;
    padding-bottom: 15vh;
  }

  .section.grey-bg {
    padding-bottom: 15vh;
  }

  .ctr-section {
    padding-top: 15vh;
    padding-bottom: 15vh;
  }

  .footer {
    padding-top: 10vh;
    padding-bottom: 5vh;
  }
}

@media screen and (max-width: 991px) {
  h1 {
    letter-spacing: -4px;
    font-size: 80px;
  }

  h2 {
    font-size: 56px;
  }

  .rich-text p {
    margin-bottom: 16px;
  }

  .rich-text strong {
    font-weight: 600;
  }

  .rich-text ul, .rich-text ol {
    margin-bottom: 16px;
  }

  .rich-text blockquote {
    margin-top: 48px;
    margin-bottom: 48px;
    margin-left: 0;
    padding-right: 24px;
  }

  .container {
    padding-left: 6%;
    padding-right: 6%;
  }

  .heading-huge {
    letter-spacing: -4px;
    font-size: 80px;
  }

  .heading-huge.is-white.portfolio {
    font-size: 22px;
  }

  .heading-large {
    font-size: 56px;
  }

  .style-guide-links {
    grid-column-gap: 16px;
  }

  .brand-link {
    width: 112px;
  }

  .text-link {
    transition-property: none;
  }

  .text-link:hover {
    color: var(--red);
  }

  .text-tiny.is-hidden-mobile {
    display: none;
  }

  .navi-bar {
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
    display: block;
  }

  .side-menu-items {
    width: 50%;
    min-width: 448px;
    padding-bottom: 10vh;
  }

  .side-menu-top {
    min-height: 96px;
  }

  .side-menu-social {
    padding: 32px 48px;
  }

  .side-menu-link {
    transition-property: none;
  }

  .side-menu-link:hover {
    background-color: var(--white);
  }

  .social-link.for-side-menu {
    width: 64px;
    height: 64px;
  }

  .social-links {
    grid-column-gap: 8px;
  }

  .hero-full-page {
    height: 90vh;
    padding-bottom: 48px;
  }

  .project-desktop-image {
    display: none;
  }

  .spacer-huge {
    height: 140px;
  }

  .narrow-container {
    max-width: 642px;
  }

  .spacer-regular.for-work-case {
    height: 96px;
  }

  .thumb-info {
    margin-bottom: 0;
  }

  .thumb-info.for-news {
    min-height: 200px;
  }

  .intro-bar {
    margin-bottom: 24px;
  }

  .news-wrapper {
    max-width: 642px;
    margin-left: auto;
    margin-right: auto;
  }

  .news-list {
    grid-column-gap: 24px;
    grid-row-gap: 24px;
    grid-template-columns: 1fr 1fr;
  }

  .cta {
    padding: 60px 48px;
  }

  .cta-text {
    font-size: 56px;
  }

  .cta-arrow {
    width: 40px;
  }

  .footer-info {
    grid-row-gap: 12px;
    flex-direction: column;
    align-items: flex-end;
  }

  .nav-buttons {
    grid-column-gap: 24px;
  }

  .oveview-intro {
    grid-row-gap: 24px;
    flex-direction: column;
    max-width: 642px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
  }

  .oveview-intro.for-work-case {
    grid-row-gap: 48px;
    max-width: 642px;
    display: flex;
  }

  .flexbox-paragraphs {
    grid-row-gap: 16px;
  }

  .flexbox-paragraphs.for-work-case {
    max-width: 642px;
  }

  .section-post {
    padding-top: 144px;
  }

  .post-wrapper {
    max-width: 642px;
  }

  .post-intro {
    margin-bottom: 48px;
  }

  .project-details {
    grid-column-gap: 24px;
    width: 100%;
  }

  .first-group-images {
    grid-column-gap: 16px;
    grid-row-gap: 16px;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    align-items: center;
  }

  .work-case-content {
    grid-row-gap: 160px;
    margin-top: 160px;
  }

  .second-group-images {
    grid-column-gap: 16px;
    grid-row-gap: 16px;
  }

  .section-404 {
    padding-left: 6%;
    padding-right: 6%;
  }

  .pop-newsletter {
    min-width: 524px;
    min-height: 0;
    padding: 48px;
  }

  .form-block {
    font-size: 16px;
  }

  .close-fixed {
    top: 16px;
    right: 16px;
  }

  .project-mobile-image {
    display: inline-block;
  }

  .hero-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/KennyHeights_LinearGarden03.webp');
    background-position: 0 0, 0 0;
    padding-left: 6vw;
    padding-right: 6vw;
  }

  .hero-content {
    justify-content: center;
    height: 100vh;
  }

  .hero-content-container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
    padding-top: 5vh;
    padding-left: 10vw;
    padding-right: 10vw;
  }

  .hero-content-container.vertical {
    justify-content: center;
    align-items: center;
  }

  .hero-details {
    align-items: center;
    width: auto;
  }

  .big-title-h1 {
    text-align: center;
    margin-bottom: 6vh;
    padding-left: 0;
    padding-right: 0;
    font-size: 2.5rem;
    line-height: 3rem;
  }

  .big-paragraph {
    text-align: center;
    width: auto;
    margin-left: 0;
    margin-right: 0;
    padding-right: 0;
    font-size: 1.1rem;
    line-height: 1.6rem;
  }

  .content-photo {
    object-fit: cover;
    width: 100%;
    height: 100%;
    min-height: 0;
    max-height: 60vh;
  }

  .content-photo.smaller.with-bottom-padding, .content-photo.with-bottom-padding {
    margin-bottom: 5vh;
  }

  .content-h-container {
    grid-column-gap: 2vw;
    grid-row-gap: 2vw;
    grid-template-columns: 1fr;
    align-content: stretch;
    margin-bottom: 10vh;
  }

  .content-h-container.smaller-gap {
    margin-bottom: 0;
  }

  .small-paragraph {
    text-align: center;
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
  }

  .small-paragraph.reverse {
    text-align: center;
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph.no-right-padding {
    padding-right: 0;
  }

  .small-paragraph.white {
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph.white.reverse {
    padding-left: 0;
  }

  .small-paragraph.white.with-small-title.right-aligned {
    margin-bottom: 3vh;
  }

  .small-paragraph.with-small-title {
    margin-top: 5vh;
    margin-bottom: 1.3vh;
  }

  .content-details {
    max-width: none;
    padding-left: 7vw;
    padding-right: 7vw;
  }

  .content-details.reverse {
    padding-left: 7vw;
    padding-right: 7vw;
  }

  .content-details.bottom-tanked {
    max-width: 50vw;
    padding-left: 0;
    padding-right: 0;
  }

  .section {
    padding: 15vh 6vw;
  }

  .section.green-bg {
    background-image: none;
    padding-top: 15vh;
    padding-bottom: 15vh;
  }

  .section.no-top-padding {
    padding-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .section.grey-bg {
    padding-top: 15vh;
    padding-bottom: 15vh;
  }

  .content-description {
    padding-left: 0;
  }

  .section-content.top-padding {
    padding-top: 30vh;
    padding-bottom: 0;
  }

  .section-content.white-smoke-bg {
    box-shadow: none;
    padding: 15vh 6vw;
  }

  .big-title-h3 {
    text-align: center;
    padding-left: 7vw;
    padding-right: 7vw;
    font-size: 2rem;
    font-weight: 700;
    line-height: 2.5rem;
  }

  .big-title-h3.reverse {
    text-align: center;
    margin-bottom: 6vh;
    padding-left: 7vw;
    padding-right: 7vw;
  }

  .big-title-h3.reverse.white {
    padding-left: 7vw;
    padding-right: 7vw;
  }

  .big-title-h3.reverse.with-small-title {
    margin-top: 5vh;
  }

  .big-title-h3.white {
    margin-top: 6vh;
    padding-left: 7vw;
    padding-right: 7vw;
    font-size: 2rem;
    line-height: 2.5rem;
  }

  .big-title-h3.no-right-padding {
    margin-top: 0;
    padding-right: 7vw;
  }

  .big-title-h3.with-small-title {
    margin-top: 0;
    margin-bottom: 3vh;
  }

  .big-title-h3.with-small-title.with-top-padding {
    margin-top: 5vh;
  }

  .content-image {
    width: auto;
    min-width: 0;
    min-height: 0;
  }

  .navi-link {
    background-color: #1e1e1e;
    padding: 3vh 6vw;
  }

  .township-logo {
    height: 7vh;
  }

  .ctr-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/ms3.webp');
    background-position: 0 0, 50%;
    padding: 15vh 6vw;
  }

  .button-primary {
    padding-left: 4vw;
    padding-right: 4vw;
  }

  .footer-small-title {
    letter-spacing: .18rem;
  }

  .footer {
    padding-bottom: 8vh;
    padding-left: 6vw;
    padding-right: 6vw;
  }

  .social {
    margin-bottom: 2vh;
  }

  .socials-column {
    justify-content: flex-start;
    margin-top: 15vh;
  }

  .footer-copyright-container {
    padding-top: 3vh;
  }

  .links-column {
    width: 25vw;
  }

  .footer-container {
    padding-bottom: 5vh;
  }

  .container-2 {
    flex: 0 auto;
    order: 1;
    align-self: auto;
    align-items: stretch;
  }

  .navbar {
    justify-content: space-between;
    align-items: stretch;
  }

  .brand-logo {
    width: 6rem;
  }

  .navi-bar-container {
    flex-wrap: wrap;
    padding: 1vh 6vw;
  }

  .content-grouping-logo {
    width: 30vw;
  }

  .content-grouping-details {
    margin-top: 0;
    padding-left: 7vw;
    padding-right: 7vw;
  }

  .navi-bar-div {
    justify-content: space-between;
    align-items: center;
    display: flex;
  }

  .content-v-container {
    margin-bottom: 10vh;
  }

  .content-intro {
    max-width: none;
    padding-left: 7vw;
    padding-right: 7vw;
  }

  .small-title-h2 {
    font-weight: 400;
    line-height: 1.25rem;
  }

  .big-title-h2 {
    margin-bottom: 6vh;
    font-weight: 700;
    line-height: 2rem;
  }

  .content-paragraph {
    max-width: none;
    padding-left: 4vw;
    padding-right: 4vw;
  }

  .content-intro-paragraph {
    padding-left: 0;
    padding-right: 0;
    font-size: 1.1rem;
    line-height: 1.6rem;
  }

  .content-intro-paragraph.side-padding {
    padding-left: 0;
    padding-right: 0;
  }

  .content-grouping-button {
    padding-bottom: 10vh;
  }

  .content-grouping-button.no-bottom-padding {
    padding-bottom: 0;
  }

  .content-h3-container.no-bottom-padding {
    grid-template-rows: auto auto auto;
    grid-template-columns: 1fr;
  }

  .small-title-h3 {
    margin-top: 6vh;
    margin-bottom: 4vh;
    font-weight: 700;
    line-height: 2rem;
  }

  .icon {
    color: var(--white);
  }

  .mobile-menu {
    background-color: #c8c8c800;
    padding: 3vh;
  }

  .mobile-menu.w--open {
    background-color: #0000;
  }

  .privacy-paragraph {
    max-width: none;
    padding-left: 4vw;
    padding-right: 4vw;
  }

  .privacy-intro-paragraph {
    padding-left: 0;
    padding-right: 0;
    font-size: 1.1rem;
    line-height: 1.6rem;
  }

  .privacy-points-paragraph {
    line-height: 1.6rem;
  }

  .content-v-policy-container {
    margin-bottom: 10vh;
  }

  .big-title-h2-small {
    font-weight: 700;
    line-height: 2rem;
  }

  .big-title-h2-small.side-padding {
    margin-bottom: 6vh;
    padding-left: 7vw;
    padding-right: 7vw;
  }

  .sub-hero-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/this-is-parkcity.webp');
    background-position: 0 0, 50%;
    padding-left: 6vw;
    padding-right: 6vw;
  }

  .hero-details2 {
    align-items: center;
    width: auto;
  }

  .small-description {
    text-align: center;
    width: auto;
    margin-left: 0;
    margin-right: 0;
    padding-right: 0;
    font-size: 1.1rem;
    line-height: 1.6rem;
  }

  .sub-hero-content {
    justify-content: center;
    height: auto;
  }

  .sub-hero-content-container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
    padding-left: 10vw;
    padding-right: 10vw;
  }

  .sub-hero-details {
    align-items: center;
    width: auto;
  }

  .big-title-h1-for-sub {
    text-align: center;
    margin-bottom: 6vh;
    padding-left: 0;
    padding-right: 0;
    font-size: 2.5rem;
    line-height: 3rem;
  }

  .small-title {
    text-align: center;
    margin-top: 0;
    margin-bottom: 1.3vh;
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
  }

  .small-title.reverse {
    text-align: center;
    margin-bottom: 3ch;
    padding-left: 0;
    padding-right: 0;
  }

  .small-title.reverse.with-small-title {
    margin-top: 0;
  }

  .small-title.no-right-padding {
    padding-right: 0;
  }

  .small-title.white {
    padding-left: 0;
    padding-right: 0;
  }

  .small-title.white.reverse {
    padding-left: 0;
  }

  .small-title.first {
    margin-top: 5vh;
  }

  .photo-hero-content {
    justify-content: flex-end;
  }

  .photo-hero-content-container {
    flex-direction: row;
    justify-content: center;
    align-items: flex-end;
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .site-plan-map {
    object-fit: cover;
    width: 100%;
    height: 100%;
    min-height: 0;
    max-height: 60vh;
  }

  .small-paragraph-floor-plan {
    text-align: center;
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
  }

  .small-paragraph-floor-plan.reverse {
    text-align: center;
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph-floor-plan.no-right-padding {
    padding-right: 0;
  }

  .small-paragraph-floor-plan.white {
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph-floor-plan.white.reverse {
    padding-left: 0;
  }
}

@media screen and (max-width: 767px) {
  body {
    font-size: 14px;
    font-weight: 400;
    line-height: 170%;
  }

  h1 {
    letter-spacing: -2px;
    font-size: 44px;
    line-height: 110%;
  }

  h2 {
    font-size: 40px;
  }

  h3 {
    font-size: 28px;
  }

  h4 {
    font-size: 20px;
  }

  h5 {
    letter-spacing: 0;
    font-size: 16px;
    line-height: 140%;
  }

  h6 {
    font-size: 14px;
  }

  .rich-text h1, .rich-text h2 {
    font-size: 28px;
  }

  .rich-text h3 {
    font-size: 20px;
  }

  .rich-text p {
    font-size: 14px;
    line-height: 170%;
  }

  .rich-text li {
    font-size: 14px;
    font-weight: 400;
    line-height: 170%;
  }

  .rich-text figcaption {
    text-align: left;
  }

  .rich-text blockquote {
    padding-left: 16px;
    padding-right: 16px;
    font-size: 20px;
  }

  .container {
    padding-left: 5%;
    padding-right: 5%;
  }

  .information-nav.bottom {
    grid-row-gap: 16px;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    height: auto;
    padding-top: 32px;
    padding-bottom: 32px;
  }

  .heading-huge {
    letter-spacing: -2px;
    font-size: 44px;
    line-height: 110%;
  }

  .heading-huge.is-white.portfolio {
    line-height: 100%;
  }

  .heading-small {
    font-size: 20px;
  }

  .heading-large {
    font-size: 40px;
  }

  .text-large {
    font-size: 20px;
  }

  .heading-medium {
    font-size: 28px;
  }

  .text-regular {
    font-size: 14px;
    font-weight: 400;
    line-height: 170%;
  }

  .style-guide-links {
    order: -1;
  }

  .brand-link {
    width: 96px;
  }

  .text-xlarge {
    font-size: 28px;
  }

  .nav {
    min-height: 72px;
  }

  .side-menu-items {
    width: 100%;
    min-width: 0;
  }

  .side-menu-top {
    padding-right: 6%;
  }

  .side-menu-links {
    padding-bottom: 96px;
  }

  .side-menu-social {
    padding-left: 6%;
    padding-right: 6%;
  }

  .side-menu-link {
    padding-left: 6%;
    padding-right: 8%;
  }

  .spacer-huge {
    height: 100px;
  }

  .narrow-container {
    padding-left: 5%;
    padding-right: 5%;
  }

  .spacer-regular {
    height: 96px;
  }

  .spacer-regular.for-work-case {
    height: 64px;
  }

  .thumb-info {
    padding-right: 16px;
  }

  .thumb-info.for-news {
    min-height: 180px;
  }

  .news-list {
    grid-column-gap: 16px;
  }

  .cta {
    grid-column-gap: 12px;
    padding-bottom: 60px;
    padding-left: 0;
    padding-right: 0;
  }

  .cta-text {
    letter-spacing: -3px;
    font-size: 40px;
  }

  .cta-line {
    height: 3px;
  }

  .cta-arrow {
    width: 28px;
  }

  .nav-buttons {
    grid-column-gap: 16px;
  }

  .oveview-intro {
    padding-left: 5%;
    padding-right: 5%;
  }

  .oveview-intro.for-work-case {
    grid-row-gap: 32px;
  }

  .section-post {
    padding-top: 104px;
  }

  .project-details {
    grid-column-gap: 16px;
  }

  .work-case-content {
    grid-row-gap: 96px;
    margin-top: 96px;
  }

  ._404-content {
    grid-row-gap: 32px;
  }

  .section-404 {
    padding-left: 10%;
    padding-right: 10%;
  }

  .link-404 {
    min-width: 128px;
    min-height: 48px;
  }

  .pop-newsletter {
    width: 100%;
    min-width: 0;
    min-height: 0;
    padding: 32px;
  }

  .newsletter-content {
    grid-row-gap: 24px;
  }

  .text-field {
    padding-left: 16px;
    padding-right: 16px;
    font-weight: 300;
  }

  .hero-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/KennyHeights_LinearGarden03.webp');
    background-position: 0 0, 50%;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .hero-content {
    justify-content: center;
    height: 100vh;
  }

  .hero-content-container {
    margin-top: 0;
    margin-right: 0;
    padding-top: 5vh;
  }

  .hero-content-container.vertical {
    justify-content: center;
    align-items: center;
  }

  .big-title-h1 {
    margin-bottom: 5vh;
    padding-left: 0;
    padding-right: 0;
    font-size: 1.8rem;
    line-height: 2.5rem;
  }

  .big-paragraph {
    text-align: center;
    width: auto;
    font-size: 1.05rem;
    font-weight: 400;
    line-height: 1.5rem;
  }

  .content-photo {
    z-index: 2;
    min-height: 0;
    max-height: 50vh;
  }

  .content-h-container {
    flex-direction: column;
    justify-content: flex-start;
    margin-top: 0;
    margin-bottom: 10vh;
  }

  .content-h-container.no-bottom-padding {
    flex-direction: column;
    margin-top: 0;
  }

  .small-paragraph {
    text-align: center;
    padding-left: 2vw;
    padding-right: 2vw;
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .small-paragraph.reverse {
    text-align: center;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .small-paragraph.white {
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .content-details {
    text-align: center;
    max-width: none;
  }

  .section {
    padding: 10vh 2vw;
  }

  .section.green-bg, .section.mobile-no-padding {
    padding-top: 10vh;
    padding-bottom: 10vh;
  }

  .section.photo-section {
    padding-right: 5vw;
  }

  .section.grey-bg {
    padding-top: 10vh;
    padding-bottom: 10vh;
  }

  .content-description {
    margin-top: 0;
    margin-bottom: 0;
    padding-left: 0;
  }

  .section-content {
    padding-left: 0;
    padding-right: 0;
  }

  .section-content.top-padding {
    padding: 25vh 0 0;
  }

  .section-content.white-smoke-bg {
    padding: 10vh 2vw;
  }

  .big-title-h3 {
    text-align: center;
    font-size: 1.4rem;
    line-height: 1.8rem;
  }

  .big-title-h3.reverse {
    text-align: center;
    margin-bottom: 5vh;
  }

  .big-title-h3.reverse.white {
    margin-bottom: 5vh;
  }

  .big-title-h3.white {
    margin-top: 5vh;
    font-size: 1.4rem;
    line-height: 1.8rem;
  }

  .big-title-h3.white.with-small-title.right-aligned {
    margin-top: 0;
  }

  .big-title-h3.with-small-title.with-top-padding {
    margin-top: 5vh;
  }

  .content-image {
    width: auto;
    min-width: 0;
    min-height: 0;
    margin-top: 0;
  }

  .navi-link {
    padding: 3vh 4vw;
  }

  .township-logo {
    height: 60px;
    margin-bottom: 40px;
    padding-bottom: 0;
  }

  .ctr-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/ms3.webp');
    background-position: 0 0, 50%;
    height: 60vh;
    padding: 10vh 2vw;
  }

  .button-primary {
    margin-top: 4vh;
    padding-left: 4vw;
    padding-right: 4vw;
    font-size: 12px;
    line-height: 22px;
  }

  .button-primary.solid-color {
    font-size: .75rem;
    line-height: .8rem;
  }

  .links-container {
    justify-content: space-between;
    width: 100%;
    margin-top: 24px;
    margin-bottom: 24px;
  }

  .footer {
    padding-left: 3vw;
    padding-right: 3vw;
  }

  .social {
    margin-bottom: 2vh;
  }

  .socials-column {
    margin-top: 2vh;
  }

  .footer-copyright-container {
    flex-direction: column;
    align-items: flex-start;
    padding-top: 18px;
  }

  .links-column {
    width: auto;
  }

  .footer-container {
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    padding-bottom: 8px;
  }

  .copyright-links {
    margin-top: 12px;
  }

  .brand-logo {
    width: 5rem;
  }

  .navi-bar-container {
    justify-content: center;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .content-grouping-logo {
    margin-top: 5vh;
    margin-bottom: 0;
  }

  .content-grouping-image {
    order: -1;
  }

  .navi-bar-div {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    display: flex;
  }

  .content-v-container {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    flex-direction: column;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    place-content: space-between flex-start;
    align-items: center;
    margin-top: 0;
    margin-bottom: 5vh;
    display: grid;
  }

  .content-intro {
    text-align: center;
    max-width: none;
  }

  .small-title-h2 {
    text-align: center;
    margin-top: 0;
    font-size: 1rem;
    line-height: 1.25rem;
  }

  .big-title-h2 {
    text-align: center;
    margin-top: 0;
    font-size: 1.5rem;
    line-height: 2rem;
  }

  .content-bg-image-container {
    display: none;
  }

  .content-paragraph {
    text-align: center;
  }

  .content-intro-paragraph {
    text-align: center;
    padding-left: 2vw;
    padding-right: 2vw;
    font-size: 1rem;
    line-height: 1.6rem;
  }

  .content-h3-container {
    flex-direction: column;
    justify-content: flex-start;
    margin-top: 0;
  }

  .content-h3-container.no-bottom-padding {
    flex-direction: column;
    margin-top: 0;
  }

  .small-title-h3 {
    text-align: center;
    margin-top: 5vh;
    font-size: 1rem;
    line-height: 2rem;
  }

  .mobile-menu {
    padding: 2vh;
  }

  .div-form {
    flex-direction: column;
    justify-content: center;
    align-self: center;
    align-items: center;
    padding-top: 10%;
    display: flex;
  }

  .privacy-paragraph {
    text-align: center;
  }

  .privacy-intro-paragraph {
    text-align: justify;
    padding-left: 2vw;
    padding-right: 2vw;
    font-size: 1rem;
    line-height: 1.6rem;
  }

  .privacy-points-paragraph {
    letter-spacing: .08rem;
    font-size: 1rem;
  }

  .content-v-policy-container {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    flex-direction: column;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    place-content: space-between flex-start;
    align-items: center;
    margin-top: 0;
    margin-bottom: 5vh;
    display: grid;
  }

  .big-title-h2-small {
    text-align: center;
    margin-top: 0;
    font-size: 1.3rem;
    line-height: 1.8rem;
  }

  .big-title-h2-small.side-padding {
    font-size: 1.3rem;
    line-height: 1.8rem;
  }

  .sub-hero-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/this-is-parkcity.webp');
    background-position: 0 0, 50%;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .small-description {
    text-align: center;
    width: auto;
    font-size: 1.05rem;
    font-weight: 400;
    line-height: 1.5rem;
  }

  .sub-hero-content {
    justify-content: center;
  }

  .sub-hero-content-container {
    margin-top: 0;
    margin-right: 0;
  }

  .big-title-h1-for-sub {
    margin-bottom: 5vh;
    padding-left: 0;
    padding-right: 0;
    font-size: 1.8rem;
    line-height: 2.5rem;
  }

  .small-title {
    text-align: center;
    padding-left: 2vw;
    padding-right: 2vw;
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .small-title.reverse {
    text-align: center;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .small-title.white {
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .photo-hero-content {
    justify-content: flex-end;
  }

  .photo-hero-content-container {
    margin-top: 0;
    margin-right: 0;
  }

  .site-plan-map {
    z-index: 2;
    min-height: 0;
    max-height: 50vh;
  }

  .small-paragraph-floor-plan {
    text-align: center;
    padding-left: 2vw;
    padding-right: 2vw;
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .small-paragraph-floor-plan.reverse {
    text-align: center;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .small-paragraph-floor-plan.white {
    font-size: 1rem;
    line-height: 1.55rem;
  }
}

@media screen and (max-width: 479px) {
  .rich-text ul, .rich-text ol {
    padding-left: 5%;
  }

  .rich-text blockquote {
    border-left-style: none;
    padding-left: 8px;
    padding-right: 8px;
  }

  .container.for-footer {
    padding-left: 7.5%;
    padding-right: 7.5%;
  }

  .information-nav {
    height: 80px;
  }

  .information-nav.bottom {
    justify-content: center;
  }

  .heading-huge.is-white.portfolio {
    font-size: 18px;
  }

  .style-guide-links {
    grid-row-gap: 8px;
    flex-flow: column wrap;
    align-items: flex-start;
  }

  .text-tiny.for-post-author {
    display: none;
  }

  .side-menu-top {
    padding-right: 5%;
  }

  .side-menu-link {
    padding-left: 7.5%;
    padding-right: 7.5%;
  }

  .hero-full-page {
    padding-bottom: 48px;
  }

  .spacer-huge {
    height: 80px;
  }

  .narrow-container {
    padding-left: 2.5%;
    padding-right: 2.5%;
  }

  .spacer-regular.for-work-case {
    height: 48px;
  }

  .thumb-image.for-news {
    display: none;
  }

  .thumb-info.for-news {
    min-height: 0;
    padding-top: 8px;
  }

  .news-wrapper {
    padding-left: 2.5%;
    padding-right: 2.5%;
  }

  .news-list {
    grid-template-columns: 1fr;
  }

  .cta {
    padding-top: 70px;
    padding-bottom: 70px;
  }

  .footer-items {
    grid-row-gap: 32px;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
    padding-bottom: 32px;
  }

  .footer-legal {
    justify-content: space-between;
    width: 100%;
  }

  .footer-info {
    grid-row-gap: 16px;
    align-items: flex-start;
    width: 100%;
  }

  .oveview-intro, .oveview-intro.for-work-case, .flexbox-paragraphs.for-work-case, .post-wrapper {
    padding-left: 2.5%;
    padding-right: 2.5%;
  }

  .post-image {
    max-width: none;
  }

  .project-details {
    grid-template-rows: auto auto auto auto auto auto;
    grid-template-columns: 1fr;
  }

  .project-details-item._2 {
    border-top-style: none;
  }

  .project-details-item._3 {
    border-bottom-style: solid;
  }

  .project-details-item._5 {
    border-bottom-style: none;
  }

  .first-group-images {
    grid-template-rows: auto auto auto auto auto auto auto;
    grid-template-columns: 1fr;
  }

  .work-case-image {
    height: 90vw;
  }

  .second-group-images {
    grid-template-rows: auto auto auto auto;
    grid-template-columns: 1fr;
  }

  .section-404 {
    padding-left: 7.5%;
    padding-right: 7.5%;
  }

  .pop-newsletter {
    width: 100%;
    padding-left: 24px;
    padding-right: 24px;
  }

  .hero-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/KennyHeights_LinearGarden03.webp');
    background-position: 0 0, 50%;
    margin-left: 0;
    margin-right: 0;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .hero-content {
    justify-content: center;
    height: 110vh;
  }

  .hero-content-container {
    margin-top: 0;
    margin-right: 0;
    padding-top: 5vh;
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .hero-content-container.vertical {
    justify-content: center;
    align-items: center;
  }

  .big-title-h1 {
    padding-left: 0;
    padding-right: 0;
    font-size: 1.8rem;
    line-height: 2.2rem;
  }

  .big-paragraph {
    width: auto;
    font-size: 1.05rem;
    line-height: 1.7rem;
  }

  .content-photo {
    aspect-ratio: auto;
    text-align: center;
    width: auto;
    max-width: 100vw;
    height: auto;
    min-height: 0;
    max-height: none;
    display: inline-block;
  }

  .content-h-container {
    grid-column-gap: 0vw;
    grid-row-gap: 0vw;
    align-self: auto;
    justify-items: stretch;
  }

  .content-h-container.no-bottom-padding {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    grid-auto-flow: row;
  }

  .small-paragraph {
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .small-paragraph.reverse {
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph.grouping-paragraph {
    padding-bottom: 5vh;
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph.no-right-padding {
    padding-left: 0;
  }

  .content-details.reverse {
    width: 100vw;
  }

  .section.green-bg {
    padding-bottom: 10vh;
    padding-left: 0;
    padding-right: 0;
  }

  .section.mobile-no-padding {
    padding: 10vh 0;
  }

  .section.photo-section {
    background-image: linear-gradient(#0000, #0000), url('../images/the-mansions-linear-garden.webp');
    background-position: 0 0, 100% 100%;
    background-repeat: repeat, no-repeat;
    background-size: auto, cover;
    width: auto;
    height: 500px;
  }

  .section.grey-bg {
    padding-bottom: 10vh;
    padding-left: 0;
    padding-right: 0;
  }

  .content-description {
    margin-top: 0;
    margin-bottom: 0;
  }

  .section-content {
    padding-left: 0;
    padding-right: 0;
  }

  .section-content.top-padding {
    padding-top: 25vh;
    padding-left: 0;
    padding-right: 0;
  }

  .section-content.white-smoke-bg {
    padding-left: 0;
    padding-right: 0;
  }

  .big-title-h3 {
    font-size: 1.4rem;
    line-height: 1.6rem;
  }

  .big-title-h3.reverse {
    margin-bottom: 5vh;
  }

  .big-title-h3.reverse.white {
    line-height: 1.6rem;
  }

  .big-title-h3.white {
    margin-top: 5vh;
    font-size: 1.4rem;
    line-height: 1.6rem;
  }

  .content-image {
    grid-column-gap: 16px;
    grid-row-gap: 16px;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    width: 100vw;
    display: block;
  }

  .content-image.smaller-content-image {
    width: 100vw;
  }

  .content-image.for-intro-to-mansions {
    margin-top: 5vh;
    margin-bottom: 5vh;
  }

  .navi-link {
    padding-top: 2vh;
    padding-bottom: 2vh;
  }

  .township-logo {
    height: 50px;
  }

  .semi-transparent-image {
    opacity: .44;
    right: -57%;
  }

  .ctr-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/ms3.webp');
    background-position: 0 0, 50%;
    margin-left: 0;
    margin-right: 0;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .button-primary {
    text-align: center;
    margin-top: 3vh;
    padding: 2vh 10vw;
    font-size: 10px;
    line-height: 18px;
  }

  .footer-contact-link {
    text-align: center;
  }

  .logo-image {
    margin-right: 0;
  }

  .footer-small-title {
    margin-bottom: 12px;
  }

  .logo-container {
    text-align: center;
    flex-direction: column;
    align-items: center;
    margin-bottom: 20px;
  }

  .links-container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }

  .footer {
    text-align: left;
    padding-top: 5vh;
    padding-bottom: 5vh;
  }

  .social {
    margin-bottom: 0;
    margin-left: 4vw;
    margin-right: 4vw;
  }

  .socials-column {
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin-top: 0;
  }

  .footer-copyright-container {
    align-items: center;
  }

  .footer-block {
    text-align: center;
  }

  .links-column {
    align-items: center;
    width: auto;
    margin-bottom: 20px;
    margin-right: 0;
  }

  .footer-container {
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 32px;
  }

  .navi-bar-container {
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .content-grouping-logo {
    width: 40vw;
    margin-top: 5vh;
    margin-bottom: 0;
  }

  .content-grouping-image {
    order: -1;
    width: 100vw;
  }

  .content-grouping {
    width: 100%;
  }

  .content-v-container {
    grid-auto-flow: row;
  }

  .small-title-h2 {
    font-size: .8rem;
    line-height: 1rem;
  }

  .big-title-h2 {
    margin-bottom: 5vh;
    font-size: 1.5rem;
    line-height: 1.8rem;
  }

  .content-bg-image-container {
    display: none;
  }

  .content-intro-paragraph {
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .small-title-h3 {
    margin-top: 5vh;
    font-size: 1rem;
    line-height: 1.25rem;
  }

  .privacy-intro-paragraph {
    text-align: left;
    letter-spacing: .02rem;
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
    line-height: 1.4rem;
  }

  .privacy-points {
    margin-top: 3vh;
    margin-bottom: 3vh;
  }

  .privacy-points-paragraph {
    text-align: left;
    letter-spacing: .02rem;
    line-height: 1.4rem;
  }

  .content-v-policy-container {
    grid-auto-flow: row;
  }

  .big-title-h2-small {
    margin-bottom: 5vh;
    font-size: 1.5rem;
    line-height: 1.8rem;
  }

  .sub-hero-section {
    background-image: linear-gradient(#00000054, #00000054), url('../images/this-is-parkcity.webp');
    background-position: 0 0, 50%;
    margin-left: 0;
    margin-right: 0;
    padding-left: 2vw;
    padding-right: 2vw;
  }

  .small-description {
    width: auto;
    font-size: 1.05rem;
    line-height: 1.7rem;
  }

  .sub-hero-content {
    justify-content: center;
  }

  .sub-hero-content-container {
    margin-top: 0;
    margin-right: 0;
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .big-title-h1-for-sub {
    padding-left: 0;
    padding-right: 0;
    font-size: 1.8rem;
    line-height: 2.2rem;
  }

  .small-title {
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .small-title.reverse {
    padding-left: 0;
    padding-right: 0;
  }

  .small-title.grouping-paragraph {
    padding-bottom: 5vh;
    padding-left: 0;
    padding-right: 0;
  }

  .small-title.no-right-padding {
    padding-left: 0;
  }

  .photo-hero-content {
    justify-content: center;
    display: flex;
  }

  .photo-hero-content-container {
    margin-top: 0;
    margin-right: 0;
    padding-top: 5vh;
    padding-left: 5vw;
    padding-right: 5vw;
    display: none;
  }

  .site-plan-map {
    aspect-ratio: auto;
    text-align: center;
    width: auto;
    max-width: 100vw;
    height: auto;
    min-height: 0;
    max-height: none;
    display: inline-block;
  }

  .small-paragraph-floor-plan {
    padding-left: 0;
    padding-right: 0;
    font-size: 1rem;
    line-height: 1.55rem;
  }

  .small-paragraph-floor-plan.reverse {
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph-floor-plan.grouping-paragraph {
    padding-bottom: 5vh;
    padding-left: 0;
    padding-right: 0;
  }

  .small-paragraph-floor-plan.no-right-padding {
    padding-left: 0;
  }
}

#w-node-d7c677b1-7bd2-36ae-485c-a3286a99eae2-ac7c9c6d, #w-node-d7c677b1-7bd2-36ae-485c-a3286a99eae2-ac7c9c86, #w-node-_384dffbc-4773-5acc-c4f9-8a617ccd0060-043773af, #w-node-_7e5d91cd-1f92-8f11-af1c-f8d02bcdaad7-043773af {
  grid-area: span 1 / span 1 / span 1 / span 1;
  place-self: auto;
}

#w-node-_050e2400-f4f3-5cbb-3326-6c4690bb775b-043773af {
  align-self: center;
}

@media screen and (max-width: 991px) {
  #w-node-ec810473-ccd6-64b1-b78b-ddd88ee24146-ac7c9c6d, #w-node-f8e3e679-5b50-a607-2eee-96f03789f107-ac7c9c6d, #w-node-_72346b03-7f79-bcf2-68f2-65c6cbe59dab-92ae3828, #w-node-_72346b03-7f79-bcf2-68f2-65c6cbe59dc3-92ae3828, #w-node-a5f50b7a-bcd6-2b88-d865-ec1ea1b50da1-92ae3828 {
    order: 9999;
  }
}

@media screen and (max-width: 767px) {
  #w-node-_7e5d91cd-1f92-8f11-af1c-f8d02bcdaad7-043773af {
    justify-self: auto;
  }
}

@media screen and (max-width: 479px) {
  #w-node-ec810473-ccd6-64b1-b78b-ddd88ee24138-ac7c9c6d, #w-node-ac863ee8-a8c2-6f04-44fc-a8a94df40da8-ac7c9c6d, #w-node-_72346b03-7f79-bcf2-68f2-65c6cbe59d9f-92ae3828, #w-node-_72346b03-7f79-bcf2-68f2-65c6cbe59db7-92ae3828, #w-node-a5f50b7a-bcd6-2b88-d865-ec1ea1b50d95-92ae3828, #w-node-a5f50b7a-bcd6-2b88-d865-ec1ea1b50dad-92ae3828, #w-node-_7ec76f79-a683-b126-2d9a-43c03f849658-92ae3828, #w-node-a0b6f01b-50d7-d17c-99b1-fe973c12b0a5-92ae3828 {
    grid-area: span 2 / span 1 / span 2 / span 1;
    place-self: auto;
  }
}


