html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  font-family: sans-serif;
}

body {
  margin: 0;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

audio, canvas, progress, video {
  vertical-align: baseline;
  display: inline-block;
}

audio:not([controls]) {
  height: 0;
  display: none;
}

[hidden], template {
  display: none;
}

a {
  background-color: #0000;
}

a:active, a:hover {
  outline: 0;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b, strong {
  font-weight: bold;
}

dfn {
  font-style: italic;
}

h1 {
  margin: .67em 0;
  font-size: 2em;
}

mark {
  color: #000;
  background: #ff0;
}

small {
  font-size: 80%;
}

sub, sup {
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
  position: relative;
}

sup {
  top: -.5em;
}

sub {
  bottom: -.25em;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}

hr {
  box-sizing: content-box;
  height: 0;
}

pre {
  overflow: auto;
}

code, kbd, pre, samp {
  font-family: monospace;
  font-size: 1em;
}

button, input, optgroup, select, textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}

button {
  overflow: visible;
}

button, select {
  text-transform: none;
}

button, html input[type="button"], input[type="reset"] {
  -webkit-appearance: button;
  cursor: pointer;
}

button[disabled], html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

input[type="checkbox"], input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

input[type="search"] {
  -webkit-appearance: none;
}

input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

legend {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

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

td, th {
  padding: 0;
}

@font-face {
  font-family: webflow-icons;
  src: url("data:application/x-font-ttf;charset=utf-8;base64,AAEAAAALAIAAAwAwT1MvMg8SBiUAAAC8AAAAYGNtYXDpP+a4AAABHAAAAFxnYXNwAAAAEAAAAXgAAAAIZ2x5ZmhS2XEAAAGAAAADHGhlYWQTFw3HAAAEnAAAADZoaGVhCXYFgQAABNQAAAAkaG10eCe4A1oAAAT4AAAAMGxvY2EDtALGAAAFKAAAABptYXhwABAAPgAABUQAAAAgbmFtZSoCsMsAAAVkAAABznBvc3QAAwAAAAAHNAAAACAAAwP4AZAABQAAApkCzAAAAI8CmQLMAAAB6wAzAQkAAAAAAAAAAAAAAAAAAAABEAAAAAAAAAAAAAAAAAAAAABAAADpAwPA/8AAQAPAAEAAAAABAAAAAAAAAAAAAAAgAAAAAAADAAAAAwAAABwAAQADAAAAHAADAAEAAAAcAAQAQAAAAAwACAACAAQAAQAg5gPpA//9//8AAAAAACDmAOkA//3//wAB/+MaBBcIAAMAAQAAAAAAAAAAAAAAAAABAAH//wAPAAEAAAAAAAAAAAACAAA3OQEAAAAAAQAAAAAAAAAAAAIAADc5AQAAAAABAAAAAAAAAAAAAgAANzkBAAAAAAEBIAAAAyADgAAFAAAJAQcJARcDIP5AQAGA/oBAAcABwED+gP6AQAABAOAAAALgA4AABQAAEwEXCQEH4AHAQP6AAYBAAcABwED+gP6AQAAAAwDAAOADQALAAA8AHwAvAAABISIGHQEUFjMhMjY9ATQmByEiBh0BFBYzITI2PQE0JgchIgYdARQWMyEyNj0BNCYDIP3ADRMTDQJADRMTDf3ADRMTDQJADRMTDf3ADRMTDQJADRMTAsATDSANExMNIA0TwBMNIA0TEw0gDRPAEw0gDRMTDSANEwAAAAABAJ0AtAOBApUABQAACQIHCQEDJP7r/upcAXEBcgKU/usBFVz+fAGEAAAAAAL//f+9BAMDwwAEAAkAABcBJwEXAwE3AQdpA5ps/GZsbAOabPxmbEMDmmz8ZmwDmvxmbAOabAAAAgAA/8AEAAPAAB0AOwAABSInLgEnJjU0Nz4BNzYzMTIXHgEXFhUUBw4BBwYjNTI3PgE3NjU0Jy4BJyYjMSIHDgEHBhUUFx4BFxYzAgBqXV6LKCgoKIteXWpqXV6LKCgoKIteXWpVSktvICEhIG9LSlVVSktvICEhIG9LSlVAKCiLXl1qal1eiygoKCiLXl1qal1eiygoZiEgb0tKVVVKS28gISEgb0tKVVVKS28gIQABAAABwAIAA8AAEgAAEzQ3PgE3NjMxFSIHDgEHBhUxIwAoKIteXWpVSktvICFmAcBqXV6LKChmISBvS0pVAAAAAgAA/8AFtgPAADIAOgAAARYXHgEXFhUUBw4BBwYHIxUhIicuAScmNTQ3PgE3NjMxOAExNDc+ATc2MzIXHgEXFhcVATMJATMVMzUEjD83NlAXFxYXTjU1PQL8kz01Nk8XFxcXTzY1PSIjd1BQWlJJSXInJw3+mdv+2/7c25MCUQYcHFg5OUA/ODlXHBwIAhcXTzY1PTw1Nk8XF1tQUHcjIhwcYUNDTgL+3QFt/pOTkwABAAAAAQAAmM7nP18PPPUACwQAAAAAANciZKUAAAAA1yJkpf/9/70FtgPDAAAACAACAAAAAAAAAAEAAAPA/8AAAAW3//3//QW2AAEAAAAAAAAAAAAAAAAAAAAMBAAAAAAAAAAAAAAAAgAAAAQAASAEAADgBAAAwAQAAJ0EAP/9BAAAAAQAAAAFtwAAAAAAAAAKABQAHgAyAEYAjACiAL4BFgE2AY4AAAABAAAADAA8AAMAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAADgCuAAEAAAAAAAEADQAAAAEAAAAAAAIABwCWAAEAAAAAAAMADQBIAAEAAAAAAAQADQCrAAEAAAAAAAUACwAnAAEAAAAAAAYADQBvAAEAAAAAAAoAGgDSAAMAAQQJAAEAGgANAAMAAQQJAAIADgCdAAMAAQQJAAMAGgBVAAMAAQQJAAQAGgC4AAMAAQQJAAUAFgAyAAMAAQQJAAYAGgB8AAMAAQQJAAoANADsd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzVmVyc2lvbiAxLjAAVgBlAHIAcwBpAG8AbgAgADEALgAwd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzUmVndWxhcgBSAGUAZwB1AGwAYQByd2ViZmxvdy1pY29ucwB3AGUAYgBmAGwAbwB3AC0AaQBjAG8AbgBzRm9udCBnZW5lcmF0ZWQgYnkgSWNvTW9vbi4ARgBvAG4AdAAgAGcAZQBuAGUAcgBhAHQAZQBkACAAYgB5ACAASQBjAG8ATQBvAG8AbgAuAAAAAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==") format("truetype");
  font-weight: normal;
  font-style: normal;
}

[class^="w-icon-"], [class*=" w-icon-"] {
  speak: none;
  font-variant: normal;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  font-family: webflow-icons !important;
}

.w-icon-slider-right:before {
  content: "";
}

.w-icon-slider-left:before {
  content: "";
}

.w-icon-nav-menu:before {
  content: "";
}

.w-icon-arrow-down:before, .w-icon-dropdown-toggle:before {
  content: "";
}

.w-icon-file-upload-remove:before {
  content: "";
}

.w-icon-file-upload-icon:before {
  content: "";
}

* {
  box-sizing: border-box;
}

html {
  height: 100%;
}

body {
  color: #333;
  background-color: #fff;
  min-height: 100%;
  margin: 0;
  font-family: Arial, sans-serif;
  font-size: 14px;
  line-height: 20px;
}

img {
  vertical-align: middle;
  max-width: 100%;
  display: inline-block;
}

html.w-mod-touch * {
  background-attachment: scroll !important;
}

.w-block {
  display: block;
}

.w-inline-block {
  max-width: 100%;
  display: inline-block;
}

.w-clearfix:before, .w-clearfix:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-clearfix:after {
  clear: both;
}

.w-hidden {
  display: none;
}

.w-button {
  color: #fff;
  line-height: inherit;
  cursor: pointer;
  background-color: #3898ec;
  border: 0;
  border-radius: 0;
  padding: 9px 15px;
  text-decoration: none;
  display: inline-block;
}

input.w-button {
  -webkit-appearance: button;
}

html[data-w-dynpage] [data-w-cloak] {
  color: #0000 !important;
}

.w-code-block {
  margin: unset;
}

pre.w-code-block code {
  all: inherit;
}

.w-optimization {
  display: contents;
}

.w-webflow-badge, .w-webflow-badge > img {
  box-sizing: unset;
  width: unset;
  height: unset;
  max-height: unset;
  max-width: unset;
  min-height: unset;
  min-width: unset;
  margin: unset;
  padding: unset;
  float: unset;
  clear: unset;
  border: unset;
  border-radius: unset;
  background: unset;
  background-image: unset;
  background-position: unset;
  background-size: unset;
  background-repeat: unset;
  background-origin: unset;
  background-clip: unset;
  background-attachment: unset;
  background-color: unset;
  box-shadow: unset;
  transform: unset;
  direction: unset;
  font-family: unset;
  font-weight: unset;
  color: unset;
  font-size: unset;
  line-height: unset;
  font-style: unset;
  font-variant: unset;
  text-align: unset;
  letter-spacing: unset;
  -webkit-text-decoration: unset;
  text-decoration: unset;
  text-indent: unset;
  text-transform: unset;
  list-style-type: unset;
  text-shadow: unset;
  vertical-align: unset;
  cursor: unset;
  white-space: unset;
  word-break: unset;
  word-spacing: unset;
  word-wrap: unset;
  transition: unset;
}

.w-webflow-badge {
  white-space: nowrap;
  cursor: pointer;
  box-shadow: 0 0 0 1px #0000001a, 0 1px 3px #0000001a;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: 2147483647 !important;
  color: #aaadb0 !important;
  overflow: unset !important;
  background-color: #fff !important;
  border-radius: 3px !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 6px !important;
  font-size: 12px !important;
  line-height: 14px !important;
  text-decoration: none !important;
  display: inline-block !important;
  position: fixed !important;
  inset: auto 12px 12px auto !important;
  transform: none !important;
}

.w-webflow-badge > img {
  position: unset;
  visibility: unset !important;
  opacity: 1 !important;
  vertical-align: middle !important;
  display: inline-block !important;
}

h1, h2, h3, h4, h5, h6 {
  margin-bottom: 10px;
  font-weight: bold;
}

h1 {
  margin-top: 20px;
  font-size: 38px;
  line-height: 44px;
}

h2 {
  margin-top: 20px;
  font-size: 32px;
  line-height: 36px;
}

h3 {
  margin-top: 20px;
  font-size: 24px;
  line-height: 30px;
}

h4 {
  margin-top: 10px;
  font-size: 18px;
  line-height: 24px;
}

h5 {
  margin-top: 10px;
  font-size: 14px;
  line-height: 20px;
}

h6 {
  margin-top: 10px;
  font-size: 12px;
  line-height: 18px;
}

p {
  margin-top: 0;
  margin-bottom: 10px;
}

blockquote {
  border-left: 5px solid #e2e2e2;
  margin: 0 0 10px;
  padding: 10px 20px;
  font-size: 18px;
  line-height: 22px;
}

figure {
  margin: 0 0 10px;
}

ul, ol {
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 40px;
}

.w-list-unstyled {
  padding-left: 0;
  list-style: none;
}

.w-embed:before, .w-embed:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-embed:after {
  clear: both;
}

.w-video {
  width: 100%;
  padding: 0;
  position: relative;
}

.w-video iframe, .w-video object, .w-video embed {
  border: none;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

button, [type="button"], [type="reset"] {
  cursor: pointer;
  -webkit-appearance: button;
  border: 0;
}

.w-form {
  margin: 0 0 15px;
}

.w-form-done {
  text-align: center;
  background-color: #ddd;
  padding: 20px;
  display: none;
}

.w-form-fail {
  background-color: #ffdede;
  margin-top: 10px;
  padding: 10px;
  display: none;
}

label {
  margin-bottom: 5px;
  font-weight: bold;
  display: block;
}

.w-input, .w-select {
  color: #333;
  vertical-align: middle;
  background-color: #fff;
  border: 1px solid #ccc;
  width: 100%;
  height: 38px;
  margin-bottom: 10px;
  padding: 8px 12px;
  font-size: 14px;
  line-height: 1.42857;
  display: block;
}

.w-input::placeholder, .w-select::placeholder {
  color: #999;
}

.w-input:focus, .w-select:focus {
  border-color: #3898ec;
  outline: 0;
}

.w-input[disabled], .w-select[disabled], .w-input[readonly], .w-select[readonly], fieldset[disabled] .w-input, fieldset[disabled] .w-select {
  cursor: not-allowed;
}

.w-input[disabled]:not(.w-input-disabled), .w-select[disabled]:not(.w-input-disabled), .w-input[readonly], .w-select[readonly], fieldset[disabled]:not(.w-input-disabled) .w-input, fieldset[disabled]:not(.w-input-disabled) .w-select {
  background-color: #eee;
}

textarea.w-input, textarea.w-select {
  height: auto;
}

.w-select {
  background-color: #f3f3f3;
}

.w-select[multiple] {
  height: auto;
}

.w-form-label {
  cursor: pointer;
  margin-bottom: 0;
  font-weight: normal;
  display: inline-block;
}

.w-radio {
  margin-bottom: 5px;
  padding-left: 20px;
  display: block;
}

.w-radio:before, .w-radio:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-radio:after {
  clear: both;
}

.w-radio-input {
  float: left;
  margin: 3px 0 0 -20px;
  line-height: normal;
}

.w-file-upload {
  margin-bottom: 10px;
  display: block;
}

.w-file-upload-input {
  opacity: 0;
  z-index: -100;
  width: .1px;
  height: .1px;
  position: absolute;
  overflow: hidden;
}

.w-file-upload-default, .w-file-upload-uploading, .w-file-upload-success {
  color: #333;
  display: inline-block;
}

.w-file-upload-error {
  margin-top: 10px;
  display: block;
}

.w-file-upload-default.w-hidden, .w-file-upload-uploading.w-hidden, .w-file-upload-error.w-hidden, .w-file-upload-success.w-hidden {
  display: none;
}

.w-file-upload-uploading-btn {
  cursor: pointer;
  background-color: #fafafa;
  border: 1px solid #ccc;
  margin: 0;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: normal;
  display: flex;
}

.w-file-upload-file {
  background-color: #fafafa;
  border: 1px solid #ccc;
  flex-grow: 1;
  justify-content: space-between;
  margin: 0;
  padding: 8px 9px 8px 11px;
  display: flex;
}

.w-file-upload-file-name {
  font-size: 14px;
  font-weight: normal;
  display: block;
}

.w-file-remove-link {
  cursor: pointer;
  width: auto;
  height: auto;
  margin-top: 3px;
  margin-left: 10px;
  padding: 3px;
  display: block;
}

.w-icon-file-upload-remove {
  margin: auto;
  font-size: 10px;
}

.w-file-upload-error-msg {
  color: #ea384c;
  padding: 2px 0;
  display: inline-block;
}

.w-file-upload-info {
  padding: 0 12px;
  line-height: 38px;
  display: inline-block;
}

.w-file-upload-label {
  cursor: pointer;
  background-color: #fafafa;
  border: 1px solid #ccc;
  margin: 0;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: normal;
  display: inline-block;
}

.w-icon-file-upload-icon, .w-icon-file-upload-uploading {
  width: 20px;
  margin-right: 8px;
  display: inline-block;
}

.w-icon-file-upload-uploading {
  height: 20px;
}

.w-container {
  max-width: 940px;
  margin-left: auto;
  margin-right: auto;
}

.w-container:before, .w-container:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-container:after {
  clear: both;
}

.w-container .w-row {
  margin-left: -10px;
  margin-right: -10px;
}

.w-row:before, .w-row:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-row:after {
  clear: both;
}

.w-row .w-row {
  margin-left: 0;
  margin-right: 0;
}

.w-col {
  float: left;
  width: 100%;
  min-height: 1px;
  padding-left: 10px;
  padding-right: 10px;
  position: relative;
}

.w-col .w-col {
  padding-left: 0;
  padding-right: 0;
}

.w-col-1 {
  width: 8.33333%;
}

.w-col-2 {
  width: 16.6667%;
}

.w-col-3 {
  width: 25%;
}

.w-col-4 {
  width: 33.3333%;
}

.w-col-5 {
  width: 41.6667%;
}

.w-col-6 {
  width: 50%;
}

.w-col-7 {
  width: 58.3333%;
}

.w-col-8 {
  width: 66.6667%;
}

.w-col-9 {
  width: 75%;
}

.w-col-10 {
  width: 83.3333%;
}

.w-col-11 {
  width: 91.6667%;
}

.w-col-12 {
  width: 100%;
}

.w-hidden-main {
  display: none !important;
}

@media screen and (max-width: 991px) {
  .w-container {
    max-width: 728px;
  }

  .w-hidden-main {
    display: inherit !important;
  }

  .w-hidden-medium {
    display: none !important;
  }

  .w-col-medium-1 {
    width: 8.33333%;
  }

  .w-col-medium-2 {
    width: 16.6667%;
  }

  .w-col-medium-3 {
    width: 25%;
  }

  .w-col-medium-4 {
    width: 33.3333%;
  }

  .w-col-medium-5 {
    width: 41.6667%;
  }

  .w-col-medium-6 {
    width: 50%;
  }

  .w-col-medium-7 {
    width: 58.3333%;
  }

  .w-col-medium-8 {
    width: 66.6667%;
  }

  .w-col-medium-9 {
    width: 75%;
  }

  .w-col-medium-10 {
    width: 83.3333%;
  }

  .w-col-medium-11 {
    width: 91.6667%;
  }

  .w-col-medium-12 {
    width: 100%;
  }

  .w-col-stack {
    width: 100%;
    left: auto;
    right: auto;
  }
}

@media screen and (max-width: 767px) {
  .w-hidden-main, .w-hidden-medium {
    display: inherit !important;
  }

  .w-hidden-small {
    display: none !important;
  }

  .w-row, .w-container .w-row {
    margin-left: 0;
    margin-right: 0;
  }

  .w-col {
    width: 100%;
    left: auto;
    right: auto;
  }

  .w-col-small-1 {
    width: 8.33333%;
  }

  .w-col-small-2 {
    width: 16.6667%;
  }

  .w-col-small-3 {
    width: 25%;
  }

  .w-col-small-4 {
    width: 33.3333%;
  }

  .w-col-small-5 {
    width: 41.6667%;
  }

  .w-col-small-6 {
    width: 50%;
  }

  .w-col-small-7 {
    width: 58.3333%;
  }

  .w-col-small-8 {
    width: 66.6667%;
  }

  .w-col-small-9 {
    width: 75%;
  }

  .w-col-small-10 {
    width: 83.3333%;
  }

  .w-col-small-11 {
    width: 91.6667%;
  }

  .w-col-small-12 {
    width: 100%;
  }
}

@media screen and (max-width: 479px) {
  .w-container {
    max-width: none;
  }

  .w-hidden-main, .w-hidden-medium, .w-hidden-small {
    display: inherit !important;
  }

  .w-hidden-tiny {
    display: none !important;
  }

  .w-col {
    width: 100%;
  }

  .w-col-tiny-1 {
    width: 8.33333%;
  }

  .w-col-tiny-2 {
    width: 16.6667%;
  }

  .w-col-tiny-3 {
    width: 25%;
  }

  .w-col-tiny-4 {
    width: 33.3333%;
  }

  .w-col-tiny-5 {
    width: 41.6667%;
  }

  .w-col-tiny-6 {
    width: 50%;
  }

  .w-col-tiny-7 {
    width: 58.3333%;
  }

  .w-col-tiny-8 {
    width: 66.6667%;
  }

  .w-col-tiny-9 {
    width: 75%;
  }

  .w-col-tiny-10 {
    width: 83.3333%;
  }

  .w-col-tiny-11 {
    width: 91.6667%;
  }

  .w-col-tiny-12 {
    width: 100%;
  }
}

.w-widget {
  position: relative;
}

.w-widget-map {
  width: 100%;
  height: 400px;
}

.w-widget-map label {
  width: auto;
  display: inline;
}

.w-widget-map img {
  max-width: inherit;
}

.w-widget-map .gm-style-iw {
  text-align: center;
}

.w-widget-map .gm-style-iw > button {
  display: none !important;
}

.w-widget-twitter {
  overflow: hidden;
}

.w-widget-twitter-count-shim {
  vertical-align: top;
  text-align: center;
  background: #fff;
  border: 1px solid #758696;
  border-radius: 3px;
  width: 28px;
  height: 20px;
  display: inline-block;
  position: relative;
}

.w-widget-twitter-count-shim * {
  pointer-events: none;
  -webkit-user-select: none;
  user-select: none;
}

.w-widget-twitter-count-shim .w-widget-twitter-count-inner {
  text-align: center;
  color: #999;
  font-family: serif;
  font-size: 15px;
  line-height: 12px;
  position: relative;
}

.w-widget-twitter-count-shim .w-widget-twitter-count-clear {
  display: block;
  position: relative;
}

.w-widget-twitter-count-shim.w--large {
  width: 36px;
  height: 28px;
}

.w-widget-twitter-count-shim.w--large .w-widget-twitter-count-inner {
  font-size: 18px;
  line-height: 18px;
}

.w-widget-twitter-count-shim:not(.w--vertical) {
  margin-left: 5px;
  margin-right: 8px;
}

.w-widget-twitter-count-shim:not(.w--vertical).w--large {
  margin-left: 6px;
}

.w-widget-twitter-count-shim:not(.w--vertical):before, .w-widget-twitter-count-shim:not(.w--vertical):after {
  content: " ";
  pointer-events: none;
  border: solid #0000;
  width: 0;
  height: 0;
  position: absolute;
  top: 50%;
  left: 0;
}

.w-widget-twitter-count-shim:not(.w--vertical):before {
  border-width: 4px;
  border-color: #75869600 #5d6c7b #75869600 #75869600;
  margin-top: -4px;
  margin-left: -9px;
}

.w-widget-twitter-count-shim:not(.w--vertical).w--large:before {
  border-width: 5px;
  margin-top: -5px;
  margin-left: -10px;
}

.w-widget-twitter-count-shim:not(.w--vertical):after {
  border-width: 4px;
  border-color: #fff0 #fff #fff0 #fff0;
  margin-top: -4px;
  margin-left: -8px;
}

.w-widget-twitter-count-shim:not(.w--vertical).w--large:after {
  border-width: 5px;
  margin-top: -5px;
  margin-left: -9px;
}

.w-widget-twitter-count-shim.w--vertical {
  width: 61px;
  height: 33px;
  margin-bottom: 8px;
}

.w-widget-twitter-count-shim.w--vertical:before, .w-widget-twitter-count-shim.w--vertical:after {
  content: " ";
  pointer-events: none;
  border: solid #0000;
  width: 0;
  height: 0;
  position: absolute;
  top: 100%;
  left: 50%;
}

.w-widget-twitter-count-shim.w--vertical:before {
  border-width: 5px;
  border-color: #5d6c7b #75869600 #75869600;
  margin-left: -5px;
}

.w-widget-twitter-count-shim.w--vertical:after {
  border-width: 4px;
  border-color: #fff #fff0 #fff0;
  margin-left: -4px;
}

.w-widget-twitter-count-shim.w--vertical .w-widget-twitter-count-inner {
  font-size: 18px;
  line-height: 22px;
}

.w-widget-twitter-count-shim.w--vertical.w--large {
  width: 76px;
}

.w-background-video {
  color: #fff;
  height: 500px;
  position: relative;
  overflow: hidden;
}

.w-background-video > video {
  object-fit: cover;
  z-index: -100;
  background-position: 50%;
  background-size: cover;
  width: 100%;
  height: 100%;
  margin: auto;
  position: absolute;
  inset: -100%;
}

.w-background-video > video::-webkit-media-controls-start-playback-button {
  -webkit-appearance: none;
  display: none !important;
}

.w-background-video--control {
  background-color: #0000;
  padding: 0;
  position: absolute;
  bottom: 1em;
  right: 1em;
}

.w-background-video--control > [hidden] {
  display: none !important;
}

.w-slider {
  text-align: center;
  clear: both;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  background: #ddd;
  height: 300px;
  position: relative;
}

.w-slider-mask {
  z-index: 1;
  white-space: nowrap;
  height: 100%;
  display: block;
  position: relative;
  left: 0;
  right: 0;
  overflow: hidden;
}

.w-slide {
  vertical-align: top;
  white-space: normal;
  text-align: left;
  width: 100%;
  height: 100%;
  display: inline-block;
  position: relative;
}

.w-slider-nav {
  z-index: 2;
  text-align: center;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  height: 40px;
  margin: auto;
  padding-top: 10px;
  position: absolute;
  inset: auto 0 0;
}

.w-slider-nav.w-round > div {
  border-radius: 100%;
}

.w-slider-nav.w-num > div {
  font-size: inherit;
  line-height: inherit;
  width: auto;
  height: auto;
  padding: .2em .5em;
}

.w-slider-nav.w-shadow > div {
  box-shadow: 0 0 3px #3336;
}

.w-slider-nav-invert {
  color: #fff;
}

.w-slider-nav-invert > div {
  background-color: #2226;
}

.w-slider-nav-invert > div.w-active {
  background-color: #222;
}

.w-slider-dot {
  cursor: pointer;
  background-color: #fff6;
  width: 1em;
  height: 1em;
  margin: 0 3px .5em;
  transition: background-color .1s, color .1s;
  display: inline-block;
  position: relative;
}

.w-slider-dot.w-active {
  background-color: #fff;
}

.w-slider-dot:focus {
  outline: none;
  box-shadow: 0 0 0 2px #fff;
}

.w-slider-dot:focus.w-active {
  box-shadow: none;
}

.w-slider-arrow-left, .w-slider-arrow-right {
  cursor: pointer;
  color: #fff;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  -webkit-user-select: none;
  user-select: none;
  width: 80px;
  margin: auto;
  font-size: 40px;
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.w-slider-arrow-left [class^="w-icon-"], .w-slider-arrow-right [class^="w-icon-"], .w-slider-arrow-left [class*=" w-icon-"], .w-slider-arrow-right [class*=" w-icon-"] {
  position: absolute;
}

.w-slider-arrow-left:focus, .w-slider-arrow-right:focus {
  outline: 0;
}

.w-slider-arrow-left {
  z-index: 3;
  right: auto;
}

.w-slider-arrow-right {
  z-index: 4;
  left: auto;
}

.w-icon-slider-left, .w-icon-slider-right {
  width: 1em;
  height: 1em;
  margin: auto;
  inset: 0;
}

.w-slider-aria-label {
  clip: rect(0 0 0 0);
  border: 0;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  position: absolute;
  overflow: hidden;
}

.w-slider-force-show {
  display: block !important;
}

.w-dropdown {
  text-align: left;
  z-index: 900;
  margin-left: auto;
  margin-right: auto;
  display: inline-block;
  position: relative;
}

.w-dropdown-btn, .w-dropdown-toggle, .w-dropdown-link {
  vertical-align: top;
  color: #222;
  text-align: left;
  white-space: nowrap;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  text-decoration: none;
  position: relative;
}

.w-dropdown-toggle {
  -webkit-user-select: none;
  user-select: none;
  cursor: pointer;
  padding-right: 40px;
  display: inline-block;
}

.w-dropdown-toggle:focus {
  outline: 0;
}

.w-icon-dropdown-toggle {
  width: 1em;
  height: 1em;
  margin: auto 20px auto auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
}

.w-dropdown-list {
  background: #ddd;
  min-width: 100%;
  display: none;
  position: absolute;
}

.w-dropdown-list.w--open {
  display: block;
}

.w-dropdown-link {
  color: #222;
  padding: 10px 20px;
  display: block;
}

.w-dropdown-link.w--current {
  color: #0082f3;
}

.w-dropdown-link:focus {
  outline: 0;
}

@media screen and (max-width: 767px) {
  .w-nav-brand {
    padding-left: 10px;
  }
}

.w-lightbox-backdrop {
  cursor: auto;
  letter-spacing: normal;
  text-indent: 0;
  text-shadow: none;
  text-transform: none;
  visibility: visible;
  white-space: normal;
  word-break: normal;
  word-spacing: normal;
  word-wrap: normal;
  color: #fff;
  text-align: center;
  z-index: 2000;
  opacity: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -webkit-tap-highlight-color: transparent;
  background: #000000e6;
  outline: 0;
  font-family: Helvetica Neue, Helvetica, Ubuntu, Segoe UI, Verdana, sans-serif;
  font-size: 17px;
  font-style: normal;
  font-weight: 300;
  line-height: 1.2;
  list-style: disc;
  position: fixed;
  inset: 0;
  -webkit-transform: translate(0);
}

.w-lightbox-backdrop, .w-lightbox-container {
  -webkit-overflow-scrolling: touch;
  height: 100%;
  overflow: auto;
}

.w-lightbox-content {
  height: 100vh;
  position: relative;
  overflow: hidden;
}

.w-lightbox-view {
  opacity: 0;
  width: 100vw;
  height: 100vh;
  position: absolute;
}

.w-lightbox-view:before {
  content: "";
  height: 100vh;
}

.w-lightbox-group, .w-lightbox-group .w-lightbox-view, .w-lightbox-group .w-lightbox-view:before {
  height: 86vh;
}

.w-lightbox-frame, .w-lightbox-view:before {
  vertical-align: middle;
  display: inline-block;
}

.w-lightbox-figure {
  margin: 0;
  position: relative;
}

.w-lightbox-group .w-lightbox-figure {
  cursor: pointer;
}

.w-lightbox-img {
  width: auto;
  max-width: none;
  height: auto;
}

.w-lightbox-image {
  float: none;
  max-width: 100vw;
  max-height: 100vh;
  display: block;
}

.w-lightbox-group .w-lightbox-image {
  max-height: 86vh;
}

.w-lightbox-caption {
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
  background: #0006;
  padding: .5em 1em;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  overflow: hidden;
}

.w-lightbox-embed {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.w-lightbox-control {
  cursor: pointer;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 24px;
  width: 4em;
  transition: all .3s;
  position: absolute;
  top: 0;
}

.w-lightbox-left {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii0yMCAwIDI0IDQwIiB3aWR0aD0iMjQiIGhlaWdodD0iNDAiPjxnIHRyYW5zZm9ybT0icm90YXRlKDQ1KSI+PHBhdGggZD0ibTAgMGg1djIzaDIzdjVoLTI4eiIgb3BhY2l0eT0iLjQiLz48cGF0aCBkPSJtMSAxaDN2MjNoMjN2M2gtMjZ6IiBmaWxsPSIjZmZmIi8+PC9nPjwvc3ZnPg==");
  display: none;
  bottom: 0;
  left: 0;
}

.w-lightbox-right {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii00IDAgMjQgNDAiIHdpZHRoPSIyNCIgaGVpZ2h0PSI0MCI+PGcgdHJhbnNmb3JtPSJyb3RhdGUoNDUpIj48cGF0aCBkPSJtMC0waDI4djI4aC01di0yM2gtMjN6IiBvcGFjaXR5PSIuNCIvPjxwYXRoIGQ9Im0xIDFoMjZ2MjZoLTN2LTIzaC0yM3oiIGZpbGw9IiNmZmYiLz48L2c+PC9zdmc+");
  display: none;
  bottom: 0;
  right: 0;
}

.w-lightbox-close {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9Ii00IDAgMTggMTciIHdpZHRoPSIxOCIgaGVpZ2h0PSIxNyI+PGcgdHJhbnNmb3JtPSJyb3RhdGUoNDUpIj48cGF0aCBkPSJtMCAwaDd2LTdoNXY3aDd2NWgtN3Y3aC01di03aC03eiIgb3BhY2l0eT0iLjQiLz48cGF0aCBkPSJtMSAxaDd2LTdoM3Y3aDd2M2gtN3Y3aC0zdi03aC03eiIgZmlsbD0iI2ZmZiIvPjwvZz48L3N2Zz4=");
  background-size: 18px;
  height: 2.6em;
  right: 0;
}

.w-lightbox-strip {
  white-space: nowrap;
  padding: 0 1vh;
  line-height: 0;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  overflow: auto hidden;
}

.w-lightbox-item {
  box-sizing: content-box;
  cursor: pointer;
  width: 10vh;
  padding: 2vh 1vh;
  display: inline-block;
  -webkit-transform: translate3d(0, 0, 0);
}

.w-lightbox-active {
  opacity: .3;
}

.w-lightbox-thumbnail {
  background: #222;
  height: 10vh;
  position: relative;
  overflow: hidden;
}

.w-lightbox-thumbnail-image {
  position: absolute;
  top: 0;
  left: 0;
}

.w-lightbox-thumbnail .w-lightbox-tall {
  width: 100%;
  top: 50%;
  transform: translate(0, -50%);
}

.w-lightbox-thumbnail .w-lightbox-wide {
  height: 100%;
  left: 50%;
  transform: translate(-50%);
}

.w-lightbox-spinner {
  box-sizing: border-box;
  border: 5px solid #0006;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  margin-top: -20px;
  margin-left: -20px;
  animation: .8s linear infinite spin;
  position: absolute;
  top: 50%;
  left: 50%;
}

.w-lightbox-spinner:after {
  content: "";
  border: 3px solid #0000;
  border-bottom-color: #fff;
  border-radius: 50%;
  position: absolute;
  inset: -4px;
}

.w-lightbox-hide {
  display: none;
}

.w-lightbox-noscroll {
  overflow: hidden;
}

@media (min-width: 768px) {
  .w-lightbox-content {
    height: 96vh;
    margin-top: 2vh;
  }

  .w-lightbox-view, .w-lightbox-view:before {
    height: 96vh;
  }

  .w-lightbox-group, .w-lightbox-group .w-lightbox-view, .w-lightbox-group .w-lightbox-view:before {
    height: 84vh;
  }

  .w-lightbox-image {
    max-width: 96vw;
    max-height: 96vh;
  }

  .w-lightbox-group .w-lightbox-image {
    max-width: 82.3vw;
    max-height: 84vh;
  }

  .w-lightbox-left, .w-lightbox-right {
    opacity: .5;
    display: block;
  }

  .w-lightbox-close {
    opacity: .8;
  }

  .w-lightbox-control:hover {
    opacity: 1;
  }
}

.w-lightbox-inactive, .w-lightbox-inactive:hover {
  opacity: 0;
}

.w-richtext:before, .w-richtext:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-richtext:after {
  clear: both;
}

.w-richtext[contenteditable="true"]:before, .w-richtext[contenteditable="true"]:after {
  white-space: initial;
}

.w-richtext ol, .w-richtext ul {
  overflow: hidden;
}

.w-richtext .w-richtext-figure-selected.w-richtext-figure-type-video div:after, .w-richtext .w-richtext-figure-selected[data-rt-type="video"] div:after, .w-richtext .w-richtext-figure-selected.w-richtext-figure-type-image div, .w-richtext .w-richtext-figure-selected[data-rt-type="image"] div {
  outline: 2px solid #2895f7;
}

.w-richtext figure.w-richtext-figure-type-video > div:after, .w-richtext figure[data-rt-type="video"] > div:after {
  content: "";
  display: none;
  position: absolute;
  inset: 0;
}

.w-richtext figure {
  max-width: 60%;
  position: relative;
}

.w-richtext figure > div:before {
  cursor: default !important;
}

.w-richtext figure img {
  width: 100%;
}

.w-richtext figure figcaption.w-richtext-figcaption-placeholder {
  opacity: .6;
}

.w-richtext figure div {
  color: #0000;
  font-size: 0;
}

.w-richtext figure.w-richtext-figure-type-image, .w-richtext figure[data-rt-type="image"] {
  display: table;
}

.w-richtext figure.w-richtext-figure-type-image > div, .w-richtext figure[data-rt-type="image"] > div {
  display: inline-block;
}

.w-richtext figure.w-richtext-figure-type-image > figcaption, .w-richtext figure[data-rt-type="image"] > figcaption {
  caption-side: bottom;
  display: table-caption;
}

.w-richtext figure.w-richtext-figure-type-video, .w-richtext figure[data-rt-type="video"] {
  width: 60%;
  height: 0;
}

.w-richtext figure.w-richtext-figure-type-video iframe, .w-richtext figure[data-rt-type="video"] iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.w-richtext figure.w-richtext-figure-type-video > div, .w-richtext figure[data-rt-type="video"] > div {
  width: 100%;
}

.w-richtext figure.w-richtext-align-center {
  clear: both;
  margin-left: auto;
  margin-right: auto;
}

.w-richtext figure.w-richtext-align-center.w-richtext-figure-type-image > div, .w-richtext figure.w-richtext-align-center[data-rt-type="image"] > div {
  max-width: 100%;
}

.w-richtext figure.w-richtext-align-normal {
  clear: both;
}

.w-richtext figure.w-richtext-align-fullwidth {
  text-align: center;
  clear: both;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  display: block;
}

.w-richtext figure.w-richtext-align-fullwidth > div {
  padding-bottom: inherit;
  display: inline-block;
}

.w-richtext figure.w-richtext-align-fullwidth > figcaption {
  display: block;
}

.w-richtext figure.w-richtext-align-floatleft {
  float: left;
  clear: none;
  margin-right: 15px;
}

.w-richtext figure.w-richtext-align-floatright {
  float: right;
  clear: none;
  margin-left: 15px;
}

.w-nav {
  z-index: 1000;
  background: #ddd;
  position: relative;
}

.w-nav:before, .w-nav:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-nav:after {
  clear: both;
}

.w-nav-brand {
  float: left;
  color: #333;
  text-decoration: none;
  position: relative;
}

.w-nav-link {
  vertical-align: top;
  color: #222;
  text-align: left;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.w-nav-link.w--current {
  color: #0082f3;
}

.w-nav-menu {
  float: right;
  position: relative;
}

[data-nav-menu-open] {
  text-align: center;
  background: #c8c8c8;
  min-width: 200px;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  overflow: visible;
  display: block !important;
}

.w--nav-link-open {
  display: block;
  position: relative;
}

.w-nav-overlay {
  width: 100%;
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  overflow: hidden;
}

.w-nav-overlay [data-nav-menu-open] {
  top: 0;
}

.w-nav[data-animation="over-left"] .w-nav-overlay {
  width: auto;
}

.w-nav[data-animation="over-left"] .w-nav-overlay, .w-nav[data-animation="over-left"] [data-nav-menu-open] {
  z-index: 1;
  top: 0;
  right: auto;
}

.w-nav[data-animation="over-right"] .w-nav-overlay {
  width: auto;
}

.w-nav[data-animation="over-right"] .w-nav-overlay, .w-nav[data-animation="over-right"] [data-nav-menu-open] {
  z-index: 1;
  top: 0;
  left: auto;
}

.w-nav-button {
  float: right;
  cursor: pointer;
  -webkit-tap-highlight-color: #0000;
  tap-highlight-color: #0000;
  -webkit-user-select: none;
  user-select: none;
  padding: 18px;
  font-size: 24px;
  display: none;
  position: relative;
}

.w-nav-button:focus {
  outline: 0;
}

.w-nav-button.w--open {
  color: #fff;
  background-color: #c8c8c8;
}

.w-nav[data-collapse="all"] .w-nav-menu {
  display: none;
}

.w-nav[data-collapse="all"] .w-nav-button, .w--nav-dropdown-open, .w--nav-dropdown-toggle-open {
  display: block;
}

.w--nav-dropdown-list-open {
  position: static;
}

@media screen and (max-width: 991px) {
  .w-nav[data-collapse="medium"] .w-nav-menu {
    display: none;
  }

  .w-nav[data-collapse="medium"] .w-nav-button {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .w-nav[data-collapse="small"] .w-nav-menu {
    display: none;
  }

  .w-nav[data-collapse="small"] .w-nav-button {
    display: block;
  }

  .w-nav-brand {
    padding-left: 10px;
  }
}

@media screen and (max-width: 479px) {
  .w-nav[data-collapse="tiny"] .w-nav-menu {
    display: none;
  }

  .w-nav[data-collapse="tiny"] .w-nav-button {
    display: block;
  }
}

.w-tabs {
  position: relative;
}

.w-tabs:before, .w-tabs:after {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-tabs:after {
  clear: both;
}

.w-tab-menu {
  position: relative;
}

.w-tab-link {
  vertical-align: top;
  text-align: left;
  cursor: pointer;
  color: #222;
  background-color: #ddd;
  padding: 9px 30px;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.w-tab-link.w--current {
  background-color: #c8c8c8;
}

.w-tab-link:focus {
  outline: 0;
}

.w-tab-content {
  display: block;
  position: relative;
  overflow: hidden;
}

.w-tab-pane {
  display: none;
  position: relative;
}

.w--tab-active {
  display: block;
}

@media screen and (max-width: 479px) {
  .w-tab-link {
    display: block;
  }
}

.w-ix-emptyfix:after {
  content: "";
}

@keyframes spin {
  0% {
    transform: rotate(0);
  }

  100% {
    transform: rotate(360deg);
  }
}

.w-dyn-empty {
  background-color: #ddd;
  padding: 10px;
}

.w-dyn-hide, .w-dyn-bind-empty, .w-condition-invisible {
  display: none !important;
}

.wf-layout-layout {
  display: grid;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c00_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bff_font.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c01_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c02_font.woff") format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c04_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c03_font.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c10_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c05_font.woff") format("woff");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c12_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c11_font.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c13_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c14_font.woff") format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c16_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c15_font.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Eina04;
  src: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c18_font.woff2") format("woff2"), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c17_font.woff") format("woff");
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

:root {
  --dark-slate-grey: #325b6d;
  --midnight-blue: #00344a;
  --bg-color: #fafafa;
  --white-smoke: #edeff1;
  --white: white;
  --dodger-blue: #009ddc;
  --border-blue: #c8dae2;
  --border: #e1eaee;
  --border-negative: #ffffff80;
}

.w-checkbox {
  margin-bottom: 5px;
  padding-left: 20px;
  display: block;
}

.w-checkbox:before {
  content: " ";
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox:after {
  content: " ";
  clear: both;
  grid-area: 1 / 1 / 2 / 2;
  display: table;
}

.w-checkbox-input {
  float: left;
  margin: 4px 0 0 -20px;
  line-height: normal;
}

.w-checkbox-input--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 2px;
  width: 12px;
  height: 12px;
}

.w-checkbox-input--inputType-custom.w--redirected-checked {
  background-color: #3898ec;
  background-image: url("https://d3e54v103j8qbb.cloudfront.net/static/custom-checkbox-checkmark.589d534424.svg");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  border-color: #3898ec;
}

.w-checkbox-input--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-pagination-wrapper {
  flex-wrap: wrap;
  justify-content: center;
  display: flex;
}

.w-pagination-previous {
  color: #333;
  background-color: #fafafa;
  border: 1px solid #ccc;
  border-radius: 2px;
  margin-left: 10px;
  margin-right: 10px;
  padding: 9px 20px;
  font-size: 14px;
  display: block;
}

.w-pagination-previous-icon {
  margin-right: 4px;
}

.w-pagination-next {
  color: #333;
  background-color: #fafafa;
  border: 1px solid #ccc;
  border-radius: 2px;
  margin-left: 10px;
  margin-right: 10px;
  padding: 9px 20px;
  font-size: 14px;
  display: block;
}

.w-form-formradioinput--inputType-custom {
  border: 1px solid #ccc;
  border-radius: 50%;
  width: 12px;
  height: 12px;
}

.w-form-formradioinput--inputType-custom.w--redirected-focus {
  box-shadow: 0 0 3px 1px #3898ec;
}

.w-form-formradioinput--inputType-custom.w--redirected-checked {
  border-width: 4px;
  border-color: #3898ec;
}

body {
  color: var(--dark-slate-grey);
  letter-spacing: -.28px;
  background-color: #fafafa;
  font-family: Eina04, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
}

h1 {
  color: var(--midnight-blue);
  letter-spacing: -4.8px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 80px;
  font-weight: 400;
  line-height: 1;
}

h2 {
  color: var(--midnight-blue);
  letter-spacing: -1.36px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 32px;
  font-weight: 400;
  line-height: 40px;
}

h3 {
  color: var(--midnight-blue);
  letter-spacing: -1.12px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 28px;
  font-weight: 400;
  line-height: 34px;
}

h4 {
  color: var(--midnight-blue);
  letter-spacing: -.32px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 22px;
}

h5 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
}

h6 {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
}

p {
  margin-bottom: 0;
  line-height: 22px;
}

a {
  color: var(--dark-slate-grey);
  text-decoration: underline;
}

ul {
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 40px;
}

img {
  max-width: 100%;
  display: inline-block;
}

strong {
  font-weight: bold;
}

blockquote {
  border-left: 5px solid #e2e2e2;
  margin-bottom: 10px;
  padding: 10px 20px;
  font-size: 18px;
  line-height: 22px;
}

figure {
  margin-bottom: 10px;
}

figcaption {
  text-align: center;
  margin-top: 5px;
}

.button__copy {
  white-space: nowrap;
  flex: none;
  display: inline-block;
}

.cookies__slide2-dummy {
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.cookies__checkbox-lable {
  margin-bottom: 0;
  font-size: 12px;
  line-height: 18px;
}

.cookies__checkbox {
  cursor: pointer;
  background-color: #f9f7f8;
  border-style: none;
  border-radius: 7px;
  flex: none;
  width: 20px;
  height: 20px;
  margin-top: 0;
  margin-left: 0;
  margin-right: 15px;
  padding: 8px;
}

.cookies__checkbox.checked {
  background-color: #1c1c1c;
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bbc_tws-icon-check.svg");
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 11px;
}

.button__icon {
  flex: none;
  margin-left: 8px;
  display: block;
  position: relative;
  bottom: 0;
}

.button__icon.before {
  margin-left: 0;
  margin-right: 8px;
}

.button {
  color: #fff;
  background-color: #1c1c1c;
  border-style: none;
  border-radius: 200px;
  flex: none;
  justify-content: center;
  align-items: center;
  height: 52px;
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
  padding-left: 30px;
  padding-right: 30px;
  text-decoration: none;
  transition: all .2s cubic-bezier(.456, -.233, .193, 1.714);
  display: flex;
}

.button:hover {
  background-color: #333;
  left: -4px;
  right: -4px;
}

.cookies__slide1 {
  text-align: center;
  flex-direction: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.cookies__slide2 {
  text-align: left;
  display: none;
}

.cookies__checkboxes {
  width: 100%;
  margin-bottom: 40px;
  font-weight: 300;
}

.cookies__section {
  z-index: 99999;
  justify-content: center;
  align-items: flex-start;
  padding: 60px;
  display: none;
  position: fixed;
  inset: 0%;
  overflow: auto;
}

.cookies__span {
  color: #3c3c3c;
  cursor: pointer;
  font-weight: 400;
  text-decoration: none;
}

.cookies__span:hover {
  text-decoration: underline;
}

.cookies__container {
  z-index: 20;
  transform: scale3d(1none, 1none, 1none);
  color: #868686;
  text-align: center;
  transform-style: preserve-3d;
  background-color: #fff;
  width: 450px;
  margin-top: auto;
  margin-bottom: auto;
  padding: 60px 50px;
  transition: opacity .2s cubic-bezier(.455, .03, .515, .955), transform .5s cubic-bezier(.55, .055, .675, .19);
  position: relative;
}

.cookies__selection-button {
  color: #c1c1c1;
  margin-top: 14px;
  font-size: 10px;
}

.cookies__selection-button:hover {
  color: #868686;
  text-decoration: none;
}

.utl-hidden {
  display: none;
}

.utl-hidden.cc-active {
  display: block;
}

.cookies__copy__bold {
  color: #3c3c3c;
  font-weight: 500;
}

.cookies__checkbox-wrapper {
  cursor: pointer;
  align-items: flex-start;
  margin-bottom: 10px;
  padding-left: 0;
  display: flex;
}

.cookies__copy {
  max-width: 330px;
  margin-top: 40px;
  margin-bottom: 40px;
  font-size: 12px;
}

.cookies__heading {
  color: #1c1c1c;
  margin-top: 15px;
  font-size: 30px;
  line-height: 1.3;
}

.cookies__background {
  z-index: 10;
  background-color: #1c1c1cf2;
  transition: opacity 1s cubic-bezier(.455, .03, .515, .955);
  position: absolute;
  inset: 0%;
}

.utility__section {
  padding: 150px 90px;
}

.utility__container {
  width: 100%;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}

.buttton__container {
  align-items: center;
  display: flex;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-wrap.cc-hidden {
  display: none;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 100%;
  max-width: 400px;
  display: flex;
}

.styleguide {
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
}

.c-form__input {
  color: var(--bg-color);
  background-color: #0000;
  border: 0 solid #000;
  border-bottom: 1px solid #ffffff54;
  border-radius: 0;
  height: 40px;
  margin-bottom: 0;
  padding: 14px 0;
  font-size: 14px;
  transition: all .25s ease-in-out;
}

.c-form__input:active {
  color: var(--white-smoke);
  border-radius: 0;
  padding-left: 0;
  padding-right: 0;
  font-size: 14px;
}

.c-form__input:focus {
  border-color: #00000080 #00000080 var(--white-smoke);
}

.c-form__input::placeholder {
  color: #fffc;
  font-size: 14px;
}

.c-form__input.cc-textarea {
  height: 11.46em;
  min-height: auto;
  padding-top: 1.25em;
  padding-bottom: 1.25em;
}

.s-icons-wrapper {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  display: flex;
}

.c-social-button {
  color: var(--white);
  cursor: pointer;
  background-color: #00344a33;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  transition: all .2s ease-in-out;
  display: flex;
}

.c-social-button:hover {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.c-social-button.cc-last {
  margin-right: 0;
}

.c-tab-menu {
  border: 1px solid #0000001a;
  border-radius: 12px;
  flex: 0 auto;
  justify-content: flex-start;
  align-self: flex-end;
  align-items: center;
  max-width: none;
  height: 2.92em;
  padding-left: 1.25em;
  padding-right: 1.25em;
  display: flex;
  overflow: hidden;
}

.text-hidden {
  display: none;
}

.s-tabs-menu-wrapper {
  display: flex;
}

.c-button-bg {
  z-index: 10;
  transform-origin: 0%;
  background-color: #fff;
  width: 100%;
  height: 100%;
  transition: background-color .25s ease-in-out;
  position: absolute;
  inset: 0%;
}

.c-button-bg.cc-gray {
  background-color: #f4f4f4;
}

.s-typo-label {
  opacity: .3;
  text-transform: uppercase;
  font-size: 12px;
}

.s-typo-label.cc-white {
  color: var(--white-smoke);
}

.c-icon {
  z-index: 10;
  flex: 0 auto;
  order: 0;
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 16px;
  display: block;
  position: relative;
}

.c-icon.cc-24 {
  width: 24px;
  height: 24px;
}

.c-icon.cc-down {
  width: 16px;
  height: 16px;
  transform: rotate(90deg);
}

.c-icon.cc-icon-right {
  margin-right: 6px;
}

.c-icon.cc-20 {
  width: 20px;
  height: 20px;
}

.c-icon.cc-icon-left {
  transform: rotate(180deg);
}

.c-icon.cc-up {
  width: 16px;
  height: 16px;
  transform: rotate(-90deg);
}

.c-tab-menu__item__line {
  background-color: #000;
  width: 100%;
  height: 2px;
  position: absolute;
  inset: auto 0% 0;
}

.c-aktuell-rich-text {
  max-width: 810px;
  margin-left: auto;
  margin-right: auto;
}

.c-tab-content {
  display: block;
}

.s-color {
  border-radius: 4px;
  width: 100%;
  height: 160px;
  padding: 16px;
}

.s-color._7 {
  color: #fff;
  background-color: #ff9e4b;
  border-radius: 8px;
  flex-direction: column;
  display: flex;
}

.s-color._2 {
  background-color: var(--dark-slate-grey);
  color: #fff;
  border-radius: 8px;
  flex-direction: column;
  display: flex;
}

.s-color._6 {
  color: #fff;
  background-color: #4cd35b;
  border-radius: 8px;
  flex-direction: column;
  display: flex;
}

.s-color._4 {
  color: var(--dark-slate-grey);
  background-color: #fafafa;
  border: 1px solid #325b6d1a;
  border-radius: 8px;
  flex-direction: column;
  display: flex;
}

.s-color._1 {
  background-color: var(--midnight-blue);
  color: #fff;
  border-radius: 8px;
  flex-direction: column;
  display: flex;
}

.s-color._3 {
  background-color: var(--dodger-blue);
  color: #fff;
  border-radius: 8px;
  flex-direction: column;
  display: flex;
}

.s-color._5 {
  color: var(--dark-slate-grey);
  background-color: #edeff1;
  border-radius: 8px;
  flex-direction: column;
  display: flex;
}

.c-button {
  z-index: 50;
  background-color: var(--white-smoke);
  color: var(--midnight-blue);
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  flex-wrap: nowrap;
  flex: none;
  justify-content: center;
  align-items: center;
  min-height: 34px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 600;
  line-height: 20px;
  text-decoration: none;
  transition: all .2s ease-in-out;
  display: flex;
  position: relative;
  overflow: hidden;
}

.c-button:hover {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.c-button.cc-secondary {
  color: #00000080;
  padding: 0;
}

.c-button.cc-category {
  padding-left: 18px;
  padding-right: 18px;
}

.c-button.cc-category.w--current {
  background-color: var(--midnight-blue);
  color: var(--white);
}

.c-button.cc-category.utility__hidden {
  display: none;
}

.c-button.cc-submit {
  background-color: var(--dodger-blue);
  padding-left: 15px;
  padding-right: 15px;
}

.c-button.cc-download {
  padding-right: 12px;
}

.c-button.cc-icon-left {
  padding-left: 10px;
  padding-right: 10px;
}

.c-button.cc-produkt-download-pdf {
  padding-right: 12px;
}

.c-button.js-menu-link.utility__hidden {
  display: none;
}

.c-button.cc-primary {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.c-button.aktuell__button {
  margin-bottom: 30px;
}

.c-button.cc-architekten {
  z-index: 200;
  color: #007367;
  background-color: #eef3f2;
  overflow: visible;
}

.c-button.cc-architekten:hover {
  color: #fff;
  background-color: #007367;
}

.c-button.cc-fachplaner {
  z-index: 200;
  color: #00344a;
  background-color: #edeff2;
  overflow: visible;
}

.c-button.cc-fachplaner:hover {
  color: #fff;
  background-color: #002c5e;
}

.c-button.cc-home-hero {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.c-button.cc-home-hero:hover {
  background-color: var(--dodger-blue);
}

.c-button.fdl-pop__submit {
  color: var(--white);
  background-color: #0087bf;
  padding-left: 15px;
  padding-right: 15px;
}

.c-button.fdl-pop__submit:hover {
  background-color: #00344a;
}

.c-button.pagination-button {
  border-color: #ccc0;
  margin-top: 20px;
}

.c-button.weitere-infomationen__button {
  background-color: #edeff1;
}

.c-button.weitere-infomationen__button:hover {
  background-color: var(--midnight-blue);
}

.c-button.produkte-page__button.w--current {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.color-box {
  background-color: #00b5eb1a;
  width: 100%;
  padding: 20px;
}

.s-buttons {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-wrap: wrap;
  align-items: flex-start;
  display: flex;
}

.s-buttons.cc-kontakt {
  margin-top: 0;
}

.s-color__info {
  justify-content: space-between;
  margin-top: auto;
  font-size: 13px;
  display: flex;
}

.s-item {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  border-top: 1px solid #6a6a6a29;
  border-radius: 0;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  padding-top: 24px;
  padding-bottom: 24px;
  display: grid;
}

.s-item.cc-form {
  background-color: var(--dodger-blue);
}

.s-header {
  text-align: center;
  justify-content: center;
  align-items: center;
  padding-top: 80px;
  padding-bottom: 80px;
  display: flex;
}

.styleguide__row {
  padding-top: 64px;
  padding-bottom: 64px;
}

.c-container {
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

.c-container.cc-sc-header {
  justify-content: space-between;
  align-items: flex-end;
  display: flex;
}

.c-container.cc-aktuell {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 626px) 1fr;
  grid-auto-columns: 1fr;
  height: auto;
  min-height: auto;
  display: grid;
  position: static;
  top: 0;
}

.c-container.cc-technologien {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 486px) minmax(auto, 914px);
  grid-auto-columns: 1fr;
  height: 100%;
  min-height: 100vh;
  display: grid;
  position: static;
}

.c-container.landscape {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 486px) minmax(auto, 914px);
  grid-auto-columns: 1fr;
  height: 100%;
  min-height: 100vh;
  display: grid;
  position: relative;
}

.c-container.portrait {
  z-index: 1;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743px) minmax(auto, 657px);
  grid-auto-columns: 1fr;
  height: 100%;
  min-height: 100vh;
  display: grid;
}

.c-container.cc-kontakt {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 612px) minmax(auto, 743fr);
  grid-auto-columns: 1fr;
  display: grid;
}

.c-container.r-thumbnail {
  z-index: 100;
  padding-top: 0%;
  padding-bottom: 0;
  position: absolute;
}

.c-container.cc-referenzen-cms-hero {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743fr) minmax(auto, 657px);
  grid-auto-columns: 1fr;
  align-content: start;
  align-items: start;
  height: 100%;
  display: grid;
  position: relative;
}

.c-container.cc-referenzen-info {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743fr) minmax(auto, 657px);
  grid-auto-columns: 1fr;
  align-content: stretch;
  align-items: start;
  height: auto;
  display: grid;
}

.c-container.cc-referenzen-hero {
  align-items: flex-end;
  height: auto;
  min-height: 420px;
  padding-bottom: 20px;
  display: flex;
}

.c-container.cc-swiper-grid-container {
  grid-column-gap: 20px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 357px) 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.c-container.cc-aktuell-cms {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 356px) 1fr;
  grid-auto-columns: 1fr;
  height: auto;
  min-height: auto;
  display: grid;
  position: relative;
  top: 0;
}

.c-container.a-hero-image-copy {
  z-index: 100;
  padding-bottom: 20px;
  position: relative;
}

.c-container.cc-a-hero {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 356px) minmax(auto, 1fr);
  grid-auto-columns: 1fr;
  align-content: stretch;
  align-items: end;
  height: auto;
  display: grid;
}

.c-container.cc-navbar {
  justify-content: space-between;
  align-items: center;
  height: 100px;
  padding-top: 30px;
  display: flex;
  position: relative;
}

.c-container.cc-geschichte {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: 1fr auto;
  grid-auto-columns: 1fr;
  height: 100vh;
  display: grid;
  position: relative;
}

.c-container.cc-swiper {
  position: relative;
}

.c-container.cc-s-result {
  max-width: 900px;
}

.c-container.cc-kontakt-hero {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743fr) minmax(auto, 612px);
  grid-auto-columns: 1fr;
  display: grid;
}

.c-container.cc-fch-hero {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: 1fr auto;
  grid-auto-columns: 1fr;
  height: auto;
  display: grid;
  position: relative;
}

.c-container.is-hidden {
  display: none;
}

.c-container.is-static {
  height: auto;
  position: static;
}

.c-container.nav__container {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  display: flex;
}

.c-container.nav__container.top-nav__container {
  justify-content: flex-end;
  align-items: center;
}

.c-container.kontakt__cta-container {
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.c-container.cc-neu-g {
  flex-flow: column;
  display: flex;
}

.c-container.neu-g__container {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  display: flex;
}

.c-button-text {
  z-index: 20;
  color: #000;
  width: auto;
  margin-left: 20px;
  margin-right: 30px;
  font-size: 1.04em;
  line-height: 1.04em;
  display: block;
  position: relative;
  left: 0;
}

.c-form__label {
  text-transform: none;
  margin-bottom: 13px;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
}

.c-tab-menu__item {
  background-color: #0000;
  align-items: center;
  height: 100%;
  padding-left: 0;
  padding-right: 0;
  font-size: 1.04em;
  line-height: 1.2;
  display: flex;
}

.c-tab-menu__item.w--current {
  background-color: #0000;
  border: 1px #000;
  align-items: center;
  height: 100%;
  display: flex;
}

.c-tab-menu__item.cc-3 {
  flex: none;
  margin-left: 1.35em;
}

.c-tab-menu__item.cc-2 {
  margin-left: 1.35em;
}

.c-button-icon {
  z-index: 20;
  color: #fff;
  background-color: #ff9e4b;
  border-radius: .52em;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 2.5em;
  height: 2.5em;
  margin-right: 0;
  display: flex;
  position: relative;
}

.s-colors {
  grid-column-gap: 32px;
  grid-row-gap: 32px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.c-icon-button {
  color: #000;
  background-color: #fff;
  border-radius: .52em;
  justify-content: center;
  align-items: center;
  width: 2.5em;
  height: 2.5em;
  display: flex;
}

.form-block {
  margin-bottom: 0;
}

.c-form__label--asteriks {
  color: #ff9e4b;
}

.c-download-button {
  color: #fff;
  background-color: #ff9e4b;
  border-radius: .52em;
  justify-content: center;
  align-items: center;
  width: 2.5em;
  height: 2.5em;
  display: flex;
}

.c-button__text {
  margin-left: 5px;
  margin-right: 5px;
  font-weight: 600;
  line-height: 18px;
  position: relative;
  top: -1px;
}

.c-button__text.cc-icon-left {
  margin-left: 5px;
}

.c-swiper-btns {
  background-color: var(--white-smoke);
  border-radius: 4px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.c-swiper-button {
  z-index: 10;
  color: var(--midnight-blue);
  cursor: pointer;
  background-color: #0000;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  transition: all .2s ease-in-out;
  display: flex;
  position: relative;
}

.c-swiper-button:hover {
  background-color: var(--midnight-blue);
  color: var(--white-smoke);
}

.c-swiper-button.cc-blur {
  background-color: var(--bg-color);
  filter: blur(5px);
  mix-blend-mode: normal;
}

.c-swiper-btns__divider {
  z-index: 5;
  background-color: #00344a1a;
  width: 1px;
  height: 12px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.cta {
  min-height: 600px;
  padding-top: 18vw;
  padding-bottom: 37vw;
  position: relative;
}

.cta__img-container {
  position: absolute;
  inset: 0%;
}

.cta__overlay {
  z-index: 10;
  background-image: linear-gradient(#fafafa, #fff0 80%), linear-gradient(#fafafa, #fafafa00);
  width: 100%;
  height: 412px;
  position: absolute;
  inset: 0% 0% auto;
}

.cta__content {
  z-index: 100;
  text-align: center;
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  position: relative;
}

.cta__btns {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  justify-content: center;
  margin-top: 20px;
  display: flex;
}

.footer {
  padding-top: 20px;
  padding-bottom: 20px;
}

.footer__grid {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 744px) minmax(400px, 1fr);
  grid-auto-columns: 1fr;
  margin-bottom: 100px;
  display: grid;
}

.footer__col-1 {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 357px) 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.footer__block.cc-kontakt {
  width: 100%;
  max-width: 280px;
}

.footer__block.cc-sonstiges {
  text-align: right;
  margin-left: 20px;
}

.footer__list {
  margin-bottom: 0;
  padding-left: 0;
}

.footer__list__item {
  list-style-type: none;
}

.footer__link {
  color: var(--midnight-blue);
  font-weight: 600;
  line-height: 22px;
  text-decoration: none;
}

.footer__link.made-by {
  font-weight: 400;
}

.footer__caption {
  opacity: .5;
  letter-spacing: -.12px;
  text-transform: uppercase;
  margin-bottom: 20px;
  font-size: 12px;
}

.footer__kontakt {
  margin-bottom: 20px;
}

.footer__kontakt.cc-last {
  margin-bottom: 0;
}

.footer__kontakt__title {
  color: var(--midnight-blue);
  margin-bottom: 10px;
  font-weight: 600;
  line-height: 16px;
}

.footer__col-2 {
  justify-content: space-between;
  width: 100%;
  display: flex;
}

.c-section.cc-w-bg {
  z-index: 100;
  background-color: var(--bg-color);
  width: 100%;
  position: static;
}

.c-section.cc-relative {
  position: relative;
}

.c-section.cc-relative.has-blue-bg {
  background-color: var(--dodger-blue);
  color: var(--white);
}

.c-section.cc-legal {
  padding-top: 200px;
  padding-bottom: 100px;
}

.c-section.cc-kontakt-team {
  background-color: #fff;
}

.c-section__header {
  padding-top: 100px;
  padding-bottom: 10px;
  position: relative;
}

.c-section__body {
  padding-top: 20px;
  padding-bottom: 20px;
  position: relative;
  overflow: hidden;
}

.c-section__body.cc-p-0, .c-section__body.cc-h-aktuell-list {
  padding-top: 0;
  padding-bottom: 0;
}

.c-line {
  background-color: #c8dae2;
}

.horizontal-line {
  background-color: var(--border-blue);
  width: 100%;
  height: 1px;
  position: absolute;
}

.horizontal-line.cc-bottom {
  z-index: 20;
  flex: none;
  width: 100%;
  inset: auto 0% 0%;
}

.horizontal-line.cc-bottom.cc-hide {
  display: block;
}

.horizontal-line.cc-bottom.z-2000 {
  z-index: 2000;
}

.horizontal-line.cc-top {
  z-index: 100;
  inset: 0% 0% auto;
}

.horizontal-line.cc-top.z-200 {
  z-index: 200;
}

.c-section__header__nav {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  align-items: center;
  display: flex;
}

.swiper-container-wrapper {
  width: 100%;
  margin-right: 0;
  position: relative;
  overflow: visible;
}

.referenzen-swiper-collection-list {
  width: 100%;
  display: flex;
  overflow: visible;
}

.referenzen-swiper-collection-item {
  flex-direction: column;
  flex: none;
  margin-right: 20px;
  display: flex;
  position: relative;
}

.referenzen-swiper-collection-item.cc-last {
  margin-right: 0;
}

.referenzen__image {
  width: 612px;
  height: 400px;
  margin-bottom: 0;
  position: relative;
  overflow: hidden;
}

.referenzen__image.inspiration__img-wrapper {
  width: 100%;
}

.hero {
  align-items: center;
  padding-top: 100px;
  padding-bottom: 100px;
  display: block;
}

.flex-container {
  flex-direction: row;
  flex: 1;
  align-items: center;
  display: flex;
}

.hero-image-mask {
  width: 100%;
  margin-left: 40px;
}

.hero-image {
  object-fit: cover;
  object-position: 50% 50%;
  flex: 0 .5 auto;
  width: 100%;
  height: 100%;
}

.referenzen__info {
  flex-direction: column;
  justify-content: flex-start;
  padding-top: 20px;
  display: flex;
}

.referenzen__title {
  color: var(--midnight-blue);
  border: 1px #000;
  font-size: 16px;
  font-weight: 600;
  line-height: 16px;
}

.caption-text {
  opacity: .6;
  letter-spacing: -.12px;
  text-transform: uppercase;
  margin-bottom: 0;
  font-size: 12px;
}

.caption-text.cc-aktuell-date {
  margin-top: auto;
}

.caption-text.cc-kontakt-person {
  color: var(--midnight-blue);
  margin-bottom: auto;
}

.caption-text.lineheight {
  line-height: 1.2;
}

.caption-text.cc-karriere__caption {
  max-width: 200px;
  line-height: 18px;
}

.caption-text.capitalize-off {
  text-transform: none;
}

.about-swiper-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 357px) 1fr;
  grid-auto-columns: 1fr;
  padding-left: 377px;
  display: flex;
  overflow: visible;
}

.portfolio-collection-item {
  flex: none;
  width: 100%;
  margin-right: 20px;
}

.portfolio-collection-item.cc-last {
  margin-right: 0;
}

.portfolio-collection-item.cc-portrait {
  flex: 1;
  max-width: none;
  margin-right: 0;
}

.portfolio__image {
  z-index: 30;
  width: 296px;
  height: 379px;
  position: relative;
  overflow: hidden;
}

.portfolio__image.is-portait {
  width: 100%;
  min-width: 296px;
  height: auto;
  padding-top: 135%;
}

.portfolio__image.is-fch-portfolio {
  width: 100%;
  height: 100vh;
  max-height: 379px;
}

.portfolio__image.is-landscape {
  width: 100%;
  height: auto;
  max-height: 220px;
  padding-top: 66.67%;
}

.portfolio__info {
  flex-flow: column;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  max-width: 296px;
  height: 100%;
  padding-top: 20px;
  text-decoration: none;
  display: flex;
}

.portfolio__info.inspiration__info {
  max-width: none;
}

.portfolio__info.desings__info {
  max-width: 450px;
}

.aktuell-swiper-collection-item {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex: none;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 744px) 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.c-image-responsive {
  z-index: 10;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.aktuell-swiper__image {
  z-index: 10;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  height: 500px;
  padding-bottom: 20px;
  padding-left: 20px;
  text-decoration: none;
  display: flex;
  position: relative;
  overflow: hidden;
}

.aktuell-swiper__image.neu-g__swiper-image {
  pointer-events: none;
}

.aktuell-swiper__image.neu-g__swiper-image.with-border {
  border: 1px solid var(--border-blue);
}

.aktuell-swiper__image--overlay {
  z-index: 50;
  opacity: .66;
  background-image: linear-gradient(to top, #000, #0000);
  width: 100%;
  height: 122px;
  position: absolute;
  inset: auto 0% 0%;
}

.image-copyright-text {
  z-index: 100;
  color: var(--bg-color);
  font-size: 10px;
  line-height: 1;
  display: block;
  position: absolute;
  inset: auto auto 20px 20px;
}

.image-copyright-text.utility__hidden, .image-copyright-text.centered.hide-on-mobile {
  display: none;
}

.aktuell-swiper__col {
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  max-width: 447px;
  display: flex;
}

.c-title-wrapper.cc-h-aktuell {
  margin-top: 40px;
  margin-bottom: 20px;
}

.c-title-wrapper.cc-video-title {
  margin-top: 20px;
  margin-bottom: 40px;
}

.c-title-wrapper.cc-aktuel-cms-title {
  width: 100%;
  max-width: 679px;
}

.c-title-wrapper.cc-technologie {
  margin-top: 20px;
  margin-bottom: 20px;
}

.c-title-wrapper.with__produkte-button {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.c-paragraph-wrapper.cc-aktuell-excerpt {
  margin-bottom: 20px;
}

.c-paragraph-wrapper.cc-about-info {
  margin-bottom: auto;
}

.c-paragraph-wrapper.cc-about-info.link-reset {
  color: var(--dark-slate-grey);
  text-decoration: none;
}

.c-paragraph.cc-small {
  font-size: 12px;
  line-height: 16px;
}

.c-paragraph.cc-semi-bold {
  font-weight: 600;
}

.c-paragraph.cc-semi-bold.cc-midnight-blue {
  color: var(--midnight-blue);
}

.c-paragraph.cc-semi-bold.cc-midnight-blue.inline {
  display: inline;
}

.aktuell-list {
  padding-top: 70px;
  padding-bottom: 0;
}

.aktuell-grid {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  border-top: 1px #e1eaee;
  border-bottom: 1px solid var(--border);
  grid-template-rows: auto;
  grid-template-columns: minmax(200px, 357px) minmax(auto, 367px) 1fr;
  grid-auto-columns: 1fr;
  margin-top: 0;
  padding-top: 20px;
  padding-bottom: 20px;
  display: grid;
}

.aktuell-grid.cc-first {
  border-top-style: none;
  border-top-width: 0;
  border-bottom-style: none;
  grid-template-columns: minmax(auto, 327px) 1fr 1fr;
}

.aktuell-grid.cc-last {
  border-bottom-color: #0000;
}

.aktuell-g__image-wrapper {
  flex: none;
  width: 375px;
  height: 235.79px;
  position: relative;
  overflow: hidden;
}

.aktuell-g__image-wrapper.w--current {
  overflow: hidden;
}

.aktuell-g__col {
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.aktuell-g__col.cc-mw-44 {
  max-width: 440px;
}

.div-block-9 {
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  max-width: 440px;
  display: flex;
}

.heading {
  letter-spacing: -.32px;
}

.aktuell {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  color: var(--dark-slate-grey);
  border-bottom: 1px solid #d5e2e8;
  grid-template-rows: auto;
  grid-template-columns: auto 1fr;
  grid-auto-columns: 1fr;
  padding-top: 20px;
  padding-bottom: 20px;
  text-decoration: none;
  display: flex;
}

.aktuell.cc-last {
  border-bottom-color: #0000;
}

.div-block-11 {
  padding-left: 377px;
}

.c-hero__grid {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 873px) 1fr;
  grid-auto-columns: 1fr;
  justify-items: start;
  max-width: none;
  min-height: 420px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
}

.c-hero__grid.home__grid {
  grid-template-columns: minmax(auto, 873px) minmax(350px, 1fr);
  min-height: 440px;
}

.div-block-13 {
  min-height: auto;
}

.c-hero-slider {
  width: 100%;
  height: auto;
  padding-top: 56.25%;
  position: relative;
}

.c-hero__copy {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.c-hero__copy.is-architekt {
  justify-content: flex-end;
  align-items: flex-start;
}

.hero-title {
  margin-top: auto;
  margin-bottom: -6px;
  margin-right: auto;
  padding-right: 20px;
}

.hero-title.hero-title__home {
  padding-right: 80px;
}

.vertical-line {
  background-color: #c8dae2;
  width: 1px;
  height: 100%;
  position: absolute;
}

.vertical-line.cc-abs-bottom {
  inset: auto 0% 0%;
}

.vertical-line.cc-hero, .vertical-line.cc-right {
  inset: 0% 0% 0% auto;
}

.vertical-line.cc-right.cc-menu {
  background-color: #33b1e3;
}

.vertical-line.cc-left {
  inset: 0% auto 0% 0%;
}

.vertical-line.cc-left.z-2000, .vertical-line.cc-left.cc-hide-mobile.z-200 {
  z-index: 2000;
}

.c-hero__col {
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.c-hero__block__bottom {
  grid-column-gap: 20px;
  align-items: center;
  width: 100%;
  padding-top: 20px;
  padding-bottom: 15px;
  padding-left: 20px;
  display: flex;
  position: relative;
}

.paragraph {
  flex: 0 auto;
}

.c-hero__block__top {
  z-index: 10;
  flex: 1;
  align-items: flex-end;
  width: 100%;
  padding-bottom: 15px;
  padding-left: 20px;
  display: flex;
  position: relative;
}

.c-hero__block__top.c-hero__block__top__home {
  flex-flow: column;
  justify-content: flex-end;
  align-items: flex-start;
}

.c-hero {
  align-items: center;
  padding-top: 0;
  padding-bottom: 0;
  display: block;
  overflow: hidden;
}

.c-hero.c-home__hero {
  padding-top: 90px;
}

.utility-page-form {
  flex-direction: column;
  align-items: stretch;
  display: flex;
}

.navbar {
  z-index: 5000;
  background-color: #fafafa;
  width: 100%;
  height: auto;
  position: fixed;
  inset: 0% 0% auto;
}

.navbar.cc-kontakt-page {
  background-color: var(--dodger-blue);
}

.navbar__spacer {
  height: 100px;
}

.about-swiper-item {
  flex-direction: column;
  flex: none;
  align-items: flex-start;
  width: 100%;
  max-width: 317px;
  min-height: 266px;
  margin-right: 60px;
  display: flex;
}

.about-swiper-item.cc-hide {
  display: none;
}

.about-swiper-item.cc-last {
  margin-right: 0;
}

.about-swiper-list {
  display: flex;
}

.sticky-sc {
  min-height: 100vh;
  display: flex;
}

.sc-fixed {
  z-index: 100;
  float: none;
  clear: none;
  background-color: var(--dodger-blue);
  color: var(--white-smoke);
  justify-content: center;
  align-items: center;
  width: 50vw;
  height: 100vh;
  display: block;
  position: sticky;
  top: 0;
}

.section-large {
  z-index: 40;
  background-color: var(--midnight-blue);
  width: 100%;
  height: 200vh;
  display: block;
  position: relative;
}

.div-block-17 {
  flex-direction: column;
  height: auto;
  min-height: 100vh;
  display: flex;
  position: static;
  top: 0;
}

.section-scroll {
  z-index: 100;
  float: none;
  clear: none;
  background-color: var(--dark-slate-grey);
  color: var(--white-smoke);
  justify-content: center;
  align-items: center;
  width: 50vw;
  height: 200vh;
  display: block;
  position: sticky;
  top: 0;
}

.absolute {
  position: absolute;
  top: 50%;
  left: 50%;
}

.div-block-18 {
  flex-direction: column;
  display: flex;
}

.sticky-box {
  color: var(--bg-color);
  background-color: #00344a6b;
  justify-content: center;
  align-items: center;
  width: 50%;
  height: 100vh;
  display: flex;
  position: sticky;
  top: 0;
}

.white-heading {
  color: var(--white);
}

.scroll-box {
  color: var(--bg-color);
  background-color: #00344ab3;
  justify-content: center;
  align-items: center;
  width: 50%;
  height: 200vh;
  min-height: 100vh;
  display: flex;
  position: sticky;
  top: 0;
}

.video-collection-list {
  display: flex;
}

.video-collection-item {
  width: auto;
  margin-right: 20px;
}

.video-collection-item:last-child {
  margin-right: 0;
}

.video {
  background-color: var(--white-smoke);
  object-fit: cover;
  width: 100%;
  height: 100%;
  max-height: 100%;
  position: absolute;
}

.spacer-90 {
  z-index: 1;
  height: 90px;
  position: relative;
}

.aktuell-sticky-wrapper {
  background-color: #0000;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  height: 100vh;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 20px;
  display: flex;
  position: sticky;
  top: 100px;
}

.aktuell-sticky-wrapper.cc-aktuell-cms {
  justify-content: flex-start;
  padding-top: 217px;
}

.aktuell-list-wrapper {
  width: 100%;
  height: 100%;
  min-height: auto;
  padding-top: 0;
  padding-left: 20px;
  position: relative;
}

.aktuell-h__image-wrapper {
  width: 100%;
  height: 420px;
  position: relative;
  overflow: hidden;
}

.aktuell-h {
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  min-height: auto;
  display: flex;
}

.aktuell-h__info, .div-block-22 {
  justify-content: space-between;
  width: 100%;
  margin-top: auto;
  display: flex;
}

.aktuell__title, .aktuell__paragraph {
  margin-bottom: 20px;
}

.aktuell__info {
  justify-content: space-between;
  width: 100%;
  margin-top: auto;
  display: none;
}

.aktuell-h__content {
  flex-direction: column;
  align-items: flex-start;
  padding-top: 20px;
  display: flex;
}

.aktuell-h__title {
  width: 100%;
  max-width: 398px;
  font-size: 20px;
  line-height: 24px;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
}

.aktuell-h__title:hover {
  opacity: .7;
}

.aktuell-h__paragraph {
  width: 100%;
  max-width: 377px;
  margin-top: 20px;
  margin-bottom: 20px;
}

.aktuell-spacer {
  height: 220px;
}

.aktuell-g__paragraph {
  margin-bottom: 20px;
}

.portfolio-block {
  z-index: 100;
  height: 100%;
  min-height: auto;
  margin-top: -1px;
  padding-top: 0;
  padding-left: 20px;
  position: relative;
}

.portfolio-block.cc-landscape {
  background-color: var(--bg-color);
  width: 100%;
  height: 100%;
  margin-top: -1px;
  display: none;
}

.portfolio-block.cc-portrait {
  grid-column-gap: 10px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  flex-wrap: wrap;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  height: auto;
  min-height: auto;
  display: flex;
}

.portfolio__item {
  z-index: 300;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  color: var(--dark-slate-grey);
  border-bottom: 1px solid #d5e2e8;
  grid-template-rows: auto;
  grid-template-columns: auto 1fr;
  grid-auto-columns: 1fr;
  padding-top: 20px;
  padding-bottom: 20px;
  text-decoration: none;
  display: flex;
  position: relative;
}

.portfolio__item.cc-last {
  border-bottom-color: #0000;
}

.portfolio__item.cc-portrait {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex: 0 auto;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 204px) 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  max-width: none;
  display: flex;
}

.portfolio__item.cc-portrait.cc-hide {
  display: none;
}

.technologien__image-wrapper {
  flex: none;
  width: 367px;
  height: 244px;
  position: relative;
}

.technologien__image-wrapper.cc-portrait {
  width: 100%;
  height: 260px;
}

.technologien__info {
  justify-content: space-between;
  width: 100%;
  margin-top: auto;
  display: flex;
}

.technologien__info.portfolio__mini-text {
  max-width: 400px;
}

.portfolio__item__title {
  width: 100%;
  max-width: 170px;
  margin-bottom: 10px;
  text-decoration: none;
}

.portfolio__item__title.cc-portrait {
  max-width: 100%;
}

.sticky-box {
  width: 100%;
  height: 300px;
}

.technologien-sticky {
  background-color: #0000;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100vh;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
  display: flex;
  position: sticky;
  top: 0;
}

.aktuell-sticky-wrapper-copy {
  background-color: #0000;
  height: 100vh;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 20px;
  position: sticky;
  top: 0;
}

.t-sticky__btns {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  flex-wrap: wrap;
  max-width: 80%;
  display: flex;
}

.t-sticky__btns.utility__hidden {
  display: none;
}

.t-sticky__top {
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  height: 420px;
  max-height: none;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.t-sticky__bottom {
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
}

.technologien-sticky__title {
  letter-spacing: -2.6px;
  font-size: 52px;
  line-height: 1;
}

.portfolio-sticky-slider {
  background-color: var(--bg-color);
  color: var(--midnight-blue);
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  height: 420px;
  max-height: none;
  display: flex;
  position: sticky;
  top: 100px;
}

.produkte-column {
  z-index: 1000;
  flex-direction: column;
  width: 100%;
  min-height: 100vh;
  display: flex;
}

.portfolio-sticky-slider-wrapper {
  width: 100%;
  padding: 20px;
  position: relative;
}

.portfolio-slider__image {
  flex: none;
  width: 443px;
  max-width: none;
  height: 297px;
  max-height: none;
  position: relative;
}

.t-sticky-slider__item {
  grid-column-gap: 20px;
  flex: none;
  width: 100%;
  display: flex;
}

.portfolio-slider__content {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 356px;
  padding-top: 0;
  display: flex;
}

.t-sticky-slider__content__date {
  margin-top: auto;
}

.portfolio-slider__title {
  width: 100%;
  max-width: 286px;
  margin-top: 16px;
  font-size: 20px;
  line-height: 24px;
  text-decoration: none;
}

.t-sticky-slider__paragraph {
  width: 100%;
  max-width: none;
  margin-top: 20px;
  margin-bottom: 20px;
}

.portfolio-slider__nav {
  position: absolute;
  inset: 20px 0% auto auto;
}

.t-sticky-slider {
  width: auto;
  display: none;
  overflow: hidden;
}

.technologien-list__bg {
  z-index: 100;
  background-color: var(--bg-color);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.portfolio-sticky__bottom__paragraph {
  margin-bottom: 20px;
}

.produkte-sticky-image {
  z-index: 10;
  color: var(--midnight-blue);
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  width: 100%;
  height: 654px;
  max-height: none;
  display: flex;
  position: sticky;
  top: 54px;
}

.produkte-sticky-image.cc-portrait {
  z-index: 10;
  background-image: none;
  height: 100vh;
}

.produkte-sticky-image.cc-innovation-und-tech {
  z-index: 10;
  background-image: none;
  height: 100vh;
  top: 54px;
}

.produkte-info__desc {
  z-index: 100;
  color: var(--midnight-blue);
  letter-spacing: -1.1px;
  order: 0;
  width: 100%;
  max-width: 896px;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 20px;
  font-size: 27.5px;
  line-height: 34px;
  position: relative;
}

.produkte-info-container {
  z-index: 1000;
  width: 100%;
  height: 100%;
  min-height: auto;
  padding-top: 0;
  padding-left: 0;
  position: relative;
}

.produkte-info-container.cc-landscape {
  background-color: var(--bg-color);
  width: 100%;
  height: 100%;
  margin-top: -1px;
  display: block;
}

.produkte-info-container.cc-portrait {
  grid-column-gap: 10px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  flex-wrap: wrap;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  height: auto;
  min-height: auto;
  display: none;
}

.produkte-info-wrapper {
  z-index: 2000;
  width: 100%;
  position: relative;
}

.produkte-info-wrapper.has-flex {
  flex-flow: column;
  display: flex;
}

.produkte-info-wrapper.karriere__info-wrapper {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.produkte-info__block {
  order: 1;
  position: relative;
}

.produkte-info__block.karriere__first-block {
  width: 100%;
}

.produkte-info__block__header {
  padding-top: 70px;
  padding-bottom: 20px;
  padding-left: 20px;
  position: relative;
}

.produkte-info__block__header.karriere__first-block {
  padding-top: 20px;
}

.produkte-info__block__body {
  flex-direction: column;
  align-items: flex-start;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 20px;
  display: flex;
}

.produkte-info__block__body.cc-produkt-q {
  padding-top: 0;
  padding-bottom: 0;
}

.produkte-info__block__body.cc-produkt-q.darker-block {
  z-index: 1;
  background-color: #f4f4f4;
}

.produkte-list {
  margin-bottom: 100px;
  padding-left: 10px;
  font-size: 14px;
  line-height: 22px;
}

.produkte-list.cc-herausforderungen {
  margin-top: 40px;
  margin-bottom: 0;
}

.herausforderungen-paragraph {
  width: 100%;
  max-width: 380px;
}

.produkt-q {
  grid-column-gap: 20px;
  border-bottom: 1px solid var(--border);
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  text-decoration: none;
  display: flex;
}

.produkt-q.dark__produkt-block {
  border-bottom-color: #d6dee2;
  align-items: stretch;
}

.produkt-q__image {
  flex: none;
  width: 202px;
  height: 136px;
  margin-bottom: 0;
  position: relative;
}

.produkt-q__info {
  width: 100%;
  max-width: 351px;
}

.produkt-q__info.weitere-informationen__info-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.produkt-q__title {
  margin-top: 15px;
}

.kontakt-page {
  background-color: var(--dodger-blue);
  color: var(--white);
}

.kontakt-form-block {
  max-width: 780px;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}

.form__input {
  color: var(--white);
  background-color: #0000;
  border: 0 solid #000;
  border-bottom: 1px solid #ffffff54;
  height: auto;
  margin-bottom: auto;
  padding: 14px 14px 14px 0;
  transition: all .2s ease-in-out;
}

.form__input:focus {
  border-bottom-color: #fff;
}

.form__input::placeholder {
  color: #fffc;
}

.form__input.cc-textarea {
  border-width: 1px;
  border-color: #ffffff54;
  border-radius: 8px;
  height: 280px;
  margin-bottom: 20px;
  padding-left: 14px;
}

.form__input.cc-textarea:focus {
  border-color: #fff;
}

.form__checkbox {
  text-transform: uppercase;
  background-color: #0000;
  border: 1px solid #ffffff54;
  border-radius: 4px;
  align-items: center;
  height: 34px;
  margin-bottom: 0;
  padding: 4px 14px;
  font-size: 12px;
  font-weight: 600;
  display: flex;
}

.form__checkboxes {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-wrap: wrap;
  max-width: 575px;
  margin-top: 10px;
  display: flex;
}

.form__checkbox__icon {
  clear: none;
  border-color: var(--white);
  border-radius: 4px;
  width: 14px;
  height: 14px;
  margin-top: 0;
  margin-left: 0;
  margin-right: 8px;
  position: relative;
}

.form__checkbox__icon.w--redirected-checked {
  clear: none;
  background-color: var(--bg-color);
  background-image: none;
  border-width: 0;
  border-radius: 4px;
}

.form__checkbox__label {
  font-weight: 600;
}

.div-block-24 {
  margin-top: 40px;
  margin-bottom: 40px;
}

.form__label {
  margin-bottom: 12px;
  font-weight: 600;
}

.locmap__main {
  color: var(--midnight-blue);
  background-color: #0000;
  width: 100%;
  height: 800px;
  position: relative;
}

.k-hero {
  color: var(--white);
  padding-bottom: 50px;
}

.k-hero__top {
  align-items: flex-end;
  min-height: 420px;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.k-hero__bottom {
  padding-top: 20px;
  padding-bottom: 20px;
}

.div-block-25 {
  grid-column-gap: 80px;
  width: 336px;
  max-width: 336px;
  display: flex;
}

.div-block-26 {
  justify-content: space-between;
  align-items: flex-end;
  padding-left: 20px;
  display: flex;
}

.div-block-27 {
  justify-content: space-between;
  margin-left: 20px;
  display: flex;
}

.kontakt-form-wrapper {
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 20px;
  position: relative;
}

.kontakt-form-wrapper.is-newsletter {
  padding-left: 0;
}

.kontaktformular__title {
  text-transform: uppercase;
  margin-bottom: 40px;
  font-weight: 600;
}

.k-hero__subtitle {
  font-size: 28px;
  line-height: 36px;
}

.k-hero__title {
  color: var(--white);
  letter-spacing: -2.6px;
  margin-top: auto;
  margin-bottom: -5px;
  font-size: 52px;
}

.r-thumbnail {
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  height: auto;
  min-height: 450px;
  padding-top: 63%;
  display: flex;
  position: relative;
}

.r-hero {
  color: var(--dark-slate-grey);
  flex-direction: column;
  justify-content: flex-start;
  min-height: 420px;
  padding-bottom: 0;
  display: flex;
  position: relative;
}

.div-block-28 {
  grid-column-gap: 30px;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  height: 100%;
  padding-bottom: 20px;
  display: flex;
}

.c-title-1-smaller {
  color: var(--midnight-blue);
  letter-spacing: -2.6px;
  margin-bottom: 0;
  font-size: 52px;
  line-height: 1;
  overflow: visible;
}

.c-title-1-smaller.portfolio__title, .c-title-1-smaller.hero-offset {
  margin-bottom: -5px;
}

.r-info-column {
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  min-height: 420px;
  padding-bottom: 20px;
  padding-left: 20px;
  display: flex;
  position: relative;
}

.r-galerie-collection-list {
  width: 100%;
  display: flex;
}

.r-galerie-collection-item {
  z-index: 1;
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  width: 100%;
  max-width: 70vw;
  margin-right: 20px;
  display: flex;
  position: relative;
}

.r-galerie-collection-item:last-child {
  margin-right: 0;
}

.r-galerie-collection-item__overlay {
  z-index: 50;
  opacity: .5;
  background-image: linear-gradient(to top, #000, #0000);
  width: 100%;
  height: 122px;
  position: absolute;
  inset: auto 0% 0%;
}

.r-galerie-collection-item__overlay.h-hero__gradient {
  opacity: .5;
  background-image: linear-gradient(to top, #000, #0000);
  height: 60%;
}

.r-galerie-collection-item__overlay.smaller {
  height: 80px;
}

.kontakt-info-grid {
  grid-column-gap: 40px;
  grid-row-gap: 16px;
  flex-direction: column;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 167px) minmax(auto, 167px) minmax(auto, 167px);
  grid-auto-columns: 1fr;
  margin-bottom: 40px;
  display: flex;
}

.kontakt-info-wrapper {
  flex-direction: column;
  justify-content: space-between;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 20px;
  display: flex;
}

.div-block-30 {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 300px;
  display: flex;
}

.kontakt-p {
  grid-column-gap: 20px;
  grid-row-gap: 16px;
  flex-direction: column;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 167px) minmax(auto, 167px) minmax(auto, 167px);
  grid-auto-columns: 1fr;
  align-items: start;
  display: flex;
}

.kontakt-person__img {
  background-color: var(--dark-slate-grey);
  width: 167px;
  height: 208px;
  margin-bottom: 20px;
  position: relative;
}

.kontakt-info__title {
  color: var(--white);
  text-transform: uppercase;
  margin-bottom: 20px;
  font-weight: 600;
  line-height: 16px;
}

.kontakt-cms-item {
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  max-width: 170.75px;
  margin-right: 20px;
  display: flex;
}

.kontakt-cms-item:last-child {
  margin-right: 0;
}

.kontakt-person-btns {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-top: 20px;
  display: flex;
}

.kontakt-person-btns.cc-kontakt {
  margin-top: 20px;
}

.kontakt-person-title {
  color: var(--midnight-blue);
  font-weight: 600;
}

.r-info {
  color: var(--dark-slate-grey);
  flex-direction: column;
  justify-content: space-between;
  padding-bottom: 0;
  display: flex;
  position: relative;
}

.c-paragraph-large {
  color: var(--midnight-blue);
  letter-spacing: -1.12px;
  font-size: 28px;
  line-height: 36px;
}

.r-summary-wrapper {
  max-width: 613px;
  margin-top: 0;
  margin-bottom: 80px;
}

.r-rich-wrapper {
  width: 100%;
  max-width: 408px;
  margin-top: 20px;
  margin-bottom: 0;
  padding-bottom: 20px;
}

.referenzen__rich-text h4 {
  margin-bottom: 10px;
}

.referenzen__rich-text p {
  margin-bottom: 20px;
}

.referenzen__rich-text.sidebar ul {
  padding-left: 20px;
}

.referenzen-hero {
  z-index: auto;
  color: var(--dark-slate-grey);
  flex-direction: column;
  justify-content: space-between;
  padding-bottom: 0;
  display: flex;
  position: relative;
}

.referenzen-cms-collection-list {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
  overflow: visible;
}

.referenzen-cms-collection-list.uber-uns-cms-collection-list {
  grid-template-columns: 1fr 1fr 1fr;
}

.referenzen-cms-collection-wrapper.uber-uns-cms-collection {
  padding-left: 377px;
}

.referenzen-list-section {
  z-index: 1;
  padding-top: 20px;
  padding-bottom: 20px;
  position: relative;
}

.referenzen-list-section.cc-w-bg {
  z-index: 100;
  background-color: var(--bg-color);
  width: 100%;
  position: static;
}

.referenzen-list-section.cc-relative, .referenzen-cms-collection-item {
  position: relative;
}

.referenzen-link {
  text-decoration: none;
}

.referenzen {
  border: 1px #000;
  text-decoration: none;
}

.r-link {
  z-index: 10;
  width: 100%;
  padding-bottom: 20px;
  text-decoration: none;
  position: relative;
}

.r-link__image {
  width: 100%;
  height: 100%;
  max-height: 220px;
  padding-top: 66.67%;
  position: relative;
  overflow: hidden;
}

.r-link__title {
  color: var(--midnight-blue);
  cursor: pointer;
  border: 1px #000;
  margin-top: 20px;
  margin-bottom: 32px;
  font-size: 16px;
  font-weight: 600;
  line-height: 16px;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
}

.r-link__title:hover {
  opacity: .7;
}

.r-link__caption {
  color: #00344a99;
}

.filter-button {
  z-index: 1000;
  color: var(--midnight-blue);
  background-color: #edeff1;
  align-items: center;
  padding: 7px 32px 7px 24px;
  display: block;
}

.filter-button.w--open {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
}

.f-box__range-track {
  z-index: 100;
  background-color: #ffffff54;
  width: 100%;
  height: 1px;
  margin-top: 10px;
  position: relative;
}

.filter-sub-dropdown {
  border-bottom: 1px solid #f4f5f733;
  width: 100%;
}

.f-box__range--handle {
  z-index: 50;
  background-color: #fff;
  border-radius: 0%;
  width: 8px;
  height: 8px;
  position: absolute;
  inset: 50% auto auto 0%;
  transform: translate(0, -50%);
}

.filter-sub-dropdown-toggle {
  color: #fff;
  justify-content: space-between;
  width: 100%;
  padding: 12px 30px;
  font-size: 14px;
  line-height: 22px;
  display: flex;
}

.filter-sub-dropdown-toggle.w--open {
  color: #fff;
  background-color: #333;
  width: 100%;
}

.filter-close {
  color: #fff;
  background-color: #000;
  border-right: 1px solid #f4f5f724;
  justify-content: center;
  align-items: center;
  width: 38px;
  height: 38px;
  margin-right: 24px;
  display: none;
}

.filter-button__text {
  margin-left: 4px;
  font-size: 12px;
}

.filter-sub-dropdown-list {
  padding-left: 30px;
  padding-right: 30px;
}

.filter-sub-dropdown-list.w--open {
  color: #fff;
  background-color: #333;
  padding-left: 0;
  padding-right: 0;
  font-size: 14px;
  line-height: 22px;
  position: static;
}

.filter-dropdown {
  z-index: 101;
}

.filter-dropdown.w--open {
  color: var(--dark-slate-grey);
  background-color: #edeff1;
  border-radius: 4px;
  width: 100%;
  min-width: 200px;
  max-height: 300px;
  padding-top: 0;
  padding-bottom: 0;
  inset: 48px 0 auto auto;
  overflow: scroll;
}

.f-box__range-track--fill {
  background-color: #fff;
  width: 20%;
  position: absolute;
  inset: 0%;
}

.filter-buttons {
  grid-column-gap: 10px;
  justify-content: flex-end;
  margin-left: auto;
  display: flex;
}

.c-icon-2 {
  width: 24px;
  height: 24px;
}

.c-icon-2.cc-20 {
  order: 0;
  width: 20px;
  height: 20px;
}

.f-box__range--values {
  color: #fff;
  font-size: 14px;
  line-height: 20px;
  position: absolute;
  top: -25px;
}

.rangeslider-input {
  display: none;
}

.filter-checkbox-icon {
  border-style: solid;
  border-color: var(--dark-slate-grey);
  border-radius: 4px;
  flex: none;
  width: 14px;
  height: 14px;
  margin-top: 0;
  margin-left: 0;
  margin-right: 8px;
}

.filter-checkbox-icon.w--redirected-checked {
  border-color: var(--dark-slate-grey);
  background-color: var(--dark-slate-grey);
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bd2_checkbox-dot.svg");
  background-size: cover;
  margin-top: 0;
  margin-left: 0;
  margin-right: 8px;
  font-size: 11px;
}

.filter-checkbox-icon.w--redirected-focus {
  box-shadow: 0 0 #3898ec;
}

.filter-button-dropdown {
  z-index: 100;
  margin-left: 0;
  margin-right: 0;
}

.filter-checkbox-label {
  color: var(--midnight-blue);
  font-size: 14px;
  font-weight: 400;
  line-height: 22px;
}

.filter-checkbox {
  border: 1px #000;
  border-bottom: 1px solid #f4f5f733;
  align-items: center;
  width: 100%;
  margin-bottom: 0;
  padding: 10px 15px;
  display: flex;
}

.filter-checkbox.cc-last {
  border-style: none;
  border-color: #000;
  padding-left: 15px;
  padding-right: 15px;
}

.f-box__rangeslider {
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  height: 30px;
  padding-bottom: 0;
  display: flex;
}

.f-box__rangeslider.cc-filter {
  margin-top: 0;
  margin-bottom: 0;
  padding: 60px 30px 40px;
}

.form {
  grid-column-gap: 10px;
  display: flex;
}

.reset-filter {
  opacity: .6;
  color: var(--midnight-blue);
  letter-spacing: -.12px;
  text-transform: uppercase;
  align-items: center;
  margin-bottom: 0;
  padding-top: 2px;
  font-size: 12px;
  text-decoration: none;
  display: flex;
}

.reset-filter.cc-aktuell-date, .reset-filter.cc-kontakt-person {
  margin-top: auto;
}

.r-link__filter-data {
  z-index: 20;
  display: none;
}

.r-info-list__item {
  grid-row-gap: 8px;
  border-bottom: 1px solid var(--border);
  flex-direction: column;
  padding: 20px;
  display: flex;
  position: relative;
}

.r-info-list__item.cc-last {
  border-bottom-style: none;
}

.r-info-list {
  border: 1px solid var(--border);
  width: 100%;
  max-width: 376px;
}

.r-info__col {
  flex-direction: column;
  align-items: flex-start;
  padding-top: 20px;
  display: flex;
}

.r-info__col.cc-right {
  padding-left: 20px;
  position: relative;
}

.aktuell-content-wrapper {
  z-index: 100;
  padding-top: 0;
  padding-left: 0;
  position: relative;
}

.aktuell-cms-rich {
  width: 100%;
  max-width: none;
}

.aktuell-cms-rich blockquote {
  z-index: 100;
  border-left-width: 2px;
  border-left-color: var(--midnight-blue);
  color: var(--midnight-blue);
  max-width: 480px;
  margin-top: 80px;
  margin-bottom: 80px;
  margin-left: -20.5px;
  padding-left: 20.5px;
  font-weight: 600;
  position: relative;
}

.aktuell-cms-rich h4 {
  max-width: 612px;
  margin-bottom: 20px;
  font-size: 15px;
  font-weight: 600;
}

.aktuell-cms-rich p {
  max-width: 612px;
  margin-bottom: 40px;
}

.aktuell-cms-rich figcaption {
  color: #00344a99;
  text-align: left;
  margin-top: 0;
  padding-top: 10px;
  padding-bottom: 20px;
  font-size: 12px;
  line-height: 16px;
}

.aktuell-cms-rich figure {
  flex-direction: column;
  align-items: flex-start;
  margin-top: 80px;
  margin-bottom: 80px;
  margin-left: 0;
  padding-top: 20px;
  padding-bottom: 0;
  padding-left: 0;
  display: flex;
  position: relative;
}

.aktuell-cms-rich img {
  width: 100%;
  max-width: 612px;
  margin-bottom: 0;
  display: block;
}

.aktuell-cms-rich.cc-legal {
  max-width: 650px;
  margin-left: auto;
  margin-right: auto;
}

.aktuell-cms-rich a {
  color: var(--dark-slate-grey);
}

.aktuel-cms-excerpt {
  max-width: 624px;
  margin-top: 20px;
  margin-bottom: 170px;
}

.aktuel-cms-thumbnail {
  width: 100%;
  height: auto;
  padding-top: 60%;
  position: relative;
}

.aktuel-cms-hero {
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-end;
  min-height: 420px;
  padding-bottom: 20px;
  padding-left: 20px;
  display: flex;
  position: relative;
}

.aktuel-cms-hero__info {
  grid-column-gap: 60px;
  flex: none;
  margin-bottom: -5px;
  padding-bottom: 0;
  display: flex;
}

.aktuell-content {
  padding: 20px 0 20px 20px;
}

.share-buttons {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  margin-bottom: auto;
  display: flex;
  position: static;
}

.share-buttons.referenzen-share {
  grid-column-gap: 10px;
  flex-flow: row;
  margin-top: 10px;
}

.c-share-button {
  color: var(--midnight-blue);
  cursor: pointer;
  background-color: #edeff1;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  transition: all .2s ease-in-out;
  display: flex;
}

.c-share-button:hover {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.c-share-button.cc-last {
  margin-right: 0;
}

.aktuell-g__title {
  cursor: pointer;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
}

.aktuell-g__title:hover {
  opacity: .7;
}

.aktuell-g__title.w--current:hover {
  opacity: .8;
}

.div-block-33 {
  overflow: hidden;
}

.aktuell__image-wrapper {
  flex: none;
  width: 327px;
  height: 221px;
  position: relative;
  overflow: hidden;
}

.aktuell__image-wrapper.w--current {
  overflow: hidden;
}

.aktuell__col {
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.aktuell__col.cc-mw-44 {
  max-width: 440px;
}

.aktuell-h-collection-item, .aktuell-h__collection-wrapper {
  width: 100%;
  height: 100%;
}

.aktuell-h__collection-list {
  height: 100%;
}

.aktuell-collection-item:last-child {
  margin-bottom: 0;
}

.a-hero {
  color: var(--dark-slate-grey);
  flex-direction: column;
  justify-content: space-between;
  padding-bottom: 0;
  display: flex;
  position: relative;
}

.a-hero-image {
  z-index: 100;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  height: auto;
  padding-top: 56.25%;
  display: flex;
  position: relative;
}

.a-info-col {
  flex-direction: column;
  justify-content: flex-end;
  height: auto;
  min-height: 420px;
  padding-bottom: 20px;
  padding-left: 20px;
  display: flex;
  position: relative;
}

.empty-div {
  grid-column-gap: 30px;
  align-items: flex-end;
  width: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
}

.empty-div__text {
  opacity: 0;
}

.team {
  flex-direction: column;
  flex: none;
  justify-content: flex-start;
  height: 100%;
  display: flex;
}

.team.cc-last {
  margin-right: 0;
}

.team__image {
  background-image: url("https://d3e54v103j8qbb.cloudfront.net/img/background-image.svg");
  background-position: 50% 0;
  background-size: cover;
  flex-direction: row;
  flex: none;
  width: 296px;
  height: 379px;
  display: block;
}

.team__image.full-width__team {
  object-fit: cover;
  width: 100%;
  height: auto;
}

.team__info {
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  padding-top: 20px;
  display: flex;
}

.team__buttons {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-top: 20px;
  display: flex;
}

.team__buttons.cc-kontakt {
  margin-top: 20px;
}

.team__buttons.hidden {
  display: none;
}

.team__contact-btn {
  color: var(--midnight-blue);
  cursor: pointer;
  background-color: #edeff1;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  transition: all .2s ease-in-out;
  display: flex;
}

.team__contact-btn:hover {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.team__contact-btn.cc-last {
  margin-right: 0;
}

.team__contact-btn.small__contant-btn {
  width: 34px;
  height: 34px;
}

.team__name {
  margin-bottom: 0;
}

.team__position {
  align-items: flex-end;
  max-width: 128px;
  margin-bottom: auto;
  display: flex;
}

.team__position.edited__team-position {
  max-width: 260px;
}

.team-collection-list {
  display: flex;
}

.team-collection-wrapper {
  width: 100%;
  padding-left: 377px;
  display: flex;
  overflow: hidden;
}

.team-collection-item {
  background-color: #0000;
  flex-direction: column;
  flex: none;
  align-self: auto;
  padding-bottom: 16px;
  padding-right: 0;
  display: flex;
  position: relative;
}

.div-block-34 {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto;
  grid-template-columns: minmax(20px, 1fr) minmax(auto, 376px) minmax(auto, 1024px) minmax(20px, 1fr);
  grid-auto-columns: 1fr;
  display: grid;
}

.job-list {
  display: flex;
}

.job {
  flex: none;
  padding-right: 86px;
}

.job__rich-text {
  max-width: 436px;
}

.job__rich-text strong {
  color: var(--midnight-blue);
  margin-bottom: 20px;
}

.job__rich-text h5 {
  color: var(--midnight-blue);
  letter-spacing: -.3px;
  margin-bottom: 20px;
  font-size: 15px;
}

.job__title {
  white-space: normal;
  flex-wrap: wrap;
  max-width: 343px;
  margin-top: 20px;
  margin-bottom: 90px;
  font-size: 26px;
  line-height: 32px;
  display: flex;
}

.job__title.mb-0 {
  margin-bottom: 0;
}

.job__contact {
  grid-column-gap: 10px;
  align-items: center;
  margin-top: 40px;
  display: flex;
}

.job__contact__btn {
  background-color: var(--white-smoke);
  color: var(--dark-slate-grey);
  cursor: pointer;
  border-radius: 4px;
  align-items: center;
  height: 34px;
  padding-left: 16px;
  padding-right: 18px;
  text-decoration: none;
  transition: all .2s ease-in-out;
  display: flex;
}

.job__contact__btn:hover {
  background-color: var(--midnight-blue);
  color: var(--white);
}

.job__contact__text-bold {
  text-transform: uppercase;
  margin-left: 5px;
  margin-right: 10px;
  padding-right: 0;
  font-size: 12px;
  font-weight: 600;
}

.div-block-35 {
  grid-column-gap: 4px;
  align-items: center;
  margin-right: 10px;
  display: flex;
}

.referenzen__link {
  cursor: pointer;
  flex: 0 auto;
  margin-bottom: 40px;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
  display: block;
}

.referenzen__link:hover {
  opacity: .7;
}

.referenzen-swiper-collection-wrapper {
  padding-left: 377px;
}

.aktuell-swiper-collection-list {
  width: 100%;
  display: flex;
}

.aktuell-swiper-collection-list.neu-g__list {
  flex-flow: column;
  margin-bottom: 30px;
  position: relative;
}

.aktuell-swiper-collection-wrapper {
  width: 100%;
  overflow: hidden;
}

.aktuell-swiper__title {
  cursor: pointer;
  margin-top: 40px;
  margin-bottom: 20px;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
}

.aktuell-swiper__title:hover {
  opacity: .7;
}

.menu {
  z-index: 9999;
  width: 100%;
  height: 100vh;
  display: none;
  position: fixed;
  inset: 0%;
  overflow: hidden;
}

.menu.active {
  display: block;
  overflow: hidden;
}

.menu__overlay {
  z-index: 1000;
  opacity: 0;
  background-color: #00090d;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.menu__wrapper {
  z-index: 2000;
  background-color: #0000;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  height: 100%;
  display: flex;
  position: relative;
}

.menu__bg {
  z-index: 100;
  background-color: var(--dodger-blue);
  width: auto;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.menu__nav {
  z-index: 2000;
  background-color: var(--dodger-blue);
  flex-direction: column;
  flex: none;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 260px;
  height: 100%;
  padding-top: 70px;
  padding-bottom: 150px;
  padding-left: 70px;
  display: flex;
  position: relative;
  left: -100%;
  overflow: auto;
}

.menu__nav.active {
  left: 0%;
}

.menu__panel {
  z-index: 2000;
  background-color: var(--dodger-blue);
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 685px;
  height: 100vh;
  padding-top: 70px;
  padding-left: 0;
  display: flex;
  position: relative;
}

.menu__panel.js-produkte-panel, .menu__panel.js-referenzen-panel, .menu__panel.js-about-panel {
  background-color: var(--dodger-blue);
  display: none;
}

.menu__panel.js-about-panel.active {
  background-color: var(--dodger-blue);
  display: block;
}

.menu__panel.js-downloads-panel {
  background-color: var(--dodger-blue);
  display: none;
}

.menu__panel.js-downloads-panel.active {
  background-color: var(--dodger-blue);
  display: block;
}

.menu__panel__item {
  color: var(--white);
  letter-spacing: -1.28px;
  border-top: 1px solid #33b1e3;
  width: 100%;
  padding-top: 0;
  padding-bottom: 0;
  font-size: 32px;
  line-height: 1;
}

.menu__panel__wrapper {
  z-index: 3000;
  opacity: 0;
  width: 100%;
  position: relative;
}

.menu__panel__wrapper.active {
  opacity: 1;
}

.menu__panel__list {
  color: var(--bg-color);
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  display: block;
  overflow: visible;
}

.menu__nav__link {
  opacity: .6;
  color: var(--white);
  letter-spacing: .36px;
  text-transform: uppercase;
  cursor: pointer;
  margin-bottom: 0;
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
  display: block;
}

.menu__nav__link:hover {
  opacity: 1;
}

.menu__nav__link.cc-aktuell-date, .menu__nav__link.cc-kontakt-person {
  margin-top: auto;
}

.menu__nav__link.cc-active {
  opacity: 1;
}

.menu__nav__link.current {
  opacity: 1;
  display: block;
}

.produkt-sticky__wrapper {
  z-index: 1;
  background-color: #0000;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100vh;
  min-height: 116vh;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
  display: flex;
  position: sticky;
  top: 100px;
}

.produkt-sticky__top {
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  height: 420px;
  max-height: none;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.produkt-sticky__bottom {
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 20px;
  display: flex;
}

.produkt-sticky__bottom.with__zuruck-button {
  justify-content: space-between;
  align-items: flex-start;
}

.produkte__rich-text {
  max-width: 380px;
}

.produkte__rich-text ul {
  flex-direction: column;
  margin-bottom: 0;
  padding-left: 20px;
  list-style-type: disc;
  display: flex;
}

.produkte__rich-text a {
  color: var(--dark-slate-grey);
}

.produkte-info__pdf {
  grid-column-gap: 10px;
  align-items: center;
  margin-top: 100px;
  font-size: 12px;
  line-height: 1.2;
  display: flex;
}

.produkte-gallery-collection-list {
  width: 100%;
  display: flex;
}

.produkte-gallery-collection-item {
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  width: 100%;
  max-width: 70vw;
  margin-right: 20px;
  display: flex;
  position: relative;
}

.produkte-gallery-collection-item:last-child {
  margin-right: 0;
}

.total-images {
  grid-column-gap: 4px;
  display: flex;
}

.portfolio-sticky__top {
  flex-flow: column;
  flex: none;
  justify-content: flex-end;
  height: 420px;
  max-height: none;
  padding-bottom: 20px;
  padding-right: 20px;
  display: flex;
  position: relative;
}

.portfolio-sticky__bottom {
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-right: 20px;
  display: flex;
}

.portfolio-sticky {
  background-color: #0000;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100vh;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
  display: flex;
  position: sticky;
  top: 100px;
}

.portfolio-column {
  z-index: 1000;
  flex-direction: column;
  width: 100%;
  min-height: 100vh;
  display: flex;
  position: relative;
}

.portfolio-sticky__buttons {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-wrap: wrap;
  display: flex;
}

.portfolio__item__image {
  flex: none;
  width: 367px;
  height: 244px;
  position: relative;
  overflow: hidden;
}

.portfolio__item__image.cc-portrait {
  width: 100%;
  max-width: 204px;
  height: 260px;
}

.portfolio__item__content {
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.portfolio__item__content.cc-mw-44 {
  max-width: 440px;
}

.portfolio-collection-list {
  grid-column-gap: 10px;
  grid-row-gap: 16px;
  flex-direction: column;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-around;
  width: 100%;
  display: block;
}

.portfolio-collection-list.cc-portrait {
  grid-column-gap: 20px;
  grid-row-gap: 16px;
  flex-flow: wrap;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: flex-start;
  display: block;
}

.portfolio-portrait-item {
  flex: 1;
  width: 100%;
  max-width: 388px;
}

.portfolio-collection-wrapper {
  z-index: 20;
  width: 100%;
  position: relative;
}

.portfolio-block__bg {
  z-index: 10;
  background-color: var(--bg-color);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.portfolio-title {
  white-space: normal;
  width: 100%;
}

.portfolio-title.cc-h-aktuell {
  margin-top: 40px;
  margin-bottom: 20px;
}

.portfolio-title.cc-video-title {
  margin-top: 20px;
  margin-bottom: 40px;
}

.portfolio-title.cc-aktuel-cms-title {
  width: 100%;
  max-width: 679px;
}

.produkte-info-container__bg {
  z-index: 1000;
  background-color: var(--bg-color);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.div-block-36 {
  display: block;
}

.menu__subnav-copy {
  z-index: 2000;
  background-color: var(--dodger-blue);
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 258px;
  height: 100%;
  padding-left: 70px;
  display: flex;
  position: relative;
}

.menu__list {
  flex-direction: column;
  margin-top: auto;
  margin-bottom: auto;
  padding-left: 0;
  list-style-type: none;
  display: flex;
}

.menu__list__item.cc-mobile-show {
  display: none;
}

.menu__panel__link {
  color: var(--white);
  cursor: pointer;
  padding: 16px 20px;
  text-decoration: none;
  transition: all .2s ease-in-out;
  display: block;
  position: relative;
}

.menu__panel__link:hover {
  opacity: .7;
}

.menu__panel__link.is-sub {
  font-size: 24px;
}

.navbar__link {
  color: var(--midnight-blue);
  letter-spacing: -.24px;
  text-transform: uppercase;
  flex: none;
  align-items: center;
  height: 32px;
  padding: 0 15px;
  font-size: 12px;
  font-weight: 600;
  line-height: 16px;
  text-decoration: none;
  display: flex;
}

.navbar__link.w--current {
  color: var(--midnight-blue);
}

.navbar__menu {
  align-items: center;
  margin-left: 15px;
  display: flex;
  position: absolute;
  left: 50%;
  transform: translate(-50%);
}

.searchhelp__item {
  color: #33333380;
  cursor: pointer;
  border-radius: 4px;
  margin-left: -8px;
  margin-right: -8px;
  padding: 5px 7px 4px;
  font-size: 12px;
  text-decoration: none;
  display: block;
}

.searchhelp__section {
  transform-style: preserve-3d;
  background-color: #fff;
  border-bottom: 1px solid #efefef;
  border-left: 1px solid #efefef;
  border-right: 1px solid #efefef;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
  padding: 10px 18px 12px;
  display: none;
  position: absolute;
  top: 28px;
  left: 0;
  right: 0;
  overflow: hidden;
  transform: scale3d(1, 1, 1);
}

.searchhelp__section.searchhelp__nav-section {
  padding-top: 5px;
  top: 27px;
}

.search__container {
  color: var(--dark-slate-grey);
  flex: 1;
  max-width: none;
  position: relative;
}

.search__wrapper {
  width: 100%;
  max-width: 133px;
}

.search-button {
  display: none;
}

.search__input {
  color: var(--midnight-blue);
  text-transform: uppercase;
  background-color: #edeff1;
  border: 1px #efefef;
  border-radius: 4px;
  height: 32px;
  margin-bottom: 0;
  padding-top: 10px;
  padding-left: 15px;
  padding-right: 15px;
  font-size: 10px;
  font-weight: 600;
  line-height: 16px;
  transition: none;
}

.search__input:focus {
  color: var(--dark-slate-grey);
  border-style: none;
  border-color: #000;
}

.search__input::placeholder {
  color: #00344a54;
}

.search__input.inside-navmenu {
  color: var(--midnight-blue);
  text-transform: uppercase;
  background-color: #edeff1;
  max-width: 150px;
  padding-left: 10px;
  padding-right: 30px;
  font-size: 10px;
  font-weight: 600;
}

.search__input.cc-large {
  flex: 1;
  height: 34px;
}

.search {
  z-index: 100;
  color: var(--dark-slate-grey);
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  display: flex;
  position: relative;
}

.searchhelp__container {
  border-top: 1px solid #efefef;
  padding-top: 8px;
}

.searchhelp__words {
  display: none;
}

.search_icon {
  z-index: 10;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 12px;
  height: 12px;
  margin: auto;
  transition: all .2s;
  display: flex;
  position: absolute;
  inset: 0% 16px 0% auto;
}

.wg-element-wrapper {
  align-items: center;
  display: flex;
  position: relative;
}

.wg-element-wrapper.sw5 {
  border: 1px #00000026;
  border-radius: 0;
  margin-left: auto;
}

.wg-dropdown-1 {
  z-index: 999999;
  text-transform: uppercase;
  align-items: stretch;
  width: auto;
  font-weight: 700;
}

.wg-dd-1-togle {
  z-index: 1;
  color: var(--midnight-blue);
  border: 1px solid #005b8080;
  border-radius: 4px;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: auto;
  padding: 5px 8px 5px 10px;
  font-size: 12px;
  font-weight: 600;
  line-height: 20px;
  display: flex;
}

.wg-dd-1-togle:hover {
  color: #000;
  background-color: #0000;
}

.wg-dd-1-togle.w--open {
  height: auto;
  padding-top: 5px;
  padding-bottom: 5px;
}

.wg-dd-1-togle._w--open {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.c-navbar-link-icon {
  margin: 0 0 0 4px;
  font-size: .78em;
  position: static;
}

.wg-dd-1-list {
  z-index: 9999;
  background-color: #fff;
  border: 1px solid #00000026;
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 -13px 50px 3px #11179c12;
}

.wg-dd-1-list.w--open {
  background-color: var(--bg-color);
  border-color: #005b8080;
  border-radius: 4px;
  margin-top: 2px;
}

.wg-dd-1-list._w--open {
  border-top-style: none;
  border-radius: 0 0 4px 4px;
  margin-top: 0;
}

.wg-dropdown-1-link {
  color: var(--midnight-blue);
  background-color: #fafafa;
  width: 100%;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 600;
  line-height: 20px;
  text-decoration: none;
}

.wg-dropdown-1-link:hover {
  color: #fff;
  background-color: #0394c6;
}

.navbar__col {
  grid-column-gap: 10px;
  display: flex;
}

.jobs-collection-wrapper {
  padding-left: 377px;
}

.jobs-collection-list {
  display: flex;
}

.jobs-collection-item {
  flex: none;
  padding-right: 86px;
}

.job__contact__name {
  font-weight: 700;
}

.geschichte-sticky {
  background-color: #0000;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100vh;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
  display: flex;
  position: sticky;
  top: 100px;
}

.geschichte-sticky__top {
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  height: 420px;
  max-height: none;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.geschichte-sticky__bottom {
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
}

.geschichte__wrapper {
  z-index: 1000;
  flex-direction: column;
  width: 100%;
  height: 100vh;
  display: flex;
  position: relative;
}

.geschichte__wrapper.is-hidden, .geschichte__wrapper.utility__hidden {
  display: none;
}

.geschichte__list {
  flex-direction: row;
  justify-content: flex-start;
  height: 100vh;
  display: flex;
  overflow: visible;
}

.geschichte {
  cursor: pointer;
  border-right: 1px solid #c8dae2;
  flex-direction: column;
  flex: 0 auto;
  justify-content: flex-start;
  align-items: flex-start;
  width: auto;
  height: 100vh;
  padding: 20px 0 0 20px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.geschichte.is-open {
  z-index: 100;
  align-items: flex-start;
  max-height: none;
  padding-bottom: 0;
  padding-right: 20px;
  position: static;
  overflow: hidden;
}

.geschichte__image {
  flex: none;
  align-items: flex-start;
  width: 80px;
  min-height: 400px;
  margin-bottom: auto;
  display: block;
  position: relative;
}

.geschichte__image.is-2009 {
  perspective-origin: 100%;
  transform-origin: 100%;
  width: 80px;
}

.geschichte__image.is-2010 {
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bd8_g_img_2.jpg");
  flex: none;
  height: 80%;
}

.geschichte__image.is-2012 {
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bd9_g_img_3.jpg");
  height: 80%;
}

.geschichte__image.is-2020 {
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bda_g_img_4.jpg");
  height: 75%;
}

.geschichte__image.is-2021 {
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bd7_g_img_5.jpg");
  height: 80%;
}

.geschichte__image.is-2022 {
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bd6_g_img_6.jpg");
  width: 80px;
}

.geschichte__image.is-vision {
  perspective-origin: 100%;
  transform-origin: 100%;
  background-image: none;
  width: 80px;
  height: 40%;
}

.geschichte__image.is-mission {
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bd8_g_img_2.jpg");
  flex: none;
  height: 80%;
}

.geschichte__image.is-werte {
  background-image: url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2bd9_g_img_3.jpg");
  height: 40%;
}

.geschichte__year {
  z-index: 10;
  color: var(--midnight-blue);
  text-align: left;
  align-self: flex-start;
  width: 100%;
  max-width: 80px;
  margin-top: 0;
  padding-bottom: 20px;
  padding-left: 0;
  padding-right: 0;
  font-weight: 600;
  position: static;
  inset: auto 0% 0%;
}

.geschichte__content__wrapper {
  opacity: 1;
  flex-direction: column;
  width: 0%;
  max-width: 447px;
  margin-top: 20px;
  padding-bottom: 100px;
  display: none;
  position: relative;
  overflow: hidden;
  transform: translate(0);
}

.geschichte__title {
  margin-top: 10px;
  margin-bottom: 20px;
}

.geschichte__content {
  width: 100%;
  max-width: 447px;
  margin-top: 20px;
  margin-bottom: 100px;
  display: none;
}

.geschichte__content.is-active {
  display: block;
}

.geschichte__content.neu-g__content {
  flex-flow: column;
  margin-top: 0;
  margin-bottom: 0;
  display: flex;
}

.portfolio-swiper-collection-list {
  display: flex;
}

.portfolio-swiper-collection-item {
  background-color: #0000;
  flex-direction: column;
  flex: none;
  align-self: auto;
  margin-right: 20px;
  padding-right: 0;
  display: flex;
}

.portfolio-swiper-collection-item:last-child {
  margin-right: 0;
}

.portfolio-swiper-collection-wrapper {
  width: 100%;
  padding-left: 377px;
  display: flex;
  overflow: visible;
}

.portfolio__info__sub {
  grid-column-gap: 4px;
  margin-top: 40px;
  display: flex;
}

.portfolio__info__sub.is-fch-portfolio {
  margin-top: 10px;
  margin-bottom: auto;
  padding-bottom: 40px;
}

.portfolio__info__title {
  cursor: pointer;
  border: 1px #000;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
}

.portfolio__info__title:hover {
  opacity: .7;
}

.eingesetzte-produkte-link {
  color: var(--midnight-blue);
  cursor: pointer;
  font-weight: 600;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
}

.eingesetzte-produkte-link:hover {
  opacity: .7;
}

.popup {
  z-index: 999999;
  background-color: #000000e6;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100vh;
  display: none;
  position: fixed;
  inset: 0%;
}

.popup__container {
  background-color: var(--white);
  border-radius: 12px;
  width: 100%;
  max-width: 612px;
  padding: 10px;
  display: flex;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.popup__slider {
  z-index: 100;
  border-radius: 6px;
  flex: none;
  width: 297px;
  height: 297px;
  margin-right: 20px;
  position: relative;
  overflow: hidden;
}

.popup__content {
  flex-direction: column;
  height: 297px;
  max-height: 297px;
  margin-top: 0;
  padding-top: 30px;
  padding-right: 40px;
  display: block;
  overflow: hidden;
}

.popup__title {
  margin-top: 10px;
  margin-bottom: 20px;
  font-size: 18px;
}

.popup__close {
  z-index: 10;
  color: var(--midnight-blue);
  cursor: pointer;
  background-color: #ebeff1;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  transition: all .2s ease-in-out;
  display: flex;
  position: absolute;
  inset: 10px 10px auto auto;
}

.popup__close:hover {
  background-color: var(--midnight-blue);
  color: var(--white-smoke);
}

.popup__slider__btns {
  z-index: 140;
  grid-column-gap: 4px;
  display: flex;
  position: absolute;
  inset: auto 10px 10px auto;
}

.popup_slider__btn {
  z-index: 10;
  color: var(--white);
  cursor: pointer;
  background-color: #fff3;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  transition: all .2s ease-in-out;
  display: flex;
  position: static;
  inset: 10px 10px auto auto;
}

.popup_slider__btn:hover {
  color: var(--white-smoke);
  background-color: #ffffff4d;
}

.test-link {
  z-index: 99999;
  color: var(--dodger-blue);
  display: block;
  position: fixed;
  inset: 0% 0% auto auto;
}

.test-link.cc-1 {
  top: 30%;
  right: 10%;
}

.test-link.cc-close {
  top: 50%;
}

.test-link.cc-2 {
  top: 10%;
  right: 10%;
}

.test-link.cc-3 {
  top: 40%;
  right: 10%;
}

.close-menu {
  z-index: 99999;
  color: var(--dodger-blue);
  display: block;
  position: fixed;
  inset: 0% 0% auto auto;
}

.close-menu.cc-1 {
  top: 30%;
}

.close-menu.cc-close {
  top: 50%;
  right: 10%;
}

.menu__panel__bg {
  z-index: 1000;
  background-color: var(--dodger-blue);
  width: 0%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.navbar__logo {
  z-index: 1000;
  color: var(--dodger-blue);
  background-color: #0000;
  flex-direction: column;
  flex: 0 auto;
  align-items: flex-start;
  width: auto;
  max-width: none;
  height: auto;
  margin-top: 11px;
  display: block;
}

.navbar__logo__top__image {
  cursor: pointer;
  width: 174px;
  max-width: none;
  height: 48px;
  margin-bottom: 0;
  transition: all .5s cubic-bezier(.165, .84, .44, 1);
  display: block;
  position: relative;
  bottom: 0;
}

.navbar__logo__bottom {
  -webkit-text-fill-color: inherit;
  background-color: #fafafa;
  background-clip: border-box;
  align-items: flex-start;
  width: 100%;
  max-width: none;
  margin-top: 12px;
  transition: all .5s cubic-bezier(.165, .84, .44, 1);
  display: flex;
  position: relative;
  left: -20px;
  overflow: hidden;
}

.navbar__logo__bottom.cc-kontakt-page {
  background-color: var(--dodger-blue);
}

.map__item {
  z-index: 100;
  display: block;
  position: relative;
}

.map__item__box {
  display: block;
}

.map__iw__wrapper {
  background-color: var(--white);
  text-align: center;
  border-radius: 8px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 300px;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
  display: flex;
}

.locmap__map {
  z-index: 1;
  background-color: var(--border);
  width: auto;
  height: auto;
  position: absolute;
  inset: 0%;
}

.c-map__button-container {
  padding: 1.56em;
}

.c-map__text {
  color: var(--midnight-blue);
  text-align: center;
  border-bottom: 1px solid #0000001a;
  width: 100%;
  padding: 1.56em;
}

.kontakt-map__item {
  z-index: 10;
  display: block;
  position: relative;
}

.c-map__marker {
  z-index: 5;
  width: 60px;
  height: 60px;
  position: relative;
}

.c-icon-3 {
  flex: 0 auto;
  order: 1;
  justify-content: center;
  align-items: center;
  width: 1.04em;
  height: 1.04em;
  display: block;
}

.map__marker__heading {
  margin-bottom: 20px;
}

.c-button-2 {
  z-index: 50;
  color: #000;
  cursor: pointer;
  background-color: #0000;
  border: 1px #00000026;
  border-radius: .63em;
  flex: 0 auto;
  justify-content: center;
  align-items: center;
  padding: .21em;
  text-decoration: none;
  display: flex;
  position: relative;
  overflow: hidden;
}

.c-map__info__box {
  z-index: 10;
  background-color: #fff;
  border-radius: 12px;
  flex-direction: column;
  align-items: center;
  width: 24.69em;
  max-width: 24.69em;
  display: flex;
  position: relative;
}

.c-map__info__arrow {
  background-color: #fff;
  width: 12px;
  height: 12px;
  margin-left: auto;
  margin-right: auto;
  position: absolute;
  bottom: -4px;
  transform: rotate(45deg);
}

.map__marker__copy {
  margin-bottom: 20px;
}

.portfolio-slider-wrapper {
  display: block;
  overflow: hidden;
}

.portfolio-slider-wrapper.utility__hidden {
  display: none;
}

.portfolio-slider-list {
  display: flex;
}

.portfolio-slider-item {
  grid-column-gap: 20px;
  flex: none;
  width: 100%;
  display: flex;
}

.navbar__logo__top {
  justify-content: flex-start;
  align-items: flex-end;
  margin-bottom: 0;
  display: flex;
}

.navbar__logo__bottom__image {
  opacity: 1;
  cursor: pointer;
  background-color: #0000;
  align-items: flex-start;
  width: 174px;
  max-width: none;
  height: 16px;
  margin-left: 20px;
  margin-right: 20px;
  display: block;
  position: static;
  inset: 56px auto 0% 0%;
}

.navbar__hamburger {
  display: none;
}

.geschichte__bottom__info {
  max-width: 80px;
}

.kontakt-info-adress {
  margin-bottom: 20px;
}

.kontakt-cms-wrapper {
  width: 100%;
  display: block;
  position: relative;
}

.kontakt-cms-wrapper.is-hidden {
  display: none;
}

.kontakt-cms-list {
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 167px) minmax(auto, 167px) minmax(auto, 167px);
  grid-auto-columns: 1fr;
  height: 100%;
  display: flex;
}

.kontakt-person__btn {
  color: var(--midnight-blue);
  cursor: pointer;
  background-color: #00344a33;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  transition: all .2s ease-in-out;
  display: flex;
}

.kontakt-person__btn:hover {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.kontakt-person__btn.cc-last {
  margin-right: 0;
}

.kontakt-person__btn.white-smoke__small-btn {
  background-color: var(--white-smoke);
  width: 34px;
  height: 34px;
}

.kontakt-person__btn.white-smoke__small-btn:hover {
  background-color: var(--midnight-blue);
}

.footer__bottom {
  justify-content: flex-end;
  align-items: flex-end;
  width: 100%;
  display: flex;
}

.footer__logo {
  z-index: 1000;
  color: var(--dodger-blue);
  background-color: #0000;
  flex-direction: column;
  flex: 0 auto;
  align-items: flex-start;
  margin-top: 0;
  display: block;
}

.footer__logo__top {
  z-index: 10;
  justify-content: flex-start;
  align-items: flex-end;
  margin-bottom: 0;
  display: flex;
  position: relative;
  overflow: hidden;
}

.footer__logo__bottom {
  background-color: var(--bg-color);
  align-items: flex-end;
  width: 100%;
  max-width: none;
  margin-top: 12px;
  transition: all .3s ease-in-out;
  display: flex;
  position: relative;
  right: -20px;
  overflow: hidden;
}

.footer__logo__bottom.cc-kontakt-page {
  background-color: var(--dodger-blue);
}

.footer__logo__top__img {
  max-width: none;
  height: 44px;
  margin-bottom: 0;
  margin-left: auto;
  transition: all .5s ease-in-out;
  display: block;
}

.footer__logo__bottom__img {
  opacity: 1;
  background-color: #0000;
  align-items: flex-start;
  width: 160px;
  max-width: none;
  height: 15px;
  margin-left: 20px;
  margin-right: 20px;
  padding-left: 0;
  display: block;
  position: static;
  inset: 56px auto 0% 0%;
}

.about-swiper-item__title {
  margin-top: 20px;
  margin-bottom: 20px;
}

.about-swiper-item__title.link-reset {
  color: var(--dark-slate-grey);
  text-decoration: none;
}

.map__title {
  color: var(--midnight-blue);
  font-size: 16px;
  font-weight: 600;
}

.map__adress {
  max-width: 70%;
  margin-top: 20px;
  margin-bottom: 20px;
}

.collection-list-wrapper {
  z-index: 100;
  position: relative;
}

.map {
  position: absolute;
  inset: 0% 0% 0;
}

.map-wrapper {
  z-index: 1;
  background-color: #6a6a6a;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 790px;
  margin-bottom: 90px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.map__icon {
  width: 40px;
  height: 40px;
}

.map__info-box {
  z-index: 10;
  color: var(--midnight-blue);
  text-align: center;
  background-color: #fff;
  border-radius: 8px;
  flex-direction: column;
  align-items: center;
  width: 100vw;
  max-width: 320px;
  padding: 20px;
  display: flex;
  position: relative;
}

.map__info {
  color: var(--midnight-blue);
}

.locmap-info-window {
  display: none;
}

.video__wrapper {
  z-index: 10;
  justify-content: center;
  align-items: center;
  width: 360px;
  height: 236px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.aktuell-cms-info {
  grid-column-gap: 20px;
  justify-content: space-between;
  width: 100%;
  display: flex;
}

.text-link {
  color: var(--midnight-blue);
  cursor: pointer;
  text-decoration: none;
  transition: all .2s ease-in-out;
}

.text-link:hover {
  opacity: .7;
}

.technologie-swiper-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 357px) 1fr;
  grid-auto-columns: 1fr;
  padding-left: 377px;
  display: flex;
  overflow: visible;
}

.technologie-swiper-list {
  display: flex;
}

.technologie-swiper-item {
  flex-direction: column;
  flex: none;
  align-items: flex-start;
  width: 100%;
  max-width: 317px;
  min-height: 266px;
  margin-right: 60px;
  display: flex;
}

.technologie-swiper-item.cc-hide {
  display: none;
}

.technologie-swiper-item.cc-last {
  margin-right: 0;
}

.cc-hide, .portfolio-subcategories {
  display: none;
}

.filter-dropdown-up {
  z-index: 100;
}

.filter-dropdown-up.w--open {
  color: var(--dark-slate-grey);
  background-color: #edeff1;
  border-radius: 4px;
  width: 100%;
  min-width: 200px;
  padding-top: 0;
  padding-bottom: 0;
  inset: auto auto 48px 0;
  overflow: hidden;
}

.portfolio__layout {
  display: none;
}

.t-vw {
  background-color: var(--dark-slate-grey);
  width: 500px;
  height: 500px;
}

.t-vw-2 {
  background-color: var(--dark-slate-grey);
  width: 34.722vw;
  height: 34.722vw;
  margin: 1.38vw;
}

.swiper-sec-nav {
  z-index: 1000;
  justify-content: space-between;
  width: 100%;
  padding-left: 0;
  padding-right: 40px;
  display: flex;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
}

.swiper-sec-nav.h-referenzen {
  top: 183px;
  transform: none;
}

.swiper-sec-nav.h-referenzen.h-aboutus {
  top: 150px;
}

.swiper-sec-nav.h-portfolio, .swiper-sec-nav.kst-team {
  top: 190px;
}

.swiper-sec-nav.kontakt-team {
  display: none;
}

.c-swiper-button-copy {
  z-index: 10;
  color: var(--midnight-blue);
  cursor: pointer;
  background-color: #0000;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  transition: all .2s ease-in-out;
  display: flex;
  position: relative;
}

.c-swiper-button-copy:hover {
  background-color: var(--midnight-blue);
  color: var(--white-smoke);
}

.c-swiper-button-bg {
  z-index: 1;
  background-color: var(--bg-color);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.c-swiper-button-sec {
  z-index: 10;
  background-color: var(--white-smoke);
  color: var(--midnight-blue);
  cursor: pointer;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  transition: all .2s ease-in-out;
  display: flex;
  position: relative;
}

.c-swiper-button-sec:hover {
  background-color: var(--midnight-blue);
  color: var(--white-smoke);
}

.c-swiper-button-sec.cc-blur {
  background-color: var(--bg-color);
  filter: blur(5px);
  mix-blend-mode: normal;
}

.geschichte-text-wrapper {
  max-width: 220px;
}

.geschichte-text-wrapper.neu-g__text-wrapper {
  max-width: 320px;
}

.menu__nav__close {
  z-index: 100;
  color: var(--white);
  background-color: #ffffff1a;
  border-radius: 4px;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  margin-bottom: 50px;
  display: flex;
  position: relative;
}

._404 {
  background-image: linear-gradient(#0009, #0009), url("https://cdn.prod.website-files.com/662f62df3c4fb7bcb06a2b8c/662f62df3c4fb7bcb06a2c31_kst-cta-img2-p-2000-404-site.jpg");
  background-position: 0 0, 50%;
  background-size: auto, cover;
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 100vh;
  display: flex;
}

._404__content {
  z-index: 100;
  color: var(--bg-color);
  text-align: center;
  flex-direction: column;
  align-items: center;
  display: flex;
  position: relative;
}

._404__title {
  color: var(--white);
  margin-bottom: 10px;
}

._404__text {
  margin-bottom: 24px;
}

._404__large {
  z-index: 1;
  color: #ffffff1a;
  font-size: 40vw;
  line-height: 1;
  position: absolute;
}

.s-result.cc-w-bg {
  z-index: 100;
  background-color: var(--bg-color);
  width: 100%;
  position: static;
}

.s-result.cc-relative {
  position: relative;
}

.s-result.cc-legal {
  padding-top: 200px;
  padding-bottom: 100px;
}

.s-result__hero {
  align-items: flex-end;
  height: 420px;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.s-result__body {
  padding-top: 40px;
  padding-bottom: 90px;
  position: relative;
}

.s-result__item {
  margin-top: 30px;
  margin-bottom: 30px;
}

.div-block-37 {
  display: flex;
}

.s-result__item__link {
  color: var(--dodger-blue);
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
}

.s-result__item__url {
  color: #325b6db3;
  margin-top: 8px;
  font-size: 12px;
}

.link-block {
  background-color: var(--midnight-blue);
  color: #fff;
  border-radius: 4px;
  width: 52px;
  height: 34px;
  position: relative;
}

.aktuell-hero.cc-w-bg {
  z-index: 100;
  background-color: var(--bg-color);
  width: 100%;
  position: static;
}

.aktuell-hero.cc-relative {
  position: relative;
}

.aktuell-hero.cc-legal {
  padding-top: 200px;
  padding-bottom: 100px;
}

.c-section__header-copy {
  padding-top: 100px;
  padding-bottom: 10px;
  position: relative;
}

.aktuell-hero_line {
  position: relative;
}

.aktuell-hero_container {
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

.aktuell-hero_container.cc-sc-header {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
  min-height: 420px;
  padding-bottom: 20px;
  display: flex;
}

.aktuell-hero_container.cc-aktuell {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 626px) 1fr;
  grid-auto-columns: 1fr;
  height: auto;
  min-height: auto;
  display: grid;
  position: static;
  top: 0;
}

.aktuell-hero_container.cc-technologien {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 486px) minmax(auto, 914px);
  grid-auto-columns: 1fr;
  height: 100%;
  min-height: 100vh;
  display: grid;
  position: static;
}

.aktuell-hero_container.cc-produkte-landscape {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 486px) minmax(auto, 914px);
  grid-auto-columns: 1fr;
  height: 100%;
  min-height: 100vh;
  display: grid;
  position: relative;
}

.aktuell-hero_container.cc-produkte-portrait {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743px) minmax(auto, 657px);
  grid-auto-columns: 1fr;
  height: 100%;
  min-height: 100vh;
  display: grid;
  position: relative;
}

.aktuell-hero_container.cc-kontakt {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743fr) minmax(auto, 657px);
  grid-auto-columns: 1fr;
  display: grid;
}

.aktuell-hero_container.r-thumbnail {
  z-index: 100;
  padding-top: 0%;
  padding-bottom: 0;
  position: absolute;
}

.aktuell-hero_container.cc-referenzen-cms-hero {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743fr) minmax(auto, 657px);
  grid-auto-columns: 1fr;
  align-content: start;
  align-items: start;
  height: 100%;
  display: grid;
  position: relative;
}

.aktuell-hero_container.cc-referenzen-info {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 743fr) minmax(auto, 657px);
  grid-auto-columns: 1fr;
  align-content: stretch;
  align-items: start;
  height: auto;
  display: grid;
}

.aktuell-hero_container.cc-referenzen-hero {
  align-items: flex-end;
  height: auto;
  min-height: 420px;
  padding-bottom: 10px;
  display: flex;
}

.aktuell-hero_container.cc-swiper-grid-container {
  grid-column-gap: 20px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 357px) 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.aktuell-hero_container.cc-aktuell-cms {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 356px) 1fr;
  grid-auto-columns: 1fr;
  height: auto;
  min-height: auto;
  display: grid;
  position: relative;
  top: 0;
}

.aktuell-hero_container.a-hero-image-copy {
  z-index: 100;
  padding-bottom: 20px;
  position: relative;
}

.aktuell-hero_container.cc-a-hero {
  grid-column-gap: 0px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 356px) minmax(auto, 1fr);
  grid-auto-columns: 1fr;
  align-content: stretch;
  align-items: end;
  height: auto;
  display: grid;
}

.aktuell-hero_container.cc-navbar {
  justify-content: space-between;
  align-items: center;
  height: 100px;
  padding-top: 30px;
  display: flex;
  position: relative;
}

.aktuell-hero_container.cc-geschichte {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--bg-color);
  grid-template-rows: auto;
  grid-template-columns: 1fr auto;
  grid-auto-columns: 1fr;
  height: 100vh;
  display: grid;
  position: static;
}

.aktuell-hero_container.cc-swiper {
  position: relative;
}

.aktuell-hero_container.cc-s-result {
  max-width: 900px;
}

.aktuell-hero_container.cc-kst {
  padding-top: 20px;
}

.r-besonderheiten-wrapper {
  width: 100%;
  max-width: 408px;
  margin-top: 20px;
  margin-bottom: 20px;
}

.gen-hero-img {
  z-index: 1;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.gen-hero-img.show-on-mobile {
  display: none;
}

.gen-hero-wrapper {
  z-index: 2;
  width: 100%;
  overflow: hidden;
}

.gen-hero-list {
  width: 100%;
  height: 100%;
  padding-top: 63%;
  display: flex;
  position: relative;
}

.gen-hero-item {
  z-index: auto;
  opacity: 1;
  flex: none;
  width: 100%;
  transition: all 1s cubic-bezier(.455, .03, .515, .955);
  position: absolute;
  inset: 0%;
}

.gen-hero-nav {
  z-index: 2;
  justify-content: center;
  width: 100%;
  display: flex;
  position: relative;
  bottom: 30px;
}

.gen-hero-nav-button {
  background-color: #d8d8d8;
  padding: 5px;
  text-decoration: none;
}

.gen-hero-nav-button.prev {
  transform-style: preserve-3d;
  margin-right: 10px;
  transform: rotateX(0)rotateY(-180deg)rotateZ(0);
}

.gen-hero-nav-button.next {
  margin-left: 10px;
}

.gen-hero-nav-button-icon {
  width: 20px;
  height: 20px;
}

.gen-hero-nav-button-label {
  color: #333;
  object-fit: cover;
  text-decoration: none;
}

.link-block-2 {
  text-decoration: none;
  display: block;
}

.new-tab-icon {
  color: var(--midnight-blue);
  margin-left: 5px;
  display: inline-block;
}

.link-block-3 {
  color: var(--midnight-blue);
  text-decoration: none;
  display: flex;
}

.hh-point__big {
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background-color: #0003;
  border-radius: 4px;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  transition: all .4s cubic-bezier(.165, .84, .44, 1);
  display: flex;
  position: relative;
  box-shadow: 0 0 80px #fff;
}

.hh-point__small {
  z-index: 10;
  background-color: #fff;
  border-radius: 100%;
  width: 10px;
  height: 10px;
  position: absolute;
}

.hh-point__zero {
  z-index: 5;
  cursor: pointer;
  width: 0;
  height: 0;
  position: absolute;
  top: 71%;
  left: 20%;
}

.kontakt-lower-text {
  max-width: 336px;
}

.kontakt-upper-text {
  max-width: 336px;
  position: relative;
}

.collection-list-2 {
  display: flex;
}

.collection-item-3 {
  flex: none;
  width: 100%;
}

.footer___contact__link {
  color: var(--dark-slate-grey);
}

.footer___contact__link.footer___contact__link__white {
  color: var(--white-smoke);
}

.gen-hero__nav {
  z-index: 100;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 30px;
  display: flex;
  position: absolute;
  inset: auto 20px 20px;
}

.gen-hero__nav.horizontal {
  z-index: 10;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-end;
}

.geschichte-img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  inset: 0%;
}

.hh-point__wrapper {
  justify-content: center;
  align-items: center;
  width: 100px;
  height: 100px;
  display: flex;
  position: absolute;
  top: -50px;
  left: -50px;
}

.gen-hero__section {
  z-index: 201;
  position: relative;
}

.gen-hero__section.generator {
  max-width: 159vh;
}

.gen-hero__nav__button {
  color: #fff;
  text-transform: uppercase;
  background-color: #ffffff26;
  border-radius: 4px;
  flex: none;
  justify-content: center;
  align-items: center;
  min-width: 34px;
  min-height: 34px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  transition: all .2s ease-in-out;
  display: flex;
}

.gen-hero__nav__button:hover {
  color: var(--bg-color);
  background-color: #fff3;
}

.gen-hero__nav__button.cc-secondary {
  color: #00000080;
  padding: 0;
}

.gen-hero__nav__button.cc-category {
  padding-left: 18px;
  padding-right: 18px;
}

.gen-hero__nav__button.cc-category.w--current {
  background-color: var(--midnight-blue);
  color: var(--white);
}

.gen-hero__nav__button.cc-category.utility__hidden {
  display: none;
}

.gen-hero__nav__button.cc-submit {
  background-color: var(--dodger-blue);
  padding-right: 15px;
}

.gen-hero__nav__button.cc-download {
  padding-right: 12px;
}

.gen-hero__nav__button.cc-icon-left {
  padding-left: 10px;
  padding-right: 10px;
}

.gen-hero__nav__button.cc-produkt-download-pdf {
  padding-right: 12px;
}

.gen-hero__nav__button.js-menu-link.utility__hidden {
  display: none;
}

.gen-hero__nav__button.cc-primary {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.gen-hero__nav-gradient {
  z-index: 5;
  background-image: linear-gradient(#0c172100, #0c172180);
  height: 30%;
  position: absolute;
  inset: auto 0% 0%;
}

.gen-hero__nav-gradient.higher {
  height: 50%;
}

.gen-hero__nav-row {
  grid-column-gap: 20px;
  display: flex;
}

.gen-hero__nav-row.toprow {
  grid-column-gap: 4px;
}

.gen-hero__nav-row.tight {
  grid-column-gap: 5px;
}

.c-button-copy {
  z-index: 50;
  background-color: var(--white-smoke);
  color: var(--midnight-blue);
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  flex-wrap: nowrap;
  flex: none;
  justify-content: center;
  align-items: center;
  min-height: 34px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 600;
  line-height: 20px;
  text-decoration: none;
  transition: all .2s ease-in-out;
  display: flex;
  position: relative;
  overflow: hidden;
}

.c-button-copy:hover {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.c-button-copy.cc-secondary {
  color: #00000080;
  padding: 0;
}

.c-button-copy.cc-category {
  padding-left: 18px;
  padding-right: 18px;
}

.c-button-copy.cc-category.w--current {
  background-color: var(--midnight-blue);
  color: var(--white);
}

.c-button-copy.cc-category.utility__hidden {
  display: none;
}

.c-button-copy.cc-submit {
  background-color: var(--dodger-blue);
  padding-right: 15px;
}

.c-button-copy.cc-download {
  padding-right: 12px;
}

.c-button-copy.cc-icon-left {
  padding-left: 10px;
  padding-right: 10px;
}

.c-button-copy.cc-produkt-download-pdf {
  padding-right: 12px;
}

.c-button-copy.js-menu-link.utility__hidden {
  display: none;
}

.c-button-copy.cc-primary {
  background-color: var(--midnight-blue);
  color: var(--bg-color);
}

.gen-hero__nav__pagination {
  cursor: pointer;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  transition: all .2s ease-in-out;
  display: flex;
  position: relative;
}

.hp-pop__item {
  z-index: 10000;
  justify-content: center;
  align-items: flex-start;
  padding: 20px;
  display: none;
  position: fixed;
  inset: 0%;
  overflow: auto;
}

.hp-pop__item.hp-pop__active {
  display: flex;
}

.hp-pop__bg {
  opacity: 0;
  background-color: #00090de6;
  transition: all .4s cubic-bezier(.25, .46, .45, .94);
  position: fixed;
  inset: 0%;
}

.hp-pop__bg.hp-pop__active {
  opacity: 1;
}

.hp-pop__block {
  z-index: 10;
  grid-column-gap: 10px;
  grid-row-gap: 20px;
  opacity: 0;
  background-color: #fff;
  border-radius: 12px;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  max-width: 620px;
  min-height: 320px;
  margin: auto;
  padding: 10px 20px 10px 10px;
  transition: all .4s cubic-bezier(.165, .84, .44, 1);
  display: flex;
  position: relative;
  overflow: hidden;
  transform: translate(0, 10px);
}

.hp-pop__block.hp-pop__active {
  grid-column-gap: 10px;
  opacity: 1;
  transform: translate(0);
}

.hp-pop__gallery__container {
  z-index: 1;
  align-self: stretch;
  width: 100%;
  height: 100%;
  position: relative;
}

.hp-pop__text-container {
  align-self: stretch;
  width: 100%;
  height: 300px;
  padding-top: 30px;
  padding-bottom: 30px;
  padding-left: 10px;
  overflow: auto;
}

.hp-pop__gallery__wrapper {
  justify-content: flex-start;
  align-items: stretch;
  height: 100%;
  display: flex;
}

.hp-pop__gallery__item {
  flex: none;
  align-self: stretch;
  width: 100%;
  height: 300px;
  position: relative;
}

.hp-pop__gallery__img {
  object-fit: cover;
  width: 100%;
  min-width: 100%;
  height: 100%;
  min-height: 100%;
  display: block;
  position: absolute;
  inset: 0%;
}

.hp-pop__copy {
  padding-right: 30px;
}

.hp-pop__preheading {
  opacity: .5;
  text-transform: uppercase;
  margin-bottom: 5px;
  padding-right: 90px;
  line-height: 1;
}

.hp-pop__heading {
  margin-bottom: 20px;
  padding-right: 90px;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.2;
}

.hp-pop__close {
  z-index: 200;
  color: var(--dark-slate-grey);
  background-color: #00344a14;
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  text-decoration: none;
  transition: all .2s ease-in-out;
  display: flex;
  position: absolute;
  inset: 10px 10px auto auto;
}

.hp-pop__close:hover {
  background-color: #00344a26;
}

.hp-pop__gallery {
  z-index: 1;
  border-radius: 6px;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.hp-pop__scrollbar-overlay {
  z-index: 100;
  background-color: #fff;
  width: 30px;
  height: 60px;
  position: absolute;
  inset: 0% 0% auto auto;
}

.cta__img {
  object-fit: cover;
  object-position: 50% 0%;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.cta__img.cta-img {
  display: none;
}

.image {
  width: 174px;
  height: 75px;
  position: absolute;
  inset: 0% auto auto 0%;
}

.point-template, .geschichte__year__mobile {
  display: none;
}

.utility__copyright-container {
  opacity: 1;
  transition: all .25s;
}

.utility__copyright-container.hidden {
  opacity: 0;
}

.r-galerie__img-container {
  padding-top: 70%;
  position: relative;
}

.hp-pop__richtext {
  padding-right: 30px;
}

.hp-pop__richtext h4 {
  margin-top: 20px;
  margin-bottom: 10px;
}

.hp-pop__richtext p {
  margin-bottom: 10px;
}

.hp-pop__richtext h2 {
  margin-bottom: 20px;
}

.hp-pop__more__wrapper {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  flex-wrap: wrap;
  place-content: flex-start;
  align-items: flex-start;
  margin-top: 40px;
  display: flex;
}

.hp-pop__more__copy {
  width: 100%;
}

.div-block-38 {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.utility__guides {
  z-index: 10000;
  background-color: red;
  height: 1px;
  display: flex;
  position: absolute;
  inset: 520px 0% auto;
}

.utility__guides._2 {
  top: 500px;
}

.utility__guides-wrapper {
  display: none;
}

.heading-4 {
  margin-bottom: -5px;
}

.link {
  color: var(--midnight-blue);
  font-weight: 600;
  line-height: 22px;
  text-decoration: none;
}

.utility__empty {
  opacity: 0;
}

.cb-lightbox {
  z-index: 100000;
  -webkit-text-fill-color: inherit;
  background-color: #000000e6;
  background-clip: border-box;
  justify-content: center;
  align-items: center;
  padding: 2vh;
  display: flex;
  position: fixed;
  inset: 0%;
}

.cb-lightbox.hidden {
  display: none;
}

.cb-lightbox__img {
  max-width: 90vw;
  max-height: 96vh;
}

.cb-lightbox__close {
  opacity: .8;
  cursor: pointer;
  justify-content: center;
  align-items: center;
  width: 4em;
  height: 2.6em;
  transition: all .3s;
  display: flex;
  position: absolute;
  inset: 2vh 0% auto auto;
}

.cb-lightbox__close-img {
  width: 13px;
  height: 13px;
}

.print-only {
  width: 100%;
  display: none;
}

.body {
  justify-content: center;
  align-items: center;
}

.produkte-image {
  object-fit: cover;
  flex: none;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.image-2 {
  object-fit: cover;
  width: 100%;
  height: 100vh;
}

.imprint_image {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.imprint_image.ibsolute__img {
  position: absolute;
  inset: 0%;
}

.team__contact-wrapper {
  grid-column-gap: 6px;
  color: var(--dark-slate-grey);
  justify-content: flex-start;
  align-items: center;
  margin-left: -5px;
  text-decoration: none;
  display: flex;
}

.team__contact-wrapper:hover {
  color: var(--dodger-blue);
}

.team__contact-wrapper.first {
  margin-top: 20px;
}

.r-info__link-richtext {
  color: var(--midnight-blue);
  font-weight: 600;
}

.r-info__link-richtext p {
  line-height: 20px;
}

.r-info__link-richtext h4 {
  font-size: 14px;
  line-height: 20px;
}

.r-info__link-richtext h2 {
  font-size: 14px;
  font-weight: 600;
  line-height: 20px;
}

.r-info__link-richtext a {
  color: var(--midnight-blue);
  text-decoration: none;
}

.utl__hidden {
  display: none;
}

.cd-cta {
  color: var(--white);
  width: 240px;
  height: 240px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}

.cd-cta.cd-cta__hero {
  z-index: 1;
  pointer-events: auto;
  width: 230px;
  height: 230px;
  position: absolute;
  inset: 30px -10% 0% auto;
}

.cd-cta.cd-cta__hero2 {
  width: 220px;
  height: 220px;
  margin-top: 60px;
  position: absolute;
  inset: 0% 60px auto auto;
}

.cd-cta.cd-cta__hero3 {
  z-index: 50;
  margin-left: 150px;
  display: block;
  position: absolute;
  bottom: -60px;
  right: 25px;
}

.cd-cta.cd-cta__referenzen {
  z-index: 10;
  width: 160px;
  height: 160px;
  position: absolute;
  inset: auto 30px 12px auto;
}

.cd-cta.cd-cta__popup {
  justify-content: center;
  width: 420px;
  height: 420px;
  display: flex;
}

.cd-cta.cd-cta__hero4 {
  z-index: 50;
  margin-left: 150px;
  display: block;
  position: absolute;
  bottom: -60px;
  right: auto;
}

.cd-cta.cd-cta__kontakt {
  pointer-events: auto;
  margin-right: 0;
}

.cd-cta__circle {
  grid-row-gap: 8px;
  text-align: center;
  background-color: #755192;
  border-radius: 100%;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  position: absolute;
  inset: 0%;
}

.cd-cta__circle.cd-cta__circle__popup {
  padding: 30px 40px;
}

.cd-cta__circle-left {
  background-color: #dcd1e6;
  border-radius: 100%;
  width: 101%;
  height: 101%;
  position: absolute;
  inset: -4% auto auto -3.5%;
}

.cd-cta__circle-left.regular-color {
  background-color: #dcd1e600;
}

.cd-cta__circle-left-right {
  background-color: #dcd1e6;
  border-radius: 100%;
  width: 101%;
  height: 101%;
  position: absolute;
  inset: auto -4% -3% auto;
}

.cd-cta__circle-left-right.regular-color {
  background-color: #dcd1e600;
}

.cd-cta__title {
  font-size: 30px;
  line-height: 1;
}

.cd-cta__button {
  color: #252525;
  text-transform: uppercase;
  background-color: #fff;
  border-radius: 4px;
  margin-top: 6px;
  padding: 5px 8px 6px;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
}

.cd-cta__button:hover {
  background-color: #ffffffe6;
}

.cd-cta__text {
  opacity: .84;
  font-size: 15px;
  line-height: 1.3;
}

.cd-cta__richtext h2 {
  color: #fff;
  margin-bottom: 8px;
  font-size: 28px;
  line-height: 1.1;
}

.cd-cta__richtext h4 {
  color: #fff;
}

.cd-cta__richtext h1 {
  color: #fff;
  font-size: 32px;
}

.cd-cta__richtext p {
  color: #ffffffd6;
  font-size: 15px;
  line-height: 1.3;
}

.pp__fixed {
  z-index: 9999;
  opacity: 0;
  justify-content: center;
  align-items: center;
  transition: opacity .3s;
  display: none;
  position: fixed;
  inset: 0%;
}

.pp__fixed.cc-active {
  opacity: 1;
  display: flex;
}

.pp__fixed-close__img {
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 16px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.pp__fixed-close {
  justify-content: center;
  align-items: center;
  width: 42px;
  height: 42px;
  display: flex;
  position: relative;
  top: 40px;
  left: 90px;
}

.pp__fixed-bg {
  cursor: pointer;
  background-color: #252525f0;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.cms-project__gallery__container {
  align-items: flex-start;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
  display: flex;
}

.cms-project__gallery__container.utility__hidden {
  display: none;
}

.cms-project__gallery__wrapper {
  flex-wrap: wrap;
  align-content: flex-start;
  align-items: stretch;
  width: 100%;
  display: flex;
}

.cms-project__gallery__wrapper.cms-inspiration {
  flex-flow: wrap;
  padding-bottom: 100px;
}

.cms-project__gallery__wrapper.horizontal-direction {
  grid-row-gap: 100px;
  flex-wrap: wrap;
  justify-content: space-between;
}

.cms-project__gallery__image-item {
  margin-top: 0;
  margin-bottom: 100px;
  position: relative;
}

.cms-project__gallery__image-item.cms-project__rectangle {
  width: 100%;
  max-height: 120vh;
  margin-top: 50px;
  margin-bottom: 50px;
  overflow: hidden;
}

.cms-project__gallery__image-item.cms-project__quadruple-left {
  width: 25%;
  max-height: 240px;
  margin-left: 0;
  margin-right: auto;
  padding-right: 1%;
}

.cms-project__gallery__image-item.cms-project__landscape {
  width: 100%;
  max-width: 914px;
  height: 810px;
  margin-left: auto;
  position: relative;
}

.cms-project__gallery__image-item.cms-project__triple-centre {
  width: 33.3333%;
  height: 100%;
  max-height: 640px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 5px;
  padding-right: 5px;
}

.cms-project__gallery__image-item.cms-project__triple-left {
  width: 33.3333%;
  height: 100%;
  max-height: 640px;
  margin-left: 0;
  margin-right: auto;
  padding-right: 10px;
}

.cms-project__gallery__image-item.cms-project__square {
  align-self: flex-end;
  width: 100%;
  max-width: 1080px;
  height: 100%;
  max-height: 1080px;
  margin: 0 auto 100px;
  padding-left: 200px;
  padding-right: 200px;
}

.cms-project__gallery__image-item.cms-project__portrait {
  width: auto;
  max-width: 657px;
  margin-top: 0;
  margin-bottom: 100px;
  margin-left: auto;
}

.cms-project__gallery__image-item.cms-project__rectangle {
  align-self: flex-end;
  width: 100%;
  max-width: 940px;
  height: 100%;
  max-height: 654px;
  margin: 0 auto 100px;
}

.cms-project__gallery__image-item.cms-project__triple-right {
  width: 33.3333%;
  height: 100%;
  max-height: 640px;
  margin-left: auto;
  margin-right: 0;
  padding-left: 10px;
}

.cms-project__gallery__image-item.cms-project__quadruple-right {
  width: 25%;
  max-height: 240px;
  margin-left: auto;
  margin-right: 0;
  padding-right: 0;
}

.cms-project__gallery__image-item.cms-project__quadruple-almostright, .cms-project__gallery__image-item.cms-project__quadruple-almostleft {
  width: 25%;
  max-height: 240px;
  margin-left: 0%;
  margin-right: auto;
  padding-right: 1%;
}

.cms-project__gallery__image-item.cms-project__rectangle-right {
  width: 100%;
  max-width: 1092px;
  height: 640px;
  margin-left: auto;
}

.cms-project__gallery__image-item.cms-project__rectangle-left {
  width: 100%;
  max-width: 880px;
  height: 540px;
  margin-right: 400px;
}

.cms-project__gallery__img-container {
  cursor: pointer;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.lightbox-link {
  width: 100%;
  height: 100%;
  position: relative;
}

.cms-project__gallery__img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.cms-project__gallery__copy {
  color: var(--bg-color);
  text-align: right;
  font-size: 10px;
  line-height: 1.1;
  position: absolute;
  inset: auto auto 20px 20px;
}

.cms-project__gallery__copy.cms-project__gallery__id {
  left: auto;
  right: 20px;
}

.project__images {
  object-fit: cover;
  object-position: 50% 50%;
  width: 100%;
  height: 100%;
  display: block;
}

.c-section__inspiration {
  width: 100%;
  padding-left: 377px;
}

.c-insipartion__img-wrapper {
  background-color: var(--border);
  width: 100%;
  height: 400px;
  position: relative;
  overflow: hidden;
}

.div-block-40 {
  position: relative;
}

.ig__alt-text {
  margin-top: 10px;
}

.ig__alt-text a:hover {
  color: var(--midnight-blue);
}

.cb-lightbox__wrapper {
  position: relative;
}

.cb-lightbox__copyright {
  z-index: 20;
  color: var(--bg-color);
  width: 100%;
  position: absolute;
  inset: auto auto 20px 20px;
}

.button__bottom-left__collection {
  width: 100%;
}

.checkbox-field {
  align-items: center;
  margin-bottom: 20px;
  padding-left: 0;
  display: flex;
}

.impressum-link {
  opacity: 1;
  color: #fff;
}

.impressum-link:hover {
  opacity: .7;
}

.privacybee {
  width: 100%;
  margin-bottom: 15px;
}

.kontakt-swiper-wrapper {
  width: 100%;
  margin-right: 0;
  position: relative;
}

.div-block-41 {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  margin-bottom: 16px;
  display: flex;
}

.kontakt-info-block {
  width: 100%;
  max-width: 409px;
  margin-bottom: 0;
}

.kontakt-info-block.cc-last {
  margin-top: 32px;
}

.utl__text-color-white {
  color: var(--white);
}

.div-block-42 {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  display: block;
}

.c-button__image {
  z-index: 420;
  pointer-events: none;
  width: 160px;
  position: absolute;
  bottom: 100%;
}

.aspec-ratio {
  width: 100%;
  padding-top: 66.66%;
  position: relative;
}

.aspec-ratio.is-16x9 {
  z-index: 1;
  padding-top: 56.25%;
  overflow: hidden;
}

.c-button__wrapper {
  z-index: 1;
  margin-left: -10px;
  margin-right: -10px;
  position: relative;
  overflow: hidden;
}

.fch-portfolio__header {
  justify-content: flex-end;
  align-items: flex-end;
  padding-top: 90px;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.fch-portfolio__title {
  flex: 1;
  max-width: 560px;
}

.fch-portfolio__title.architektur__title {
  max-width: 580px;
}

.fch-portfolio__body {
  padding-top: 20px;
}

.fch-portfolio__wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.fch-portfolio__wrapper.grid-2 {
  grid-template-columns: 1fr 1fr;
}

.fch-portfolio__item {
  flex-flow: column;
  padding-bottom: 25px;
  display: flex;
  position: relative;
}

.fch-portfolio__header__layout {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: space-between;
  align-items: flex-end;
  display: flex;
}

.portfolio__info__action {
  margin-top: 20px;
}

.fch-portfolio__filter-data {
  display: none;
}

.fch-hero {
  position: relative;
  overflow: hidden;
}

.fch-hero__wrapper {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  height: calc(100vh - 100px);
  display: grid;
}

.fch-hero__slider {
  width: 100%;
  position: relative;
  overflow: hidden;
}

.fch-hero__content {
  flex-flow: column;
  flex: 1;
  justify-content: center;
  align-items: flex-start;
  min-height: 25vh;
  padding-top: 20px;
  padding-bottom: 56px;
  padding-right: 20px;
  display: flex;
}

.fch-hero__action {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-flow: column;
  margin-top: 30px;
  display: flex;
}

.fch-hero__text {
  max-width: 400px;
}

.fch-hero__title {
  margin-bottom: 20px;
}

.fch-hero__slider__container {
  width: 100%;
  height: 100%;
}

.fch-hero__slider__wrapper {
  width: 100%;
  height: 100%;
  display: flex;
}

.fch-hero__slider__item {
  flex: none;
  width: 100%;
  height: 100%;
  margin-right: 10px;
  position: relative;
}

.fch-hero__slider__item:last-child {
  margin-right: 0;
}

.fch-slider-coll-wrapper {
  width: 100%;
  height: auto;
  display: flex;
}

.fch-slider-coll-container {
  height: auto;
}

.fch-slider-coll-item {
  flex: none;
  width: 100%;
  max-width: 690px;
  margin-right: 20px;
  position: relative;
}

.fch-slider-coll-item:last-child {
  margin-right: 0;
}

.fch-slider__content {
  z-index: 100;
  color: var(--white);
  text-align: center;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  max-width: 600px;
  height: 100%;
  padding: 80px 0;
  display: flex;
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
}

.fch-slider__action {
  margin-top: auto;
}

.fch-slider__overlay {
  z-index: 50;
  opacity: .3;
  pointer-events: none;
  background-color: #00090d;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.portfolio__fact {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.portfolio__fact.two-column-facts-item {
  width: 46%;
}

.portfolio__facts {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  margin-top: auto;
  margin-bottom: 0;
  display: flex;
}

.portfolio__facts.two-column-facts {
  grid-column-gap: 20px;
  grid-row-gap: 4px;
  flex-flow: wrap;
  justify-content: flex-start;
  align-items: flex-start;
}

.arc-slider {
  background-color: var(--white-smoke);
  width: 100%;
  display: flex;
  position: relative;
  overflow: hidden;
}

.arc-slider__container {
  z-index: 10;
  width: 100%;
  position: relative;
}

.arc-slider__wrapper {
  width: 100%;
  display: flex;
}

.arc-slider__item {
  flex: none;
  width: 100%;
  position: relative;
}

.arc-slider__image {
  padding-top: 63%;
  position: relative;
}

.arc-slider__nav {
  z-index: 100;
  width: 100%;
  height: 34px;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
}

.arc-materialien__wrapper {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  flex-flow: wrap;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: flex-start;
  align-items: stretch;
  margin-left: -10px;
  margin-right: -10px;
  display: flex;
}

.arc-materialien__wrapper.no-hover {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.arc-materialien__wrapper.no-hover.grid-2 {
  grid-template-columns: 1fr 1fr;
}

.arc-materialien__item {
  width: 100%;
  max-width: 50%;
  padding: 10px;
  transition: all .2s ease-in-out;
}

.arc-materialien__item:hover {
  width: 66%;
}

.arc-materialien__item.no-hover {
  flex-flow: column;
  max-width: 100%;
  padding: 0 0 25px;
  display: flex;
  position: relative;
}

.arc-materialien__item.no-hover:hover {
  width: 100%;
}

.arc-materialien__image-wrapper {
  z-index: 1;
  width: 100%;
  padding-top: 63%;
  position: relative;
  overflow: hidden;
}

.arc-materialien__image {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.arc-materialien__image.is-referenzen {
  opacity: 0;
}

.arc-materialien__info {
  margin-bottom: auto;
  padding-top: 10px;
}

.arc-materialien__action {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-flow: wrap;
  margin-top: 40px;
  display: flex;
}

.produkte-info__download {
  width: 100%;
  padding-top: 20px;
}

.produkte-info__action {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
}

.produkt__facts__icon {
  flex: none;
  width: 20px;
  height: 20px;
  margin-top: 1px;
}

.produkt__facts__item {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  margin-bottom: 4px;
  display: flex;
}

.produkt__facts__item:last-child {
  margin-bottom: 0;
}

.produkt__facts__wrapper {
  padding-top: 10px;
}

.referenzen__facts__info {
  flex-flow: column;
  display: flex;
}

.karriere-benefits-container {
  margin-top: 10px;
  padding-left: 377px;
}

.karriere-benefits-wrapper {
  display: flex;
}

.karriere-benefits-wrapper.has-view-all {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  flex-flow: wrap;
}

.karriere-benefits-item {
  flex-flow: column;
  flex: none;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 440px;
  height: auto;
  margin-right: 48px;
  display: flex;
}

.karriere-benefits__icon {
  z-index: 1;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 70px;
  height: 70px;
  margin-bottom: 40px;
  display: flex;
  position: relative;
  overflow: visible;
}

.karriere-benefits-text {
  max-width: 360px;
  margin-top: 20px;
}

.karriere-benefits-title {
  max-width: 270px;
}

.karriere-benefits__img {
  object-fit: cover;
  width: 70%;
  height: 70%;
  margin: auto;
  position: absolute;
}

.process {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  padding-bottom: 20px;
}

.process__item {
  text-align: center;
}

.process__title {
  margin-top: 10px;
}

.karriere-intro__text {
  max-width: 800px;
  margin-top: 0;
  margin-bottom: 32px;
}

.jobs__action__text {
  max-width: 360px;
  margin-top: 40px;
  margin-bottom: 24px;
}

.values__title {
  width: 100%;
  max-width: 400px;
  margin-bottom: 20px;
}

.values__text {
  max-width: 400px;
}

.testimonial {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  border-top: 1px #e1eaee;
  border-bottom: 1px solid #e1eaee00;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  margin-top: 0;
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 377px;
  display: grid;
  position: relative;
}

.testimonial:last-child {
  border-bottom-width: 0;
}

.testimonial.cc-first {
  border-top-style: none;
  border-top-width: 0;
  border-bottom-style: none;
  grid-template-columns: minmax(auto, 327px) 1fr 1fr;
}

.testimonial.cc-last {
  border-bottom-color: #0000;
}

.testimonial__image-wrapper {
  flex: none;
  width: 100%;
  padding-top: 100%;
  position: relative;
  overflow: hidden;
}

.testimonial__image-wrapper.w--current {
  overflow: hidden;
}

.testimonial__name {
  cursor: pointer;
  margin-bottom: 20px;
  text-decoration: none;
  transition: opacity .2s ease-in-out;
}

.testimonial__name:hover {
  opacity: .7;
}

.testimonial__name.w--current:hover {
  opacity: .8;
}

.testimonial__col {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.testimonial__col.cc-mw-44 {
  max-width: 440px;
}

.testimonial__col.is-1 {
  flex-flow: row;
}

.aktuell-g__col-copy {
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.aktuell-g__col-copy.cc-mw-44 {
  max-width: 440px;
}

.testimonial__text {
  margin-bottom: auto;
}

.testimonial__image {
  object-fit: cover;
  object-position: 50% 0%;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.div-block-43 {
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.arc-materialien__text {
  margin-top: 10px;
}

.arc-materialien__title {
  margin-top: 20px;
}

.form-social {
  justify-content: space-between;
  align-items: stretch;
  margin-top: 40px;
  display: flex;
}

.form__helper {
  margin-top: 20px;
  margin-bottom: 20px;
}

.form__text {
  margin-bottom: 20px;
}

.fch-slider__title {
  margin-top: auto;
}

.fch-slider-link {
  width: 100%;
  position: relative;
}

.fch-hero__top {
  flex-direction: column;
  flex: none;
  justify-content: flex-end;
  height: 280px;
  max-height: none;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.geschichte-sticky-copy {
  background-color: #0000;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100vh;
  padding-top: 0;
  padding-bottom: 0;
  padding-right: 0;
  display: flex;
  position: sticky;
  top: 100px;
}

.fch-hero__container {
  flex-flow: column;
  display: flex;
}

.fch {
  max-width: 220px;
}

.h-hero-content-buttons {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.h-hero-content-right {
  grid-column-gap: 10px;
  grid-row-gap: 20px;
  flex-flow: wrap;
  margin-top: auto;
  padding-bottom: 20px;
  padding-left: 20px;
  display: flex;
}

.h-hero-content-text {
  margin-right: auto;
}

.k-process__wrapper {
  justify-content: space-around;
  margin-top: 20px;
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
  position: relative;
}

.k-process__step {
  text-align: center;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 30%;
  display: flex;
}

.u-text-size-normal {
  color: #ffffffb3;
  margin-bottom: 0;
  font-size: 16px;
  line-height: 1.5;
}

.k-process__step__title {
  margin-top: 4px;
  margin-bottom: 20px;
}

.u-title-m {
  margin-top: 0;
  margin-bottom: 0;
}

.k-process__step__point {
  z-index: 10;
  background-color: var(--midnight-blue);
  border-radius: 50%;
  width: 20px;
  height: 20px;
  position: absolute;
  bottom: -10px;
}

.k-process__line {
  z-index: 1;
  background-color: var(--border);
  width: 100%;
  height: 1px;
  position: absolute;
  inset: auto 0% 0%;
}

.typ-buttons-list {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.typ-buttons-item, .portfolio__eigenschaften.two-column-eigenschaften {
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.menu__panel__body {
  display: none;
}

.menu__panel__icon {
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  display: flex;
  position: absolute;
  inset: 50% 10px auto auto;
  transform: translate(0, -50%);
}

.menu__panel__svg {
  width: 24px;
  height: 24px;
  transition: all .2s ease-in-out;
}

.menu__nav__link__icon {
  justify-content: center;
  align-items: center;
  width: 12px;
  height: 12px;
  margin-left: 4px;
  display: flex;
}

.menu__nav__link__svg {
  width: 10px;
  height: 10px;
  transition: all .2s;
}

.karriere-benefits__logo-wrapper {
  width: 70px;
  height: 70px;
  position: relative;
}

.nav {
  width: 100%;
  height: 54px;
  font-size: 12px;
  line-height: 1;
}

.nav__fixed {
  z-index: 5000;
  border-bottom: 1px solid var(--border-blue);
  background-color: var(--bg-color);
  width: 100%;
  height: 54px;
  position: relative;
  inset: 0% 0% auto;
}

.nav__logo {
  z-index: 10;
  color: var(--dodger-blue);
  margin-top: -30px;
  position: relative;
}

.nav__logo__embed__icon {
  justify-content: center;
  align-items: center;
  height: 44px;
  display: flex;
}

.nav__logo__embed__copy {
  background-color: var(--bg-color);
  flex: none;
  justify-content: center;
  align-items: center;
  width: 200px;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  position: absolute;
}

.nav__line {
  background-color: var(--border-blue);
  height: 1px;
  transition: left .2s cubic-bezier(.165, .84, .44, 1);
  position: absolute;
  inset: auto 0% 0%;
}

.nav__link__wrapper {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  justify-content: center;
  align-items: center;
  margin-bottom: 1px;
  padding-left: 0;
  list-style-type: none;
  display: flex;
}

.nav__link__wrapper.small__nav-link__wrapper {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
}

.nav__link {
  grid-column-gap: 6px;
  grid-row-gap: 6px;
  color: var(--midnight-blue);
  text-transform: uppercase;
  white-space: nowrap;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  display: flex;
  position: relative;
}

.nav__link.small__nav-linkls {
  color: #00344aad;
  text-transform: uppercase;
  font-weight: 400;
}

.nav__link__bg {
  border: 1px solid var(--border-blue);
  opacity: 0;
  pointer-events: none;
  border-radius: 4px;
  height: 34px;
  transition: transform .2s cubic-bezier(.165, .84, .44, 1), opacity .2s cubic-bezier(.165, .84, .44, 1);
  position: absolute;
  left: -10px;
  right: -10px;
  transform: scale(.9);
}

.nav__link__bg.small-nav__link-bg {
  height: 26px;
  left: -6px;
  right: -6px;
}

.nav__link__icon {
  background-color: var(--white-smoke);
  border-radius: 3px;
  justify-content: center;
  align-items: center;
  width: 14px;
  height: 14px;
  transition: color .1s, background-color .1s;
  display: flex;
  position: relative;
  bottom: -.5px;
}

.nav__link__text {
  color: #325b6d80;
}

.nav__controls {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.nav__lang__button {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  border: 1px solid var(--border-blue);
  color: var(--midnight-blue);
  text-transform: uppercase;
  border-radius: 4px;
  justify-content: space-between;
  align-items: center;
  height: 34px;
  padding-left: 10px;
  padding-right: 10px;
  font-weight: 600;
  text-decoration: none;
  display: flex;
}

.nav__lang__button.neu-nav {
  border-color: #c8dae200;
}

.nav__lang__icon {
  justify-content: center;
  align-items: center;
  width: 9px;
  height: 7px;
  display: flex;
}

.nav__search {
  margin-bottom: 0;
  display: flex;
  position: relative;
}

.nav__search.produkte-page__search {
  width: 100%;
}

.nav__search__input {
  border: 1px solid var(--border-blue);
  color: var(--midnight-blue);
  letter-spacing: -.28px;
  text-transform: uppercase;
  background-color: #0000;
  border-radius: 4px;
  width: 100%;
  max-width: none;
  height: 34px;
  margin-bottom: 0;
  padding: 0 34px 0 10px;
  font-size: 12px;
  font-weight: 600;
}

.nav__search__input:focus {
  border-color: var(--dodger-blue);
}

.nav__search__input::placeholder {
  color: #00344a66;
}

.nav__search__input.produkte-page__searcj {
  max-width: none;
}

.nav__search__button-wrapper {
  border-radius: 4px;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  padding: 0;
  font-size: 0;
  display: flex;
  position: absolute;
  inset: 0% 0% 0% auto;
  overflow: hidden;
}

.nav__search__icon {
  z-index: 10;
  pointer-events: none;
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
}

.nav__search__link {
  background-color: #0000;
  position: absolute;
  inset: 0%;
}

.nav__lang {
  position: relative;
}

.nav__lang__popup {
  border: 1px solid var(--border-blue);
  background-color: var(--white);
  opacity: 0;
  pointer-events: none;
  border-radius: 4px;
  margin-top: 4px;
  transition: transform .2s cubic-bezier(.165, .84, .44, 1), opacity .2s cubic-bezier(.165, .84, .44, 1);
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  overflow: hidden;
  transform: translate(0, 10px);
}

.sidenav__bg {
  opacity: 0;
  pointer-events: none;
  background-color: #000b1099;
  transition: opacity .2s;
  position: fixed;
  inset: 0%;
}

.sidenav {
  z-index: 6000;
  pointer-events: none;
  line-height: 1;
  display: flex;
  position: fixed;
  inset: 0%;
}

.sidenav__column {
  z-index: 50;
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  border-right: 1px solid var(--border-negative);
  background-color: var(--midnight-blue);
  pointer-events: auto;
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  width: 300px;
  height: 100%;
  padding: 150px 20px 20px;
  transition: transform .2s;
  display: flex;
  position: relative;
  overflow: auto;
  transform: translate(0%);
}

.sidenav__column.column2 {
  z-index: 30;
  width: 450px;
}

.sidenav__column.column1 {
  z-index: 40;
}

.sidenav__heading {
  opacity: .65;
  color: var(--white);
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 400;
}

.sidenav__item {
  color: var(--white);
}

.sidenav__item.sidenav__divider {
  margin-top: 40px;
}

.sidenav__list {
  flex-flow: column;
  margin-bottom: 0;
  padding-left: 0;
  list-style-type: none;
  display: flex;
}

.sidenav__link {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  border-bottom: 1px solid var(--border-negative);
  color: var(--white);
  justify-content: flex-start;
  align-items: center;
  padding-top: 13px;
  padding-bottom: 13px;
  font-size: 16px;
  text-decoration: none;
  display: flex;
}

.sidenav__link.small__sidenav-link {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  text-transform: uppercase;
  border-bottom-style: none;
  padding-top: 6px;
  padding-bottom: 6px;
  font-size: 14px;
}

.sidenav__link.capital__sidenav-link {
  text-transform: uppercase;
  font-weight: 600;
}

.sidenav__link__arrow {
  justify-content: center;
  align-items: center;
  width: 8px;
  height: 12px;
  display: flex;
}

.sidenav__link__text {
  margin-right: auto;
}

.sidenav__link-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  display: flex;
}

.sidenav__link__amount {
  border: 1px solid var(--border-negative);
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  height: 18px;
  padding-bottom: 1px;
  padding-left: 8px;
  padding-right: 8px;
  font-size: 12px;
  display: flex;
}

.div-block-45 {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: stretch;
  display: flex;
}

.sidenav__prd__block {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  width: 100%;
  padding-top: 8px;
  padding-bottom: 8px;
  display: flex;
}

.sidenav__prd__img {
  align-self: stretch;
  width: 150px;
  height: 100%;
  display: block;
  overflow: hidden;
}

.sidenav__prd__heading {
  font-weight: 600;
}

.sidenav__prd__text__wrapper {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  flex-flow: column;
  flex: 1;
  display: flex;
}

.sidenav__prd__subline {
  color: #fff9;
  text-transform: uppercase;
  font-size: 12px;
  line-height: 1;
}

.sidenav__prd__copy {
  margin-top: auto;
  font-size: 12px;
  line-height: 1.3;
}

.nav__burger {
  z-index: 20;
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  border: 1px solid var(--border-blue);
  border-radius: 4px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  display: none;
  position: relative;
}

.nav__burger__line {
  background-color: var(--midnight-blue);
  width: 12px;
  height: 1.5px;
}

.nav__logo__embed__copy-wrapper {
  justify-content: flex-start;
  align-items: center;
  width: 200px;
  height: 17px;
  margin-top: 7px;
  transition: width .2s cubic-bezier(.165, .84, .44, 1);
  display: flex;
  position: absolute;
  top: 100%;
  bottom: auto;
  left: -20px;
  overflow: hidden;
}

.sidenav__controls__link {
  border: 1px solid var(--border-negative);
  color: var(--white);
  border-radius: 4px;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  display: flex;
}

.sidenav__controls__link.ult__invisible {
  opacity: 0;
  width: 0;
  height: 0;
  overflow: hidden;
}

.sidenav__controls {
  justify-content: space-between;
  align-items: center;
  display: flex;
  position: absolute;
  top: 30px;
  left: 20px;
  right: 20px;
}

.sidenav__controls__icons {
  justify-content: center;
  align-items: center;
  width: 12px;
  height: 12px;
  display: flex;
}

.fdl-pop {
  z-index: 10000;
  pointer-events: none;
  flex-flow: column;
  justify-content: flex-start;
  align-items: stretch;
  display: flex;
  position: fixed;
  inset: 0%;
  overflow: auto;
}

.fdl-pop__bg {
  opacity: 0;
  background-color: #00344aed;
  transition: opacity .2s;
  position: fixed;
  inset: 0%;
}

.fdl-pop__wrapper {
  grid-column-gap: 60px;
  grid-row-gap: 60px;
  background-color: var(--dodger-blue);
  opacity: 0;
  color: var(--white);
  flex-flow: column;
  flex: none;
  width: 100%;
  max-width: 600px;
  margin: auto;
  padding: 50px;
  transition: transform .2s cubic-bezier(.165, .84, .44, 1), opacity .2s;
  display: flex;
  transform: scale(.8);
}

.fdl-pop__heading {
  color: var(--white);
  margin-bottom: 20px;
}

.ddl-pop__block {
  display: none;
}

.ddl-pop__block.cb-active {
  display: block;
}

.fdl-pop__container {
  z-index: 10;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  min-height: 100%;
  padding: 20px;
  display: flex;
  position: relative;
}

.form-2-copy {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.ddl-pop__text-link {
  opacity: 1;
  color: #fff;
}

.ddl-pop__text-link:hover {
  opacity: .7;
}

.success-message {
  background-color: var(--midnight-blue);
}

.karriere-benefits__content {
  flex: 1;
}

.div-block-46 {
  width: 200px;
  margin-right: 20px;
}

.testimonial__line {
  background-color: var(--border-blue);
  width: calc(100% - 377px);
  height: 1px;
  position: absolute;
  inset: auto 0% 0% auto;
}

.aktuell-h__paragraph__link {
  text-decoration: none;
}

.arrow-down {
  margin-left: 8px;
  display: flex;
}

.kontakt-page__cta {
  z-index: 20;
  pointer-events: none;
  width: 100%;
  padding-right: 10px;
  position: absolute;
  top: 120px;
}

.kontakt-page__cta-mobile {
  display: none;
}

.team__img {
  width: 100%;
}

.k-page__button-wrapper {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.product-q__image-wrapper {
  position: relative;
}

.gallery__icon {
  justify-content: center;
  align-items: center;
  width: 10px;
  height: 10px;
  display: flex;
}

.gallery__icon-wrapper {
  z-index: 20;
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  pointer-events: none;
  background-color: #fff9;
  border-radius: 2px;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  display: flex;
  position: absolute;
  inset: auto 10px 10px auto;
}

.gallery__icon-wrapper:hover {
  background-color: #ffffffbf;
}

.main-produkte__link {
  grid-column-gap: 6px;
  grid-row-gap: 6px;
  color: #829ba5;
  letter-spacing: -.12px;
  text-transform: uppercase;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 18px;
  font-size: 12px;
  text-decoration: none;
  display: flex;
}

.main-produkte__link:hover {
  color: var(--midnight-blue);
}

.top-nav {
  background-color: var(--bg-color);
  justify-content: center;
  align-items: center;
  min-height: 36px;
  display: flex;
}

.nav-wrapper {
  z-index: 5000;
  width: 100%;
  position: fixed;
  top: 0;
}

.produkte-page__button-wrapper {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  display: flex;
}

.produkte-p__popup {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  pointer-events: none;
  grid-template-rows: auto;
  grid-template-columns: minmax(auto, 873px) minmax(350px, 1fr);
  grid-auto-columns: 1fr;
  margin-left: auto;
  margin-right: auto;
  padding-top: 90px;
  padding-right: 20px;
  display: grid;
  position: absolute;
  inset: 0%;
}

.produkte-p__popup-item {
  position: relative;
}

.neu-g__item {
  background-color: var(--bg-color);
  padding-top: 36px;
  padding-bottom: 44px;
}

.neu-g__image {
  width: 50%;
  height: 500px;
  position: relative;
}

.neu-g__year {
  border-bottom: 1px solid var(--border-blue);
  color: var(--midnight-blue);
  margin-bottom: 20px;
  padding-bottom: 20px;
  font-size: 28px;
  line-height: 1;
}

@media screen and (min-width: 1440px) {
  .c-button.cc-home-hero:hover {
    background-color: var(--dodger-blue);
  }

  .c-container.r-thumbnail {
    left: 50%;
    transform: translate(-50%);
  }

  .c-container.cc-kontakt-hero {
    grid-template-columns: minmax(auto, 743fr) minmax(auto, 612px);
  }

  .portfolio-collection-item.cc-portrait {
    flex: 1;
  }

  .c-hero__block__bottom {
    justify-content: space-between;
  }

  .produkt-sticky__wrapper {
    min-height: 100vh;
  }

  .t-vw {
    margin: 20px;
  }

  .swiper-sec-nav {
    max-width: 1440px;
    margin-left: auto;
    margin-right: auto;
  }

  .aktuell-hero_container.r-thumbnail {
    left: 50%;
    transform: translate(-50%);
  }

  .cd-cta.cd-cta__hero3, .cd-cta.cd-cta__hero4 {
    margin-left: 170px;
  }

  .cms-project__gallery__wrapper {
    align-content: flex-start;
    align-items: flex-start;
  }

  .cms-project__gallery__image-item.cms-project__rectangle {
    margin-top: 0;
    margin-bottom: 100px;
  }

  .cms-project__gallery__image-item.cms-project__portrait {
    max-height: 100vh;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-almostright, .cms-project__gallery__image-item.cms-project__quadruple-almostleft {
    max-height: 240px;
  }

  .h-hero-content-buttons {
    flex: none;
    justify-content: flex-end;
    align-items: flex-start;
  }

  .h-hero-content-right {
    justify-content: space-between;
    width: 100%;
  }

  .h-hero-content-text {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
    flex-flow: column;
    max-width: 200px;
    margin-right: auto;
    display: flex;
  }

  .produkte-p__popup {
    padding-left: 20px;
    padding-right: 0;
  }
}

@media screen and (min-width: 1920px) {
  .c-container.cc-referenzen-hero {
    min-height: 420px;
  }

  .c-container.cc-swiper {
    position: static;
  }

  .referenzen-swiper-collection-item, .c-hero__col {
    position: relative;
  }

  .kontakt-form-block {
    max-width: 900px;
  }

  .swiper-sec-nav {
    max-width: none;
    left: 20px;
  }

  .swiper-sec-nav.h-referenzen.h-aboutus {
    top: 170px;
  }

  .swiper-sec-nav.kst-team, .swiper-sec-nav.kontakt-team {
    top: 210px;
  }

  .aktuell-hero_container.cc-referenzen-hero {
    min-height: 420px;
  }

  .cd-cta.cd-cta__hero2 {
    z-index: 2;
    right: 40%;
  }

  .cd-cta.cd-cta__hero3, .cd-cta.cd-cta__hero4 {
    margin-left: 200px;
  }

  .cd-cta__button {
    text-decoration: none;
  }

  .cd-cta__button:hover {
    background-color: #ffffffe6;
  }

  .cd-cta__richtext {
    color: #fff;
  }

  .pp__fixed {
    z-index: 9999;
  }

  .cms-project__gallery__wrapper {
    padding-bottom: 100px;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-left {
    max-height: none;
    padding-right: .5%;
    overflow: hidden;
  }

  .cms-project__gallery__image-item.cms-project__landscape {
    max-width: 1414px;
    padding-left: 500px;
  }

  .cms-project__gallery__image-item.cms-project__triple-centre, .cms-project__gallery__image-item.cms-project__triple-left {
    max-height: none;
  }

  .cms-project__gallery__image-item.cms-project__square {
    max-width: 1280px;
    max-height: 1280px;
    padding-left: 300px;
    padding-right: 300px;
  }

  .cms-project__gallery__image-item.cms-project__triple-right {
    max-height: none;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-right {
    max-height: none;
    margin-right: -.5%;
    padding-right: .5%;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-almostright {
    max-height: none;
    margin-left: 50%;
    padding-right: .5%;
    overflow: hidden;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-almostleft {
    max-height: none;
    margin-left: 25%;
    padding-right: .5%;
    overflow: hidden;
  }

  .produkte-p__popup {
    grid-template-columns: minmax(auto, 873px) minmax(350px, 1fr);
  }
}

@media screen and (max-width: 991px) {
  .button__copy {
    white-space: nowrap;
  }

  .cookies__section {
    padding: 40px;
  }

  .utility__section {
    padding: 120px 60px;
  }

  .c-button.cc-download {
    order: 1;
    margin-bottom: 20px;
  }

  .s-buttons.cc-kontakt {
    position: absolute;
    inset: 0% 20px auto auto;
  }

  .c-container.cc-aktuell {
    grid-template-columns: 1fr;
  }

  .c-container.cc-technologien {
    grid-template-columns: minmax(1px, 914px);
    height: auto;
    min-height: auto;
    display: block;
  }

  .c-container.cc-kontakt {
    grid-template-columns: 1fr;
  }

  .c-container.cc-kontakt.top-column {
    position: relative;
  }

  .c-container.r-thumbnail {
    height: auto;
  }

  .c-container.cc-referenzen-cms-hero {
    grid-template-columns: 1fr;
    margin-top: auto;
  }

  .c-container.cc-referenzen-info {
    grid-template-columns: 1fr;
  }

  .c-container.cc-referenzen-hero {
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding-bottom: 20px;
  }

  .c-container.cc-aktuell-cms, .c-container.cc-a-hero {
    grid-template-columns: 1fr;
  }

  .c-container.cc-navbar {
    justify-content: flex-start;
    max-width: 100vw;
    height: 65px;
    padding-top: 10px;
  }

  .c-container.cc-geschichte {
    height: auto;
    display: block;
    position: relative;
  }

  .c-container.cta-button__hero3 {
    justify-content: flex-end;
    padding-right: 30px;
    display: flex;
  }

  .c-container.cc-kontakt-hero {
    grid-template-columns: 1fr;
  }

  .c-container.cc-kontakt-hero.top-column {
    position: relative;
  }

  .c-container.cc-fch-hero {
    height: auto;
    display: block;
    position: relative;
  }

  .c-container.nav__container {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
  }

  .c-container.kontakt__cta-container {
    padding-top: 30px;
  }

  .c-button-text {
    flex: 0 auto;
  }

  .form-block {
    width: 100%;
  }

  .cta {
    min-height: 700px;
  }

  .footer__grid, .footer__col-1 {
    grid-template-columns: 1fr 1fr;
  }

  .c-section__body.cc-h-aktuell-list {
    padding-top: 0;
  }

  .horizontal-line.cc-top.cc-mobile-hide {
    display: none;
  }

  .caption-text.cc-aktuell-date {
    margin-top: 20px;
    display: none;
  }

  .caption-text.cc-hide-mobile {
    display: none;
  }

  .caption-text.g-neu__caption {
    margin-bottom: 20px;
  }

  .about-swiper-wrapper {
    padding-left: 0;
  }

  .aktuell-swiper-collection-item {
    flex-direction: column;
    grid-template-columns: 1fr;
    justify-content: flex-start;
    display: flex;
  }

  .image-copyright-text {
    padding-top: 0%;
  }

  .c-title-wrapper.cc-technologie {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .aktuell-grid {
    grid-row-gap: 0px;
    flex-direction: column;
    grid-template-columns: 1fr;
    display: block;
  }

  .aktuell-g__image-wrapper {
    z-index: 10;
    margin-bottom: 0;
  }

  .c-hero__grid, .c-hero__grid.home__grid {
    grid-template-columns: 1fr;
  }

  .c-hero__copy {
    padding-top: 260px;
    padding-bottom: 0;
  }

  .c-hero__copy.c-hero__home {
    padding-top: 320px;
  }

  .hero-title {
    margin-bottom: 0;
  }

  .vertical-line.cc-hero, .vertical-line.cc-right.cc-desktop-show, .vertical-line.cc-right.cc-mobile-hide, .vertical-line.cc-left.cc-hide-mobile {
    display: none;
  }

  .vertical-line.cc-left.cc-hide-mobile.z-200 {
    display: block;
  }

  .c-hero__block__bottom {
    justify-content: space-between;
    padding-left: 0;
  }

  .c-hero__block__top {
    padding-top: 40px;
    padding-left: 0;
  }

  .c-hero__block__top.c-hero__block__top__home {
    flex-direction: column;
    align-items: flex-start;
    position: static;
  }

  .c-hero {
    padding-left: 0;
  }

  .c-hero.c-home__hero {
    padding-top: 54px;
  }

  .navbar__spacer {
    height: 65px;
  }

  .video {
    object-fit: cover;
    width: 100%;
    height: 100%;
    position: absolute;
    inset: 0%;
  }

  .aktuell-sticky-wrapper {
    height: auto;
    padding-right: 0;
    position: relative;
    top: auto;
  }

  .aktuell-sticky-wrapper.cc-aktuell-cms {
    padding-top: 20px;
  }

  .aktuell-list-wrapper {
    background-color: var(--bg-color);
    height: auto;
    padding-left: 0;
  }

  .aktuell__info {
    grid-column-gap: 60px;
    grid-row-gap: 16px;
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    justify-content: flex-start;
    margin-top: 20px;
    margin-bottom: 20px;
    display: flex;
  }

  .aktuell-h__content {
    padding-bottom: 20px;
  }

  .portfolio-block {
    padding-left: 0;
  }

  .portfolio-sticky-slider {
    height: auto;
    margin-top: 70px;
    margin-bottom: 90px;
    position: relative;
    top: auto;
  }

  .portfolio-sticky-slider-wrapper {
    padding: 20px 0 0;
  }

  .portfolio-slider__image {
    z-index: 100;
    width: 100%;
    height: auto;
    padding-top: 56.25%;
  }

  .t-sticky-slider__item {
    flex-direction: column;
  }

  .portfolio-slider__content {
    margin-top: 20px;
  }

  .portfolio-slider__nav {
    top: auto;
    bottom: 20px;
  }

  .portfolio-sticky__bottom__paragraph {
    margin-bottom: 40px;
  }

  .produkte-sticky-image, .produkte-sticky-image.cc-portrait {
    top: 65px;
  }

  .form__input, .form__input.cc-textarea {
    width: 100%;
  }

  .form__checkbox__icon.impressum-form-check {
    width: 22px;
    height: 22px;
    margin-right: 12px;
  }

  .div-block-26 {
    padding-left: 0;
  }

  .div-block-27 {
    margin-left: 0;
  }

  .kontakt-form-wrapper {
    padding-left: 0;
  }

  .r-thumbnail {
    height: auto;
  }

  .div-block-28 {
    padding-bottom: 10px;
  }

  .r-info-column {
    min-height: auto;
    padding-left: 0;
  }

  .r-galerie-collection-item {
    max-width: 80vw;
    height: auto;
  }

  .kontakt-info-grid {
    margin-bottom: 40px;
  }

  .kontakt-info-wrapper {
    margin-top: 40px;
  }

  .r-summary-wrapper {
    margin-bottom: 60px;
  }

  .referenzen-cms-collection-list {
    grid-template-columns: 1fr 1fr;
  }

  .referenzen-cms-collection-wrapper.uber-uns-cms-collection {
    padding-left: 0;
  }

  .filter-buttons {
    width: 100%;
    margin-top: 20px;
    padding-bottom: 0;
  }

  .form {
    width: 100%;
  }

  .reset-filter {
    order: 1;
  }

  .r-info-list {
    margin-top: 0;
    margin-bottom: 20px;
  }

  .r-info__col.cc-right {
    padding-left: 0;
  }

  .aktuell-cms-rich blockquote {
    margin-top: 60px;
    margin-bottom: 60px;
    margin-left: -10px;
    padding-left: 10px;
  }

  .aktuel-cms-excerpt {
    margin-bottom: 90px;
  }

  .aktuel-cms-hero {
    padding-top: 266px;
    padding-left: 0;
  }

  .aktuell-content {
    padding-left: 0;
  }

  .share-buttons {
    grid-column-gap: 10px;
    flex-direction: row;
    margin-bottom: 20px;
  }

  .aktuell-g__title {
    margin-bottom: 20px;
  }

  .a-hero-image {
    height: auto;
    padding-top: 60%;
  }

  .a-info-col {
    padding-top: 266px;
    padding-left: 0;
  }

  .empty-div {
    display: none;
  }

  .team__position {
    max-width: 80%;
  }

  .team-collection-wrapper {
    padding-left: 0;
  }

  .job__rich-text {
    margin-bottom: auto;
  }

  .job__contact {
    grid-row-gap: 8px;
    flex-direction: column;
    align-items: flex-start;
  }

  .referenzen-swiper-collection-wrapper {
    padding-left: 0;
  }

  .aktuell-swiper-collection-list {
    align-items: flex-start;
  }

  .aktuell-swiper-collection-wrapper {
    align-items: flex-start;
    display: flex;
  }

  .aktuell-swiper__title {
    margin-top: 0;
  }

  .menu__nav {
    width: auto;
    max-width: none;
    padding: 20px 40px 40px 20px;
  }

  .menu__panel {
    max-width: 90vw;
  }

  .produkt-sticky__wrapper {
    min-height: 124vh;
    top: 65px;
  }

  .produkte-gallery-collection-item {
    max-width: 80vw;
  }

  .portfolio-sticky__bottom {
    height: auto;
  }

  .portfolio-sticky {
    height: auto;
    position: relative;
    top: auto;
  }

  .portfolio-column {
    min-height: auto;
  }

  .portfolio-collection-list {
    flex-direction: column;
  }

  .portfolio-portrait-item {
    max-width: none;
  }

  .menu__list__item.cc-mobile-show {
    display: block;
  }

  .menu__panel__link {
    padding-left: 16px;
    padding-right: 16px;
    font-size: 24px;
  }

  .menu__panel__link.is-sub {
    padding-top: 8px;
    padding-bottom: 8px;
    font-size: 20px;
    line-height: 1;
  }

  .search__wrapper, .search__wrapper.in-nav, .search {
    display: none;
  }

  .wg-element-wrapper.sw5 {
    margin-left: 20px;
  }

  .navbar__col {
    grid-column-gap: 10px;
  }

  .jobs-collection-wrapper {
    padding-left: 0;
  }

  .jobs-collection-item {
    flex-direction: column;
    align-self: auto;
    height: 100%;
    margin-right: 30px;
    padding-right: 0;
    display: flex;
  }

  .geschichte-sticky {
    height: auto;
    position: static;
  }

  .portfolio-swiper-collection-wrapper {
    padding-left: 0;
  }

  .navbar__logo {
    margin-top: 16px;
    margin-right: auto;
  }

  .navbar__logo__top__image {
    width: 118px;
    height: 32.25px;
  }

  .navbar__logo__bottom {
    margin-top: 8px;
  }

  .portfolio-slider-wrapper {
    flex-direction: column;
    justify-content: flex-start;
    display: flex;
  }

  .portfolio-slider-list {
    flex-direction: row;
    flex: 0 auto;
    align-items: flex-start;
  }

  .portfolio-slider-item {
    flex-direction: column;
    flex: none;
    justify-content: space-between;
    align-self: flex-start;
    margin-bottom: 0;
    display: block;
  }

  .navbar__logo__bottom__image {
    width: 118px;
    height: 11px;
  }

  .navbar__hamburger {
    color: var(--midnight-blue);
    border: 1px solid #005b8080;
    border-radius: 4px;
    flex: none;
    justify-content: center;
    align-items: center;
    width: 32px;
    height: 32px;
    margin-left: 10px;
    padding-bottom: 0;
    padding-right: 0;
    font-size: 12px;
    font-weight: 600;
    display: flex;
  }

  .menu-button {
    display: none;
  }

  .footer__bottom {
    justify-content: space-between;
  }

  .footer__logo {
    margin-left: auto;
    margin-right: 0;
  }

  .footer__logo__bottom {
    height: auto;
    margin-top: 8px;
    right: -20px;
  }

  .footer__logo__top__img {
    width: 118px;
    height: 32.5px;
  }

  .footer__logo__bottom__img {
    width: 118px;
    height: 11px;
  }

  .video__wrapper {
    z-index: 10;
    width: 360px;
    height: auto;
    padding-top: 60%;
    position: relative;
  }

  .technologie-swiper-wrapper {
    align-items: flex-start;
    padding-left: 0;
  }

  .technologie-swiper-list {
    align-items: flex-start;
  }

  .technologie-swiper-item {
    min-height: auto;
  }

  .swiper-sec-nav {
    padding-right: 0;
    left: 0;
  }

  .aktuell-hero_container.cc-sc-header {
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding-bottom: 20px;
  }

  .aktuell-hero_container.cc-aktuell {
    grid-template-columns: 1fr;
  }

  .aktuell-hero_container.cc-technologien {
    grid-template-columns: minmax(1px, 914px);
    height: auto;
    min-height: auto;
    display: block;
  }

  .aktuell-hero_container.cc-kontakt {
    grid-template-columns: 1fr;
  }

  .aktuell-hero_container.r-thumbnail {
    height: auto;
  }

  .aktuell-hero_container.cc-referenzen-cms-hero, .aktuell-hero_container.cc-referenzen-info {
    grid-template-columns: 1fr;
  }

  .aktuell-hero_container.cc-referenzen-hero {
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding-bottom: 20px;
  }

  .aktuell-hero_container.cc-aktuell-cms, .aktuell-hero_container.cc-a-hero {
    grid-template-columns: 1fr;
  }

  .aktuell-hero_container.cc-navbar {
    justify-content: flex-start;
    height: 65px;
    padding-top: 10px;
  }

  .gen-hero__nav__button.cc-download, .c-button-copy.cc-download {
    order: 1;
    margin-bottom: 20px;
  }

  .cta__img {
    object-position: 30% 0%;
    top: auto;
  }

  .r-galerie__img-container {
    padding-top: 70%;
  }

  .utility__guides {
    top: 484px;
  }

  .utility__guides._2 {
    top: 464px;
  }

  .cb-lightbox__close {
    width: 40px;
    height: 40px;
    top: 20px;
    right: 20px;
  }

  .cd-cta.cd-cta__hero {
    margin-bottom: 30px;
    margin-left: 0;
    position: absolute;
    inset: 30px 30px auto auto;
  }

  .cd-cta.cd-cta__hero2 {
    margin-top: 0;
    margin-bottom: 30px;
    position: absolute;
    top: 104px;
    right: 30px;
  }

  .cd-cta.cd-cta__hero3 {
    margin-left: auto;
    right: 25px;
  }

  .cd-cta.cd-cta__hero4 {
    margin-left: auto;
    left: 0;
    right: auto;
  }

  .cms-project__gallery__container.utility__hidden {
    display: none;
  }

  .cms-project__gallery__image-item.cms-project__landscape {
    width: 100%;
    max-width: none;
    height: 654px;
  }

  .cms-project__gallery__image-item.cms-project__square {
    width: 100%;
    height: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-left: 0;
    padding-right: 0;
  }

  .cms-project__gallery__image-item.cms-project__portrait {
    width: 100%;
    max-width: none;
  }

  .cms-project__gallery__image-item.cms-project__rectangle-right {
    height: 60vw;
    padding-top: 0;
  }

  .cms-project__gallery__image-item.cms-project__rectangle-left {
    max-width: none;
    height: 60vw;
    margin-right: auto;
  }

  .c-section__inspiration {
    padding-left: 0;
  }

  .fch-portfolio__wrapper {
    grid-template-columns: 1fr 1fr;
  }

  .fch-portfolio__header__layout {
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
  }

  .portfolio__fact.two-column-facts-item {
    width: auto;
  }

  .portfolio__facts.two-column-facts {
    grid-column-gap: 4px;
    flex-flow: column;
    justify-content: flex-end;
    align-items: flex-start;
  }

  .arc-materialien__wrapper, .arc-materialien__wrapper.no-hover {
    grid-template-columns: 1fr 1fr;
  }

  .karriere-benefits-container {
    padding-left: 0;
  }

  .karriere-benefits-item {
    max-width: 436px;
    margin-right: 30px;
  }

  .karriere-benefits-text {
    max-width: none;
  }

  .process {
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-start;
    display: flex;
  }

  .process__item {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    display: flex;
  }

  .process__title {
    text-align: right;
    flex: 1;
    max-width: 100%;
    margin-top: 0;
  }

  .jobs__action__text {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .testimonial {
    grid-row-gap: 20px;
    flex-direction: column;
    grid-template-columns: 1fr;
    padding-left: 0;
    display: flex;
  }

  .testimonial__image-wrapper {
    z-index: 10;
    margin-bottom: 0;
  }

  .testimonial__name {
    margin-bottom: 10px;
  }

  .testimonial__col.is-content {
    margin-bottom: 20px;
  }

  .fch-hero__top {
    height: 240px;
  }

  .geschichte-sticky-copy {
    height: auto;
    position: static;
  }

  .h-hero-content-right {
    width: 100%;
    padding-top: 20px;
    padding-left: 0;
  }

  .h-hero-content-text {
    margin-right: auto;
  }

  .k-process__wrapper {
    width: 100%;
  }

  .nav__logo {
    margin-top: 0;
    margin-right: auto;
  }

  .nav__logo__embed__icon {
    width: 112px;
    height: auto;
  }

  .nav__logo__embed__copy {
    width: 152px;
    height: 10px;
    padding-left: 0;
    padding-right: 0;
  }

  .nav__link__wrapper {
    display: none;
  }

  .nav__search__input {
    max-width: none;
  }

  .sidenav__column {
    padding-top: 100px;
    transition-timing-function: cubic-bezier(.165, .84, .44, 1);
  }

  .nav__burger {
    display: flex;
  }

  .nav__logo__embed__copy-wrapper {
    width: 152px;
    height: 10px;
    margin-left: auto;
  }

  .sidenav__controls {
    top: 10px;
  }

  .testimonial__line {
    width: 100%;
  }

  .kontakt-page__cta {
    padding-bottom: 30px;
    padding-left: 10px;
    display: block;
    position: relative;
    top: 0;
  }

  .kontakt-page__cta-desktop {
    display: none;
  }

  .kontakt-page__cta-mobile {
    display: flex;
  }

  .top-nav {
    display: none;
  }

  .produkte-p__popup {
    grid-template-columns: 2.75fr;
    padding-top: 54px;
  }

  .neu-g__item {
    width: 100%;
    position: relative;
  }
}

@media screen and (max-width: 767px) {
  h2 {
    letter-spacing: -1.12px;
    font-size: 28px;
  }

  .cookies__section {
    padding: 30px;
  }

  .utility__section {
    padding: 100px 40px;
  }

  .s-buttons.cc-kontakt {
    margin-top: 20px;
    position: relative;
    right: 0;
  }

  .c-container.cc-sc-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .c-container.landscape, .c-container.portrait {
    grid-template-columns: 1fr;
  }

  .c-container.cc-kontakt {
    flex-direction: column;
    display: flex;
  }

  .c-container.r-thumbnail {
    align-items: flex-start;
    padding-left: 0;
    padding-right: 0;
    display: flex;
    position: static;
    inset: auto 0% 0%;
  }

  .c-container.cc-referenzen-info {
    flex-direction: column;
    display: flex;
  }

  .c-container.cc-referenzen-hero {
    padding-top: 100px;
  }

  .c-container.cc-navbar {
    padding-top: 10px;
  }

  .c-container.cc-kontakt-hero {
    flex-direction: column;
    display: flex;
  }

  .c-container.kontakt__cta-container {
    justify-content: flex-start;
    align-items: center;
  }

  .c-swiper-btns {
    order: 1;
  }

  .cta {
    min-height: 600px;
    padding-top: 23vw;
  }

  .cta__content {
    padding-left: 20px;
  }

  .footer {
    padding-top: 50px;
  }

  .footer__grid {
    grid-template-columns: 1fr;
    margin-bottom: 90px;
    display: block;
  }

  .footer__col-1 {
    grid-row-gap: 50px;
    flex-direction: column;
    margin-bottom: 50px;
    display: flex;
  }

  .footer__block.cc-sonstiges {
    text-align: left;
    order: -1;
    margin-left: 0;
  }

  .footer__col-2 {
    grid-row-gap: 50px;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .c-section.cc-hidden {
    display: none;
  }

  .c-section__header {
    padding-top: 90px;
    padding-bottom: 20px;
  }

  .c-section__body.cc-h-aktuell-list {
    padding-top: 0;
  }

  .horizontal-line.cc-bottom.cc-mobile-hide, .horizontal-line.cc-bottom.designs__line {
    display: none;
  }

  .c-section__header__nav {
    justify-content: space-between;
    width: 100%;
    margin-top: 14px;
  }

  .c-section__header__nav.jobs__arrows {
    display: none;
  }

  .referenzen-swiper-collection-item {
    flex: none;
    width: 85%;
  }

  .referenzen__image {
    width: 100%;
    height: auto;
    padding-top: 60%;
  }

  .hero {
    padding: 40px 20px;
  }

  .flex-container {
    flex-direction: column;
  }

  .hero-image-mask {
    order: -1;
    margin-left: 0;
    margin-right: 0;
  }

  .caption-text {
    font-size: 10px;
    line-height: 14px;
  }

  .caption-text.cc-karriere__caption {
    font-size: 12px;
  }

  .aktuell-swiper__image {
    height: auto;
    padding-top: 60%;
    padding-bottom: 0;
    padding-left: 0;
  }

  .image-copyright-text {
    width: auto;
    bottom: 20px;
    left: 20px;
  }

  .image-copyright-text.centered.hide-on-mobile {
    display: none;
  }

  .aktuell-swiper__col {
    max-width: 100%;
  }

  .aktuell-grid {
    flex-direction: column;
    display: block;
  }

  .aktuell-g__image-wrapper {
    z-index: 100;
    width: 100%;
    height: auto;
    margin-bottom: 0;
    padding-top: 56.25%;
  }

  .aktuell-g__col {
    justify-content: flex-start;
  }

  .aktuell {
    flex-direction: column;
  }

  .c-hero__copy {
    padding-top: 266px;
  }

  .hero-title {
    letter-spacing: -2.52px;
    font-size: 42px;
  }

  .vertical-line.cc-left {
    z-index: 200;
  }

  .vertical-line.cc-left.z-2000.cc-mobile-hide, .vertical-line.cc-left.cc-hide-mobile.z-200 {
    display: none;
  }

  .c-hero__block__bottom {
    grid-row-gap: 20px;
    flex-direction: column;
    align-items: flex-start;
  }

  .c-hero__block__top {
    padding-bottom: 16px;
  }

  .c-hero {
    padding: 0;
  }

  .navbar__spacer {
    height: 65px;
  }

  .video {
    width: 100%;
    height: 100%;
    display: block;
  }

  .aktuell-h__image-wrapper {
    order: -1;
    height: auto;
    padding-top: 75%;
  }

  .aktuell-h__info {
    grid-column-gap: 20px;
    grid-row-gap: 16px;
    order: -1;
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    margin-top: 20px;
    display: grid;
  }

  .aktuell__paragraph {
    margin-bottom: 0;
  }

  .aktuell__info {
    grid-column-gap: 0px;
    grid-row-gap: 16px;
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    justify-content: space-between;
    margin-top: 10px;
    margin-bottom: 20px;
    display: grid;
  }

  .portfolio__item {
    flex-direction: column;
  }

  .portfolio__item.cc-portrait {
    grid-template-columns: minmax(auto, 204px);
    align-items: start;
    height: 100%;
  }

  .portfolio__item__title {
    margin-bottom: 0;
  }

  .portfolio-sticky-slider {
    top: auto;
  }

  .produkte-column.datennschutz-produkte-column {
    overflow: hidden;
  }

  .portfolio-sticky-slider-wrapper {
    flex-direction: column;
    align-items: flex-start;
    padding-top: 20px;
    display: flex;
  }

  .portfolio-slider__image {
    margin-bottom: 10px;
    padding-top: 60%;
  }

  .portfolio-slider__content {
    max-width: 100%;
    margin-top: 0;
  }

  .portfolio-slider__title {
    margin-top: 0;
  }

  .portfolio-slider__nav {
    position: static;
    bottom: 0;
    left: auto;
    right: 0;
  }

  .produkte-sticky-image {
    position: relative;
    top: 0;
  }

  .produkte-sticky-image.cc-portrait {
    height: auto;
    padding-top: 125%;
    top: 0;
  }

  .produkte-sticky-image.cc-innovation-und-tech {
    height: auto;
    padding-top: 100%;
  }

  .produkte-sticky-image.cc-innovation-und-tech.datenschutz {
    margin-top: 20px;
  }

  .produkte-sticky-image.cc-innovation-und-tech.impressum {
    margin-top: 20px;
    padding-top: 0%;
    padding-right: 20px;
  }

  .produkte-info__desc {
    letter-spacing: -.7px;
    padding-left: 0;
    font-size: 21px;
    line-height: 1.4;
  }

  .produkte-info__block__header, .produkte-info__block__body {
    padding-left: 0;
  }

  .produkte-info__block__body.cc-produkt-q.darker-block {
    margin-left: -20px;
    margin-right: -20px;
    padding-left: 20px;
    padding-right: 20px;
  }

  .produkt-q {
    flex-direction: column;
  }

  .produkt-q__info {
    margin-top: 20px;
  }

  .kontakt-form-block {
    width: 100%;
  }

  .form__checkboxes {
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
  }

  .div-block-24 {
    width: 100%;
  }

  .k-hero {
    padding-top: 0;
  }

  .k-hero__top {
    padding-top: 100px;
  }

  .div-block-25 {
    margin-bottom: 20px;
  }

  .div-block-26 {
    flex-direction: column;
    align-items: flex-start;
    padding-left: 0;
  }

  .div-block-27 {
    margin-left: 0;
    display: block;
  }

  .kontakt-form-wrapper {
    width: 100%;
    overflow: hidden;
  }

  .r-thumbnail {
    z-index: 1;
  }

  .r-thumbnail.cc-hiden {
    display: none;
  }

  .r-galerie-collection-item {
    padding-bottom: 0;
    padding-left: 0;
  }

  .kontakt-info-grid {
    grid-row-gap: 40px;
    flex-direction: column;
  }

  .r-info.cc-hidden {
    display: none;
  }

  .referenzen-cms-collection-list {
    grid-template-columns: 1fr;
  }

  .referenzen-cms-collection-list.uber-uns-cms-collection-list {
    grid-template-columns: 1fr 1fr;
  }

  .r-link__image {
    max-height: none;
    padding-top: 60%;
  }

  .r-link__title {
    margin-bottom: 20px;
  }

  .filter-dropdown {
    position: absolute;
  }

  .filter-dropdown._w--open {
    top: 0;
  }

  .form {
    grid-row-gap: 10px;
    flex-wrap: wrap;
  }

  .r-info-list {
    max-width: none;
  }

  .r-info__col {
    width: 100%;
  }

  .aktuel-cms-thumbnail {
    height: auto;
    padding-top: 100%;
  }

  .aktuel-cms-hero {
    flex-direction: column;
    align-items: flex-start;
  }

  .aktuel-cms-hero__info {
    order: -1;
  }

  .aktuell-g__title {
    margin-bottom: 20px;
  }

  .aktuell__image-wrapper {
    width: 100%;
    height: auto;
    padding-top: 60%;
  }

  .aktuell__col {
    margin-bottom: -20px;
    padding-bottom: 20px;
  }

  .a-info-col {
    padding-left: 0;
  }

  .job__rich-text {
    margin-bottom: auto;
  }

  .job__title {
    margin-bottom: 40px;
  }

  .referenzen__link {
    margin-bottom: 20px;
  }

  .referenzen-swiper-collection-wrapper {
    width: 100%;
  }

  .menu {
    display: none;
  }

  .menu__nav {
    width: 35vw;
    padding-right: 20px;
  }

  .menu__panel {
    max-width: 65vw;
  }

  .menu__panel.js-referenzen-panel {
    display: none;
  }

  .produkt-sticky__wrapper {
    height: auto;
    min-height: auto;
    position: static;
    top: 0;
  }

  .produkte__rich-text {
    width: 100%;
    max-width: none;
  }

  .portfolio-sticky {
    top: auto;
  }

  .portfolio-column {
    display: block;
  }

  .portfolio__item__image {
    width: 100%;
    height: auto;
    padding-top: 60%;
  }

  .portfolio__item__content {
    grid-row-gap: 10px;
  }

  .portfolio-collection-list {
    grid-column-gap: 20px;
    grid-row-gap: 16px;
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    display: grid;
  }

  .menu__list {
    margin-top: 10px;
    margin-bottom: 0;
  }

  .menu__panel__link {
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .searchhelp__item {
    font-size: 14px;
  }

  .searchhelp__item:hover {
    background-color: #0000;
  }

  .wg-element-wrapper.sw5 {
    margin-left: 10px;
  }

  .jobs-collection-list.flex-vertical {
    grid-row-gap: 20px;
    flex-flow: column;
  }

  .jobs-collection-item {
    justify-content: flex-start;
    align-self: stretch;
  }

  .jobs-collection-item.with-border {
    border-bottom: 1px solid var(--border-blue);
    margin-right: 20px;
    padding-bottom: 20px;
  }

  .jobs-collection-item.with-border:last-child {
    border-bottom-color: #c8dae200;
    padding-bottom: 0;
  }

  .geschichte__wrapper {
    height: auto;
  }

  .geschichte__list {
    height: auto;
    display: block;
  }

  .geschichte {
    border-right-style: none;
    height: auto;
    padding-left: 0;
    padding-right: 0;
  }

  .geschichte__image {
    width: 100%;
    min-height: 0;
    padding-top: 80%;
  }

  .geschichte__image.is-2009, .geschichte__image.is-2022 {
    width: 100%;
  }

  .geschichte__year {
    width: auto;
    max-width: none;
    padding-bottom: 0;
    display: none;
    position: absolute;
    inset: 50% 0 auto auto;
  }

  .geschichte__content {
    display: block;
  }

  .navbar__logo {
    height: 60px;
    margin-top: 24px;
  }

  .navbar__logo__bottom {
    height: 20px;
  }

  .portfolio-slider-wrapper {
    width: 100%;
    height: 100%;
    margin-bottom: 20px;
  }

  .portfolio-slider-list {
    flex: 0 auto;
    width: 100%;
    height: 100%;
  }

  .portfolio-slider-item {
    flex: none;
    margin-bottom: 0;
    display: flex;
  }

  .navbar__logo__top {
    height: 32px;
  }

  .navbar__logo__bottom__image {
    height: 12px;
  }

  .navbar__hamburger {
    color: var(--midnight-blue);
    cursor: pointer;
    background-color: #0000;
    border-radius: 4px;
    align-items: center;
    width: 32px;
    padding-left: 0;
    padding-right: 0;
    font-size: 12px;
    font-weight: 600;
    display: flex;
  }

  .navbar__hamburger:hover {
    opacity: .7;
  }

  .text-block {
    padding-left: 10px;
    padding-right: 10px;
  }

  .heading-2 {
    line-height: 1.1;
  }

  .kontakt-cms-list {
    grid-row-gap: 20px;
    flex-flow: wrap;
    grid-template-columns: minmax(auto, 167px) minmax(auto, 167px);
  }

  .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
  }

  .footer__logo {
    margin-left: 0;
    padding-left: 0;
  }

  .footer__logo__bottom {
    left: -20px;
    right: auto;
  }

  .footer__logo__top__img {
    margin-left: 0;
  }

  .map-wrapper {
    height: 100vh;
  }

  .form-2 {
    width: 100%;
  }

  .video__wrapper {
    width: 70vw;
  }

  .aktuell-cms-info {
    grid-column-gap: 20px;
    grid-row-gap: 16px;
    order: -1;
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    margin-bottom: 20px;
    display: grid;
  }

  .collection-item, .collection-list, .collection-list-wrapper-2 {
    width: 100%;
  }

  .swiper-sec-nav.h-referenzen {
    display: none;
    top: 22.2vw;
  }

  ._404__content {
    padding-left: 20px;
    padding-right: 20px;
  }

  ._404__large {
    font-size: 50vw;
  }

  .s-result.cc-hidden {
    display: none;
  }

  .s-result__item__url {
    color: #325b6db3;
  }

  .aktuell-hero.cc-hidden {
    display: none;
  }

  .c-section__header-copy {
    padding-top: 90px;
    padding-bottom: 20px;
  }

  .aktuell-hero_container.cc-sc-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .aktuell-hero_container.cc-produkte-landscape, .aktuell-hero_container.cc-produkte-portrait {
    grid-template-columns: 1fr;
  }

  .aktuell-hero_container.cc-kontakt {
    flex-direction: column;
    display: flex;
  }

  .aktuell-hero_container.r-thumbnail {
    align-items: flex-start;
    padding-left: 0;
    padding-right: 0;
    display: flex;
    position: static;
    inset: auto 0% 0%;
  }

  .aktuell-hero_container.cc-referenzen-info {
    flex-direction: column;
    display: flex;
  }

  .aktuell-hero_container.cc-referenzen-hero {
    padding-top: 266px;
  }

  .aktuell-hero_container.cc-navbar {
    padding-top: 10px;
  }

  .gen-hero-img.show-on-mobile {
    display: block;
  }

  .gen-hero-img.hide-on-mobile {
    display: none;
  }

  .hh-point__big {
    width: 30px;
    height: 30px;
  }

  .hh-point__small {
    width: 8px;
    height: 8px;
  }

  .gen-hero__nav {
    width: 100%;
    height: 100%;
    margin-top: 0;
    inset: 0;
  }

  .gen-hero__nav__button {
    color: #00344a;
    background-color: #edeff1;
  }

  .gen-hero__nav__button:hover {
    background-color: #00344a;
  }

  .gen-hero__nav__button.cc-main {
    display: none;
  }

  .gen-hero__nav-row {
    justify-content: space-between;
    width: 100%;
    display: none;
    position: absolute;
  }

  .gen-hero__nav-row.toprow {
    display: none;
  }

  .hp-pop__item {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .hp-pop__block {
    grid-row-gap: 0px;
    flex-direction: column;
    max-width: 400px;
    padding-bottom: 40px;
    padding-right: 10px;
  }

  .hp-pop__text-container {
    height: auto;
    padding-top: 40px;
    padding-left: 0;
    overflow: visible;
  }

  .hp-pop__close {
    color: #fff;
    background-color: #fff3;
    top: 30px;
    right: 30px;
  }

  .hp-pop__scrollbar-overlay {
    display: none;
  }

  .geschichte__year__mobile {
    height: 20px;
    margin-top: 20px;
    margin-bottom: -36px;
    margin-left: auto;
    font-weight: 600;
    display: block;
  }

  .heading-3 {
    line-height: 34px;
  }

  .cb-lightbox {
    padding-left: 0;
    padding-right: 0;
  }

  .cb-lightbox__img {
    max-width: 100vw;
  }

  .cd-cta {
    width: 240px;
    height: 240px;
  }

  .cd-cta.cd-cta__hero3, .cd-cta.cd-cta__hero4 {
    width: 200px;
    height: 200px;
    position: absolute;
    bottom: -80px;
    left: 25px;
    right: auto;
  }

  .cd-cta.cd-cta__kontakt {
    margin-left: 0;
    margin-right: auto;
  }

  .cd-cta__circle {
    z-index: 50;
  }

  .cd-cta__title {
    font-size: 28px;
  }

  .cd-cta__button {
    font-size: 11px;
  }

  .cd-cta__text, .cd-cta__richtext p {
    font-size: 14px;
  }

  .pp__fixed-close {
    z-index: 51;
  }

  .cms-project__gallery__wrapper {
    display: block;
  }

  .cms-project__gallery__wrapper.cms-inspiration {
    display: flex;
  }

  .cms-project__gallery__image-item {
    width: 100%;
    margin-top: 50px;
    margin-bottom: 50px;
  }

  .cms-project__gallery__image-item.cms-project__rectangle {
    width: 100%;
    margin-left: 0;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-left {
    width: 100%;
    height: 60vw;
    max-height: none;
    margin-top: 0;
    margin-bottom: 100px;
    padding-right: 0;
  }

  .cms-project__gallery__image-item.cms-project__landscape {
    width: 100%;
    max-width: none;
    height: 60vw;
    margin-top: 0;
    margin-bottom: 100px;
    margin-left: 0;
  }

  .cms-project__gallery__image-item.cms-project__triple-centre {
    width: 100%;
    max-height: none;
    margin-top: 0;
    margin-bottom: 100px;
    padding-left: 0;
    padding-right: 0;
  }

  .cms-project__gallery__image-item.cms-project__triple-left {
    width: 100%;
    height: auto;
    max-height: none;
    margin-top: 0;
    margin-bottom: 100px;
    margin-right: 0;
    padding-right: 0;
  }

  .cms-project__gallery__image-item.cms-project__square {
    margin-top: 0;
    margin-bottom: 100px;
  }

  .cms-project__gallery__image-item.cms-project__portrait {
    width: 100%;
    margin-top: 0;
    margin-bottom: 100px;
    margin-right: 0;
  }

  .cms-project__gallery__image-item.cms-project__rectangle {
    width: 100%;
    max-width: none;
    height: 60vw;
    max-height: none;
  }

  .cms-project__gallery__image-item.cms-project__triple-right {
    width: 100%;
    max-height: none;
    margin-top: 0;
    margin-bottom: 100px;
    padding-left: 0;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-right {
    width: 100%;
    height: 60vw;
    max-height: none;
    margin-top: 0;
    margin-bottom: 100px;
    padding-left: 0;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-almostright {
    width: 100%;
    height: 60vw;
    max-height: none;
    margin-top: 0;
    margin-bottom: 100px;
    margin-left: 0%;
    padding-left: 0;
    padding-right: 0;
  }

  .cms-project__gallery__image-item.cms-project__quadruple-almostleft {
    width: 100%;
    max-height: 60vw;
    margin-top: 0;
    margin-bottom: 100px;
    margin-left: 0%;
    padding-left: 0;
    padding-right: 0;
  }

  .cms-project__gallery__image-item.cms-project__rectangle-right, .cms-project__gallery__image-item.cms-project__rectangle-left {
    margin-top: 0;
    margin-bottom: 100px;
  }

  .utl__position-relative {
    position: relative;
  }

  .utl__position-relative.z-100 {
    z-index: 100;
  }

  .arc-materialien__wrapper {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
    grid-template-columns: 1fr;
  }

  .arc-materialien__wrapper.no-hover {
    grid-template-columns: 1fr 1fr;
  }

  .testimonial__image-wrapper {
    z-index: 100;
    width: 100%;
    height: auto;
    margin-bottom: 0;
  }

  .testimonial__name {
    margin-bottom: 20px;
  }

  .testimonial__col {
    justify-content: flex-start;
  }

  .testimonial__col.is-1 {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    flex-flow: column;
  }

  .aktuell-g__col-copy {
    justify-content: flex-start;
  }

  .fch-hero__top.with-popup {
    height: 470px;
  }

  .k-process__wrapper {
    grid-column-gap: 60px;
    grid-row-gap: 60px;
    flex-direction: column;
    align-items: flex-start;
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 24px;
  }

  .k-process__step {
    align-items: flex-start;
    max-width: none;
  }

  .k-process__step__title {
    text-align: left;
  }

  .k-process__step__point {
    bottom: auto;
    left: -10px;
  }

  .k-process__line {
    width: 1px;
    height: 100%;
  }

  .sidenav__link-wrapper {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .form-2-copy {
    width: 100%;
  }
}

@media screen and (max-width: 479px) {
  .cookies__checkbox-lable {
    max-width: none;
  }

  .cookies__container {
    padding-left: 10%;
    padding-right: 10%;
  }

  .cookies__checkbox-wrapper {
    justify-content: flex-start;
    width: 100%;
  }

  .cookies__heading {
    font-size: 25px;
  }

  .utility__section {
    padding: 80px 25px;
  }

  .s-buttons.cc-kontakt {
    flex-direction: row;
    justify-content: flex-start;
  }

  .c-container.r-thumbnail {
    padding-top: 0%;
  }

  .c-container.cc-referenzen-cms-hero {
    flex-direction: column;
    display: flex;
  }

  .c-container.a-hero-image-copy {
    padding-bottom: 0;
  }

  .c-container.cta-button__hero3 {
    justify-content: flex-start;
    padding-right: 20px;
  }

  .c-tab-menu__item.w--current, .c-tab-menu__item.cc-2 {
    text-align: center;
  }

  .c-download-button {
    flex: none;
    margin-top: -2.5em;
    margin-left: auto;
  }

  .cta {
    min-height: 650px;
    padding-top: 28vw;
  }

  .caption-text.cc-karriere__caption {
    max-width: 198px;
  }

  .portfolio__image {
    width: 80vw;
    height: auto;
    padding-top: 125%;
  }

  .portfolio__info {
    max-width: 80vw;
  }

  .c-image-responsive.kontakt__person-img {
    position: relative;
  }

  .image-copyright-text {
    position: absolute;
  }

  .image-copyright-text.centered {
    text-align: center;
    bottom: 16px;
    left: 20px;
    right: 20px;
  }

  .c-hero__copy.c-hero__home {
    padding-top: 270px;
  }

  .vertical-line.cc-left.z-2000.cc-mobile-hide {
    display: none;
  }

  .aktuell__paragraph {
    margin-bottom: 0;
  }

  .portfolio__item.cc-portrait {
    grid-column-gap: 0px;
    justify-content: flex-start;
    align-items: flex-start;
    height: auto;
    display: flex;
  }

  .portfolio-sticky-slider, .portfolio-slider__content, .portfolio-slider__title {
    margin-top: 0;
  }

  .produkte-sticky-image {
    height: auto;
    padding-top: 75%;
    top: 0;
  }

  .form__checkbox__icon {
    flex: none;
  }

  .div-block-25 {
    width: auto;
  }

  .div-block-27 {
    grid-column-gap: 20px;
  }

  .r-thumbnail {
    padding-top: 60%;
  }

  .r-hero {
    overflow: visible;
  }

  .div-block-28 {
    width: 100%;
    min-height: 200px;
  }

  .c-title-1-smaller {
    letter-spacing: -1.5px;
    font-size: 10vw;
    line-height: 1.1;
  }

  .c-title-1-smaller.portfolio__title, .c-title-1-smaller.hero-offset {
    margin-bottom: -1.2vw;
  }

  .r-galerie-collection-item {
    max-width: 85vw;
  }

  .kontakt-person__img {
    aspect-ratio: 108 / 167;
    width: 100%;
    height: auto;
  }

  .kontakt-cms-item {
    max-width: calc(50% - 20px);
  }

  .r-info {
    overflow: visible;
  }

  .c-paragraph-large {
    font-size: 21px;
    line-height: 1.5;
  }

  .referenzen-cms-collection-list.uber-uns-cms-collection-list {
    grid-template-columns: 1fr;
  }

  .filter-dropdown {
    position: relative;
  }

  .filter-buttons {
    justify-content: flex-end;
    margin-top: 20px;
  }

  .form {
    flex-direction: column;
  }

  .aktuel-cms-excerpt {
    margin-bottom: 60px;
  }

  .a-hero-image {
    padding-top: 100%;
    overflow: hidden;
  }

  .team__image {
    width: 80vw;
    max-width: 296px;
    height: 100vw;
    max-height: 379px;
    position: relative;
  }

  .team__image.full-width__team {
    max-width: none;
    max-height: none;
  }

  .team-collection-item {
    flex: none;
    width: auto;
  }

  .job__rich-text {
    width: 100%;
  }

  .referenzen__link {
    margin-bottom: 20px;
  }

  .menu__nav.active {
    padding-left: 10px;
    padding-right: 10px;
  }

  .menu__panel {
    padding-top: 50px;
  }

  .menu__panel.js-about-panel, .menu__panel.js-downloads-panel {
    display: none;
  }

  .menu__nav__link {
    padding-bottom: 4px;
  }

  .produkt-sticky__wrapper {
    min-height: auto;
  }

  .produkte-gallery-collection-item {
    max-width: 85vw;
  }

  .total-images {
    order: 0;
  }

  .portfolio-sticky__top {
    overflow: hidden;
  }

  .portfolio__item__image.cc-portrait {
    flex: 0 auto;
    max-width: none;
    height: auto;
    padding-top: 120%;
    display: block;
  }

  .portfolio-collection-list {
    display: block;
  }

  .menu__panel__link {
    letter-spacing: 0;
    padding-left: 10px;
    padding-right: 10px;
    font-size: 5vw;
  }

  .search__container {
    margin-bottom: 10px;
  }

  .search__input, .search {
    width: 34px;
    height: 34px;
  }

  .search_icon {
    margin-left: auto;
    margin-right: auto;
    position: absolute;
    inset: 0% 0% 0% 10%;
  }

  .jobs-collection-item {
    width: 100%;
    padding-right: 20px;
  }

  .portfolio__info__sub {
    margin-top: 20px;
  }

  .navbar__logo {
    margin-left: -10px;
  }

  .kontakt-cms-list {
    grid-template-columns: 1fr;
    margin-right: -20px;
  }

  .footer__bottom {
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
  }

  .map-wrapper {
    height: 100vh;
    min-height: 0;
  }

  .video__wrapper {
    width: 80vw;
  }

  .swiper-sec-nav.h-referenzen {
    top: 21.2vw;
  }

  .swiper-sec-nav.h-portfolio {
    top: 50vw;
  }

  .html-embed {
    letter-spacing: 0;
  }

  ._404__large {
    font-size: 60vw;
  }

  .aktuell-hero_container.r-thumbnail {
    padding-top: 0%;
  }

  .aktuell-hero_container.cc-referenzen-cms-hero {
    flex-direction: column;
    display: flex;
  }

  .aktuell-hero_container.a-hero-image-copy {
    padding-bottom: 0;
  }

  .gen-hero-wrapper {
    position: relative;
  }

  .gen-hero-list {
    padding-top: 130%;
  }

  .gen-hero-item {
    height: 100%;
  }

  .gen-hero__nav {
    z-index: auto;
  }

  .gen-hero__nav-row {
    z-index: 10;
  }

  .gen-hero__nav-row.toprow {
    display: none;
  }

  .r-galerie__img-container {
    padding-top: 80%;
  }

  .cd-cta {
    width: 210px;
    height: 210px;
  }

  .cd-cta.cd-cta__hero {
    position: absolute;
    inset: 30px 10px auto auto;
  }

  .cd-cta.cd-cta__hero3 {
    width: 180px;
    height: 180px;
    margin-left: -10px;
    position: absolute;
    top: auto;
    bottom: -80px;
    right: auto;
  }

  .cd-cta.cd-cta__referenzen {
    width: 86px;
    height: 86px;
    inset: -24px auto auto 12px;
  }

  .cd-cta.cd-cta__popup {
    width: 85vw;
    height: 85vw;
  }

  .cd-cta.cd-cta__hero4 {
    width: 180px;
    height: 180px;
    margin-left: -10px;
    position: absolute;
    top: auto;
    bottom: -80px;
    right: auto;
  }

  .cd-cta__circle {
    z-index: 50;
  }

  .cd-cta__button {
    z-index: 50;
    font-size: 10px;
    position: relative;
  }

  .cd-cta__richtext h2 {
    letter-spacing: 0;
    font-size: 19px;
    line-height: 1.2;
  }

  .cd-cta__richtext h4 {
    font-size: 14px;
    font-weight: 400;
  }

  .cd-cta__richtext p {
    font-size: 13px;
  }

  .pp__fixed-close__img {
    justify-content: center;
    align-items: center;
  }

  .pp__fixed-close {
    top: -20px;
    left: 120px;
  }

  .cms-project__gallery__image-item.cms-project__rectangle {
    height: 60vw;
    min-height: auto;
    max-height: none;
  }

  .project__images {
    height: 100%;
  }

  .c-insipartion__img-wrapper {
    height: auto;
    padding-top: 125%;
  }

  .button__bottom-left__collection {
    z-index: 50;
    position: absolute;
    bottom: 0;
  }

  .button__bottom-left__collection__item {
    position: relative;
  }

  .fch-portfolio__wrapper, .fch-portfolio__wrapper.grid-2 {
    grid-template-columns: 1fr;
  }

  .arc-materialien__wrapper.no-hover {
    flex-flow: column;
    grid-template-columns: 1fr;
    display: flex;
  }

  .k-process__step__title {
    text-align: left;
  }

  .produkte-p__popup {
    padding-right: 20px;
  }

  .div-block-47 {
    width: 100%;
  }

  .neu-g__item {
    padding-bottom: 14px;
  }
}

#w-node-_74b583c3-0fe5-c9a2-a56c-ff7db0e48e40-b06a2b95 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-cd1f9984-29eb-d52f-6ede-536e6bbcc472-b06a2b95 {
  grid-area: span 1 / span 1 / span 1 / span 1;
  align-self: end;
}

#w-node-_9c5ee1d2-c2d2-cfef-e456-9c871f60ef37-b06a2b95 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_14e7c589-0af0-379b-92d6-c33ae76fa9c3-b06a2b95, #w-node-_254eb905-7c8e-adca-9f9c-940ef50ee7d4-b06a2b95 {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-edc65df4-2b81-045b-8659-e70ec2e9a777-b06a2b95, #w-node-_7198cff6-3ecc-8c21-372e-ff1badbf4050-b06a2b95, #w-node-fce012be-c69b-4e80-c276-4d2e714d9d5f-b06a2b95, #w-node-fce012be-c69b-4e80-c276-4d2e714d9d63-b06a2b95, #w-node-b76604e1-cb7e-4030-de01-e695c27ead74-c27ead71, #w-node-b76604e1-cb7e-4030-de01-e695c27ead75-c27ead71, #w-node-b76604e1-cb7e-4030-de01-e695c27ead8b-c27ead71, #w-node-b76604e1-cb7e-4030-de01-e695c27ead98-c27ead71 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-d9048365-706b-575f-c086-3e72e504dcd0-b06a2bcc {
  align-self: start;
}

#w-node-f0461063-83c2-e45b-1cc8-2a4fb75eedff-b06a2be2 {
  align-self: stretch;
}

#w-node-_8634d950-4463-7fa2-9172-6b3877f0a880-b06a2be2, #w-node-_8634d950-4463-7fa2-9172-6b3877f0a882-b06a2be2, #w-node-_340d12aa-5a5e-175f-752d-a789e86352f0-b06a2be5 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_54b7b84d-8700-0ae3-69a2-2215601b9177-b06a2be5 {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-_9a42b880-54a7-8fb6-523e-47b1fa859b3e-b06a2be5, #form.w-node-_6812e3e9-28c4-e83c-0268-73c73d3ea8af-b06a2be5, #w-node-_5b83769c-d142-b9a2-b0b6-613a65ac11a9-b06a2be5, #w-node-_5b83769c-d142-b9a2-b0b6-613a65ac11aa-b06a2be5, #w-node-_5b83769c-d142-b9a2-b0b6-613a65ac11b4-b06a2be5, #w-node-_5b83769c-d142-b9a2-b0b6-613a65ac11d9-b06a2be5, #w-node-_68b82e21-f6ad-ec72-be0a-651f80633d7c-b06a2be7, #w-node-_68b82e21-f6ad-ec72-be0a-651f80633d7f-b06a2be7 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_68b82e21-f6ad-ec72-be0a-651f80633d80-b06a2be7 {
  align-self: auto;
}

#w-node-_0fdc6a1b-f130-18f4-dadd-a176d96d7717-b06a2be7, #w-node-bcd53c3d-15a5-a69e-c08f-94555fdaa100-b06a2be7, #w-node-c48ee33a-6c96-9905-bb91-9b4276290e0d-b06a2be7 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_34946337-b756-6b74-d97b-986211a9b6e0-b06a2be7 {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-_963d439c-36ff-9ca1-686c-ea3c3155ee68-b06a2be9 {
  align-self: auto;
}

#w-node-_6069e9b6-64ff-4965-5b81-4631cc447c7e-b06a2bea, #w-node-_6069e9b6-64ff-4965-5b81-4631cc447c83-b06a2bea {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_3d088401-4280-41a2-8526-62d4434c2e49-b06a2bed {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-d204ba9a-9c3b-2d70-5881-dbf59f82d6a2-b06a2bed, #w-node-_98512731-fed7-e83d-9a2a-26df051ffdc5-b06a2bef, #w-node-_98512731-fed7-e83d-9a2a-26df051ffddb-b06a2bef {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_896e89c0-4628-cb6d-f452-f57c3f079caf-b06a2bef, #w-node-_56a315e3-ebed-93aa-79f6-bea8c77330a3-b06a2bef {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-_71f75b8b-a5f9-b820-8981-c9d7c3625558-b06a2c09, #w-node-cce84a4d-d9e4-9273-17ff-22f7b74b2fb5-b06a2c09, #w-node-cff2c62d-7bba-a803-8635-52b6fe654c1f-b06a2c09, #w-node-_71f75b8b-a5f9-b820-8981-c9d7c3625558-b06a2c0a, #w-node-_7a0646a9-94a6-33db-cced-2d62add56c1c-b06a2c0a, #w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a22-b06a2c0c, #w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a39-b06a2c0c, #w-node-f18835e7-07e0-b260-b1ed-736a1fc1b851-b06a2c0c, #w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a22-b06a2c21, #w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a39-b06a2c21, #w-node-f18835e7-07e0-b260-b1ed-736a1fc1b851-b06a2c21, #w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a22-b06a2c29, #w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a39-b06a2c29, #w-node-_75d1823a-7a67-f522-f5e0-24bf7ca4c303-b06a2c2a, #w-node-_75d1823a-7a67-f522-f5e0-24bf7ca4c312-b06a2c2a, #w-node-_74b583c3-0fe5-c9a2-a56c-ff7db0e48e40-b06a2c4b {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-cd1f9984-29eb-d52f-6ede-536e6bbcc472-b06a2c4b {
  grid-area: span 1 / span 1 / span 1 / span 1;
  align-self: end;
}

#w-node-_9c5ee1d2-c2d2-cfef-e456-9c871f60ef37-b06a2c4b, #w-node-_6ccf0017-dbe2-47a2-0219-41ab528e62bf-b06a2c4b {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_6ccf0017-dbe2-47a2-0219-41ab528e62cd-b06a2c4b {
  grid-area: span 1 / span 1 / span 1 / span 1;
  align-self: end;
}

#w-node-_6ccf0017-dbe2-47a2-0219-41ab528e62d2-b06a2c4b, #w-node-_82b77f67-f433-6f71-fe1a-2511b395877a-b06a2c4b {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_82b77f67-f433-6f71-fe1a-2511b3958788-b06a2c4b {
  grid-area: span 1 / span 1 / span 1 / span 1;
  align-self: end;
}

#w-node-_82b77f67-f433-6f71-fe1a-2511b395878b-b06a2c4b {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_45c59c6e-2630-cc4a-18dc-1dcc5886d90f-b06a2c4c {
  grid-area: span 1 / span 2 / span 1 / span 2;
}

#w-node-d818613e-d133-af74-00db-e512dd4718d4-b06a2c4c {
  grid-area: 1 / 1 / 2 / 2;
}

#w-node-df3edfac-94f3-ed27-b000-851e922de29b-b06a2c4c {
  grid-area: 1 / 2 / 2 / 4;
}

#form.w-node-_0239ba8d-f10e-69fc-425b-894941ca7a21-b06a2c4c {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-ea68ce84-5278-faea-1048-d91fa492d40b-b06a2c4f {
  grid-area: span 1 / span 2 / span 1 / span 2;
}

#w-node-ea68ce84-5278-faea-1048-d91fa492d40d-b06a2c4f {
  grid-area: 1 / 1 / 2 / 2;
}

#w-node-c21fa135-9a85-16ba-26ff-f58767da23a2-b06a2c4f {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-df3edfac-94f3-ed27-b000-851e922de29b-b06a2c4f {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-a5753adb-a822-e7be-cb51-090c2a26ccba-b06a2c4f, #form.w-node-_0239ba8d-f10e-69fc-425b-894941ca7a21-b06a2c4f, #w-node-_33867201-9466-adea-e3cd-f5970f1a3054-b06a2c5b, #w-node-_33867201-9466-adea-e3cd-f5970f1a3061-b06a2c5b {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-fb163eb3-2741-f95c-c872-fc1291b4fe4c-b06a2c5b {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a22-b06a2c5d, #w-node-bbe7b39a-502e-dbc5-c394-7bfe2b0b2a39-b06a2c5d {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_2fb50318-a666-a120-dd37-ef38af89df5e-b06a2c5d, #w-node-dbb4f971-0057-9d6f-ae2c-03528ac5a685-b06a2c5d {
  grid-area: 1 / 2 / 2 / 4;
}

#w-node-_7899dd2f-772f-3e7f-fbee-7f34f742a933-b06a2c5d, #w-node-_7899dd2f-772f-3e7f-fbee-7f34f742a93e-b06a2c5d {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

@media screen and (max-width: 991px) {
  #form.w-node-_6812e3e9-28c4-e83c-0268-73c73d3ea8af-b06a2be5 {
    order: -9999;
  }

  #w-node-_0fdc6a1b-f130-18f4-dadd-a176d96d7717-b06a2be7, #w-node-_866e0abc-93e5-0d89-690a-be940adf33e5-b06a2bea {
    order: 9999;
  }

  #w-node-_3d088401-4280-41a2-8526-62d4434c2e49-b06a2bed {
    grid-column-start: 1;
  }

  #form.w-node-_0239ba8d-f10e-69fc-425b-894941ca7a21-b06a2c4c, #form.w-node-_0239ba8d-f10e-69fc-425b-894941ca7a21-b06a2c4f, #form.w-node-_04769734-0a33-a8ad-32d7-b82b1757d885-b06a2c5b, #form.w-node-b3e03565-e82c-520c-03d4-41bef81760fc-b06a2c5b {
    order: -9999;
  }

  #w-node-_2fb50318-a666-a120-dd37-ef38af89df5e-b06a2c5d, #w-node-dbb4f971-0057-9d6f-ae2c-03528ac5a685-b06a2c5d {
    grid-column-start: 1;
  }
}
