/* stylelint-disable */
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote::before, blockquote::after,
q::before, q::after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

button {
  border: 0;
  margin: 0;
  padding: 0;
  width: auto;
  overflow: visible;
  background: transparent;
  /* inherit font & color from ancestor */
  color: inherit;
  font: inherit;
  text-align: inherit;
  /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */
  line-height: normal;
  line-height: inherit;
}

@font-face {
  font-family: "American Grotesk";
  src: url("../../fonts/AmericanGrotesk-Thin.woff2") format("woff2"), url("../../fonts/AmericanGrotesk-Thin.woff") format("woff");
  font-weight: 100;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "American Grotesk";
  src: url("../../fonts/AmericanGrotesk-Regular.woff2") format("woff2"), url("../../fonts/AmericanGrotesk-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "American Grotesk";
  src: url("../../fonts/AmericanGrotesk-Bold.woff2") format("woff2"), url("../../fonts/AmericanGrotesk-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Tiempos Headline";
  src: url("../../fonts/TiemposHln-Light.woff2") format("woff2"), url("../../fonts/TiemposHln-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Tiempos Headline";
  src: url("../../fonts/TiemposHln-Medium.woff2") format("woff2"), url("../../fonts/TiemposHln-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Tiempos Headline";
  src: url("../../fonts/TiemposHln-Bold.woff2") format("woff2"), url("../../fonts/TiemposHln-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
.heading, .agents-block .person .name, .listing-map-travel .population-reach-box .box-value, .h6, .h5, .h4, .h3, .h2, .h1, .expandable-boxes .box-number {
  font-family: var(--font-family-secondary);
  font-weight: 500;
  line-height: 1;
  text-wrap: balance;
}

.h1, .expandable-boxes .box-number {
  font-size: var(--text-size-5xl);
}

.h2 {
  font-size: var(--text-size-4xl);
}

.h3 {
  font-size: var(--text-size-3xl);
}

.h4 {
  font-size: var(--text-size-2xl);
}

.h5 {
  font-size: var(--text-size-xl);
}

.h6 {
  font-size: var(--text-size-l);
}

.styled-text .styled-text-part {
  display: block;
}
.styled-text .styled-text-part--accent {
  color: var(--theme-text-accent);
}

.container {
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding-inline: var(--gutter);
}
@media (min-width: 768px) {
  .container {
    width: 720px;
  }
}
@media (min-width: 992px) {
  .container {
    width: 960px;
  }
}
@media (min-width: 1300px) {
  .container {
    width: 1240px;
  }
}
@media (min-width: 1600px) {
  .container {
    width: 1470px;
  }
}

:root {
  --container-width: calc(100% - var(--gutter) * 2);
  --gutter: 20px;
  --header-height: 66px;
  --font-family-primary: "American Grotesk", sans-serif;
  --font-family-secondary: "Tiempos Headline", sans-serif;
  --td-s: 0.2s;
  --td-m: 0.5s;
  --td-l: 1s;
  --td-xl: 1.4s;
  --td-theme: 1s;
  --neutral-10: #ffffff;
  --neutral-9: #f7f7f7;
  --neutral-8: #e6e6e6;
  --neutral-7: #d9d9d9;
  --neutral-6: #cccccc;
  --neutral-5: #b2b2b2;
  --neutral-4: #999999;
  --neutral-3: #666666;
  --neutral-2: #4d4d4d;
  --neutral-1: #333333;
  --neutral-0: #000000;
  --black: var(--neutral-0);
  --white: var(--neutral-10);
  --pink: #e4acad;
  --pink-40: #f4dede;
  --pink-60: #efcdce;
  --pink-20: #faeeef;
  --cream: #f5f1e9;
  --cream-60: #f9f7f2;
  --cream-40: #fbf9f6;
  --cream-20: #fdfcfb;
  --dark-green: #002922;
  --dark-green-60: #667f7a;
  --dark-green-40: #99a9a7;
  --dark-green-20: #ccd4d3;
  --charcoal: #292524;
  --charcoal-60: var(--neutral-3);
  --charcoal-40: var(--neutral-4);
  --charcoal-20: var(--neutral-6);
  --error-light: #ff7e7e;
  --error-dark: #940000;
  --text-primary: var(--black);
  --text-receding: var(--neutral-3);
  --text-light: var(--neutral-8);
  --text-size-5xl: 54px;
  --text-size-4xl: 34px;
  --text-size-3xl: 23px;
  --text-size-2xl: 21px;
  --text-size-xl: 19px;
  --text-size-l: 18px;
  --text-size-m: 16px;
  --text-size-s: 15px;
  --text-size-xs: 13px;
  --text-size-2xs: 12px;
  --spacing-4xl: 100px;
  --spacing-3xl: 75px;
  --spacing-2xl: 50px;
  --spacing-xl: 25px;
  --spacing-l: 20px;
  --spacing-m: 15px;
  --spacing-s: 10px;
  --spacing-xs: 5px;
  --spacing-2xs: 2px;
  --border-radius-round: 50%;
  --border-radius-rounded: 500px;
  --border-radius-l: 20px;
  --border-radius-m: 10px;
  --border-radius-s: 5px;
  --border-radius-xs: 3px;
}
@media (min-width: 768px) {
  :root {
    --container-width: calc(720px - var(--gutter) * 2);
    --text-size-5xl: clamp(54px, calc((120 / 1400) * var(--container-width)), 120px);
    --text-size-4xl: clamp(34px, calc((86 / 1400) * var(--container-width)), 86px);
    --text-size-3xl: clamp(23px, calc((61 / 1400) * var(--container-width)), 61px);
    --text-size-2xl: clamp(21px, calc((44 / 1400) * var(--container-width)), 44px);
    --text-size-xl: clamp(19px, calc((31 / 1400) * var(--container-width)), 31px);
    --text-size-l: clamp(18px, calc((22 / 1400) * var(--container-width)), 22px);
    --text-size-m: clamp(16px, calc((16 / 1400) * var(--container-width)), 16px);
    --text-size-s: clamp(11px, calc((11 / 1400) * var(--container-width)), 11px);
    --text-size-xs: clamp(13px, calc((8 / 1400) * var(--container-width)), 8px);
    --text-size-xs: clamp(12px, calc((6 / 1400) * var(--container-width)), 6px);
    --spacing-4xl: clamp(100px, calc((150 / 1400) * var(--container-width)), 150px);
    --spacing-3xl: clamp(75px, calc((100 / 1400) * var(--container-width)), 100px);
    --spacing-2xl: clamp(50px, calc((75 / 1400) * var(--container-width)), 75px);
    --spacing-xl: clamp(25px, calc((50 / 1400) * var(--container-width)), 50px);
    --spacing-l: clamp(20px, calc((30 / 1400) * var(--container-width)), 30px);
    --spacing-m: clamp(15px, calc((20 / 1400) * var(--container-width)), 20px);
  }
}
@media (min-width: 992px) {
  :root {
    --container-width: calc(960px - var(--gutter) * 2);
  }
}
@media (min-width: 1300px) {
  :root {
    --container-width: calc(1240px - var(--gutter) * 2);
  }
}
@media (min-width: 1600px) {
  :root {
    --container-width: calc(1470px - var(--gutter) * 2);
  }
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

* {
  outline: none;
}

html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
          text-size-adjust: 100%;
}

body {
  min-width: 320px;
  font-family: var(--font-family-primary);
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  line-height: 1.2;
  font-size: var(--text-size-m);
  text-wrap: pretty;
  background-color: var(--theme-bg);
  color: var(--theme-text-main);
  overflow-x: clip;
}
body ::-moz-selection {
  background-color: var(--black);
  color: var(--white);
}
body ::selection {
  background-color: var(--black);
  color: var(--white);
}

a {
  text-decoration: none;
}

strong {
  font-weight: bold;
}

em {
  font-style: italic;
}

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

p:not(:first-child) {
  margin-top: 0.8em;
}

.media-wrapper {
  position: relative;
  overflow: hidden;
}
.media-wrapper img,
.media-wrapper video,
.media-wrapper picture {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.focal-point-image {
  -o-object-position: calc(var(--focal-point-left, 0.5) * 100%) calc(var(--focal-point-top, 0.5) * 100%);
     object-position: calc(var(--focal-point-left, 0.5) * 100%) calc(var(--focal-point-top, 0.5) * 100%);
}

.parallax-mover {
  width: 100%;
  height: 100%;
  position: relative;
}

.header {
  height: var(--header-height);
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--theme-borders);
  position: sticky;
  top: 0;
  z-index: 999;
  background-color: var(--theme-bg);
}
.header .header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.header .header-logo {
  display: block;
  color: inherit;
}
.header .header-logo svg {
  height: 28px;
  width: auto;
}
.header .header-logo svg path {
  fill: currentColor;
}
.header .header-nav {
  align-items: center;
  gap: var(--spacing-l);
  display: none;
}
@media (min-width: 768px) {
  .header .header-nav {
    display: flex;
  }
}
.header .header-nav .nav-buttons {
  display: flex;
  gap: var(--spacing-s);
}
.header .header-nav .menu {
  display: contents;
}
.header .header-nav .menu a {
  color: inherit;
}
.header .burger-menu {
  display: none;
}

.footer {
  padding-block: 30px;
}
@media (min-width: 768px) {
  .footer {
    padding-block: clamp(30px, 50 / 1400 * var(--container-width), 50px);
  }
}
.footer .footer-inner {
  border-top: 1px solid var(--theme-borders);
  padding-block: 30px;
  display: grid;
  grid-template-columns: auto auto;
  width: 100%;
  row-gap: 20px;
  -moz-column-gap: var(--spacing-l);
       column-gap: var(--spacing-l);
}
@media (min-width: 768px) {
  .footer .footer-inner {
    padding-top: clamp(30px, 50 / 1400 * var(--container-width), 50px);
    row-gap: clamp(30px, 50 / 1400 * var(--container-width), 50px);
  }
}
.footer .footer-logo {
  grid-column: 1/-1;
  margin-bottom: 60px;
  justify-self: center;
  width: 100%;
  max-width: 360px;
}
@media (min-width: 768px) {
  .footer .footer-logo {
    grid-column: 1/span 1;
    margin: 0;
    place-self: end start;
    width: clamp(240px, 310 / 1400 * var(--container-width), 310px);
  }
}
.footer .footer-logo svg,
.footer .footer-logo img {
  width: 100%;
  overflow: visible;
}
.footer .social-links {
  grid-column: 1/-1;
  display: flex;
  gap: var(--spacing-s);
  align-items: center;
}
@media (min-width: 768px) {
  .footer .social-links {
    grid-column: 2/span 1;
    grid-row: 2/span 1;
    place-self: start end;
  }
}
.footer .social-links .social-link {
  color: inherit;
}
.footer .social-links .social-link svg {
  height: 25px;
  width: auto;
}
@media (min-width: 768px) {
  .footer .social-links .social-link svg {
    height: clamp(25px, 30 / 1400 * var(--container-width), 30px);
  }
}
.footer .footer-info {
  font-size: var(--text-size-xs);
  line-height: 1.4;
}
@media (min-width: 768px) {
  .footer .footer-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-s);
    font-size: clamp(var(--text-size-xs), 16 / 1400 * var(--container-width), 16px);
  }
}
.footer .footer-info .vertical-divider {
  display: none;
}
@media (min-width: 768px) {
  .footer .footer-info .vertical-divider {
    display: block;
  }
}
.footer .footer-info a {
  color: inherit;
}
.footer .footer-nav a {
  text-decoration: underline;
}
.footer .footer-info-top {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
@media (min-width: 768px) {
  .footer .footer-info-top {
    flex-direction: row;
    gap: var(--spacing-m);
  }
}
.footer .argo-logo {
  width: 100px;
  place-self: end;
}
@media (min-width: 768px) {
  .footer .argo-logo {
    grid-column: 2/span 1;
    grid-row: 1/span 1;
    width: clamp(140px, 200 / 1400 * var(--container-width), 200px);
  }
}
.footer .argo-logo svg,
.footer .argo-logo img {
  width: 100%;
}

@property --theme-bg {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-text-main {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-text-disabled {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-text-accent {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-text-accent-small {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-borders {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-btn-primary {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-btn-primary-hover {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-btn-primary-outline {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-btn-primary-outline-hover {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-btn-primary-text {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-btn-primary-text-hover {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-form-error {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-form-filled-text {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-image-overlay-overlay-1 {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-image-overlay-lighten-2 {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-image-overlay-hard-light-3 {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-image-overlay-colour-4 {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --theme-image-overlay-normal-5 {
  syntax: "<color>";
  inherits: true;
  initial-value: transparent;
}
@property --hover-progress {
  syntax: "<number>";
  inherits: true;
  initial-value: 0;
}
[data-theme] {
  transition: --theme-bg var(--td-theme), --theme-text-main var(--td-theme), --theme-text-disabled var(--td-theme), --theme-text-accent var(--td-theme), --theme-text-accent-small var(--td-theme), --theme-borders var(--td-theme), --theme-btn-primary var(--td-theme), --theme-btn-primary-hover var(--td-theme), --theme-btn-primary-outline var(--td-theme), --theme-btn-primary-outline-hover var(--td-theme), --theme-btn-primary-text var(--td-theme), --theme-btn-primary-text-hover var(--td-theme), --theme-form-error var(--td-theme), --theme-form-filled-text var(--td-theme), --theme-image-overlay-overlay-1 var(--td-theme), --theme-image-overlay-lighten-2 var(--td-theme), --theme-image-overlay-hard-light-3 var(--td-theme), --theme-image-overlay-colour-4 var(--td-theme), --theme-image-overlay-normal-5 var(--td-theme);
}

[data-theme=dark-green], body[data-theme=cream] .argo-banner-box, body[data-theme=pink] body.argo-banner-box .argo-banner-box, body[data-theme=dark-green] body.argo-banner-box body.argo-banner-box .argo-banner-box {
  --theme-bg: var(--dark-green);
  --theme-text-main: var(--cream);
  --theme-text-disabled: var(--dark-green-60);
  --theme-text-accent: var(--pink);
  --theme-text-accent-small: var(--pink);
  --theme-borders: var(--neutral-5);
  --theme-btn-primary: var(--pink);
  --theme-btn-primary-hover: color-mix(in srgb, var(--white) 20%, var(--pink));
  --theme-btn-primary-outline: var(--cream);
  --theme-btn-primary-outline-hover: color-mix(in srgb, var(--dark-green-60) 50%, var(--theme-bg));
  --theme-btn-primary-text: var(--dark-green);
  --theme-btn-primary-text-hover: var(--dark-green);
  --theme-form-error: var(--error-light);
  --theme-form-filled-text: var(--cream-20);
  --theme-image-overlay-overlay-1: #c3c3c3;
  --theme-image-overlay-lighten-2: #828282;
  --theme-image-overlay-hard-light-3: var(--theme-bg);
  --theme-image-overlay-colour-4: transparent;
  --theme-image-overlay-normal-5: transparent;
}

[data-theme=pink], body[data-theme=dark-green] .argo-banner-box, body[data-theme=cream] body.argo-banner-box .argo-banner-box, body[data-theme=pink] body.argo-banner-box body.argo-banner-box .argo-banner-box {
  --theme-bg: var(--pink);
  --theme-text-main: var(--dark-green);
  --theme-text-disabled: var(--dark-green-60);
  --theme-text-accent: var(--cream-20);
  --theme-text-accent-small: var(--cream-20);
  --theme-borders: var(--dark-green-40);
  --theme-btn-primary: var(--cream-20);
  --theme-btn-primary-hover: var(--pink-20);
  --theme-btn-primary-outline: var(--dark-green);
  --theme-btn-primary-outline-hover: color-mix(in srgb, var(--pink-60) 70%, transparent);
  --theme-btn-primary-text: var(--dark-green);
  --theme-btn-primary-text-hover: var(--dark-green);
  --theme-form-error: var(--error-dark);
  --theme-form-filled-text: var(--dark-green);
  --theme-image-overlay-overlay-1: #676767;
  --theme-image-overlay-lighten-2: #808080;
  --theme-image-overlay-hard-light-3: var(--theme-bg);
  --theme-image-overlay-colour-4: transparent;
  --theme-image-overlay-normal-5: transparent;
}

[data-theme=cream], body[data-theme=pink] .argo-banner-box, body[data-theme=dark-green] body.argo-banner-box .argo-banner-box, body[data-theme=cream] body.argo-banner-box body.argo-banner-box .argo-banner-box {
  --theme-bg: var(--cream);
  --theme-text-main: var(--dark-green);
  --theme-text-disabled: var(--dark-green-40);
  --theme-text-accent: var(--pink);
  --theme-text-accent-small: var(--dark-green-60);
  --theme-borders: var(--neutral-5);
  --theme-btn-primary: var(--pink);
  --theme-btn-primary-hover: color-mix(in srgb, var(--black) 20%, var(--pink));
  --theme-btn-primary-outline: var(--dark-green);
  --theme-btn-primary-outline-hover: var(--cream-20);
  --theme-btn-primary-text: var(--dark-green);
  --theme-btn-primary-text-hover: var(--cream-20);
  --theme-form-error: var(--error-dark);
  --theme-form-filled-text: var(--dark-green);
  --theme-image-overlay-overlay-1: transparent;
  --theme-image-overlay-lighten-2: transparent;
  --theme-image-overlay-hard-light-3: transparent;
  --theme-image-overlay-colour-4: var(--cream);
  --theme-image-overlay-normal-5: color-mix(in srgb, var(--cream) 70%, transparent);
}

.overlay-parent {
  position: absolute;
  display: block;
  inset: 0;
}
.overlay-parent:before {
  content: "";
  position: absolute;
  display: block;
  inset: 0;
  background-color: var(--white);
  mix-blend-mode: saturation;
  z-index: 1;
}
.overlay-parent .overlay {
  position: absolute;
  display: block;
  inset: 0;
}
.overlay-parent .overlay-1 {
  background-color: var(--theme-image-overlay-overlay-1);
  mix-blend-mode: overlay;
  z-index: 2;
}
.overlay-parent .overlay-2 {
  background-color: var(--theme-image-overlay-lighten-2);
  mix-blend-mode: lighten;
  z-index: 3;
}
.overlay-parent .overlay-3 {
  background-color: var(--theme-image-overlay-hard-light-3);
  mix-blend-mode: hard-light;
  z-index: 4;
}
.overlay-parent .overlay-4 {
  background-color: var(--theme-image-overlay-colour-4);
  mix-blend-mode: color;
  z-index: 5;
}
.overlay-parent .overlay-5 {
  background-color: var(--theme-image-overlay-normal-5);
  z-index: 6;
}

.button, .contact-form .listradio-wrap label {
  display: inline-flex;
  gap: var(--spacing-s);
  color: var(--theme-btn-primary-text);
  border-radius: var(--border-radius-xs);
  gap: var(--spacing-m);
  padding-inline: 0.9375em;
  padding-block: round(nearest, 0.5em, 1px);
  font-size: var(--text-size-m);
  text-transform: uppercase;
  align-items: center;
  letter-spacing: 0.1em;
  min-width: 8.125em;
  justify-content: space-between;
  cursor: pointer;
  line-height: round(nearest, 1.2em, 1px);
  text-align: center;
}
body:not(.is-switching-theme) .button, body:not(.is-switching-theme) .contact-form .listradio-wrap label, .contact-form .listradio-wrap body:not(.is-switching-theme) label {
  transition: color var(--td-s), background-color var(--td-s);
}
.button svg, .contact-form .listradio-wrap label svg {
  height: round(nearest, 1.3333333333em, 1px);
  width: auto;
}
.button svg path, .contact-form .listradio-wrap label svg path {
  stroke: currentColor;
}
.button:not(:has(svg)), .contact-form .listradio-wrap label:not(:has(svg)) {
  justify-content: center;
}
.button--reverse svg {
  order: -1;
}
.button--solid, .contact-form .listradio-wrap li:has(input:checked) label, .listing-map-travel .block-filter.active {
  background-color: var(--theme-btn-primary);
}
@media (hover: hover) {
  .button--solid:hover, .contact-form .listradio-wrap li:has(input:checked) label:hover, .listing-map-travel .block-filter.active:hover {
    background-color: var(--theme-btn-primary-hover);
    color: var(--theme-btn-primary-text-hover);
  }
}
.button--outline, .contact-form .listradio-wrap li:not(:has(input:checked)) label, .listing-map-travel .block-filter:not(.active) {
  background-color: var(--theme-bg);
  color: var(--theme-btn-primary-outline);
  outline: 1px solid currentColor;
  outline-offset: -1px;
}
@media (hover: hover) {
  .button--outline:hover, .contact-form .listradio-wrap li:not(:has(input:checked)) label:hover, .listing-map-travel .block-filter:hover:not(.active) {
    background-color: var(--theme-btn-primary-outline-hover);
  }
}
.button--small, .contact-form .listradio-wrap label {
  font-size: 11px;
  min-width: 100px;
  padding-block: round(nearest, 0.7272727273em, 1px);
}
.button--small:has(svg), .contact-form .listradio-wrap label:has(svg) {
  padding-block: round(nearest, 0.4545454545em, 1px);
}
.button--small svg, .contact-form .listradio-wrap label svg {
  height: round(nearest, 1.8181818182em, 1px);
}

.consent {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  transform: translateY(calc(100% + 40px));
  transition: transform 0.4s;
  z-index: 999;
  pointer-events: none;
  background-color: color-mix(in srgb, var(--white) 70%, transparent);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  padding-block: 20px;
}
@media (min-width: 768px) {
  .consent {
    padding-block: 30px;
  }
}
.consent--visible {
  transform: translateY(0);
}

.consent-inner {
  pointer-events: auto;
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media (min-width: 768px) {
  .consent-inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
  }
}
.consent-inner .consent-content {
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 11px;
}
@media (min-width: 768px) {
  .consent-inner .consent-content {
    font-size: clamp(11px, 14 / 1400 * var(--container-width), 14px);
  }
}
.consent-inner .consent-links a {
  color: inherit;
  border-bottom: 1px solid currentColor;
}
.consent-inner .consent-buttons {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  flex-shrink: 0;
}
.single-news-page {
  margin-top: var(--spacing-2xl);
  margin-bottom: var(--spacing-xl);
}
.single-news-page .single-news-inner {
  display: grid;
  row-gap: var(--spacing-xl);
}
@media (min-width: 992px) {
  .single-news-page .single-news-inner {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    -moz-column-gap: var(--spacing-m);
         column-gap: var(--spacing-m);
    row-gap: var(--spacing-xl);
  }
}
.single-news-page .single-news-header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
@media (min-width: 992px) {
  .single-news-page .single-news-header {
    grid-column: 2/-1;
  }
}
.single-news-page .header-top {
  display: flex;
  gap: var(--spacing-l);
  justify-content: space-between;
  align-items: center;
}
.single-news-page .header-date {
  display: flex;
  gap: var(--spacing-s);
  align-items: center;
}
.single-news-page .header-date .date {
  font-weight: 700;
}
.single-news-page .header-share {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
  color: inherit;
}
.single-news-page .header-share svg {
  height: 30px;
  width: auto;
}
.single-news-page .single-news-title {
  color: var(--theme-text-accent);
}
.single-news-page .single-news-executive-summary {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
@media (min-width: 992px) {
  .single-news-page .single-news-executive-summary {
    grid-column: 2/span 3;
  }
}
.single-news-page .single-news-executive-summary .content-content {
  font-size: var(--text-size-l);
}
.single-news-page .single-news-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--spacing-l);
}
@media (min-width: 992px) {
  .single-news-page .single-news-content {
    grid-column: 2/span 3;
  }
}
@media (min-width: 992px) {
  .single-news-page .divider {
    grid-column: 2/span 3;
  }
}

.dot {
  width: 10px;
  aspect-ratio: 1;
  border-radius: 50%;
  display: block;
  background-color: var(--theme-text-accent);
}

.content-content h2,
.content-content h3,
.content-content h4,
.content-content h5,
.content-content h6 {
  font-weight: 700;
  margin-top: 1.2em;
  margin-bottom: 0.6em;
}
.content-content h2 {
  font-size: var(--text-size-l);
}
.content-content ul {
  padding-left: 1.5em;
  list-style-type: disc;
  list-style-position: outside;
}
.content-content ul li:not(:first-of-type) {
  margin-top: 0.2em;
}

.divider {
  width: 100%;
  height: 1px;
  display: block;
  background-color: var(--theme-borders);
}

.single-listing-banner {
  margin-block: var(--gutter);
}
@media (min-width: 768px) {
  .single-listing-banner {
    margin-block: var(--spacing-xl);
  }
}
.single-listing-banner .single-listing-banner-inner {
  width: 100%;
  aspect-ratio: 16/9;
}
@media (min-width: 768px) {
  .single-listing-banner .single-listing-banner-inner {
    aspect-ratio: 2;
  }
}
@media (min-width: 992px) {
  .single-listing-banner .single-listing-banner-inner {
    aspect-ratio: 2.75;
  }
}

.single-listing-info {
  margin-top: var(--spacing-xl);
  margin-bottom: var(--spacing-3xl);
}
.single-listing-info .single-listing-info-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
  align-items: flex-start;
}
@media (min-width: 992px) {
  .single-listing-info .single-listing-info-inner {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
.single-listing-info .info-heading {
  color: var(--theme-text-accent);
}
.single-listing-info .info-details {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
  font-size: var(--text-size-l);
}
.single-listing-info .info-details .bold {
  color: var(--theme-text-accent);
  font-weight: 700;
  font-size: var(--text-size-xl);
}
.single-listing-info .info-details .details-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
.single-listing-info .info-details a {
  color: inherit;
}
@media (min-width: 992px) {
  .single-listing-info .info-details--mobile {
    display: none;
  }
}
.single-listing-info .info-details--desktop {
  display: none;
}
@media (min-width: 992px) {
  .single-listing-info .info-details--desktop {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-flow: dense;
    row-gap: 0;
    -moz-column-gap: var(--spacing-l);
         column-gap: var(--spacing-l);
    width: 100%;
    order: 3;
    font-size: var(--text-size-m);
  }
}
.single-listing-info .info-details--desktop .bold {
  font-size: var(--text-size-m);
}
.single-listing-info .info-details--desktop .units {
  display: contents;
}
.single-listing-info .info-details--desktop .unit {
  display: contents;
}
.single-listing-info .info-details--desktop .col-1 {
  grid-column: 1/span 1;
  grid-row: auto;
}
.single-listing-info .info-details--desktop .col-2 {
  grid-column: 2/span 1;
}
.single-listing-info .info-details--desktop .col-3 {
  grid-column: 3/span 1;
}
.single-listing-info .info-details--desktop a {
  place-self: start;
}
.single-listing-info .info-buttons {
  display: flex;
  gap: var(--spacing-s);
}
@media (min-width: 992px) {
  .single-listing-info .info-buttons {
    align-self: flex-end;
  }
}

.listing-text-image-section {
  margin-block: var(--spacing-3xl);
}
@media (min-width: 768px) {
  .listing-text-image-section {
    margin-block: var(--spacing-4xl);
  }
}
@media (min-width: 992px) {
  .listing-text-image-section {
    margin-block: var(--spacing-3xl);
  }
}
.listing-text-image-section .listing-text-image-section-inner {
  position: relative;
  display: flex;
  flex-direction: column;
}
@media (min-width: 992px) {
  .listing-text-image-section .listing-text-image-section-inner {
    flex-direction: row;
    padding-block: var(--spacing-3xl);
    align-items: center;
    max-width: clamp(800px, 1170 / 1400 * var(--container-width), 1170px);
    margin-inline: auto;
    width: 100%;
    justify-content: space-between;
  }
}
@media (min-width: 768px) {
  .listing-text-image-section .text-image-heading {
    font-size: var(--text-size-4xl);
  }
}
@media (min-width: 992px) {
  .listing-text-image-section .text-image-heading {
    font-size: var(--text-size-3xl);
  }
}
.listing-text-image-section .text-image-heading-2 {
  color: var(--theme-text-accent);
}
@media (min-width: 992px) {
  .listing-text-image-section .content-block-top {
    width: 40%;
  }
}
.listing-text-image-section .images-block {
  position: relative;
  width: 100%;
  height: 330px;
  display: flex;
  justify-content: center;
  top: calc(-1 * var(--spacing-xl));
  z-index: -1;
}
@media (min-width: 992px) {
  .listing-text-image-section .images-block {
    position: absolute;
    left: 45%;
    top: 50%;
    translate: -50% -50%;
    height: 100%;
    width: 34%;
  }
}
@media (min-width: 1300px) {
  .listing-text-image-section .images-block {
    left: 46%;
  }
}
.listing-text-image-section .block-image {
  position: absolute;
  overflow: visible;
}
.listing-text-image-section .block-image:nth-of-type(1) {
  left: 50%;
  top: 50%;
  translate: -40% -50%;
  width: 214px;
  aspect-ratio: 214/325;
  z-index: 1;
}
@media (min-width: 992px) {
  .listing-text-image-section .block-image:nth-of-type(1) {
    left: unset;
    right: 0;
    translate: 0 -50%;
    width: 73%;
  }
}
.listing-text-image-section .block-image:nth-of-type(2) {
  left: 50%;
  top: 50%;
  translate: -80% -50%;
  width: 187px;
  aspect-ratio: 1;
  z-index: 2;
}
@media (min-width: 992px) {
  .listing-text-image-section .block-image:nth-of-type(2) {
    left: 0;
    translate: 0 -50%;
    width: 64%;
  }
}
.listing-text-image-section .content-block-bottom {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
@media (min-width: 768px) {
  .listing-text-image-section .content-block-bottom {
    margin-left: auto;
    max-width: 360px;
  }
}
@media (min-width: 992px) {
  .listing-text-image-section .content-block-bottom {
    margin: 0;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto 1fr;
    width: 34%;
    max-width: unset;
  }
  .listing-text-image-section .content-block-bottom::before {
    content: "";
    display: block;
  }
}

.single-listing-carousel-specs {
  margin-block: var(--spacing-3xl);
}
@media (min-width: 1920px) {
  .single-listing-carousel-specs .single-listing-carousel-specs-inner {
    width: 1600px !important;
  }
  .single-listing-carousel-specs .specs-block {
    padding: 0 !important;
  }
}
.single-listing-carousel-specs .single-listing-carousel-specs-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
  width: var(--container-width);
  margin-inline: auto;
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .single-listing-carousel-specs-inner {
    flex-direction: row;
    width: 100%;
    height: clamp(500px, 700 / 1400 * var(--container-width), 700px);
    gap: clamp(30px, 40 / 1400 * var(--container-width), 40px);
  }
}
.single-listing-carousel-specs .carousel-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  position: relative;
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .carousel-block {
    min-width: 0;
    flex: 1;
  }
}
.single-listing-carousel-specs .carousel-block .swiper-nav {
  position: absolute;
  z-index: 9;
  bottom: var(--spacing-m);
  left: var(--spacing-m);
  display: flex;
  border: 1px solid currentColor;
  border-radius: var(--border-radius-xs);
  padding: 6px;
  gap: 6px;
  cursor: pointer;
  background-color: var(--theme-bg);
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .carousel-block .swiper-nav {
    left: unset;
    right: var(--spacing-m);
  }
}
body:not(.is-switching-theme) .single-listing-carousel-specs .carousel-block .swiper-nav {
  transition: color var(--td-s), background-color var(--td-s);
}
@media (hover: hover) {
  .single-listing-carousel-specs .carousel-block .swiper-nav:hover {
    background-color: var(--theme-btn-primary-outline-hover);
  }
}
.single-listing-carousel-specs .carousel-block .swiper-nav .swiper-button {
  cursor: pointer;
}
.single-listing-carousel-specs .carousel-block .swiper-nav .swiper-button svg {
  height: 27px;
  width: auto;
}
.single-listing-carousel-specs .carousel-swiper {
  overflow: hidden;
  position: relative;
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .carousel-swiper {
    height: 100%;
  }
}
.single-listing-carousel-specs .carousel-swiper .swiper-slide {
  box-sizing: border-box;
}
.single-listing-carousel-specs .carousel-swiper .slide-image {
  width: 100%;
  aspect-ratio: 1.24;
}
@media (min-width: 768px) {
  .single-listing-carousel-specs .carousel-swiper .slide-image {
    aspect-ratio: 1.77;
  }
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .carousel-swiper .slide-image {
    aspect-ratio: unset;
    height: 100%;
    width: 100%;
  }
}
.single-listing-carousel-specs .swiper-pagination {
  display: flex;
  justify-content: center;
  gap: var(--spacing-xs);
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .swiper-pagination {
    position: absolute;
    top: calc(100% + var(--spacing-s));
    left: 50%;
    translate: -50% 0;
  }
}
.single-listing-carousel-specs .swiper-pagination-bullet {
  width: 10px;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid var(--theme-text-accent);
  cursor: pointer;
}
@media (min-width: 768px) {
  .single-listing-carousel-specs .swiper-pagination-bullet {
    width: clamp(10px, 13 / 1400 * var(--container-width), 13px);
  }
}
.single-listing-carousel-specs .swiper-pagination-bullet-active {
  background-color: var(--theme-text-accent);
}
.single-listing-carousel-specs .specs-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .specs-block {
    flex: 0 0 auto;
    padding-right: var(--spacing-3xl);
    gap: var(--spacing-s);
  }
}
.single-listing-carousel-specs .unit-select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  padding: var(--spacing-s) var(--spacing-m);
  font-family: inherit;
  font-size: 15px;
  color: var(--theme-btn-primary-text);
  background-color: var(--theme-btn-primary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border: none;
  border-radius: var(--border-radius-xs);
  cursor: pointer;
  padding-inline: 0.9375em;
  padding-block: round(nearest, 0.5em, 1px);
  line-height: round(nearest, 1.2em, 1px);
  background-image: url("../../img/icons/chevron-down.svg");
  background-repeat: no-repeat;
  background-position: right var(--spacing-s) center;
  background-size: round(nearest, 1.5em, 1px);
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .unit-select {
    font-size: 12px;
  }
}
@supports ((-webkit-appearance: base-select) or (-moz-appearance: base-select) or (appearance: base-select)) {
  .single-listing-carousel-specs .unit-select,
  .single-listing-carousel-specs ::picker(select) {
    -webkit-appearance: base-select;
       -moz-appearance: base-select;
            appearance: base-select;
  }
  .single-listing-carousel-specs .unit-select::picker-icon {
    display: none;
  }
  .single-listing-carousel-specs .unit-select option {
    padding-inline: 0.9375em;
    cursor: auto;
  }
  .single-listing-carousel-specs .unit-select option:checked {
    background-color: color-mix(in srgb, var(--theme-btn-primary) 20%, transparent);
  }
  .single-listing-carousel-specs .unit-select option::checkmark {
    display: none;
  }
  .single-listing-carousel-specs .unit-select option:hover {
    background-color: color-mix(in srgb, var(--theme-btn-primary) 20%, transparent);
  }
}
.single-listing-carousel-specs .spec-items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -moz-column-gap: var(--spacing-s);
       column-gap: var(--spacing-s);
  row-gap: var(--spacing-m);
}
@media (min-width: 768px) {
  .single-listing-carousel-specs .spec-items {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .spec-items {
    --cols: 3;
    --col-width: 80px;
    --col-gap: var(--spacing-s);
    display: flex;
    flex-wrap: wrap;
    -moz-column-gap: var(--col-gap);
         column-gap: var(--col-gap);
    width: calc(var(--col-width) * var(--cols) + var(--col-gap) * (var(--cols) - 1));
    flex: 1;
  }
}
@media (min-width: 1600px) {
  .single-listing-carousel-specs .spec-items {
    --cols: 2;
  }
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .spec-item-wrapper {
    display: flex;
    align-items: center;
  }
}
.single-listing-carousel-specs .spec-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-s);
  text-align: center;
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .spec-item {
    width: 80px;
    gap: var(--spacing-xs);
  }
}
.single-listing-carousel-specs .spec-icon {
  width: 60px;
  height: 60px;
}
.single-listing-carousel-specs .spec-icon[data-lottie="spec-icons/epc"] svg {
  scale: 2;
  translate: 26% 0;
  pointer-events: none;
}
.single-listing-carousel-specs .spec-label {
  font-size: 15px;
  font-weight: 700;
}
@media (min-width: 992px) {
  .single-listing-carousel-specs .spec-label {
    font-size: 11px;
  }
}

.listing-map-travel {
  margin-block: var(--spacing-3xl);
}
@media (min-width: 992px) {
  .listing-map-travel {
    margin-block: var(--spacing-4xl);
  }
}
.listing-map-travel .listing-map-travel-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}
@media (min-width: 768px) {
  .listing-map-travel .listing-map-travel-inner {
    gap: var(--spacing-3xl);
  }
}
.listing-map-travel .map-content-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}
@media (min-width: 992px) {
  .listing-map-travel .map-content-block {
    flex-direction: row;
    gap: var(--spacing-3xl);
  }
}
.listing-map-travel .content-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-m);
}
@media (min-width: 992px) {
  .listing-map-travel .content-block {
    width: clamp(300px, 400 / 1400 * var(--container-width), 400px);
    justify-content: space-between;
    gap: var(--spacing-2xl);
  }
}
@media (min-width: 992px) {
  .listing-map-travel .content-block .content-block-heading {
    font-size: var(--text-size-3xl);
  }
}
.listing-map-travel .content-block .styled-text-part {
  display: inline;
}
.listing-map-travel .content-block .styled-text-part--accent {
  white-space: nowrap;
}
.listing-map-travel .map-occupiers-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
@media (min-width: 992px) {
  .listing-map-travel .map-occupiers-block {
    position: relative;
    flex: 1;
  }
}
.listing-map-travel .map-occupiers-block:has(.block-filter[data-name=map].active) .map-block {
  opacity: 1;
  pointer-events: all;
}
.listing-map-travel .map-occupiers-block:has(.block-filter[data-name=occupiers].active) .occupiers-block {
  opacity: 1;
  pointer-events: all;
}
.listing-map-travel .block-filters {
  display: flex;
  gap: var(--spacing-xs);
}
@media (min-width: 992px) {
  .listing-map-travel .block-filters {
    position: absolute;
    left: 15px;
    top: 15px;
    z-index: 2;
  }
}
.listing-map-travel .block-filter {
  font-size: 11px;
  min-width: 150px;
}
@media (min-width: 992px) {
  .listing-map-travel .block-filter {
    min-width: 120px;
  }
}
.listing-map-travel .map-occupiers-container {
  position: relative;
  width: 100%;
  aspect-ratio: 1.77;
}
@media (min-width: 992px) {
  .listing-map-travel .map-occupiers-container {
    flex: 1;
  }
}
.listing-map-travel .map-block,
.listing-map-travel .occupiers-block {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
}
.listing-map-travel .map-wrapper {
  width: 100%;
  height: 100%;
}
.listing-map-travel .map-wrapper .map {
  width: 100%;
  height: 100%;
}
.listing-map-travel .map-under {
  font-size: 12px;
  font-weight: 700;
}
@media (min-width: 768px) {
  .listing-map-travel .map-under {
    font-size: clamp(12px, 16 / 1400 * var(--container-width), 16px);
  }
}
.listing-map-travel .map-under a {
  color: inherit;
}
.listing-map-travel .marker svg {
  width: 49px;
}
@media (min-width: 768px) {
  .listing-map-travel .marker svg {
    width: clamp(50px, 126 / 1400 * var(--container-width), 126px);
  }
}
.listing-map-travel .occupiers-block {
  --dot-bg: var(--theme-bg);
  --dot-color: color-mix(in srgb, var(--theme-text-main) 34%, transparent);
  --dot-size: 1px;
  --dot-space: 22px;
  background: linear-gradient(90deg, var(--dot-bg) calc(var(--dot-space) - var(--dot-size)), transparent 1%) center/var(--dot-space) var(--dot-space), linear-gradient(var(--dot-bg) calc(var(--dot-space) - var(--dot-size)), transparent 1%) center/var(--dot-space) var(--dot-space), var(--dot-color);
}
.listing-map-travel .occupier-marquees {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
  height: 100%;
  width: 100%;
  justify-content: center;
}
@media (min-width: 768px) {
  .listing-map-travel .occupier-marquees {
    gap: 40px;
  }
}
.listing-map-travel .marquee {
  --gap: var(--spacing-2xl);
  --duration: 25s;
  --scroll-start: 0;
  --scroll-end: calc(-100% - var(--gap));
  display: flex;
  overflow: hidden;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  gap: var(--gap);
}
@media (min-width: 768px) {
  .listing-map-travel .marquee {
    --gap: clamp(80px, calc((100 / 1400) * var(--container-width)), 100px);
  }
}
.listing-map-travel .marquee--reverse .marquee__group {
  animation-direction: reverse;
}
@keyframes scroll-x {
  from {
    transform: translateX(var(--scroll-start));
  }
  to {
    transform: translateX(var(--scroll-end));
  }
}
.listing-map-travel .marquee__group {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: var(--gap);
  min-width: 100%;
  animation: scroll-x var(--duration) linear infinite;
}
.listing-map-travel .logo-wrapper {
  width: 75px;
  height: 30px;
  display: flex;
  align-items: center;
}
@media (min-width: 768px) {
  .listing-map-travel .logo-wrapper {
    width: clamp(75px, 140 / 1400 * var(--container-width), 140px);
    height: clamp(30px, 60 / 1400 * var(--container-width), 60px);
  }
}
.listing-map-travel .logo-wrapper svg,
.listing-map-travel .logo-wrapper img {
  width: 100%;
  max-height: 100%;
  opacity: 0.8;
}
.listing-map-travel .logo-wrapper svg path,
.listing-map-travel .logo-wrapper img path {
  fill: var(--theme-text-main);
}
.listing-map-travel .travel-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}
@media (min-width: 768px) {
  .listing-map-travel .travel-block {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--spacing-3xl);
  }
}
@media (min-width: 1300px) {
  .listing-map-travel .travel-block {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: var(--spacing-xl);
  }
}
@media (min-width: 768px) {
  .listing-map-travel .travel-heading {
    font-size: var(--text-size-l);
  }
}
.listing-map-travel .travel-population-reach {
  display: grid;
  row-gap: var(--spacing-xl);
}
@media (min-width: 768px) {
  .listing-map-travel .travel-population-reach {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-l);
    align-items: end;
    width: 100%;
  }
}
@media (min-width: 1300px) {
  .listing-map-travel .travel-population-reach {
    grid-area: auto/span 3;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, 1fr);
    grid-auto-flow: column;
    gap: 0;
    border-right: 1px solid var(--theme-borders);
  }
}
@media (min-width: 1300px) {
  .listing-map-travel .travel-population-reach .travel-heading {
    place-self: end start;
    padding-right: var(--spacing-l);
    padding-bottom: var(--spacing-m);
  }
}
.listing-map-travel .population-reach-boxes {
  display: grid;
  row-gap: var(--spacing-l);
}
@media (min-width: 768px) {
  .listing-map-travel .population-reach-boxes {
    display: contents;
  }
}
.listing-map-travel .population-reach-box {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
@media (min-width: 1300px) {
  .listing-map-travel .population-reach-box {
    padding-block: var(--spacing-m);
  }
  .listing-map-travel .population-reach-box:nth-of-type(1), .listing-map-travel .population-reach-box:nth-of-type(3) {
    border-top: 1px solid var(--theme-borders);
  }
}
.listing-map-travel .population-reach-box .box-heading {
  color: var(--theme-text-accent);
}
.listing-map-travel .population-reach-box .box-value {
  font-size: var(--text-size-4xl);
}
@media (min-width: 768px) {
  .listing-map-travel .population-reach-box .box-value {
    font-size: var(--text-size-2xl);
  }
}
.listing-map-travel .travel-time {
  display: grid;
  row-gap: var(--spacing-l);
}
@media (min-width: 768px) {
  .listing-map-travel .travel-time {
    flex: 1;
  }
}
@media (min-width: 1300px) {
  .listing-map-travel .travel-time {
    grid-area: auto/span 2;
    row-gap: var(--spacing-m);
  }
}
.listing-map-travel .travel-time--road {
  --cols: 3;
}
.listing-map-travel .travel-time--rail {
  --cols: 2;
}
.listing-map-travel .travel-table {
  display: grid;
  color: var(--theme-text-accent);
  grid-template-columns: repeat(var(--cols), 1fr);
  -moz-column-gap: var(--spacing-m);
       column-gap: var(--spacing-m);
}
.listing-map-travel .travel-table .table-row {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
  padding-block: var(--spacing-s);
}
.listing-map-travel .travel-table .table-row:not(:first-of-type) {
  border-top: 1px solid currentColor;
}
.listing-map-travel .travel-table .table-row > div {
  display: flex;
  gap: var(--spacing-s);
  align-items: center;
}

.listing-sitemap {
  margin-block: var(--spacing-3xl);
}
@media (min-width: 992px) {
  .listing-sitemap {
    margin-block: var(--spacing-4xl);
  }
}
.listing-sitemap .listing-sitemap-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}
@media (min-width: 992px) {
  .listing-sitemap .listing-sitemap-inner {
    flex-direction: row;
    gap: var(--spacing-3xl);
  }
}
.listing-sitemap .sitemap-block {
  width: 100%;
}
@media (min-width: 992px) {
  .listing-sitemap .sitemap-block {
    width: auto;
    flex: 1;
  }
}
.listing-sitemap .sitemap-block img {
  width: 100%;
}
.listing-sitemap .content-block {
  display: flex;
  flex-direction: column;
  gap: 30px;
  max-width: 310px;
}
@media (min-width: 768px) {
  .listing-sitemap .content-block {
    max-width: unset;
    align-items: flex-start;
  }
}
@media (min-width: 992px) {
  .listing-sitemap .content-block {
    flex: 0 0 auto;
    justify-content: space-between;
  }
}
.listing-sitemap .content-block-top {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
@media (min-width: 992px) {
  .listing-sitemap .content-block-heading {
    font-size: var(--text-size-3xl);
  }
}
.listing-sitemap .table-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-m);
}
.listing-sitemap .units-table {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.listing-sitemap .table-row {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
  padding-block: var(--spacing-s);
  color: var(--theme-text-accent);
}
.listing-sitemap .table-row-heading {
  font-weight: 700;
  border-bottom: 1px solid var(--theme-text-accent);
  color: var(--theme-text-main);
}
.listing-sitemap .content-buttons {
  display: flex;
  gap: var(--spacing-s);
}
.listing-sitemap .content-buttons .button {
  font-size: 11px;
  flex: 1 1 150px;
}
@media (min-width: 768px) {
  .listing-sitemap .content-buttons .button {
    flex: unset;
    min-width: clamp(120px, 150 / 1400 * var(--container-width), 150px);
  }
}

.banner-text-section {
  margin-top: var(--spacing-3xl);
  margin-bottom: var(--spacing-4xl);
}
@media (min-width: 768px) {
  .banner-text-section {
    margin-bottom: var(--spacing-3xl);
  }
}
.banner-text-section .banner-text-section-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
.banner-text-section .banner-heading {
  color: var(--theme-text-accent);
}
.banner-text-section .banner-text {
  font-weight: 700;
  max-width: 255px;
}
@media (min-width: 768px) {
  .banner-text-section .banner-text {
    max-width: 25em;
  }
}

#article-listings {
  margin-top: var(--spacing-2xl);
  margin-bottom: var(--spacing-xl);
}
#article-listings .article-listings-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 50px;
}
#article-listings .listings {
  display: grid;
  grid-template-columns: 1fr var(--container-width) 1fr;
  row-gap: 50px;
  width: 100%;
  position: relative;
}
#article-listings .grid-lines {
  position: absolute;
  grid-row: 1;
  grid-column: 2/span 1;
  width: 100%;
  height: calc(100% + var(--gutter) * 2);
  top: 50%;
  translate: 0 -50%;
  border-left: 1px solid color-mix(in srgb, var(--theme-borders) 20%, transparent);
  border-right: 1px solid color-mix(in srgb, var(--theme-borders) 20%, transparent);
}
#article-listings .article-listing {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
  padding-bottom: 30px;
  border-bottom: 1px solid color-mix(in srgb, var(--theme-borders) 20%, transparent);
  border-top: 1px solid color-mix(in srgb, var(--theme-borders) 20%, transparent);
  position: relative;
}
#article-listings .article-listing-inner {
  grid-column: 2/span 1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
#article-listings .listing-image-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
#article-listings .listing-image {
  width: 100%;
  aspect-ratio: 4/3;
}
#article-listings .listing-date {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
  font-weight: 700;
}
#article-listings .listing-content-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  align-items: flex-start;
}

.people-grid-section {
  margin-block: var(--spacing-3xl);
}
.people-grid-section .people-grid {
  --gap: 50px;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  border: 1px solid var(--theme-borders);
  padding: var(--gap);
  overflow: hidden;
  row-gap: var(--gap);
}
@media (min-width: 768px) {
  .people-grid-section .people-grid {
    grid-template-columns: repeat(2, 1fr);
    -moz-column-gap: calc(var(--gap) * 2);
         column-gap: calc(var(--gap) * 2);
  }
}
@media (min-width: 992px) {
  .people-grid-section .people-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.people-grid-section .divider-single {
  display: none;
}
@media (max-width: 767px) {
  .people-grid-section .divider-single:not(:last-of-type) {
    display: block;
    height: 1px;
    width: 100%;
    background-color: var(--theme-borders);
  }
}
.people-grid-section .divider-2-col {
  display: none;
}
@media (min-width: 767px) and (max-width: 991px) {
  .people-grid-section .divider-2-col {
    display: block;
    width: 100%;
    height: 1px;
    grid-column: 1/-1;
    background-color: var(--theme-borders);
  }
}
.people-grid-section .divider-3-col {
  display: none;
}
@media (min-width: 992px) {
  .people-grid-section .divider-3-col {
    display: block;
    width: 100%;
    height: 1px;
    grid-column: 1/-1;
    background-color: var(--theme-borders);
  }
}
.people-grid-section .person-card {
  position: relative;
}
@media (min-width: 767px) and (max-width: 991px) {
  .people-grid-section .person-card:nth-of-type(2n)::before {
    content: "";
    height: 100%;
    width: 1px;
    background-color: var(--theme-borders);
    position: absolute;
    left: calc(-1 * var(--gap));
  }
}
@media (min-width: 992px) {
  .people-grid-section .person-card:not(:nth-of-type(3n + 1))::before {
    content: "";
    height: 100%;
    width: 1px;
    background-color: var(--theme-borders);
    position: absolute;
    left: calc(-1 * var(--gap));
  }
}
.people-grid-section .person-card-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-m);
}
@media (min-width: 768px) {
  .people-grid-section .person-card-inner {
    padding-block: 0;
  }
}
.people-grid-section .person-image {
  width: 200px;
  aspect-ratio: 0.8;
}
@media (min-width: 768px) {
  .people-grid-section .person-image {
    width: clamp(180px, 200 / 1400 * var(--container-width), 200px);
  }
}
.people-grid-section .person-details {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
.people-grid-section .person-details-top {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.people-grid-section .person-details-bottom {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.people-grid-section .person-details a {
  color: var(--theme-text-accent);
}
.people-grid-section .person-name {
  font-size: var(--text-size-l);
}

.contact-form-section {
  margin-block: var(--spacing-3xl);
  scroll-margin-top: calc(var(--header-height) + var(--spacing-3xl));
}
@media (min-width: 768px) {
  .contact-form-section {
    margin-top: var(--spacing-4xl);
    scroll-margin-top: calc(var(--header-height) + var(--spacing-4xl));
  }
}
.contact-form-section .contact-form-section-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
@media (min-width: 992px) {
  .contact-form-section .contact-form-section-inner {
    flex-direction: row;
    justify-content: space-between;
  }
}
@media (min-width: 992px) {
  .contact-form-section .content-block {
    flex: 0 0 clamp(250px, 405 / 1400 * var(--container-width), 405px);
  }
}
@media (min-width: 768px) {
  .contact-form-section .content-heading {
    font-size: var(--text-size-3xl);
  }
}
.contact-form-section .form-block {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}
@media (min-width: 992px) {
  .contact-form-section .form-block {
    width: clamp(400px, 800 / 1400 * var(--container-width), 800px);
    gap: clamp(40px, 50 / 1400 * var(--container-width), 50px);
  }
}

body:not(.single-listing) .nf-row:has(input[type=radio]) {
  display: none !important;
}

.contact-form .nf-form-fields-required {
  display: none !important;
}
.contact-form .field-wrap:not(:has(input[type=checkbox])) .nf-field-label {
  display: none !important;
}
.contact-form .nf-before-field {
  display: none !important;
}
.contact-form .nf-cell {
  padding: 0 !important;
  width: 100% !important;
  float: none !important;
}
@media (min-width: 768px) {
  .contact-form .nf-cell {
    width: auto !important;
    flex: 1;
  }
}
.contact-form .nf-field-container {
  margin: 0 !important;
}
.contact-form .nf-after-field {
  display: none !important;
}
.contact-form .nf-after-form-content {
  display: none;
}
.contact-form nf-rows-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
.contact-form nf-rows-wrap nf-cells {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
@media (min-width: 768px) {
  .contact-form nf-rows-wrap nf-cells {
    flex-direction: row;
  }
}
@media (min-width: 768px) {
  .contact-form nf-rows-wrap nf-cells:has(input[type=checkbox]) {
    gap: var(--spacing-xl);
    margin-top: var(--spacing-m) !important;
  }
  .contact-form nf-rows-wrap nf-cells:has(input[type=checkbox]) .nf-cell:nth-of-type(2) {
    flex: 0 0 auto !important;
  }
}
.contact-form input[type=text],
.contact-form input[type=email],
.contact-form input[type=tel],
.contact-form textarea {
  border: none !important;
  border-bottom: 1px solid var(--theme-borders) !important;
  border-radius: 0 !important;
  background-color: transparent !important;
  color: var(--theme-form-filled-text) !important;
  padding-block: var(--spacing-xs) !important;
  padding-inline: var(--spacing-s) !important;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
}
.contact-form input[type=text]::-moz-placeholder, .contact-form input[type=email]::-moz-placeholder, .contact-form input[type=tel]::-moz-placeholder, .contact-form textarea::-moz-placeholder {
  opacity: 0.5 !important;
  color: inherit !important;
}
.contact-form input[type=text]::placeholder,
.contact-form input[type=email]::placeholder,
.contact-form input[type=tel]::placeholder,
.contact-form textarea::placeholder {
  opacity: 0.5 !important;
  color: inherit !important;
}
.contact-form input[type=text][aria-invalid=true],
.contact-form input[type=email][aria-invalid=true],
.contact-form input[type=tel][aria-invalid=true],
.contact-form textarea[aria-invalid=true] {
  border-color: var(--theme-form-error) !important;
}
.contact-form textarea {
  resize: none;
  height: 120px !important;
}
.contact-form .listradio-wrap {
  margin-bottom: -5px;
}
.contact-form .listradio-wrap ul {
  display: flex;
  gap: var(--spacing-xs);
}
@media (min-width: 768px) {
  .contact-form .listradio-wrap ul {
    gap: var(--spacing-s);
  }
}
.contact-form .listradio-wrap li {
  flex: 1;
  margin: 0 !important;
}
.contact-form .listradio-wrap li input {
  display: none;
}
.contact-form .listradio-wrap label {
  display: flex !important;
  margin: 0 !important;
}
.contact-form .checkbox-container .nf-field-label {
  padding-left: var(--spacing-xs);
}
.contact-form .checkbox-container label {
  font-weight: 400;
  color: var(--theme-form-filled-text);
  opacity: 0.5;
  font-size: var(--text-size-s);
}
.contact-form .checkbox-container input {
  accent-color: var(--theme-text-accent);
}
@media (min-width: 768px) {
  .contact-form .checkbox-container input {
    width: 16px !important;
    height: 16px !important;
  }
}
.contact-form .checkbox-container .ninja-forms-req-symbol {
  color: var(--theme-form-error);
}
.contact-form button[type=submit] {
  margin-top: var(--spacing-s);
}
@media (min-width: 768px) {
  .contact-form button[type=submit] {
    margin: 0 !important;
  }
}

.agents-block .agents {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xl);
}
@media (min-width: 768px) {
  .agents-block .agents {
    flex-direction: row;
  }
}
.agents-block .agent {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
@media (min-width: 768px) {
  .agents-block .agent {
    flex: 1;
  }
}
.agents-block .logo svg,
.agents-block .logo img {
  max-width: 180px;
  max-height: 50px;
}
.agents-block .logo svg path,
.agents-block .logo img path {
  fill: currentColor;
}
.agents-block .people {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
.agents-block .person {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.agents-block .person .name {
  color: var(--theme-text-accent);
}
.agents-block .person-details {
  display: flex;
  flex-direction: column;
  align-items: start;
}
.agents-block .person-details a {
  color: inherit;
}

.argo-banner-section {
  padding-block: var(--spacing-3xl);
  position: relative;
  overflow: hidden;
}
@media (min-width: 768px) {
  .argo-banner-section {
    padding-block: clamp(100px, 200 / 1400 * var(--container-width), 200px);
  }
}
.argo-banner-section .banner-bg-image {
  position: absolute;
  overflow: visible;
}
.argo-banner-section .banner-bg-image:nth-of-type(1) {
  top: -8%;
  left: -15%;
  width: 105%;
  aspect-ratio: 405/435;
  z-index: 1;
}
@media (min-width: 768px) {
  .argo-banner-section .banner-bg-image:nth-of-type(1) {
    top: 10%;
    left: 0;
    width: 26%;
  }
}
.argo-banner-section .banner-bg-image:nth-of-type(2) {
  bottom: -5%;
  left: 70%;
  width: 100%;
  aspect-ratio: 390/370;
  z-index: 2;
}
@media (min-width: 768px) {
  .argo-banner-section .banner-bg-image:nth-of-type(2) {
    left: 23%;
    bottom: 0;
    top: 40%;
    width: 26%;
  }
}
.argo-banner-section .banner-bg-image:nth-of-type(3) {
  display: none;
}
@media (min-width: 768px) {
  .argo-banner-section .banner-bg-image:nth-of-type(3) {
    display: block;
    left: 60%;
    top: 15%;
    width: 40%;
    aspect-ratio: 600/450;
    z-index: 3;
  }
}
.argo-banner-section .banner-bg-image:nth-of-type(4) {
  display: none;
}
@media (min-width: 768px) {
  .argo-banner-section .banner-bg-image:nth-of-type(4) {
    display: block;
    right: -5%;
    top: 0%;
    width: 18%;
    aspect-ratio: 270/360;
    z-index: 4;
  }
}
.argo-banner-section .container {
  position: relative;
  z-index: 9;
}
.argo-banner-section .argo-banner-box {
  background-color: var(--theme-bg);
  color: var(--theme-text-main);
  padding-block: 50px;
  padding-inline: 35px;
  display: flex;
  flex-direction: column;
  gap: 40px;
  transition: --theme-bg var(--td-theme), --theme-text-main var(--td-theme), --theme-text-disabled var(--td-theme), --theme-text-accent var(--td-theme), --theme-text-accent-small var(--td-theme), --theme-borders var(--td-theme), --theme-btn-primary var(--td-theme), --theme-btn-primary-hover var(--td-theme), --theme-btn-primary-outline var(--td-theme), --theme-btn-primary-outline-hover var(--td-theme), --theme-btn-primary-text var(--td-theme), --theme-btn-primary-text-hover var(--td-theme), --theme-form-error var(--td-theme), --theme-form-filled-text var(--td-theme), --theme-image-overlay-overlay-1 var(--td-theme), --theme-image-overlay-lighten-2 var(--td-theme), --theme-image-overlay-hard-light-3 var(--td-theme);
}
@media (min-width: 768px) {
  .argo-banner-section .argo-banner-box {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding-inline: clamp(35px, 50 / 1400 * var(--container-width), 50px);
    padding-block: clamp(50px, 60 / 1400 * var(--container-width), 60px);
    max-width: clamp(700px, 1200 / 1400 * var(--container-width), 1200px);
    margin-inline: auto;
  }
}
.argo-banner-section .argo-box-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
.argo-banner-section .content-top {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
}
@media (min-width: 768px) {
  .argo-banner-section .content-heading-large {
    font-size: var(--text-size-3xl);
  }
}
.argo-banner-section .content-heading-medium {
  color: var(--theme-text-accent);
}
@media (min-width: 768px) {
  .argo-banner-section .content-heading-medium {
    font-size: var(--text-size-xl);
  }
}
.argo-banner-section .argo-box-buttons {
  display: inline-flex;
  flex-direction: column;
  gap: var(--spacing-s);
  width: -moz-fit-content;
  width: fit-content;
}

.banner-home-section {
  position: relative;
  margin-bottom: var(--spacing-3xl);
  overflow-x: clip;
  height: calc(100svh - var(--header-height));
}
@media (min-width: 768px) {
  .banner-home-section {
    margin: 0;
  }
}
.banner-home-section .home-banner-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  container-type: size;
}
.banner-home-section .home-banner-bg .banner-bg-image {
  position: absolute;
  will-change: translate;
  overflow: visible;
}
.banner-home-section .home-banner-bg .banner-bg-image .parallax-mover {
  position: relative;
  width: 100%;
  height: 100%;
  will-change: transform;
}
.banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(1) {
  left: 0;
  top: 0;
  translate: -35% -5%;
  width: 260px;
  aspect-ratio: 260/137;
  z-index: 1;
}
@media (min-width: 768px) {
  .banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(1) {
    left: -2vw;
    top: 2vw;
    translate: 0;
    width: 27%;
  }
}
.banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(2) {
  left: 0;
  top: 0;
  translate: 60% 40%;
  width: 180px;
  aspect-ratio: 200/190;
  z-index: 2;
}
@media (min-width: 768px) {
  .banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(2) {
    left: 20vw;
    top: 5vw;
    translate: 0;
    width: 27%;
  }
}
.banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(3) {
  right: 0;
  top: 55%;
  width: 180px;
  aspect-ratio: 180/130;
  z-index: 3;
}
@media (min-width: 768px) {
  .banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(3) {
    right: -5vw;
    top: 100%;
    translate: 0 -50%;
    width: 40%;
  }
}
.banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(4) {
  right: 0;
  top: 50%;
  translate: 30% 0;
  width: 82px;
  aspect-ratio: 82/110;
  z-index: 4;
}
@media (min-width: 768px) {
  .banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(4) {
    right: -10vw;
    top: 80%;
    translate: 0 -50%;
    width: 18%;
  }
}
.banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(5) {
  left: 0;
  bottom: 0;
  translate: -10% 0;
  width: 165px;
  aspect-ratio: 165/140;
  z-index: 5;
}
@media (min-width: 768px) {
  .banner-home-section .home-banner-bg .banner-bg-image:nth-of-type(5) {
    left: -2vw;
    translate: 0 100%;
    width: 26%;
    bottom: 0;
  }
}
.banner-home-section .banner-home-content {
  height: 100%;
  display: flex;
}
.banner-home-section .banner-home-content-inner {
  display: grid;
  place-content: center;
  height: 100%;
}
.banner-home-section .banner-home-top {
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
}
.banner-home-section .banner-heading {
  max-width: 20ch;
}
@media (min-width: 992px) {
  .banner-home-section .banner-heading {
    font-size: min(var(--text-size-5xl), 14vh);
    max-width: 18ch;
  }
}
.banner-home-section .banner-content-top {
  grid-area: 1/1/-1/-1;
  display: flex;
  align-items: center;
  height: 100%;
  text-align: center;
  justify-content: center;
}
.banner-home-section .scroll-dot {
  position: absolute;
  left: 50%;
  bottom: 50px;
  transform: translateX(-50%);
  width: 18px;
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: var(--theme-text-accent);
  animation: bob 1s infinite alternate;
}
@media (min-width: 768px) {
  .banner-home-section .scroll-dot {
    bottom: max(6vh, 50px);
    width: clamp(18px, 26 / 1400 * var(--container-width), 26px);
  }
}
.banner-home-section .banner-content-bottom {
  grid-area: 1/1/-1/-1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-xl);
  text-align: center;
  justify-content: center;
}
.banner-home-section .banner-content-bottom .bottom-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-l);
}
.banner-home-section .banner-subheading {
  visibility: hidden;
}
.banner-home-section .banner-subheading .line {
  visibility: hidden;
  translate: 0 10%;
}
.banner-home-section .banner-text {
  max-width: 250px;
  font-size: var(--text-size-l);
  visibility: hidden;
}
@media (min-width: 768px) {
  .banner-home-section .banner-text {
    max-width: unset;
  }
}
.banner-home-section .button {
  visibility: hidden;
}

@keyframes bob {
  from {
    translate: 0 -50%;
  }
  to {
    translate: 0 50%;
  }
}
body[data-theme=dark-green] .expandable-box {
  color: color-mix(in srgb, var(--dark-green) calc(var(--hover-progress) * 100%), currentColor);
  background-color: color-mix(in srgb, var(--theme-text-accent) calc(var(--hover-progress) * 100%), var(--theme-bg));
}
body[data-theme=pink] .expandable-box {
  background-color: color-mix(in srgb, var(--theme-text-accent) calc(var(--hover-progress) * 100%), var(--theme-bg));
}
body[data-theme=pink] .box-number {
  color: color-mix(in srgb, var(--pink) calc(var(--hover-progress) * 100%), currentColor);
}

.expandable-boxes {
  padding-block: var(--spacing-3xl);
  position: relative;
  overflow-x: clip;
}
@media (min-width: 768px) {
  .expandable-boxes {
    margin-top: var(--spacing-4xl);
  }
}
.expandable-boxes .expandable-boxes-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.expandable-boxes .expandable-boxes-bg .expandable-boxes-bg-image {
  position: absolute;
  will-change: translate;
  overflow: visible;
}
.expandable-boxes .expandable-boxes-bg .expandable-boxes-bg-image:nth-of-type(1) {
  right: 0;
  top: 0;
  translate: 50% 0;
  width: 460px;
  aspect-ratio: 460/285;
  z-index: 1;
}
@media (min-width: 768px) {
  .expandable-boxes .expandable-boxes-bg .expandable-boxes-bg-image:nth-of-type(1) {
    translate: 3% 10%;
    width: 40%;
    aspect-ratio: 600/450;
  }
}
.expandable-boxes .expandable-boxes-bg .expandable-boxes-bg-image:nth-of-type(2) {
  left: 0;
  bottom: 0;
  translate: -10% 5%;
  width: 350px;
  aspect-ratio: 350/336;
  z-index: 2;
}
@media (min-width: 768px) {
  .expandable-boxes .expandable-boxes-bg .expandable-boxes-bg-image:nth-of-type(2) {
    translate: -1% 10%;
    width: 38%;
  }
}
.expandable-boxes .expandable-boxes-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-3xl);
}
.expandable-boxes .boxes-intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--spacing-l);
}
.expandable-boxes .intro-text {
  max-width: 17em;
}
@media (min-width: 768px) {
  .expandable-boxes .intro-text {
    max-width: 32em;
  }
}
.expandable-boxes .boxes-boxes {
  --inactive-flex-basis: clamp(150px, calc((200 / 1400) * var(--container-width)), 200px);
  --active-flex-basis: clamp(220px, calc((315 / 1400) * var(--container-width)), 315px);
  --gap: var(--spacing-l);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
.expandable-boxes .expandable-box {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  row-gap: var(--spacing-xl);
  border: 1px solid var(--theme-text-accent);
  padding: var(--spacing-xl);
  align-items: center;
  position: relative;
  overflow: hidden;
}
@media (min-width: 992px) {
  .expandable-boxes .expandable-box {
    gap: var(--spacing-xl);
    justify-content: flex-start;
    padding-block: var(--spacing-l);
    align-items: flex-start;
    flex: 0 0 var(--inactive-flex-basis);
    transition: --hover-progress var(--td-m), flex-grow var(--td-m);
  }
}
@media (min-width: 992px) {
  .expandable-boxes .expandable-box.active {
    --hover-progress: 1;
    flex-grow: 1;
  }
  .expandable-boxes .expandable-box.active .content-bottom {
    grid-template-rows: 1fr;
    opacity: 1;
  }
  .expandable-boxes .expandable-box.active .box-icon {
    scale: 1.3;
  }
}
.expandable-boxes .expandable-box .expandable-box-inner {
  display: contents;
}
@media (min-width: 992px) {
  .expandable-boxes .expandable-box .expandable-box-inner {
    display: flex;
    gap: var(--spacing-xl);
    width: 100%;
  }
}
.expandable-boxes .box-number {
  line-height: 0.8;
  font-size: 100px;
}
@media (min-width: 992px) {
  .expandable-boxes .box-number {
    order: 1;
    line-height: 1;
    font-size: clamp(70px, 100 / 1400 * var(--container-width), 100px);
  }
}
.expandable-boxes .box-icon-wrapper {
  width: 85px;
  aspect-ratio: 1;
  position: absolute;
  top: var(--spacing-xl);
  right: var(--spacing-xl);
  transition: scale var(--td-s), translate var(--td-s);
}
@media (min-width: 992px) {
  .expandable-boxes .box-icon-wrapper {
    width: clamp(85px, 140 / 1400 * var(--container-width), 140px);
    bottom: 50%;
    translate: 0 50%;
    top: unset;
    right: clamp(20px, 80 / 1400 * var(--container-width), 80px);
  }
}
.expandable-boxes .box-icon {
  height: calc(100% * var(--scale));
  width: calc(100% * var(--scale));
  position: absolute;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
  transition: scale var(--td-m), translate var(--td-m);
}
.expandable-boxes .box-icon svg {
  height: 100%;
  width: auto;
}
.expandable-boxes .box-content {
  width: 100%;
  display: flex;
  flex-direction: column;
}
@media (min-width: 992px) {
  .expandable-boxes .box-content {
    order: 2;
    width: auto;
    flex: 0 0 clamp(450px, 620 / 1400 * var(--container-width), 620px);
  }
}
.expandable-boxes .box-content .content-top {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
  align-items: flex-start;
}
@media (min-width: 992px) {
  .expandable-boxes .box-content .content-top {
    gap: var(--spacing-s);
  }
}
@media (min-width: 992px) {
  .expandable-boxes .box-content .box-heading {
    font-size: var(--text-size-2xl);
  }
}
.expandable-boxes .box-content .content-bottom {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows var(--td-s), opacity var(--td-m);
}
@media (min-width: 992px) {
  .expandable-boxes .box-content .content-bottom {
    grid-template-rows: 0fr;
    opacity: 0;
  }
}
.expandable-boxes .box-content .content-bottom-inner {
  overflow: hidden;
  grid-row: 1/span 2;
}
.expandable-boxes .box-content .content-bottom-inner-inner {
  padding-top: var(--spacing-m);
  padding-bottom: var(--spacing-xl);
}
.expandable-boxes .box-pill {
  border-radius: 500px;
  border: 1px solid currentColor;
  padding-inline: 1.25em;
  padding-block: round(nearest, 0.3125em, 1px);
  line-height: round(nearest, 1.2em, 1px);
}
@media (min-width: 992px) {
  .expandable-boxes .box-pill {
    font-size: clamp(12px, 16 / 1400 * var(--container-width), 16px);
  }
}

[data-lottie] {
  --scale: 1;
}
[data-lottie][data-lottie=bricks] {
  --scale: 0.9;
  transform: translateX(10%);
}
[data-lottie][data-lottie=building] {
  --scale: 1;
}
[data-lottie][data-lottie=bulb] {
  --scale: 1.2;
}
[data-lottie][data-lottie=friends] {
  --scale: 1.5;
}
[data-lottie][data-lottie=handshake] {
  --scale: 1.5;
}
[data-lottie][data-lottie=mobile] {
  --scale: 0.9;
}
[data-lottie] svg .fill path,
[data-lottie] svg .hand path,
[data-lottie] svg .fill-bg path {
  fill: color-mix(in srgb, var(--theme-text-accent) calc(var(--hover-progress) * 100%), var(--theme-bg));
}
[data-lottie] svg .line path {
  stroke: var(--theme-text-main);
  fill: var(--theme-text-main);
}

.banner-general {
  min-height: calc(100svh - var(--header-height));
  display: flex;
  position: relative;
  overflow: hidden;
}
.banner-general .banner-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}
.banner-general .banner-bg .banner-bg-image {
  position: absolute;
  will-change: translate;
}
.banner-general .banner-bg .banner-bg-image:nth-of-type(1) {
  left: 0;
  top: 0;
  width: 154px;
  aspect-ratio: 154/100;
  z-index: 1;
}
@media (min-width: 768px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(1) {
    width: 26%;
  }
}
@media (min-width: 992px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(1) {
    top: 20%;
  }
}
.banner-general .banner-bg .banner-bg-image:nth-of-type(2) {
  left: 0;
  top: 0;
  translate: 80% 40%;
  width: 150px;
  aspect-ratio: 1;
  z-index: 2;
}
@media (min-width: 768px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(2) {
    width: 25%;
  }
}
@media (min-width: 992px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(2) {
    top: 20%;
  }
}
.banner-general .banner-bg .banner-bg-image:nth-of-type(3) {
  right: 0;
  bottom: 0;
  translate: -25% -10%;
  width: 230px;
  aspect-ratio: 230/170;
  z-index: 3;
}
@media (min-width: 768px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(3) {
    width: 40%;
  }
}
@media (min-width: 992px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(3) {
    bottom: unset;
    top: 0;
    translate: -10% 45%;
  }
}
.banner-general .banner-bg .banner-bg-image:nth-of-type(4) {
  right: 0;
  bottom: 0;
  translate: 0 -80%;
  width: 104px;
  aspect-ratio: 104/138;
  z-index: 4;
}
@media (min-width: 768px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(4) {
    width: 18%;
  }
}
@media (min-width: 992px) {
  .banner-general .banner-bg .banner-bg-image:nth-of-type(4) {
    bottom: unset;
    top: 0;
    translate: 55% -5%;
  }
}
.banner-general .banner-general-content {
  display: flex;
  align-items: center;
  text-align: center;
  padding-block: var(--spacing-4xl);
  width: 100%;
}
.banner-general .banner-general-content-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-2xl);
}
@media (min-width: 768px) {
  .banner-general .banner-general-content-inner {
    gap: var(--spacing-xl);
  }
}
.banner-general .content-top {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
  align-items: center;
}
.banner-general .banner-heading .styled-text-part {
  display: inline-block;
}
.banner-general .banner-heading .styled-text-part--accent {
  white-space: nowrap;
}
.banner-general .banner-text {
  font-size: var(--text-size-l);
  max-width: 18em;
}
@media (min-width: 768px) {
  .banner-general .banner-text {
    max-width: 32em;
  }
}
.banner-general .banner-buttons {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-s);
  align-items: center;
}
@media (min-width: 768px) {
  .banner-general .banner-buttons {
    flex-direction: row;
  }
}

#portfolio {
  scroll-margin-top: var(--header-height);
}

.portfolio-map-section {
  width: 100%;
  height: calc(100vh - var(--header-height));
  display: flex;
  flex-direction: column;
}
.portfolio-map-section .map-wrapper {
  flex: 1;
  position: relative;
}
.portfolio-map-section .portfolio-map {
  height: 100%;
  width: 100%;
}
.portfolio-map-section .custom-marker {
  aspect-ratio: 1;
  border-radius: 50%;
  z-index: 1;
}
.portfolio-map-section .custom-marker--available {
  background-color: var(--pink);
  width: 25px;
  z-index: 2;
}
@media (min-width: 768px) {
  .portfolio-map-section .custom-marker--available {
    width: clamp(25px, 40 / 1400 * var(--container-width), 40px);
  }
}
.portfolio-map-section .custom-marker--owned {
  background-color: var(--dark-green);
  width: 15px;
  z-index: 1;
}
@media (min-width: 768px) {
  .portfolio-map-section .custom-marker--owned {
    width: clamp(15px, 25 / 1400 * var(--container-width), 25px);
  }
}
.portfolio-map-section .map-key {
  display: flex;
  position: absolute;
  left: var(--spacing-l);
  bottom: var(--spacing-l);
  background-color: var(--cream);
  gap: var(--spacing-l);
  align-items: center;
  color: var(--dark-green);
  text-transform: uppercase;
  padding: var(--spacing-s);
  border-radius: var(--border-radius-xs);
}
.portfolio-map-section .map-key .key-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-s);
  font-size: 11px;
  letter-spacing: 0.1em;
  line-height: round(nearest, 1.2em, 1px);
}
.portfolio-map-section .map-key .key-item .dot {
  width: 17px;
}
.portfolio-map-section .map-key .key-item--available .dot {
  background-color: var(--pink);
}
.portfolio-map-section .map-key .key-item--owned .dot {
  background-color: var(--dark-green);
}
.portfolio-map-section .filter-buttons {
  display: flex;
  padding-block: var(--spacing-l);
  justify-content: center;
  gap: var(--spacing-xs);
  margin-inline: auto;
}
@media (min-width: 768px) {
  .portfolio-map-section .filter-buttons {
    gap: clamp(5px, 10 / 1400 * var(--container-width), 10px);
  }
}
.portfolio-map-section .filter-buttons .filter-button {
  min-width: 105px;
  font-size: 11px;
}
@media (min-width: 768px) {
  .portfolio-map-section .filter-buttons .filter-button {
    min-width: clamp(105px, 160 / 1400 * var(--container-width), 160px);
    font-size: clamp(11px, 13 / 1400 * var(--container-width), 13px);
  }
}

.portfolio-available {
  margin-block: var(--spacing-3xl);
}
@media (min-width: 992px) {
  .portfolio-available {
    margin-block: var(--spacing-4xl);
  }
}
.portfolio-available .portfolio-available-inner {
  width: 100%;
  max-width: var(--container-width);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
@media (min-width: 992px) {
  .portfolio-available .portfolio-available-inner {
    gap: var(--spacing-3xl);
  }
}
@media (min-width: 992px) {
  .portfolio-available .portfolio-available-heading {
    font-size: var(--text-size-4xl);
  }
}

.portfolio-available-listings-mobile .portfolio-available-listing {
  padding-block: var(--spacing-xl);
  display: flex;
  flex-direction: column;
}
.portfolio-available-listings-mobile .listing-image-wrapper-outer {
  height: 0;
  overflow: hidden;
  opacity: 0;
  will-change: height;
}
.portfolio-available-listings-mobile .listing-image-wrapper {
  padding-bottom: 35px;
}
.portfolio-available-listings-mobile .listing-image {
  width: 100%;
  aspect-ratio: 1.67;
}
.portfolio-available-listings-mobile .listing-content {
  display: flex;
  flex-direction: column;
}
.portfolio-available-listings-mobile .listing-heading {
  color: var(--theme-text-accent);
}
.portfolio-available-listings-mobile .listing-details-wrapper {
  height: 0;
  overflow: hidden;
  opacity: 0;
  will-change: height;
}
.portfolio-available-listings-mobile .listing-details {
  padding-top: var(--spacing-l);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
  align-items: flex-start;
}
.portfolio-available-listings-mobile .listing-details .button {
  min-width: 200px;
}
.portfolio-available-listings-mobile .listing-units {
  display: flex;
  flex-direction: column;
  width: 100%;
  font-size: var(--text-size-xl);
}
.portfolio-available-listings-mobile .listing-unit {
  display: flex;
  justify-content: space-between;
}
.portfolio-available-listings-mobile .listing-details-group {
  display: flex;
  justify-content: space-between;
  width: 100%;
  gap: var(--spacing-xl);
}
.portfolio-available-listings-mobile .details-group {
  font-size: var(--text-size-l);
}
.portfolio-available-listings-mobile .details-group:nth-of-type(1) {
  flex: 1;
  white-space: nowrap;
}
.portfolio-available-listings-mobile .details-group:nth-of-type(2) {
  flex: 0 1 auto;
}

.portfolio-available-listings-desktop {
  position: relative;
}
.portfolio-available-listings-desktop .portfolio-available-listing {
  --active-font-size: clamp(16px, calc((200 / 1400) * var(--container-width)), 200px);
  height: clamp(70px, 128 / 1400 * var(--container-width), 128px);
  display: flex;
  align-items: center;
  position: relative;
  z-index: 2;
}
.portfolio-available-listings-desktop .listing-main {
  opacity: 0.5;
}
.portfolio-available-listings-desktop .listing-content-wrapper-outer {
  height: 0;
  overflow: hidden;
}
.portfolio-available-listings-desktop .listing-content-wrapper {
  padding-top: clamp(20px, 40 / 1400 * var(--container-width), 40px);
  padding-bottom: 2px;
}
.portfolio-available-listings-desktop .listing-heading {
  font-size: var(--text-size-2xl);
  color: var(--theme-text-accent);
}
.portfolio-available-listings-desktop .listing-floating-block {
  position: absolute;
  right: 0;
  top: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(70px, 140 / 1400 * var(--container-width), 140px);
  width: clamp(70px, 600 / 1400 * var(--container-width), 600px);
}
.portfolio-available-listings-desktop .listing-image {
  width: 100%;
  aspect-ratio: 3/2;
}
.portfolio-available-listings-desktop .listing-details {
  font-size: var(--text-size-l);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
.portfolio-available-listings-desktop .listing-units {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: 100%;
}
.portfolio-available-listings-desktop .listing-unit {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
}

.portfolio-wider {
  margin-block: var(--spacing-3xl);
}
@media (min-width: 992px) {
  .portfolio-wider {
    margin-top: var(--spacing-4xl);
  }
}
.portfolio-wider .portfolio-wider-inner {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (min-width: 992px) {
  .portfolio-wider .portfolio-wider-inner {
    gap: var(--spacing-3xl);
  }
}
@media (min-width: 992px) {
  .portfolio-wider .portfolio-wider-heading {
    font-size: var(--text-size-4xl);
    padding-top: var(--spacing-xl);
    border-top: 1px solid var(--theme-text-main);
  }
}
.portfolio-wider .portfolio-wider-listings {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (min-width: 992px) {
  .portfolio-wider .portfolio-wider-listings {
    gap: var(--spacing-xl);
  }
}
.portfolio-wider .portfolio-wider-listing {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: 35px;
}
@media (min-width: 992px) {
  .portfolio-wider .portfolio-wider-listing {
    flex-direction: row;
    gap: var(--spacing-xl);
    align-items: center;
  }
}
.portfolio-wider .listing-image {
  width: 100%;
  aspect-ratio: 1.67;
}
@media (min-width: 992px) {
  .portfolio-wider .listing-image {
    width: clamp(200px, 450 / 1400 * var(--container-width), 450px);
  }
}
@media (min-width: 992px) {
  .portfolio-wider .divider {
    display: none;
  }
}
.portfolio-wider .listing-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-l);
}
@media (min-width: 992px) {
  .portfolio-wider .listing-content {
    flex: 1;
  }
}
.portfolio-wider .listing-heading {
  color: var(--theme-text-accent);
}
@media (min-width: 992px) {
  .portfolio-wider .listing-heading {
    font-size: var(--text-size-4xl);
  }
}
.portfolio-wider .listing-details {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
.portfolio-wider .listing-details-group {
  display: flex;
  justify-content: space-between;
  width: 100%;
  gap: var(--spacing-xl);
  max-width: 500px;
}
@media (min-width: 992px) {
  .portfolio-wider .listing-details-group {
    max-width: unset;
  }
}
.portfolio-wider .details-group {
  font-size: var(--text-size-l);
  flex: 1;
}
