:root, body {
  padding: 0;
  margin:  0;
  background-color: #fff;
}
a {
  text-decoration: none !important;
  color: inherit;
}
#page {
  position: relative;
  max-width: 100vw;
  /* overflow: hidden; */
}
.hidden {
  display: none !important;
}
.visible {
  display: flex !important;
  visibility: visible;
}
.unvisible {
  visibility: hidden !important;
}
.temporary-hidden {
  display: none !important;
}
.grey-background {
  padding: 4em 0;
  width: 100%;
  background-color: #EEEEEE;
}
.transparent {
  background: transparent !important;
}
.centered {
  margin-right: auto !important;
  margin-left: auto !important;
  text-align: center !important;
}


:root {
  --container-width: 82vw;
  --bigger-container-width: 90vw;
  --smaller-container-width: 70vw;
  --container-max-width: var(--container-width);
  --bigger-container-max-width: var(--bigger-container-width);
  --smaller-container-max-width: var(--smaller-container-width);
}
@media (max-width: 575px) {
  :root {
    --smaller-container-width: 82vw;
  }
}
@media (min-width: 576px) {
  :root {
    --container-max-width: 540px;
    --smaller-container-max-width: 540px;
    --bigger-container-max-width: 540px;
  }
}
@media (min-width: 768px) {
  :root {
    --container-max-width: 720px;
    --smaller-container-max-width: 720px;
    --bigger-container-max-width: 720px;
  }
}
@media (min-width: 992px) {
  :root {
    --container-max-width: 960px;
    --smaller-container-max-width: 960px;
    --bigger-container-max-width: 960px;
  }
}
@media (min-width: 1100px) {
  :root {
    --container-max-width: 1060px;
    --smaller-container-max-width: 968px;
    --bigger-container-max-width: 1060px;
  }
}
@media (min-width: 1200px) {
  :root {
    --container-max-width: 1150px;
    --smaller-container-max-width: 968px;
    --bigger-container-max-width: 1150px;
  }
}
@media (min-width: 1300px) {
  :root {
    --container-max-width: 1200px;
    --smaller-container-max-width: 968px;
    --bigger-container-max-width: 1200px;
  }
}
@media (min-width: 1400px) {
  :root {
    --container-max-width: 1220px;
    --smaller-container-max-width: 968px;
    --bigger-container-max-width: 1220px;
  }
}
@media (min-width: 1700px) {
  :root {
    --container-max-width: 1640px;
    --smaller-container-max-width: 968px;
    --bigger-container-max-width: 1640px;
  }
}
@media (min-width: 2000px) {
  :root {
    --container-max-width: 1820px;
    --smaller-container-max-width: 1100px;
    --bigger-container-max-width: 1820px;
  }
}
@media (min-width: 2300px) {
  :root {
    /* --container-max-width: 1920px; */
    /* --smaller-container-max-width: 1920px; */

  }
}
.container {
  width: var(--container-width);
  max-width: var(--container-max-width);
  padding: 0;
}
.bigger-container {
  width: var(--bigger-container-width);
  max-width: var(--bigger-container-max-width);
  padding: 0;
}
.smaller-container {
  width: var(--smaller-container-width);
  max-width: var(--smaller-container-max-width);
  padding: 0;
}

@media (max-width: 992px) {
  .desktop {
    display: none !important;
  }
}
@media (min-width: 992px) {
  .mobile {
    display: none !important;
  }
}

.main-hero {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 0;
  display: flex;
  color: #fff;
}
.hero-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 140px 0 0 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
}
@media (max-width: 992px) {
}

.global-section {
  padding: 4em 0;
  width: 100%;
}
.section-top {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.section-top.left {
  align-items: flex-start;
}
.section-top.row-between {
  flex-direction: row;
  justify-content: space-between;
}
.section-top.row-between a {
  margin: 0 0 1em 0;
}
.section-wrapper {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: stretch;
  width: 100%;
}
.section-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 50%;
}
.section-middle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 50%;
}
.section-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
  width: 50%;
}
.section-title {
  font-family: "DM Sans";
  font-weight: 700;
  font-size: 22px;
  line-height: 42px;
  letter-spacing: 0;
  padding: 0;
  margin: 0 0 0.5em 0;
}
.section-title.bigger {
  font-size: 30px;
  line-height: 52px;
  margin: 0 0 0.3em 0;
}
.section-title.big {
  font-size: 35px;
  line-height: 45px;
  margin: 0 0 0.5em 0;
}
.section-subtitle {
  font-weight: 400;
  font-size: 30px;
  line-height: 40px;
  letter-spacing: 0;
  padding: 0;
  margin: 0 0 0.5em 0;
}
.section-hint {
  color: #444;
  font-weight: 400;
  font-size: var(--size-14-15-15);
  line-height: 1.6em;
  letter-spacing: 0;
  font-style: italic;
  text-align: center;
  padding: 0;
  margin: 0 0 1em 0;
  max-width: 720px;
}
.section-content {
  font-weight: 400;
  font-size: 16px;
  line-height: 26px;
  letter-spacing: 0;
  padding: 0;
  margin: 0;
}
.section-double-underlined {
  margin: 0 0 2em 0;
}
.section-double-underlined svg {
  width: 28px !important;
  height: 6px !important;
}
@media (max-width: 992px) {
  .global-section {
    padding: 1em 0;
  }
  .section-wrapper {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
  }
  .section-left {
    align-items: center;
    width: 100%;
    margin: 1em 0;
  }
  .section-right {
    align-items: center;
    width: 100%;
    margin: 1em 0;
  }
  .section-double-underlined {
    margin: 0 0 1em 0;
  }
  .section-top.row-between {
    flex-direction: column;
    padding-top: 2em;
    }
}

svg {
  width: 30px;
  height: 30px;
}

.link-hover-effect {
  position: relative;
  text-decoration: none;
  width: fit-content;
}
.link-hover-effect::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  bottom: 0;
  left: 0;
  transform-origin: center;
  transform: scaleX(0);
  transition: transform .3s ease-in-out;
  background-color: currentColor;
}
.link-hover-effect:hover::before {
  transform: scaleX(1);
}

/* Buttons */
#site-btn {
  display: flex;
  align-items: center;
  width: fit-content;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 999px;
  background-color: transparent;
}
#site-btn .btn-title {
  display: inline-flex;
  align-items: center;
  text-align: center;
  font-size: var(--size-14-20-20);
  font-weight: 700;
  line-height: 1.25em;
  letter-spacing: 0;
  text-decoration: none;
  padding: 0.85em 0.8em 0.85em 1.4em;
}
#site-btn.no-svg .btn-title {
  padding: 0.85em 1.4em;
}
#site-btn .svg-wrapper {
  display: inline-flex;
  align-items: center;
  text-align: center;
  margin-right: 1.4em;
  width: var(--size-11-13-13);
  height: var(--size-11-13-13);
}
#site-btn .svg-wrapper svg {
  width: 100%;
  height: 100%;
}
#site-btn.no-border {
  border: unset;
}
#site-btn.filled {
  background-color: var(--main-color);
  border-color: var(--main-color);
}
#site-btn.filled .btn-title {
  color: #fff;
}
#site-btn.filled-white {
  background-color: #fff;
  border-color: #fff;
}
#site-btn.filled-blue {
  background-color: var(--theme-blue);
  border-color: var(--theme-blue);
}
#site-btn.filled-orange {
  background-color: var(--theme-orange);
  border-color: #fff;
}
#site-btn.border-bottom-effect {
  border: unset;
  position: relative;
  text-decoration: none;
  width: fit-content;
}
#site-btn.border-bottom-effect .btn-title {
  font-size: var(--size-14-18-18);
  font-weight: 500;
  line-height: 1.25em;
  letter-spacing: 0;
  text-decoration: none;
  text-transform: uppercase;
  padding: 0.6em 0.5em 0.3em 0;
}
#site-btn.border-bottom-effect .svg-wrapper {
  margin: 0;
}
#site-btn.border-bottom-effect::before {
  content: '';
  position: absolute;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  bottom: 0;
  left: 0;
  transform-origin: center;
  transform: scaleX(1);
  transition: transform .3s ease-in-out;
  background-color: currentColor;
}
#site-btn.border-bottom-effect:hover::before {
  transform: scaleX(0.3);
}
#site-btn.bigger{
  border: 2px solid #fff;;
}
#site-btn.smaller .btn-title {
  font-size: var(--size-13-16-16);
  padding: 0.6em 0.4em 0.6em 1.4em;
  font-weight: 400;
}
#site-btn.smaller.no-svg .btn-title {
  padding: 0.6em 1.4em;
}
#site-btn.medium .btn-title {
  font-size: var(--size-14-18-18);
  padding: 0.5em 0.8em 0.5em 1.4em;
  font-weight: 500;
}
#site-btn.medium.no-svg .btn-title {
  padding: 0.5em 1.4em;
}
#site-btn.bigger .btn-title {
  font-size: var(--size-13-22-22);
  padding: 0.5em 0.6em 0.5em 1em;
}
#site-btn.bigger.no-svg .btn-title {
  padding: 0.5em 1em;
}
#site-btn.bigger .svg-wrapper {
  margin-right: 1.4em;
  width: var(--size-16-20-20);
  height: var(--size-16-20-20);
}
#site-btn.blue {
  color: var(--theme-blue);
  border-color: var(--theme-blue);
}
#site-btn.orange {
  color: var(--theme-orange);
  border-color: var(--theme-orange);
}
#site-btn .svg-wrapper.right {
  transform: translateX(0);
  transition: transform 0.2s ease-in-out;
}
#site-btn:hover .svg-wrapper.right {
  transform: translateX(50%);
  transition: transform 0.2s ease-in-out;
}
#site-btn .svg-wrapper.down {
  transform: translate3d(-30%,30%,0);
  transition: transform 0.2s ease-in-out;
}
#site-btn:hover .svg-wrapper.down {
  transform: translate3d(0%,0%,0);
  transition: transform 0.2s ease-in-out;
}
@media (max-width: 992px) {
}

/* 404 */
#page-404 {
}
#page-404 .container {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
}
#page-404-wrapper {
  min-height: calc(100vh - 100px);
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex: 1;
}
#page-404 .title {
  color: var(--main-color);
  font-size: 70px;
  font-weight: 700;
  line-height: 80px;
  letter-spacing: 0em;
  text-align: center;
  margin: -2em 0 0 0;
  padding: 0;
}
#page-404 .title span {
  color: var(--theme-green);
}
#page-404 .content {
  color: var(--main-color);
  font-size: 22px;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 0em;
  text-align: center;
  margin: 2em 0 4em 0;
  padding: 0;
}
