@font-face {
  font-family: "icomoon";
  src: url("/build/assets/icomoon-D4A2oBJo.eot");
  src: url("/build/assets/icomoon-D4A2oBJo.eot?#iefix") format("embedded-opentype"), url("/build/assets/icomoon-CoNfPrlm.woff") format("woff"), url("/build/assets/icomoon-Bbz7L0CH.ttf") format("truetype"), url("/build/assets/icomoon-XdNYVfhG.svg#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
}
[class^=icon-], [class*=" icon-"], .buffering-circle {
  font-family: "icomoon";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-x::before {
  content: "\e937";
}

.icon-question-mark:before {
  content: "\e951";
}

.icon-info-mark:before {
  content: "\e917";
}

.icon-list-view-mark:before {
  content: "\e91f";
}

.icon-phone-solid:before {
  content: "\e926";
}

.icon-mail-mark:before {
  content: "\e914";
}

.icon-angle-up::before {
  content: "\e908";
}

.icon-angle-down::before {
  content: "\e902";
}

.icon-angle-left::before {
  content: "\e904";
}

.icon-play-solid::before {
  content: "\e928";
}

.icon-arrow-right::before {
  content: "\e93d";
}

.icon-arrow-left::before {
  content: "\e93c";
}

.icon-download::before {
  content: "\e93f";
}

.icon-euro::before {
  content: "\e941";
}

.icon-sheets::before {
  content: "\e948";
}

.icon-at-symbol::before {
  content: "\e93e";
}

.icon-location::before {
  content: "\e940";
}

.icon-user::before {
  content: "\e949";
}

.icon-user-outlines::before {
  content: "\e97c";
}

.icon-key::before {
  content: "\e98d";
}

.icon-minus::before {
  content: "\e922";
}

.icon-add::before {
  content: "\e92a";
}

.icon-image::before {
  content: "\e942";
}

.icon-play::before {
  content: "\e927";
}

.icon-cloud-download::before {
  content: "\e9c2";
}

.icon-flatfinder-logo::before {
  content: "\e947";
}

.icon-download-simple::before {
  content: "\e943";
}

.icon-video-simple::before {
  content: "\e944";
}

.icon-visualization-simple::before {
  content: "\e945";
}

.icon-vrtour-simple::before {
  content: "\e946";
}

.icon-edit::before {
  content: "\e967";
}

.icon-bin::before {
  content: "\e95b";
}

.icon-disk::before {
  content: "\e963";
}

.icon-cancel::before {
  content: "\e986";
}

.icon-up-and-down-arrow::before {
  content: "\e987";
}

.icon-arrow::before {
  content: "\e958";
}

.icon-close-x::before {
  content: "\e95f";
}

.icon-globe::before {
  content: "\e954";
}

.icon-building-units::before {
  content: "\e98b";
}

.icon-prospects::before {
  content: "\e976";
}

.icon-edit-project::before {
  content: "\e97f";
}

.icon-frontend::before {
  content: "\e96a";
}

.icon-logout::before {
  content: "\e977";
}

.icon-user::before {
  content: "\e971";
}

.icon-connected-projects::before {
  content: "\e98a";
}

.icon-home::before {
  content: "\e970";
}

.icon-home-filled::before {
  content: "\e972";
}

.icon-info-circle::before {
  content: "\e953";
}

.icon-two-people::before {
  content: "\e97a";
}

.icon-gender::before {
  content: "\e998";
}

.icon-hand-and-flat::before {
  content: "\e98c";
}

.icon-floor::before {
  content: "\e968";
}

.icon-square::before {
  content: "\e96e";
}

.icon-rooms::before {
  content: "\e98e";
}

.icon-money::before {
  content: "\e989";
}

.icon-signal::before {
  content: "\e962";
}

.icon-pc-screen::before {
  content: "\e966";
}

.icon-arrows-in-circle::before {
  content: "\e960";
}

.icon-eye::before {
  content: "\e973";
}

.icon-request-bubble::before {
  content: "\e956";
}

.icon-downwads-trend::before {
  content: "\e959";
}

.icon-upwards-trend::before {
  content: "\e95a";
}

.icon-handshake::before {
  content: "\e981";
}

.icon-entry-list::before {
  content: "\e981";
}

.icon-letter::before {
  content: "\e913";
}

.icon-groupe::before {
  content: "\e96f";
}

.icon-calender::before {
  content: "\e95c";
}

.icon-phone::before {
  content: "\e925";
}

.icon-plus::before {
  content: "\e93b";
}

.icon-clock::before {
  content: "\e95e";
}

.icon-star::before {
  content: "\e984";
}

.icon-fancy-doors::before {
  content: "\e969";
}

.icon-upload-cloud::before {
  content: "\e988";
}

.icon-docs::before {
  content: "\e964";
}

.icon-scale::before {
  content: "\e980";
}

.icon-refresh::before {
  content: "\e961";
}

.icon-total-saved::before {
  content: "\e975";
}

.icon-smartphone::before {
  content: "\e993";
}

.icon-dots::before {
  content: "\e96c";
}

.icon-lupe::before {
  content: "\e997";
}

.icon-checked::before {
  content: "\e995";
}

.icon-checkmark::before {
  content: "\e996";
}

/* montserrat-300 - latin */
@font-face {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 300;
  src: local(""), url("/build/assets/montserrat-v25-latin-300-BNkQWmgR.woff2") format("woff2"), url("/build/assets/montserrat-v25-latin-300-B8vfLIVM.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* montserrat-regular - latin */
@font-face {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 400;
  src: local(""), url("/build/assets/montserrat-v25-latin-regular-BTyQisEy.woff2") format("woff2"), url("/build/assets/montserrat-v25-latin-regular-DTzeWEth.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* montserrat-500 - latin */
@font-face {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 500;
  src: local(""), url("/build/assets/montserrat-v25-latin-500-DOzcbrzr.woff2") format("woff2"), url("/build/assets/montserrat-v25-latin-500-CyeSa8YS.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* montserrat-600 - latin */
@font-face {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 600;
  src: local(""), url("/build/assets/montserrat-v25-latin-600-Q_BPs6ba.woff2") format("woff2"), url("/build/assets/montserrat-v25-latin-600-CPZdhQyt.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* montserrat-700 - latin */
@font-face {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 700;
  src: local(""), url("/build/assets/montserrat-v25-latin-700-D9_YRkYw.woff2") format("woff2"), url("/build/assets/montserrat-v25-latin-700-wFEXaHGn.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
/* montserrat-900 - latin */
@font-face {
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 900;
  src: local(""), url("/build/assets/montserrat-v25-latin-900-Bw_EvlHV.woff2") format("woff2"), url("/build/assets/montserrat-v25-latin-900-B1KbxZd2.woff") format("woff"); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}
html {
  margin: 0;
  padding: 0;
  height: -webkit-fill-available;
}
html body {
  margin: 0;
  padding: 0;
  height: 100vh;
  width: 100vw;
  display: flex;
  flex-direction: column;
  font-family: "Montserrat", sans-serif;
  height: -webkit-fill-available;
}
html body * {
  font-family: inherit;
}
html body a:hover {
  color: white;
}
html body img {
  vertical-align: middle;
}
html body header {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 0 10px gray;
  z-index: 4;
  flex-wrap: wrap;
}
html body header .logo {
  flex: 1;
  margin: 10px;
}
html body header .logo img {
  max-width: 100%;
  max-height: 30px;
}
html body header .navigation {
  flex: 2;
  display: flex;
  justify-content: flex-end;
}
html body header .navigation .navigation-buttons {
  display: flex;
  height: 100%;
  transition: all 1s;
}
html body header .navigation .navigation-buttons .select-user-wrapper {
  display: none;
  width: auto;
  height: auto;
  position: absolute;
  flex-direction: column;
  background-color: white;
  border: 2px solid var(--primary);
  border-radius: 3px;
  padding: 5px 12px 12px 12px;
  box-shadow: rgba(0, 0, 0, 0.25) 10px 10px 10px;
  top: 50px;
  right: 60px;
  z-index: 5;
}
html body header .navigation .navigation-buttons .select-user-wrapper p {
  padding: 0;
  margin: 0 0 20px 0;
}
html body header .navigation .navigation-buttons .select-user-wrapper a {
  background: var(--primary);
  width: 100%;
  padding: 4px 10px;
  margin-top: 10px;
  color: white;
  border-radius: 3px;
}
html body header .navigation .navigation-buttons .select-user-wrapper a:hover {
  cursor: pointer;
  background: color-mix(in srgb, var(--primary) 80%, #000 10%);
  color: white;
}
html body header .navigation .navigation-buttons .select-user-wrapper.show {
  display: block;
}
html body header .navigation .navigation-buttons a {
  display: flex;
  text-decoration: none;
  color: gray;
  margin-right: 10px;
  background-color: transparent;
  border: none;
  cursor: pointer;
  align-self: center;
}
@media (min-width: 992px) {
  html body header .navigation .navigation-buttons a {
    margin-right: 30px;
  }
}
html body header .navigation .navigation-buttons a i {
  font-size: 32px;
  color: var(--primary);
  pointer-events: none;
}
html body header .navigation .navigation-buttons a span {
  display: none;
  color: gray;
  align-self: center;
  pointer-events: none;
}
@media (min-width: 992px) {
  html body header .navigation .navigation-buttons a span {
    display: inline;
  }
}
html body header .navigation .navigation-buttons a:hover {
  color: color-mix(in srgb, var(--primary) 80%, #000 10%);
}
html body header .navigation .navigation-buttons a:hover i {
  color: color-mix(in srgb, var(--primary) 80%, #000 10%);
}
html body header .navigation .navigation-buttons a:hover span {
  color: color-mix(in srgb, var(--primary) 80%, #000 10%);
}
html body header .navigation .navigation-buttons a.hide {
  display: none;
}
html body header .navigation .navigation-buttons a.hidden {
  opacity: 0;
  pointer-events: none;
}
html body header .navigation .navigation-buttons .open-select-user-wrapper {
  display: none;
}
html body header .navigation .navigation-buttons .open-select-user-wrapper i {
  font-size: 32px;
}
html body header .navigation .navigation-buttons.hidden {
  opacity: 0;
  pointer-events: none;
}
html body header .navigation .lang-select-wrapper {
  color: #000;
  display: flex;
  align-items: center;
  width: 84px;
  gap: 0 2px;
  margin-right: 10px;
}
html body header .navigation .lang-select-wrapper div {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 100%;
  color: gray;
}
html body header .navigation .lang-select-wrapper div.active {
  background-color: var(--primary);
  color: #fff;
}
html body header .navigation .lang-select-wrapper div:hover {
  background-color: color-mix(in srgb, var(--primary) 80%, #000 10%);
  color: #fff;
  cursor: pointer;
}
html body header .navigation-bar {
  display: none;
  line-height: 1.9em;
  font-weight: 500;
}
@media (min-width: 992px) {
  html body header .navigation-bar {
    display: flex;
    flex-basis: 100%;
    height: 30px;
  }
  html body header .navigation-bar > div:before {
    display: block;
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    background: rgba(255, 255, 255, 0.5333333333);
  }
  html body header .navigation-bar > div:nth-child(1) {
    z-index: 4;
  }
  html body header .navigation-bar > div:nth-child(2) {
    z-index: 3;
  }
  html body header .navigation-bar > div:nth-child(3) {
    z-index: 2;
  }
  html body header .navigation-bar div {
    display: flex;
    flex: 1;
    color: white;
    position: relative;
  }
  html body header .navigation-bar div p {
    margin: 0;
    padding: 0 0 0 10px;
    width: 100%;
    background-color: var(--primary);
  }
  html body header .navigation-bar div .arrow-front {
    width: 17px;
    height: 100%;
    border-left: 10px white solid;
  }
  html body header .navigation-bar div .arrow-front:before {
    display: block;
    content: "";
    position: absolute;
    right: -7px;
    top: 0;
    width: 0;
    height: 0;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
    border-left: 17px solid rgba(255, 255, 255, 0.5333333333);
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    z-index: 2;
  }
  html body header .navigation-bar div .arrow-front:after {
    display: block;
    content: "";
    position: absolute;
    right: -7px;
    top: 0;
    width: 0;
    height: 0;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
    border-left: 17px solid var(--primary);
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
    z-index: 1;
  }
  html body header .navigation-bar div .arrow-behind {
    width: 0;
    height: 0;
    border-top: 15px solid var(--primary);
    border-bottom: 15px solid var(--primary);
    border-left: 17px solid white;
    -webkit-background-clip: padding-box;
    background-clip: padding-box;
  }
  html body header .navigation-bar .selected:before {
    display: none;
  }
  html body header .navigation-bar .selected .arrow-front:before {
    display: none;
  }
  html body header .navigation-bar .selected .arrow-front:after {
    border-left: 17px solid var(--primary);
  }
  html body header .navigation-bar .selected .arrow-behind {
    border-top: 15px solid var(--primary);
    border-bottom: 15px solid var(--primary);
  }
}
html body .content {
  display: flex;
  flex-direction: column;
  position: relative;
  flex: 1;
  overflow-y: auto;
}
html body footer {
  position: relative;
  display: flex;
  background-color: white;
  color: #888888;
  box-shadow: 0 0 5px 1px gray;
  z-index: 3;
  justify-content: space-between;
  height: 46px;
}
@media screen and (max-height: 768px) and (max-width: 1024px) and (orientation: landscape) {
  html body footer {
    display: none;
  }
}
@media (min-width: 992px) {
  html body footer {
    justify-content: flex-end;
  }
}
html body footer .footer-contact-wrapper {
  display: flex;
  flex: 1;
  justify-content: left;
  padding-left: 15px;
}
@media (min-width: 992px) {
  html body footer .footer-contact-wrapper {
    display: none;
  }
}
html body footer .footer-contact-wrapper a {
  font-size: 30px;
  display: flex;
  align-items: center;
  cursor: pointer;
  color: var(--primary);
  margin: 0 5px;
  text-decoration: none;
}
html body footer .link-wrapper {
  margin: auto 0;
  margin-right: 30px;
}
html body footer .link-wrapper a {
  cursor: pointer;
}
html body footer a:hover {
  color: #000000;
}
html body footer img {
  display: none;
  margin-right: 20px;
  width: auto;
  height: 38px;
  margin-top: 3px;
  opacity: 0.75;
}
@media (min-width: 992px) {
  html body footer img {
    display: block;
  }
}
html body.logged-in header .navigation .open-select-user-wrapper {
  display: flex;
}

.please-rotate {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  justify-content: center;
  align-items: center;
  background-color: var(--primary);
  font-size: 30px;
  z-index: 99;
  flex-direction: column;
}
.please-rotate .phone {
  width: 40px;
  height: 80px;
  border: solid 2px black;
  border-radius: 10px;
  margin-bottom: 20px;
  -webkit-animation: rotatePhone 1.6s ease-in-out infinite alternate;
  animation: rotatePhone 1.6s ease-in-out infinite alternate;
}

@media screen and (max-height: 768px) and (max-width: 1024px) and (min-aspect-ratio: 6/5) {
  .please-rotate {
    display: flex;
  }
}
.buffering-circle {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  overflow: hidden;
  border-radius: 6px;
  z-index: 1;
  user-select: none;
}
.buffering-circle:before {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: var(--secondary);
  content: "";
}
.buffering-circle:after {
  position: absolute;
  width: 100%;
  height: 100%;
  content: "\e961";
  display: flex;
  justify-content: center;
  align-items: center;
  left: 0;
  top: 0;
  color: var(--primary);
  -webkit-animation: rotateBuffering 2s linear infinite;
  -moz-animation: rotateBuffering 2s linear infinite;
  -ms-animation: rotateBuffering 2s linear infinite;
  -o-animation: rotateBuffering 2s linear infinite;
  animation: rotateBuffering 2s linear infinite;
}