
/* jsloader//css file: assets/css/module-header.css */
.module-header {
  container: header / inline-size;
  padding-bottom: 0;
  padding-top: 0;
  position: sticky;
  top: 0;
  z-index: 2;
}

.module-header .header-container {
  --rem: var(---rem, 100px);

  --color-first: var(---color-first, 255, 255, 255);

  align-items: center;
  display: flex;
  flex-flow: row nowrap;
  gap: 2.5em 1em;
  justify-content: space-between;
  padding-bottom: 0.8em;
  padding-top: 0.8em;
}

.module-header-sub .header-container {
  background: rgb( var(--color-first) );
}

.module-header .module-top {
  flex: 1 100%;
}

.module-header .button {
  white-space: nowrap;
}

.module-header .logo-img {
  height: 4em;
}

@container header (max-width: 1440px) {
  .module-header .header-container {
    padding: 0.25em 1em;
  }
}

@media only screen and (max-width: 64em) {
  .module-header {
    position: relative;
  }
}

@container header (max-width: 1024px) {
  .module-header .header-container {
    display: grid;
    grid-template-columns: min(100%, 30em);
    grid-template-rows: 1fr;
    justify-content: center;
  }
}
/* jsloader//css file: assets/css/module-logo.css */
.module-logo {
  container: logo;
}

.module-logo .logo-container {
  --rem: var(---rem, 100px);
  display: block;
  line-height: 0;
}

.module-logo .logo-img {
  max-height: calc( 0.8 * var(--rem) );
}
/* jsloader//css file: assets/css/module-menu.css */
.module-menu {
  container: menu;
}

.module-menu .menu-container {
  --rem: var(---rem, 100px);

  --animation-duration: 0.2s;
  --animation-timing-function: linear;

  --color-background: var(---color-background, 231, 235, 240);
  --color-first: var(---color-first, 255, 255, 255);
  --color-first-: var(---color-first-, 14, 16, 25);
  --color-main-: var(---color-main-, 12, 152, 254);

  align-items: center;
  background: rgb( var(--color-first-) );
  border: 0.25em solid rgb( var(--color-first-) );
  border-radius: 1.6em;
  display: flex;
  flex-flow: row nowrap;
}

.module-menu .menu-item {
  position: relative;
}

.module-menu .menu-link {
  background: rgba( var(--color-main-), 0 );
  border-radius: 2em;
  color: rgb( var(--color-first) );
  display: block;
  font-size: 0.8em;
  line-height: 1.25;
  padding: 1em 1.5em;
  text-align: center;
  text-decoration: none;
  transition: background var(--animation-duration) var(--animation-timing-function);
}

.module-menu .menu-link:hover,
.module-menu .menu-link:focus {
  background: rgba( var(--color-main-, 1) );
}

.module-menu .parent > .menu-link {
  align-items: center;
  display: inline-flex;
  gap: 1em;
}

.module-menu .menu-label:after,
.module-menu .parent > .menu-link:after {
  content: "\e906";
  font-family: "Icons" !important;
  font-style: normal;
  font-size: 0.625em;
  font-weight: normal;
  font-variant: normal;
  line-height: 1;
  text-transform: none;
  speak: never;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.module-menu .menu-checkbox {
  display: none;
}

.module-menu .menu-label {
  display: none;
}

.module-menu .menu-sub {
  bottom: 0.25em;
  display: none;
  padding: 1.25em 1em 1em;
  position: absolute;
  transform: translate(0, 100%);
}

.module-menu .menu-sub:hover,
.module-menu .menu-sub:focus-within,
.module-menu .menu-link:hover ~ .menu-sub,
.module-menu .menu-link:focus ~ .menu-sub {
  display: block;
}

.module-menu .menu-sub:before {
  background: rgb( var(--color-first) );
  border: 1px solid rgb( var(--color-background) );
  border-radius: 1.6em 0 1.6em 1.6em;
  content: "";
  inset: 0.5em 0 0;
  position: absolute;
}

.module-menu .menu-sub .menu-link {
  border-bottom: 1px solid rgb( var(--color-background) );
  border-radius: unset;
  color: rgb( var(--color-first-) );
  display: block;
  min-width: max-content;
  padding: 0.5em;
  text-align: left;
  transition: color var(--animation-duration) var(--animation-timing-function);
}

.module-menu .menu-sub .menu-link:hover,
.module-menu .menu-sub .menu-link:focus {
  background: none;
  color: rgb( var(--color-main-) );
}

.module-menu .menu-sub :last-child .menu-link {
  border: none;
}

@media only screen and (max-width: 1024px) {
  .module-menu .menu-container {
    align-items: unset;
    flex-flow: column;
  }

  .module-menu .menu-item {
    align-items: center;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
  }

  .module-menu .menu-sub,
  .module-menu .menu-sub:before {
    display: none;
    background: none;
    min-width: 100%;
    padding: 0.5em;
    position: static;
    transform: unset;
  }

  .module-menu .menu-sub .menu-link {
    border: unset;
    background: rgba( var(--color-main-), 0 );
    border-radius: 2em;
    color: rgb( var(--color-first) );
    display: block;
    font-size: 0.8em;
    line-height: 1.25;
    padding: 1em 1.5em;
    text-align: center;
    text-decoration: none;
    transition: background var(--animation-duration) var(--animation-timing-function);
  }

  .module-menu .menu-sub .menu-link:hover,
  .module-menu .menu-sub .menu-link:focus {
    background: rgba( var(--color-main-, 1) );
    color: rgb( var(--color-first) );
  }

  .module-menu .menu-sub:hover,
  .module-menu .menu-sub:focus-within,
  .module-menu .menu-link:hover ~ .menu-sub,
  .module-menu .menu-link:focus ~ .menu-sub {
    display: none;
  }

  .module-menu .menu-checkbox:checked ~ .menu-sub {
    display: block;
  }

  .module-menu .parent > .menu-link:after {
    display: none;
  }

  .module-menu .menu-label, 
  .module-menu .menu-checkbox {
    cursor: pointer;
    display: block;
    height: 1.5em;
    margin-right: -1.5em;
    width: 1.5em;
  }

  .module-menu .menu-checkbox {
    opacity: 0;
    margin-right: -1.5em;
    z-index: 2;
  }

  .module-menu :checked ~ .menu-label {
    transform: rotate(-180deg);
  }

  .module-menu .menu-label {
    align-items: center;
    background: rgba( var(--color-main-), 0 );
    border-radius: 2em;
    color: rgb( var(--color-first) );
    display: flex;
    justify-content: center;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    transition: transform var(--animation-duration) var(--animation-timing-function);
  }

  .module-menu .menu-label:after {
    font-size: 0.5em;
  }

  .module-menu .menu-label .hidden {
    display: none;
  }
}
/* jsloader//css file: assets/css/module-top.css */
.module-top {
  container: top / inline-size;
}

.module-top .top-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);;

  --color-first: var(---color-first, 255, 255, 255);
  --color-font: var(---color-font, 119, 131, 146);

  display: grid;
  gap: 0 var(--grid);
  grid-template-columns: 42% 1fr;
  grid-template-rows: 1fr auto auto auto auto 1fr;
  justify-items: start;
}

.module-top .top-container:before {
  content: "";
  order: -2;
  margin: 0 0 0 0;
}

.module-top .top-container:after {
  content: ""; 
  order: 2;
}

.module-top .top-heading {
  grid-column: 1;
  margin: 0.25em 0 0 0;
}

.module-top .top-headline {
  color: rgb( var(--color-font) );
  font-size: 1em;
  font-weight: 300;
  letter-spacing: 0.14em;
  line-height: 1.5;
  grid-column: 1;
  order: -1;
  text-transform: uppercase;
}

.module-top .top-content {
  font-size: 1.2em;
  grid-column: 1;
  margin: 2em 0 0;
}

.module-top .top-more {
  align-self: start;
  margin: 3em 0 0;
  grid-column: 1;
  min-width: 12em;
}

.module-top .top-picture {
  display: grid;
  grid-column: 2;
  grid-row: 1 / -1;
  width: 100%;
}

.module-top .module-social {
  align-self: end;
  container: unset;
  background: rgb( var(--color-first) );
  border-radius: 2em 0 0 0;
  grid-column: 1;
  grid-row: 1;
  justify-self: end;
  padding: 0.8em 0.8em 0.8em 2em;
  z-index: 1;
}

.module-top .module-social .social-list {
  padding: 0;
  margin: 0;
  gap: 2em;
}

.module-top .module-social .social-link:after {
  font-size: 1.25em;  
}

.module-top .module-social .social-text {
  display: none;
}

.module-top .top-img {
  border-radius: 4em 0 0 0;
  height: 100%;
  grid-column: 1;
  grid-row: 1;
  width: 100%;
  object-fit: cover;
}

@container top (max-width: 1024px) {
  .module-top .top-container {
    display: grid;
    grid-template-columns: min(100%, 30em);
    grid-template-rows: 1fr;
    justify-content: center;
  }

  .module-top .top-headline {
    order: -3;
  }

  .module-top .top-heading {
    order: -2;    
  }

  .module-top .top-picture {
    grid-column: unset;
    grid-row: unset;
    margin: 2em 0 0;
    order: -1;
  }
}
/* jsloader//css file: assets/css/module-social.css */
.module-social {
  container: social / inline-size;
  position: relative;
  z-index: 1;
}

.module-social .social-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-first: var(---color-first, 255, 255, 255);
  --color-font: var(---color-font, 119, 131, 146);
  --color-font-: var(---color-font-, 6, 16, 17);
  --color-main-: var(---color-main-, 109, 4, 254);
  align-items: center;
  display: flex;
  flex-flow: column;
  line-height: 1;
}

.module-social .social-list {
  align-items: center;
  background: rgb( var(--color-first) );
  border-radius: calc( 0.5 * var(--grid) );
  display: flex;
  flex-flow: row;
  gap: 4em;
  justify-content: center;
  margin: 0 0 calc( -2 * var(--grid) );
  padding: calc( 0.5 * var(--grid) ) var(--grid);
}

.module-social .social-heading {
  color: rgb( var(--color-font-) );
  font-size: 1em;
  font-weight: 700;
  line-height: 1.25em;
  margin: 0 0 calc( 0.5 * var(--grid) ) 0;
  text-align: center;
  text-transform: uppercase;
}

.module-social .social-link {
  align-items: center;
  color: rgb( var(--color-font) );
  display: inline-flex;
  flex-flow: column nowrap;
  font-weight: 700;
  gap: 1.6em;
  margin: -0.625em;
  padding: 0.625em;
  text-decoration: none;
  text-transform: uppercase;
  transition: color var(--animation-duration) var(--animation-timing-function);
}

.module-social .social-link:before {
  display: none;
}

.module-social .social-link:after {
  font-size: 1.5em;
  order: -1;
}

.module-social .social-link:hover,
.module-social .social-link:focus {
  color: rgb( var(--color-main-) );
}

.module-social .social-text {
  font-size: 0.8em;
  font-weight: 400;
  text-transform: none;
}

.module-social .social-img {
  display: block;
  max-width: 100%;
}

@container social (max-width: 1600px) {
  .module-social .social-list {
    margin: 0 0 calc( -1.5 * var(--grid) );
  }  
}

@container social (max-width: 1200px) {
  .module-social .social-list {
    margin: 0 0 calc( -1.25 * var(--grid) );
  }  
}

@container social (max-width: 1024px) {
  .module-social .social-list {
    flex-flow: row wrap;
    margin: 0;    
  }
}
/* jsloader//css file: assets/css/module-list.css */
.module-list {
  container: list / inline-size;
}

.module-list .list-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-font: var(---color-font, 119, 131, 146);
  --color-font-: var(---color-font-, 6, 16, 17);
  --color-first: var(---color-first, 255, 255, 255);
  --color-main-: var(---color-main-, 109, 4, 254);

  display: grid;
  gap: 1.5em 10em;
  grid-template-columns: 1fr 1fr 1fr;
  position: relative;
  z-index: 0;
}

.module-list .list-content {
  margin: 0 -4em 0 0;
  padding: 1.25em 0 0;
}

.module-list .list-content .content {
  color: rgb( var(--color-font) );
  font-style: italic;
  font-size: 1.2em;
  font-weight: 300;
  margin: 2em 0 0;
}

.module-list .list-item {
  display: grid;
  margin: 0 -2em;
  padding: 1.5em 2em;
  position: relative;
}

.module-list .list-item * {
  pointer-events: none;
  position: relative;
  z-index: 1;
}

.module-list .list-heading {
  font-size: 1.4em;
  font-weight: 700;
  line-height: 1.5em;
  margin: 0 0 0.75em;
}

.module-list .list-heading sup {
  font-size: 0.6em;
}

.module-list .list-heading:after {
  background: rgb( var(--color-main-) );
  content: "";
  display: block;
  height: 0.125em;
  margin: 0.75em 0 0;
  width: 1.25em;
}

.module-list .list-button {
  align-items: center;
  color: rgb( var(--color-font-) );
  display: inline-flex;
  font-size: 0.8em;
  font-weight: 700;
  gap: 1em;
  letter-spacing: 0.05em;
  line-height: 1.25em;
  margin: 1.5em 0 0;
  position: static;
  text-transform: uppercase;
  text-decoration: none;
  z-index: unset;
}

.module-list .list-button:before {
  align-items: center;
  border: 1px solid;
  border-color: rgb( var(--color-font) );
  border-radius: 100%;
  display: inline-flex;
  font-size: 0.625em;
  height: 4em;
  justify-content: center;
  min-height: 4em;
  min-width: 4em;
  position: relative;
  transform: rotate(30deg);
  transition: background var(--animation-duration) var(--animation-timing-function), 
              border-color var(--animation-duration) var(--animation-timing-function),
              transform var(--animation-duration) var(--animation-timing-function),
              color var(--animation-duration) var(--animation-timing-function);
  width: 4em;
  z-index: 1;
}

.module-list .list-button:hover:before,
.module-list .list-button:focus:before {
  background: rgb( var(--color-main-) );
  border-color: rgb( var(--color-first) );
  color: rgb( var(--color-first) );
  transform: rotate(0);
}

.module-list .list-button:after {
  display: none;
}

.module-list .list-text {
  opacity: 0;
  pointer-events: auto;
  position: static;
  transition: opacity var(--animation-duration) var(--animation-timing-function);
  z-index: unset;
}

.module-list .list-text:hover,
.module-list .list-text:focus {
  opacity: 1;
}

.module-list .list-text:before,
.module-list .list-text:after {
  background: rgb( var(--color-first) );
  border-radius: 1.5em 0 1.5em 1.5em;
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
}

.module-list .list-text:after {
  background: none;
  z-index: 2;
}

@container list (max-width: 1440px) {
  .module-list .list-container {
    gap: 1.5em 6em;
  }

  .module-list .list-item {
    margin: 0 -1em;
  }
}

@container list (max-width: 1024px) {
  .module-list .list-container {
    grid-template-columns: min(100%, 30em);
    justify-content: center;
  }

  .module-list .list-content {
    margin: 0;
  }
}
/* jsloader//css file: assets/css/module-form.css */
.module-form {
  container: form / inline-size;
}

.module-form .form-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);

  --color-first: var(---color-first, 255, 255, 255);
  --color-main-: var(---color-main-, 109, 4, 254);

  display: grid;
  grid-template-columns: 1fr 28em 1fr;
  padding-bottom: calc( var(--grid) / 2 );
  padding-top: calc( var(--grid) / 2 );
  text-align: center;
}

.module-form .form-container > * {
  grid-column: 2;
}

.module-form .form-container > :first-child {
  margin-top: 0;
}

.module-form .parallax-img {
  grid-column: unset;
}

.module-form .form-heading {
  color: rgb( var(--color-first) );
  font-size: 3.2em;
  font-weight: 700;
  line-height: 1;
}

.module-form .form-content {
  color: rgb( var(--color-first) );
  font-size: 1.2em;
  font-weight: 300;
  margin-top: 0.5em;
}

.module-form .form-errors {
  color: rgb( var(--color-first) );
  margin-top: 1.5em; 
}

.module-form .form {
  margin-top: 1.5em; 
}

.module-form .form-fieldset {
  align-items: center;
  display: grid;
  grid-template-columns: 1fr auto;
}

.module-form .form-fieldset + .form-fieldset {
  margin-top: 1.5em; 
}

.module-form .form-captcha {
  display: none;
}

.module-form .form-input {
  color: rgb( var(--color-first) );
  border: 1px solid rgb( var(--color-first) );
  background: rgba( var(--color-first), 0.15 );
  border-radius: 1em;
  padding: 0.7em 1.5em;
  text-align: left;
  width: 100%;
}

.module-form .form-submit {
  margin: 0 0 0 -1.5em;
  white-space: nowrap;
}

.module-form .form-submit:before {
  display: none;
}

.module-form .form-submit:after {
  font-size: 2em;
  margin: -1em 0;
}

@container form (max-width: 1000px) {
  .module-form .form-container {
    display: grid;
    grid-template-columns: 1fr min(100%, 30em) 1fr;
    grid-template-rows: 1fr;
    justify-content: center;
  }

  .module-form .form-heading {
    font-size: 2.4em;
  }
}
/* jsloader//css file: assets/css/module-modal.css */
.compsoul-modal-popup {
  --rem: var(---rem, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-first: var(---color-first, 255, 255, 255);
  --color-first-: var(---color-first-, 6, 16, 17);
  --color-main-: var(---color-main-, 109, 4, 254);

  align-items: center;
  background: rgba( var(--color-first-), 0.5 );
  bottom: 0;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: 10vh auto 10vh;
  left: 0;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  right: 0;
  top: 0;
  transition: opacity var(--animation-duration) var(--animation-timing-function);
  will-change: opacity;
  z-index: 6;
}

.compsoul-modal-popup.modal-active {
  opacity: 1;
  pointer-events: auto;
}

.compsoul-modal-popup.modal-close {
  pointer-events: auto;
}

.modal-unset, .modal-unset:before, .modal-unset:after, .compsoul-modal-popup.modal-unset, .compsoul-modal-main.modal-unset {
  animation: unset !important;
  transition: none !important;
}

.compsoul-modal-popup:before {
  align-items: center;
  animation: compsoul-modal-loading 1s infinite;
  border-bottom: 0.5em solid rgba( var(--color-first), 0 );
  border-left: 0.5em solid rgba( var(--color-first), 0 );
  border-right: 0.5em solid rgba( var(--color-first), 0 );
  border-top: 0.5em solid rgba( var(--color-first), 0 );
  border-radius: 100%;
  box-sizing: content-box;
  content: "";
  font-size: calc( 0.04 * var(--rem) );
  height: 6em;
  left: 50%;
  opacity: 1;
  position: absolute;
  top: 50%;
  transform: translate3d(-50%, -50%, 0);
  transition: opacity var(--animation-duration) var(--animation-timing-function);
  will-change: opacity;
  width: 6em;
}

.compsoul-modal-popup.modal-ready:before, .compsoul-modal-popup.modal-error:before {
  animation-play-state: paused;
  opacity: 0;
}

@keyframes compsoul-modal-loading {
  from {
    transform: translate3d(-50%, -50%, 0) rotate(0deg);
  }

to {
    transform: translate3d(-50%, -50%, 0) rotate(360deg);
  }
}

.compsoul-modal-popup:after {
  color: rgb( var(--color-first) );
  content: "\26A0";
  font-size: calc( 0.42 * var(--rem) );
  font-weight: 200;
  left: 50%;
  margin: calc( -0.06 * var(--rem) ) 0 0 0;
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: translate3d(-50%, -50%, 0);
  transition: opacity var(--animation-duration) var(--animation-timing-function);
  will-change: opacity;
}

.compsoul-modal-popup.modal-error:after {
  opacity: 1;
}

.compsoul-modal-popup .compsoul-modal-main {
  background: rgb( var(--color-first) );
  border-radius: calc( 0.80 * var(--rem) ) 0 0;
  box-shadow: 0 calc( 0.05 * var(--rem) ) calc( 0.26 * var(--rem) ) 0 rgba( var(--color-first-), 0.22), 0 calc( 0.20 * var(--rem) ) calc( 0.28 * var(--rem) ) 0 rgba( var(--color-first-), 0.30);
  box-sizing: border-box;
  grid-column: 2;
  grid-row: 2;
  max-height: calc(80vh);
  max-width: calc( 8.00 * var(--rem) );
  padding: 3em 1em 3em 3em;
  z-index: 1;
}

.compsoul-modal-popup.modal-change .compsoul-modal-main {
  transition: transform var(--animation-duration) var(--animation-timing-function), opacity var(--animation-duration) var(--animation-timing-function);
}

.compsoul-modal-popup .compsoul-modal-content {
  background: rgb( var(--color-first) );
  max-height: calc(80vh - 6em);
  overflow-y: auto;
  padding: 0 2em 0 0;
  position: relative;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.compsoul-modal-popup .compsoul-modal-content:after {
  content: "";
  display: table;
  clear: both;
}

.compsoul-modal-popup .compsoul-modal-footer {
  bottom: 0;
  margin-top: 2em;
  position: sticky;
  text-align: right;
}

.compsoul-modal-popup .compsoul-modal-close {
  align-self: start;
  align-items: center;
  border-radius: 100%;
  grid-column: 2;
  grid-row: 2;
  display: flex;
  justify-content: center;
  justify-self: end;
  transform: translate(25%, -25%);
  z-index: 2;
}

.compsoul-modal-popup .compsoul-modal-next {
  right: 8em;
  position: absolute;
  top: 50%;
  transform: translate3d(0, -50%, 0);
  z-index: 2;
}

.compsoul-modal-popup .compsoul-modal-prev {
  left: 8em;
  position: absolute;
  top: 50%;
  transform: translate3d(0, -50%, 0);
  z-index: 2;
}

.compsoul-modal-popup .compsoul-modal-close,
.compsoul-modal-popup .compsoul-modal-next,
.compsoul-modal-popup .compsoul-modal-prev {
  background: rgb( var(--color-first-) );
  border: none;
  cursor: default;
  font-size: calc( 0.032 * var(--rem) );
  height: 16em;
  opacity: 0;
  outline: 1px solid rgba( var(--color-main), 0 );
  padding: 0;
  text-align: center;
  transition: background var(--animation-duration) var(--animation-timing-function), opacity var(--animation-duration) var(--animation-timing-function), outline var(--animation-duration) var(--animation-timing-function);
  width: 16em;
}

.compsoul-modal-popup .compsoul-modal-close:hover,
.compsoul-modal-popup .compsoul-modal-close:focus {
  background: rgb( var(--color-main-) );  
}

.compsoul-modal-popup .compsoul-modal-close:focus,
.compsoul-modal-popup .compsoul-modal-close:focus-within, 
.compsoul-modal-popup .compsoul-modal-next:focus, 
.compsoul-modal-popup .compsoul-modal-next:focus-within,
.compsoul-modal-popup .compsoul-modal-prev:focus,
.compsoul-modal-popup .compsoul-modal-prev:focus-within {
  outline: 1px solid rgba( var(--color-main), 1 );
}

.compsoul-modal-popup .compsoul-modal-close,
.compsoul-modal-popup .compsoul-modal-next.modal-active,
.compsoul-modal-popup .compsoul-modal-prev.modal-active {
  cursor: pointer;
  opacity: 1;
}

.compsoul-modal-popup .compsoul-modal-close:before,
.compsoul-modal-popup .compsoul-modal-close:after,
.compsoul-modal-popup .compsoul-modal-next:before,
.compsoul-modal-popup .compsoul-modal-prev:before {
  border-top: 1em solid rgb( var(--color-first) );
  border-right: 1em solid rgb( var(--color-first) );
  box-sizing: content-box;
  content: "";
  cursor: pointer;
  display: inline-block;
  height: 4em;
  padding: 0 0 1em 1em;
  transform: rotate(45deg) translate3d(-25%, 25%, 0);
  transition: opacity var(--animation-duration) var(--animation-timing-function);
  width: 4em;
}

.compsoul-modal-popup .compsoul-modal-close:before,
.compsoul-modal-popup .compsoul-modal-close:after {
  height: 3em;
  width: 3em;
}

.compsoul-modal-popup .compsoul-modal-close:after,
.compsoul-modal-popup .compsoul-modal-prev:before {
  transform: rotate(-135deg) translate3d(-25%, 25%, 0);
}

.compsoul-modal-popup .compsoul-modal-close:before {
  transform: rotate(45deg) translate3d(-7%, 7%, 0);
}

.compsoul-modal-popup .compsoul-modal-close:after {
  transform: rotate(-135deg) translate3d(-7%, 7%, 0);
}

.compsoul-modal-popup .compsoul-modal-timer {
  height: calc( 0.03 * var(--rem) );
  left: 0;
  position: absolute;
  top: 0;
  z-index: 5;
  width: 100%;
}

.compsoul-modal-popup .compsoul-modal-timer:before {
  animation: compsoul-slide-timeline 8s linear forwards;
  animation-play-state: paused;
  background: rgb( var(--color-main) );
  content: "";
  display: block;
  height: 100%;
  transform: translate3d(-100%, 0, 0);
  width: 100%;
}

.compsoul-modal-popup.modal-ready .compsoul-modal-timer:before {
  animation-play-state: running;
}

.compsoul-modal-popup:hover .compsoul-modal-timer:before {
  animation-play-state: paused;
}

@keyframes compsoul-slide-timeline {
  from {
    transform: translate3d(-100%, 0, 0);
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

@media only screen and (max-width: 1024px) {
  .compsoul-modal-popup .compsoul-modal-main {
    max-width: 90vw;
    padding: 2em 1em 2em 2em;
  }

  .compsoul-modal-popup .compsoul-modal-content {
    max-height: calc(80vh - 4em);
    padding: 0 1em 0 0;
  }

  .compsoul-modal-popup.compsoul-modal-close,
  .compsoul-modal-popup .compsoul-modal-next,
  .compsoul-modal-popup .compsoul-modal-prev {
    font-size: calc( 0.025 * var(--rem) );
  }

  .compsoul-modal-popup .compsoul-modal-close {
    transform: translate(-35%, -50%);
  }

  .compsoul-modal-popup .compsoul-modal-next {
    right: 0;
  }

  .compsoul-modal-popup .compsoul-modal-prev {
    left: 0;
  }

}

.compsoul-modal-box {
  --rem: var(---rem, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-background: var(---color-background, 255, 255, 255);
  --color-first: var(---color-first, 255, 255, 255);
  --color-first-: var(---color-first-, 6, 16, 17);
  --color-main: var(---color-main, 144, 202, 246);
  --color-main-: var(---color-main-, 109, 4, 254);

  background: rgb( var(--color-background) );
  bottom: clamp(1em, 4vw, 2em);
  border-radius: 0.5em;
  box-shadow: 0 1em 2em 0 rgba(9, 41, 78, 0.1);
  left: clamp(1.5em, 4vw, 2em);
  max-height: min(20em, 50vh);
  max-width: min( 26em, calc(100% - ( 2 * clamp(1.5em, 4vw, 2em) ) ) );
  opacity: 0;
  padding: 0.5em;
  pointer-events: none;
  position: fixed;
  transition: opacity var(--animation-duration) var(--animation-timing-function);
  will-change: opacity;
  z-index: 6;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.compsoul-modal-box.modal-active {
  opacity: 1;
  pointer-events: auto;
}

.compsoul-modal-box.modal-close {
  pointer-events: auto;
}

.compsoul-modal-box.modal-unset {
  animation: unset !important;
  transition: none !important;
}

.compsoul-modal-box .compsoul-modal-main {
  background: rgb( var(--color-first) );
  border-radius: 0.5em;
  display: flex;
  flex-direction: column;
  overflow: auto;
  flex: 1;
}

.compsoul-modal-box .compsoul-modal-content {
  height: 100%;
  overflow-y: auto;
  padding: 1em;
}

.compsoul-modal-box .compsoul-modal-footer {
  background: linear-gradient( rgba( var(--color-first), 0 ) 50%, rgba( var(--color-first), 1 ) );
  bottom: -1.4em;
  position: sticky;
  text-align: right;
}

.compsoul-modal-box .compsoul-modal-footer .button {
  border: 0.4em solid rgb( var(--color-first) );
}

.compsoul-modal-box .compsoul-modal-content .content {
  ---margin: 1em;
  font-size: 0.8em;
}

.compsoul-modal-box .compsoul-modal-close {
  align-items: center;
  background: rgb( var(--color-first-) );
  border: none;
  border-radius: 100%;
  cursor: pointer;
  display: grid;
  font-size: 1em;
  justify-content: center;
  max-height: 2em;
  max-width: 2em;
  min-height: 2em;
  min-width: 2em;
  padding: 0;
  position: absolute;
  top: 0;
  transform: translate(50%, -50%);
  right: 0;
  text-align: center;
  transition: background var(--animation-duration) var(--animation-timing-function);
  z-index: 3;
}

.compsoul-modal-box .compsoul-modal-close:before,
.compsoul-modal-box .compsoul-modal-close:after {
  background: rgb( var(--color-first) );
  content: "";
  cursor: pointer;
  grid-column: 1;
  grid-row: 1;
  height: 1em;
  transform: rotate(45deg);
  transform-origin: center;
  transition: opacity var(--animation-duration) var(--animation-timing-function),
              background var(--animation-duration) var(--animation-timing-function);
  width: 2px;
}

.compsoul-modal-box .compsoul-modal-close:after {
  transform: rotate(-45deg);
}

.compsoul-modal-box .compsoul-modal-close:hover,
.compsoul-modal-box .compsoul-modal-close:focus {
  background: rgb( var(--color-main-) );
}

.compsoul-modal-box .compsoul-modal-timer {
  border-radius: 0.5em;
  inset: 0;
  overflow: hidden;
  position: absolute;
  z-index: -1;
}

.compsoul-modal-box .compsoul-modal-timer:before {
  animation: compsoul-slide-box-timeline 8s linear forwards;
  animation-play-state: paused;
  background: rgb( var(--color-main) );
  content: "";
  display: block;
  height: 100%;
  transform: translate3d(-100%, 0, 0);
  width: 100%;
}

.compsoul-modal-box.modal-ready .compsoul-modal-timer:before {
  animation-play-state: running;
}

.compsoul-modal-box:hover .compsoul-modal-timer:before {
  animation-play-state: paused;
}

@keyframes compsoul-slide-box-timeline {
  from {
    transform: translate3d(-100%, 0, 0);
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

@media only screen and (max-width: 640px) {
  .compsoul-modal-popup .compsoul-modal-footer {
    background: rgb( var(--color-first) );
    bottom: 0;
    margin-top: 2em;
    padding-top: 2em;
    text-align: center;
  }
}
/* jsloader//css file: assets/css/module-accordion.css */
.module-accordion {
  container: accordion / inline-size;
}

.module-accordion .accordion-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);;

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-background: var(---color-background, 231, 235, 240);
  --color-main-: var(---color-main-, 109, 4, 254);
  --color-font: var(---color-font, 119, 131, 146);

  display: grid;
  gap: 0 var(--grid);
  grid-template-columns: 1fr 60fr 160fr 1fr;
  grid-template-rows: auto 1fr;
}

.module-accordion .accordion-heading {
  grid-column: 2;
  margin: 0.25em 0 0;
}

.module-accordion .accordion-main {
  grid-column: 2;
  margin: calc( 0.5 * var(--grid) ) 0 0;
}

.module-accordion .accordion-listing {
  align-self: start;
  display: grid;
  gap: 1em 0;
  grid-column: 3;
  grid-row: 1 / span 2;
}

.module-accordion .accordion-details {
  border: 1px solid rgb( var(--color-background) );
  border-radius: 1em;
}

.module-accordion .accordion-summary {
  align-items: center;
  cursor: pointer;
  display: grid;
  gap: 0 var(--grid);
  grid-template-columns: 1fr auto;
  font-weight: 700;
  padding: 1em 1.5em;
}

.module-accordion .accordion-summary:before {
  display: none;
}

.module-accordion .accordion-summary:after {
  font-size: 0.5em;
  transition: color var(--animation-duration) var(--animation-timing-function),
              transform var(--animation-duration) var(--animation-timing-function);
}

.module-accordion .accordion-summary:hover:after,
.module-accordion .accordion-summary:focus:after {
  color: rgb( var(--color-main-) );
}

.module-accordion [open] .accordion-summary:after {
  transform: rotate(180deg);
}

.module-accordion .accordion-summary::-webkit-details-marker {
  display: none;
}

.module-accordion .accordion-content {
  color: rgb( var(--color-font) );
  margin-bottom: 1.5em;
  padding: 0 1.5em;
}

@container accordion (max-width: 1440px) {
  .module-accordion .accordion-container {
    grid-template-columns: 60fr 160fr;
  }

  .module-accordion .accordion-heading,
  .module-accordion .accordion-main {
    grid-column: 1;
  }

  .module-accordion .accordion-listing {
    grid-column: 2;
  }
}

@container accordion (max-width: 1024px) {
  .module-accordion .accordion-container {
    display: grid;
    grid-template-columns: min(100%, 30em);
    grid-template-rows: 1fr;
    justify-content: center;
  }

  .module-accordion .accordion-container > * { 
    grid-column: 1;
    grid-row: unset;
  }
  
  .module-accordion .accordion-listing {
    margin: calc( 0.5 * var(--grid) ) 0 0;
  }
}
/* jsloader//css file: assets/css/module-main.css */
.module-main {
  container: main / inline-size;;
}

.module-main .main-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-background: var(---color-background, 231, 235, 240);
  --color-first: var(---color-first, 255, 255, 255);
  --color-first-: var(---color-first-, 14, 16, 25);
  --color-font: var(---color-font, 119, 131, 146);
  --color-font-: var(---color-font-, 6, 16, 17);
  --color-main: var(---color-main, 144, 202, 246);
  --color-main-: var(---color-main-, 109, 4, 254);

  display: grid;
  gap: 0 10em;
  grid-template-columns: 1fr auto;
  margin-bottom: calc( 1.5 * var(--grid) );
  padding-bottom: var(--grid);
  padding-top: var(--grid);
  position: relative;
}

.module-main .main-container:before {
  background: rgb( var(--color-background) );
  border-radius: 4em;
  bottom: 0;
  content: "";
  left: 50%;
  max-width: 86em;
  position: absolute;
  top: 0;
  transform: translate(-50%, 0);
  width: 100%;
  z-index: -1;
}

.module-main .main-container > * {
  grid-column: 1;
}

.module-main .main-container > :first-child {
  margin: 0;
}

.module-main .main-content {
  margin: 3em 0 0;
}

.module-main .main-img {
  border-radius: 4em 0 0 0;
  display: block;
  grid-column: 2;
  grid-row: 1 / span 3;
  height: calc( 1.75 * var(--grid) + 100% );
  object-fit: cover;
  margin: calc( -0.25 * var(--grid) ) 0 calc( -1.5 * var(--grid) );
  max-width: 30em;
  width: 100%;
}

@container main (max-width: 1440px) {
  .module-main .main-container {
    gap: 0 8em;
  }  
}

@container main (max-width: 1024px) {
  .module-main .main-container {
    display: grid;
    grid-template-columns: min(100%, 20em);
    grid-template-rows: 1fr;
    justify-content: center;
    margin: 0;
  } 

  .module-main .main-container > * {
    grid-column: 1;
    grid-row: unset;
  }

  .module-main .main-heading {
    order: -2;
  }

  .module-main .main-img {
    height: unset;
    margin: 3em 0 0 0;
    order: -1;
  }
}
/* jsloader//css file: assets/css/module-checklist.css */
.module-checklist {
  container: checklist / inline-size;
}

.module-checklist .checklist-container {
  --rem: var(---rem, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-background: var(---color-background, 231, 235, 240);
  --color-first: var(---color-first, 255, 255, 255);
  --color-main-: var(---color-main-, 109, 4, 254);

  display: flex;
  flex-flow: row wrap;
  gap: 2em 5%;
  justify-content: center;
  text-align: center;
}

.module-newsletter .checklist-container > :last-child {
  margin-bottom: 0;
}

.module-checklist .checklist-heading {
  flex: 1 100%;
  margin-bottom: 1em;
}

.module-checklist .checklist-item {
  max-width: 14em;
}

.module-checklist .checklist-headline {
  display: grid;
  font-size: 1.4em;
  font-weight: 700;
  grid-template-rows: auto 1fr;
  justify-items: center;
  margin: 0 0 1em;
}

.module-checklist .checklist-headline:before,
.module-checklist .checklist-headline:after {
  align-items: center;
  border-radius: 1em;
  box-sizing: border-box;
  color: rgb( var(--color-main-) );
  display: flex;
  font-size: 0.75em;
  grid-row: 1;
  grid-column: 1;
  height: 3.25em;
  justify-content: center;
  margin: 0 0 1em;
  padding: 0 0 0 0.5em;
  width: 3.25em;
}

.module-checklist .checklist-headline:before {
  background: rgb( var(--color-background) );
  color: rgba( var(--color-main-), 0.4 );
  padding: 0 0.5em 0 0;
}

@container checklist (max-width: 1440px) {
  .module-checklist .checklist-container {
    gap: 2em 3%;
  }
}
/* jsloader//css file: assets/css/module-banner.css */
.module-banner {
    container: banner;
  }
  
  .module-banner .banner-container {
    --rem: var(---rem, 100px);
    --color-main-: var(---color-main-, 109, 4, 254);
  
    height: calc( 2.70 * var(--rem) );
    overflow: hidden;
    position: relative;
    z-index: 0;
  }
  
  .module-banner .banner-container:after {
    background: url('../../uploads/images/banner.webp') no-repeat center fixed;
    content: "";
    inset: 0;
    mix-blend-mode: multiply;
    opacity: 0.7;
    position: absolute;
    z-index: 1;
  }
  
  .module-banner .banner-img {
    display: block;
    height: 100%;
    mix-blend-mode: multiply;
    object-fit: cover;
    opacity: 1;
    position: relative;
    width: 100%;
    z-index: 2;
  }
/* jsloader//css file: assets/css/module-listing.css */
.module-listing {
  container: listing / inline-size;
}

.module-listing .listing-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-background: var(---color-background, 231, 235, 240);
  --color-font: var(---color-font, 119, 131, 146);
  --color-font-: var(---color-font-, 6, 16, 17);
  --color-first: var(---color-first, 255, 255, 255);
  --color-main-: var(---color-main-, 109, 4, 254);

  display: grid;
  gap: calc( var(--grid) / 2 );
  grid-auto-flow: row dense;
  grid-template-columns: 1fr 1fr 1fr;
}

.module-listing.listing-index .listing-container {
  gap: var(--grid) 8%;
}

.module-listing .listing-heading {
  align-self: last baseline;
  grid-column: 1 / span 3;
  grid-row: 1;
  order: -2;
}

.module-listing .listing-link {
  align-self: last baseline;
  color: rgb( var(--color-font-) );
  display: inline-flex;
  font-size: calc( 0.18 * var(--rem) );
  gap: 1em;
  grid-column: 3;
  grid-row: 1;
  margin: -1em -1em -1em auto;;
  padding: 1em;
  text-decoration: none;
  transition: color var(--animation-duration) var(--animation-timing-function);
}

.module-listing .listing-link:hover,
.module-listing .listing-link:focus {
  color: rgb( var(--color-main-) );
}

.module-listing .listing-link:before {
  display: none;
}

.module-listing .listing-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.module-listing .listing-ite > :first-child {
  margin-top: 0;
}

.module-listing .listing-img {
  border-radius: calc( 0.24 * var(--rem) ) 0 calc( 0.24 * var(--rem) ) calc( 0.24 * var(--rem) );
  grid-column: 1 / span 2;
  height: calc( 2.60 * var(--rem) );
  max-width: 100%;
  object-fit: cover;
  order: -1;
  width: 100%;
}

.module-listing .listing-headline {
  font-size: calc( 0.28 * var(--rem) );
  font-weight: 700;
  line-height: 1.25;
  grid-column: 1 / span 2;  
  margin: calc( 0.21 * var(--rem) ) 0 0;
}

.module-listing .listing-content {
  grid-column: 1 / span 2;
  margin: calc( 0.21 * var(--rem) ) 0 0;
}

.module-listing .listing-time {
  align-self: end;
  color: rgb( var(--color-font) );
  font-size: calc( 0.14 * var(--rem) );
  margin: calc( 0.42 * var(--rem) ) 0 0 0;
  order: 1;
}

.module-listing .listing-more {
  align-self: end;
  align-items: last baseline;
  color: rgb( var(--color-font-) );
  display: inline-flex;
  font-size: calc( 0.14 * var(--rem) );
  font-weight: 700;
  gap: 1em;
  letter-spacing: 0.05em;
  margin: calc( 0.28 * var(--rem) ) -1em -1em auto;
  order: 2;
  padding: 1em;
  text-decoration: none;
  text-transform: uppercase;
  transition: color var(--animation-duration) var(--animation-timing-function);
  white-space: nowrap;
}

.module-listing .listing-more:hover,
.module-listing .listing-more:focus {
  color: rgb( var(--color-main-) );
}

.module-listing .listing-more:before {
  display: none;
}

.module-listing .listing-more:after {
  align-self: last baseline;
  color: rgb( var(--color-main-) );  
}

.module-listing .listing-nextpage {
  grid-column: 1 / -1;
  height: 1px;
  opacity: 0;
  overflow: hidden;
}

.module-listing.listing-featured .listing-container {
  grid-template-columns: 1fr;
}

.module-listing.listing-featured .listing-item {
  align-items: start;
  gap: 0 var(--grid);
  grid-template-columns: 2fr 3fr;
  grid-template-rows: auto auto 1fr;
}

.module-listing.listing-featured .listing-headline {
  font-size: 2em;
  grid-column: 1;
}

.module-listing.listing-featured .listing-img {
  grid-column: 2;
  grid-row: 1 / span 3;
  height: auto;
  max-height: 100%;
  order: unset;
}

.module-listing.listing-featured .listing-content {
  grid-column: 1;
}

.module-listing.listing-featured .listing-more,
.module-listing.listing-featured .listing-time {
  grid-column: 1;
  grid-row: 3;
}

@container listing (max-width: 1024px) {
  .module-listing .listing-container,
  .module-listing.listing-featured .listing-item {
    grid-template-columns: min(100%, 30em);
    justify-content: center;
  }

  .module-listing .listing-container > *,
  .module-listing.listing-featured .listing-img  {
    grid-column: 1;
    grid-row: unset;
  }

  .module-listing.listing-featured .listing-img  {
    order: -1;
  }

  .module-listing .listing-link {
    margin: 0;
    justify-self: center;
  }
}
/* jsloader//css file: assets/css/module-carousel.css */
.module-carousel {
  container: carousel / inline-size;
  padding-right: 0;
}

.module-carousel .carousel-container {
  --rem: var(--_rem, 100px);
  --grid: var(--_grid, 100px);

  --animation-duration: var(--_animation-duration, 0.2s);
  --animation-timing-function: var(--_animation-timing-function, linear);

  --color-background: var(--_color-background, 231, 235, 240);
  --color-first: var(--_color-first, 255, 255, 255);
  --color-first_: var(--_color-first_, 14, 16, 25);
  --color-font: var(--_color-font, 119, 131, 146);
  --color-font_: var(--_color-font_, 6, 16, 17);
  --color-main: var(--_color-main, 144, 202, 246);
  --color-main_: var(--_color-main_, 12, 152, 254);
  
  align-items: start;
  display: grid;
  overflow: hidden;
  padding-left: calc( 1.5 * var(--grid) );
  position: relative;
  z-index: 0;
}

.module-carousel .carousel-container:before {
  border-left: 2px solid rgb( var(--color-main_) );
  border-top: 2px solid rgb( var(--color-main_) );
  border-radius: 4em 0 0;
  bottom: 4em;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 1em;
  z-index: -1;
}

.module-carousel .carousel-container:after {
  background: linear-gradient( -90deg, rgba( var(--color-first), 0 ), rgba( var(--color-first), 1 ) );
  border-left: 2px solid rgb( var(--color-main_) );
  bottom: 0;
  content: "";
  left: 0;
  position: absolute;
  top: var(--grid);
  width: calc( 1.5 * var(--grid) );
  z-index: 1;
}

.module-carousel .carousel-title {
  background: rgb( var(--color-first) );
  display: inline-block;
  font-size: 2em;
  grid-column: 1;
  justify-self: start;
  margin: 0 0 var(--grid) 0;
  padding: 0 0.25em;
}

.module-carousel .carousel-listing {
  display: grid;
  gap: 0;
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  grid-column: 1 / 3;
  grid-row: 2;
  grid-template-columns: unset;
  margin: 0 0 0 -4em;
  max-width: calc( ( 100% + 4em ) / 3);
  transition: transform var(--animation-duration);
}

.module-carousel .carousel-item {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: subgrid;
  grid-row: auto / span 2;
  padding: 0 0 0 4em;
  z-index: 0;
}

.module-carousel .carousel-headline {
  align-self: end;
  font-size: 1.4em;
  justify-self: start;
  grid-column: 1 / 3;
  grid-row: 1;
  max-width: calc( 100% - 2em );
}

.module-carousel .carousel-more {
  background: rgb( var(--color-first) );
  border-radius: 0 1em 0 0;
  color: rgb( var(--color-font_) );
  display: inline-block;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: -0.04em;
  padding: 1em 1em 0 0;
  position: relative;
}

.module-carousel .carousel-more:before,
.module-carousel .carousel-more:after {
  color: rgb( var(--color-first) );
  content: "\e908";
  height: 1em;
  font-size: 1.25em;
  left: -1px;
  position: absolute;
  top: 1px;
  transform: translate(0, -1em);
  width: 1em;
}

.module-carousel .carousel-more:after {
  bottom: -1px;
  font-size: 1em;
  left: unset;
  right: 1px;
  top: unset;
  transform: translate(1em, 0);
}

.module-carousel .carousel-picture {
  color: rgb( var(--color-font_) );
  grid-column: 1 / -1;
  grid-row: 1;
  text-decoration: none;
  z-index: -1;
}

.module-carousel .carousel-img {
  border-radius: 1em;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.module-carousel .carousel-subtitle {
  color: rgb( var(--color-font_) );
  font-size: 1em;
  font-weight: 300;
  grid-column: 1 / -1;
  grid-row: 2;
  margin: 0.75em 0 0;
  text-decoration: none;
}

.module-carousel .carousel-subtitle:before {
  background: rgb( var(--color-main_) );
  content: "";
  display: block;
  height: 0.25em;
  margin: 0 0 0.75em;
  width: 1.5em;
}

.module-carousel .carousel-nav {
  background: rgb( var(--color-first) );
  display: flex;
  gap: 0.5em;
  grid-column: 2;
  justify-self: end;
  padding: 0 1em;
}

.module-carousel .carousel-prev,
.module-carousel .carousel-next {
  background: rgba( var(--color-main_), 0 );
  align-items: center;
  display: flex;
  border: 1px solid rgb( var(--color-font) );
  border-radius: 100%;
  height: 2em;
  justify-content: center;
  opacity: 0.3;
  padding: 0;
  pointer-events: none;
  transition: background var(---animation-duration) var(---animation-timing-function),
              border var(---animation-duration) var(---animation-timing-function),
              color var(---animation-duration) var(---animation-timing-function),
              opacity var(---animation-duration) var(---animation-timing-function);
  width: 2em;
}

.module-carousel .carousel-prev.active,
.module-carousel .carousel-next.active {
  cursor: pointer;
  opacity: 1;
  pointer-events: auto;
}

.module-carousel .carousel-prev:before,
.module-carousel .carousel-next:before {
  font-size: 0.45em;
}

.module-carousel .carousel-prev:after,
.module-carousel .carousel-next:after {
  display: none;
}

.module-carousel .carousel-prev:hover,
.module-carousel .carousel-prev:focus,
.module-carousel .carousel-next:hover,
.module-carousel .carousel-next:focus {
  background: rgba( var(--color-main_), 1 );
  border: 1px solid rgb( var(--color-main_) );
  color: rgb( var(--color-first) );
}

@container carousel (max-width: 1600px) {
  .module-carousel .carousel-container {
    padding-left: var(--grid);
  }

  .module-carousel .carousel-container:after {
    width: var(--grid);
  }
}

@container carousel (max-width: 1024px) {
  .module-carousel .carousel-container {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: center;
    overflow: hidden;
    padding-left: 0;
  }

  .module-carousel .carousel-container:before,
  .module-carousel .carousel-container:after {
    display: none;
  }

  .module-carousel .carousel-title {
    display: block;
    font-size: 1.8em;
    justify-self: center;
    margin: 0 0 1.25em 0;
    padding: 0;
    transform: unset;
  }

  .module-carousel .carousel-listing {
    margin: 0 -0.5em;
    max-width: calc( 100% / 3);
    min-width: calc( 3 * var(--rem) );
  }

  .module-carousel .carousel-item {
    padding: 0 0.5em;
  }

  .module-carousel .carousel-headline {
    font-size: 1.2em;
  }

  .module-carousel .carousel-subtitle {
    font-size: 0.7em;
  }

  .module-carousel .carousel-nav {
    grid-column: 1;
    justify-self: center;
    margin: 1.25em 0 0 0;
    order: 2;
    transform: unset;
  }
}
/* jsloader//css file: assets/css/module-footer.css */
.module-footer {
  container: footer / inline-size;
  margin-bottom: 0;
}

.module-footer .footer-container {
  --rem: var(---rem, 100px);
  --grid: var(---grid, 100px);

  --color-background: var(---color-background, 231, 235, 240);
  --color-main-: var(---color-main-, 109, 4, 254);
  --color-font: var(---color-font, 119, 131, 146);

  display: grid;
  gap: 0 10%;
  grid-template-columns: 1fr 1fr 1fr auto;
}

.module-footer .footer-container:before {
  background: rgb( var(--color-background) );
  content: "";
  grid-column: -1 / 1;
  height: 1px;
  margin-bottom: 4em;
}

.module-footer .footer-container:after {
  content: "";
  grid-column: -1 / 1;
  grid-row: 3;
  height: 1px;
  margin-bottom: 4em;
}

.module-footer .module-logo {
  align-self: center;
}

.module-footer .module-social .social-list {
  margin: 0;
  padding: 0;
  flex-flow: column;
  gap: 2em;
}

.module-footer .module-social .social-text {
  display: none;
}

.module-footer .module-social .social-link:after {
  font-size: 1.5em;
}

.module-footer .module-logo {
  align-self: center;
}

.module-footer .module-inline {
  border-top: 1px solid rgb( var(--color-background) );
  grid-column: 1 / -1;
  grid-row: 4;
  padding: 1.5em 0;
}

.module-footer .module-inline:empty {
  display: none;
}

@container footer (max-width: 1440px) {
  .module-footer .footer-container {
    gap: 0 8%;
  }
}

@container footer (max-width: 1024px) {
  .module-footer .footer-container {
    gap: 2em;
    grid-template-columns: 1fr;
  }

  .module-footer .footer-container > *,
  .module-footer .footer-container:before,
  .module-footer .footer-container:after {
    grid-column: 1;
    grid-row: unset;
  }

  .module-footer .footer-container:before,
  .module-footer .footer-container:after {
    margin-bottom: var(--grid);
  }

  .module-footer .module-social .social-list {
    flex-flow: row wrap;
    margin: 0;    
  }
}
/* jsloader//css file: assets/css/module-submenu.css */
.module-submenu {
  container: submenu;
}

.module-submenu .submenu-container {
  --rem: var(---rem, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-main-: var(---color-main-, 109, 4, 254);
  --color-font-: var(---color-font-, 6, 16, 17);
}

.module-submenu .submenu-container > :first-child {
  margin-top: 0;
}

.module-submenu .submenu-heading {
  font-weight: 700;
  grid-column: 1 / -1;
  text-transform: uppercase;
}

.module-submenu .submenu-list {
  display: grid;
  gap: 1.5em 0.5em;
  grid-template-columns: auto auto;
  margin-top: 3em;
}

.module-submenu .submenu-link {
  color: rgb( var(--color-font-) );
  text-decoration: none;
  transition: color var(--animation-duration) var(--animation-timing-function);
}

.module-submenu .submenu-link:hover,
.module-submenu .submenu-link:focus {
  color: rgb( var(--color-main-) );  
}

@media only screen and (max-width: 1024px) {
  .module-submenu .submenu-list {
    margin-top: 1em;
  }
}
/* jsloader//css file: assets/css/module-inline.css */
.module-inline {
  container: inline;
}

.module-inline .inline-container {
  --rem: var(---rem, 100px);

  --animation-duration: var(---animation-duration, 0.2s);
  --animation-timing-function: var(---animation-timing-function, linear);

  --color-main-: var(---color-main-, 109, 4, 254);
  --color-font: var(---color-font, 119, 131, 146);

  display: flex;
  justify-content: center;
}

.module-inline .inline-item {
  align-items: center;
  display: flex;
  line-height: 1.25em;
}

.module-inline .inline-item:after {
  background: rgb( var(--color-font) );
  content: "";
  display: inline-block;
  height: 0.5em;
  margin: 0 1em;
  min-width: 1px;
  transform: rotate(10deg);
  width: 1px;
}

.module-inline .inline-item:last-child:after {
  display: none;
}

.module-inline .inline-link {
  color: rgb( var(--color-font) );
  display: inline-block;
  font-size: 0.7em;
  margin: -0.625em;
  padding: 0.625em;
  text-decoration: none;
  transition: color var(--animation-duration) var(--animation-timing-function);
}

.module-inline a:not(.inline-link) {
  color: rgb( var(--color-font-) );
  font-weight: 700;
  transition: color var(--animation-duration) var(--animation-timing-function);
  text-decoration: none;
}

.module-inline a:hover,
.module-inline a:focus {
  color: rgb( var(--color-main-) );
}
/* jsloader//css file: assets/css/module-cookies.css */
