.container-x {
  width: 100%;
  max-width: calc(96rem + 2rem);
  margin-left: auto;
  margin-right: auto;
  padding-left: 1rem;
  padding-right: 1rem;
}

button {
  cursor: pointer;
}

.hero-birds {
  pointer-events: none;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 5;
  width: 50%;
  mix-blend-mode: multiply;
}

.hero-birds__video {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

@media (max-width: 767px) {
  .hero-birds {
    width: 100%;
  }
}

#site-header {
  z-index: 3000 !important;
  isolation: isolate;
}

#mobile-backdrop {
  z-index: 3100 !important;
}

#mobile-menu {
  z-index: 3200 !important;
}

@media (max-width: 1279px) {
  #site-header.is-scrolled {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}

#project-location-map {
  min-height: 240px;
  position: relative;
  z-index: 1;
  isolation: isolate;
}

@media (min-width: 640px) {
  #project-location-map {
    min-height: 320px;
  }
}

#project-location-map.leaflet-container {
  background: #fefaf4;
  font-family: "Urbanist", sans-serif;
}

#project-location-map .leaflet-tile-pane {
  z-index: 10 !important;
}

#project-location-map .leaflet-overlay-pane {
  z-index: 20 !important;
}

#project-location-map .leaflet-shadow-pane {
  z-index: 30 !important;
}

#project-location-map .leaflet-marker-pane {
  z-index: 40 !important;
}

#project-location-map .leaflet-tooltip-pane {
  z-index: 50 !important;
}

#project-location-map .leaflet-popup-pane {
  z-index: 60 !important;
}

#project-location-map .leaflet-control-container {
  z-index: 70 !important;
}

.location-pin {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  box-shadow: 0 10px 22px rgba(37, 40, 42, 0.16);
}

.location-pin--project {
  width: 54px;
  height: 54px;
  background: #fefaf4;
  border: 1px solid rgba(148, 121, 93, 0.34);
  padding: 8px;
}

.location-pin--project img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.location-pin--default {
  width: 24px;
  height: 32px;
  box-shadow: none;
}

.location-pin--default svg {
  width: 24px;
  height: 32px;
  filter: drop-shadow(0 7px 10px rgba(37, 40, 42, 0.25));
}

.map-row {
  border-radius: 12px;
  padding-left: 10px;
  padding-right: 10px;
  transition: background-color 0.2s ease;
}

.map-row.is-active {
  background: #f5f2e9;
}

.rich-text {
  color: rgba(37, 40, 42, 0.92);
  font-size: clamp(0.95rem, 0.35vw + 0.88rem, 1.0625rem);
  line-height: 1.72;
}

.rich-text>* {
  margin: 0;
}

.rich-text>*+* {
  margin-top: clamp(0.75rem, 1.5vw, 1.2rem);
}

.rich-text h1,
.rich-text h2,
.rich-text h3,
.rich-text h4,
.rich-text h5,
.rich-text h6 {
  margin-top: clamp(1.4rem, 2.6vw, 2.2rem);
  color: #25282a;
  font-family: "Mona Sans", "Urbanist", sans-serif;
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.02em;
}

.rich-text h1 {
  font-size: clamp(1.8rem, 2.8vw, 2.5rem);
  font-weight: 800;
}

.rich-text h2 {
  font-size: clamp(1.55rem, 2.1vw, 2.15rem);
}

.rich-text h3 {
  font-size: clamp(1.3rem, 1.7vw, 1.75rem);
}

.rich-text h4,
.rich-text h5,
.rich-text h6 {
  font-size: clamp(1.05rem, 1.15vw, 1.35rem);
}

.rich-text a {
  color: #94795d;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.rich-text a:hover {
  color: #7e6247;
}

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

.rich-text em {
  font-style: italic;
}

.rich-text ul,
.rich-text ol {
  padding-left: 1.2rem;
  list-style-position: outside;
}

.rich-text ul {
  list-style-type: disc;
}

.rich-text ol {
  list-style-type: decimal;
}

.rich-text ul ul {
  list-style-type: circle;
}

.rich-text ol ol {
  list-style-type: lower-alpha;
}

.rich-text li+li {
  margin-top: 0.35rem;
}

.rich-text blockquote {
  border-left: 3px solid #94795d;
  margin: 0;
  padding: 0.35rem 0 0.35rem 1rem;
  color: rgba(37, 40, 42, 0.82);
}

.rich-text img,
.rich-text video,
.rich-text iframe {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0.95rem;
  margin-top: 0.4rem;
}

.rich-text figure {
  margin: 0;
}

.rich-text figcaption {
  margin-top: 0.55rem;
  font-size: 0.8125rem;
  color: rgba(37, 40, 42, 0.62);
}

.rich-text hr {
  border: 0;
  border-top: 1px solid rgba(37, 40, 42, 0.16);
  margin-top: 1.5rem;
}

.rich-text table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 0.75rem;
}

.rich-text table th,
.rich-text table td {
  border: 1px solid rgba(37, 40, 42, 0.12);
  padding: 0.65rem 0.7rem;
  text-align: left;
}

.rich-text table th {
  background: rgba(244, 242, 232, 0.7);
  font-weight: 700;
}

@media (max-width: 767px) {
  .rich-text>*+* {
    margin-top: 0.78rem;
  }

  .rich-text h1,
  .rich-text h2,
  .rich-text h3,
  .rich-text h4,
  .rich-text h5,
  .rich-text h6 {
    margin-top: 1.25rem;
  }
}