@charset "UTF-8";
/**
 * @license
 * MyFonts Webfont Build ID 3209488, 2016-04-26T04:24:59-0400
 * 
 * The fonts listed in this notice are subject to the End User License
 * Agreement(s) entered into by the website owner. All other parties are 
 * explicitly restricted from using the Licensed Webfonts(s).
 * 
 * You may obtain a valid license at the URLs below.
 * 
 * Webfont: UniversNextPro-Cond by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-420-condensed-regular/
 * 
 * Webfont: UniversNextPro-MediumCondIt by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-521-condensed-medium-italic/
 * 
 * Webfont: UniversNextPro-BoldCond by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-620-condensed-bold/
 * 
 * Webfont: UniversNextPro-BoldCondIt by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-621-condensed-bold-italic/
 * 
 * Webfont: UniversNextPro-CondItalic by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-421-condensed-italic/
 * 
 * Webfont: UniversNextPro-LightCondIt by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-321-condensed-light-italic/
 * 
 * Webfont: UniversNextPro-MediumCond by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-520-condensed-medium/
 * 
 * Webfont: UniversNextPro-LightCond by Linotype
 * URL: http://www.myfonts.com/fonts/linotype/univers-next/pro-320-condensed-light/
 * 
 * 
 * License: http://www.myfonts.com/viewlicense?type=web&buildid=3209488
 * Licensed pageviews: 250,000
 * Webfonts copyright: Copyright &#x00A9; 2010 Linotype GmbH, www.linotype.com. All rights reserved. This font software may not be reproduced, modified, disclosed or transferred without the express written approval of Linotype GmbH. Univers is a trademark of Linotype Corp. regi
 * 
 * Â© 2016 MyFonts Inc
*/
/* @import must be at top of file, otherwise CSS will not work 
@import url("//hello.myfonts.net/count/30f910");  
@font-face {font-family: 'UniversNextPro-LightCond';src: url('../fonts/30F910_7_0.eot');src: url('../fonts/30F910_7_0.eot?#iefix') format('embedded-opentype'),url('../fonts/30F910_7_0.woff2') format('woff2'),url('../fonts/30F910_7_0.woff') format('woff'),url('../fonts/30F910_7_0.ttf') format('truetype');}
@font-face {font-family: 'UniversNextPro-BoldCond';src: url('../fonts/30F910_2_0.eot');src: url('../fonts/30F910_2_0.eot?#iefix') format('embedded-opentype'),url('../fonts/30F910_2_0.woff2') format('woff2'),url('../fonts/30F910_2_0.woff') format('woff'),url('../fonts/30F910_2_0.ttf') format('truetype');}
@font-face {font-family: 'UniversNextPro-MediumCond';src: url('../fonts/30F910_6_0.eot');src: url('../fonts/30F910_6_0.eot?#iefix') format('embedded-opentype'),url('../fonts/30F910_6_0.woff2') format('woff2'),url('../fonts/30F910_6_0.woff') format('woff'),url('../fonts/30F910_6_0.ttf') format('truetype');}
@font-face {font-family: 'UniversNextPro-LightCondIt';src: url('../fonts/30F910_5_0.eot');src: url('../fonts/30F910_5_0.eot?#iefix') format('embedded-opentype'),url('../fonts/30F910_5_0.woff2') format('woff2'),url('../fonts/30F910_5_0.woff') format('woff'),url('../fonts/30F910_5_0.ttf') format('truetype');}
/*

/* roboto-condensed-200 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: normal;
  font-weight: 200;
  src: url("../fonts/roboto-condensed-v30-latin-200.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-200italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: italic;
  font-weight: 200;
  src: url("../fonts/roboto-condensed-v30-latin-200italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/roboto-condensed-v30-latin-300.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-300italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: italic;
  font-weight: 300;
  src: url("../fonts/roboto-condensed-v30-latin-300italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/roboto-condensed-v30-latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: italic;
  font-weight: 400;
  src: url("../fonts/roboto-condensed-v30-latin-italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/roboto-condensed-v30-latin-500.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-500italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: italic;
  font-weight: 500;
  src: url("../fonts/roboto-condensed-v30-latin-500italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/roboto-condensed-v30-latin-600.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-600italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: italic;
  font-weight: 600;
  src: url("../fonts/roboto-condensed-v30-latin-600italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/roboto-condensed-v30-latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* roboto-condensed-700italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Condensed";
  font-style: italic;
  font-weight: 700;
  src: url("../fonts/roboto-condensed-v30-latin-700italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
.button-primary,
.wp-block-button__link,
input[type=submit],
.wp-element-button {
  border-radius: 2px;
  background-color: #E2001A;
  font-size: 14px;
  line-height: 24px;
  font-weight: 400;
  border: none;
  cursor: pointer;
  min-height: 45px;
  padding: 5px 1.25rem;
  display: inline-flex;
  align-items: center;
  text-transform: uppercase;
  text-decoration: none;
}
@media only screen and (min-width: 1100px) {
  .button-primary,
  .wp-block-button__link,
  input[type=submit],
  .wp-element-button {
    font-size: 19px;
    line-height: 32px;
  }
}
.button-primary, .button-primary:visited, .button-primary:focus,
.wp-block-button__link,
.wp-block-button__link:visited,
.wp-block-button__link:focus,
input[type=submit],
input[type=submit]:visited,
input[type=submit]:focus,
.wp-element-button,
.wp-element-button:visited,
.wp-element-button:focus {
  color: white;
}
.button-primary:hover, .button-primary:visited:hover, .button-primary:focus:hover,
.wp-block-button__link:hover,
.wp-block-button__link:visited:hover,
.wp-block-button__link:focus:hover,
input[type=submit]:hover,
input[type=submit]:visited:hover,
input[type=submit]:focus:hover,
.wp-element-button:hover,
.wp-element-button:visited:hover,
.wp-element-button:focus:hover {
  background-color: #ce0920;
  color: white;
  text-decoration: none;
}
@media only screen and (max-width: 1099px) {
  .button-primary,
  .wp-block-button__link,
  input[type=submit],
  .wp-element-button {
    min-height: 38px;
    padding: 5px 15px;
  }
}

.button-primary-sm {
  border-radius: 2px;
  background-color: #E2001A;
  font-size: 14px;
  line-height: 24px;
  font-weight: 400;
  border: none;
  cursor: pointer;
  min-height: 45px;
  padding: 5px 1.25rem;
  display: inline-flex;
  align-items: center;
  text-transform: uppercase;
  text-decoration: none;
  height: 45px;
  padding: 0 15px;
}
@media only screen and (min-width: 1100px) {
  .button-primary-sm {
    font-size: 19px;
    line-height: 32px;
  }
}
.button-primary-sm, .button-primary-sm:visited, .button-primary-sm:focus {
  color: white;
}
.button-primary-sm:hover, .button-primary-sm:visited:hover, .button-primary-sm:focus:hover {
  background-color: #ce0920;
  color: white;
  text-decoration: none;
}
@media only screen and (max-width: 1099px) {
  .button-primary-sm {
    min-height: 38px;
    padding: 5px 15px;
  }
}
@media only screen and (min-width: 1100px) {
  .button-primary-sm {
    font-size: 16px;
    line-height: 25px;
  }
}

.btn-container, .wp-block-buttons {
  margin-top: 30px;
}
@media only screen and (min-width: 1100px) {
  .btn-container, .wp-block-buttons {
    margin-top: 40px;
  }
}
.btn-container > a:not(:first-child), .wp-block-buttons > a:not(:first-child) {
  margin-left: 20px;
}
@media only screen and (min-width: 1100px) {
  .btn-container > a:not(:first-child), .wp-block-buttons > a:not(:first-child) {
    margin-left: 40px;
  }
}

p + .btn-container, div:has(p:last-child) + .btn-container {
  margin-top: 15px;
}
@media only screen and (min-width: 1100px) {
  p + .btn-container, div:has(p:last-child) + .btn-container {
    margin-top: 33px;
  }
}

.wp-block-buttons {
  gap: 40px;
}
@media only screen and (max-width: 1099px) {
  .wp-block-buttons {
    gap: 20px;
  }
}

.wp-block-buttons:has(+ p) {
  margin-bottom: 30px;
}
@media only screen and (min-width: 1100px) {
  .wp-block-buttons:has(+ p) {
    margin-bottom: 3.125rem;
  }
}

@media only screen and (max-width: 699px) {
  h2 + .wp-block-buttons {
    margin-top: 23px;
  }
}

button {
  cursor: pointer;
  border: none;
}

html {
  font-size: 1vw;
}

body {
  font-family: "Roboto Condensed", sans-serif;
  letter-spacing: 0.05px;
  font-weight: 400;
  font-size: 16px;
  line-height: 26px;
}
@media only screen and (min-width: 1100px) {
  body {
    font-size: 23px;
    line-height: 36px;
    letter-spacing: 0.07px;
  }
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4 {
  font-weight: 600;
  letter-spacing: 0.15px;
}
@media only screen and (min-width: 1100px) {
  h1, .h1, h2, .h2, h3, .h3, h4, .h4 {
    letter-spacing: 0.26px;
  }
}

h1, .h1 {
  font-size: 30px;
  line-height: 42px;
}
@media only screen and (min-width: 1100px) {
  h1, .h1 {
    font-size: 52px;
    line-height: 64px;
  }
}

h2, .h2 {
  font-size: 26px;
  line-height: 37px;
}
@media only screen and (min-width: 1100px) {
  h2, .h2 {
    font-size: 40px;
    line-height: 52px;
  }
}

h3, .h3 {
  font-size: 23px;
  line-height: 34px;
}
@media only screen and (min-width: 1100px) {
  h3, .h3 {
    font-size: 33px;
    line-height: 45px;
  }
}

h4, .h4 {
  font-size: 19px;
  line-height: 30px;
}
@media only screen and (min-width: 1100px) {
  h4, .h4 {
    font-size: 28px;
    line-height: 40px;
  }
}

form input[type=text],
form input[type=email],
form input[type=url],
form input[type=password],
form input[type=tel],
form input[type=search],
form input[type=date],
form textarea,
form select {
  height: 47px;
  border-radius: 2px;
  border: 1px solid #1a1a1a;
  width: 100%;
  padding: 0 15px;
}
form input[type=text]:focus, form input[type=text]:active,
form input[type=email]:focus,
form input[type=email]:active,
form input[type=url]:focus,
form input[type=url]:active,
form input[type=password]:focus,
form input[type=password]:active,
form input[type=tel]:focus,
form input[type=tel]:active,
form input[type=search]:focus,
form input[type=search]:active,
form input[type=date]:focus,
form input[type=date]:active,
form textarea:focus,
form textarea:active,
form select:focus,
form select:active {
  outline: 1px solid #E2001A;
}
form input[type=text]:focus::-moz-placeholder, form input[type=text]:active::-moz-placeholder, form input[type=email]:focus::-moz-placeholder, form input[type=email]:active::-moz-placeholder, form input[type=url]:focus::-moz-placeholder, form input[type=url]:active::-moz-placeholder, form input[type=password]:focus::-moz-placeholder, form input[type=password]:active::-moz-placeholder, form input[type=tel]:focus::-moz-placeholder, form input[type=tel]:active::-moz-placeholder, form input[type=search]:focus::-moz-placeholder, form input[type=search]:active::-moz-placeholder, form input[type=date]:focus::-moz-placeholder, form input[type=date]:active::-moz-placeholder, form textarea:focus::-moz-placeholder, form textarea:active::-moz-placeholder, form select:focus::-moz-placeholder, form select:active::-moz-placeholder {
  color: transparent;
}
form input[type=text]:focus::placeholder, form input[type=text]:active::placeholder,
form input[type=email]:focus::placeholder,
form input[type=email]:active::placeholder,
form input[type=url]:focus::placeholder,
form input[type=url]:active::placeholder,
form input[type=password]:focus::placeholder,
form input[type=password]:active::placeholder,
form input[type=tel]:focus::placeholder,
form input[type=tel]:active::placeholder,
form input[type=search]:focus::placeholder,
form input[type=search]:active::placeholder,
form input[type=date]:focus::placeholder,
form input[type=date]:active::placeholder,
form textarea:focus::placeholder,
form textarea:active::placeholder,
form select:focus::placeholder,
form select:active::placeholder {
  color: transparent;
}
@media only screen and (max-width: 699px) {
  form input[type=text],
  form input[type=email],
  form input[type=url],
  form input[type=password],
  form input[type=tel],
  form input[type=search],
  form input[type=date],
  form textarea,
  form select {
    height: 43px;
  }
}
form input[type=text]::-moz-placeholder, form input[type=email]::-moz-placeholder, form input[type=url]::-moz-placeholder, form input[type=password]::-moz-placeholder, form input[type=tel]::-moz-placeholder, form input[type=search]::-moz-placeholder, form input[type=date]::-moz-placeholder, form textarea::-moz-placeholder, form select::-moz-placeholder {
  color: white;
}
form input[type=text]::placeholder,
form input[type=email]::placeholder,
form input[type=url]::placeholder,
form input[type=password]::placeholder,
form input[type=tel]::placeholder,
form input[type=search]::placeholder,
form input[type=date]::placeholder,
form textarea::placeholder,
form select::placeholder {
  color: white;
}
form textarea {
  height: 165px;
  padding: 15px;
}
@media only screen and (max-width: 699px) {
  form textarea {
    height: 150px;
  }
}
form select {
  padding: 0 15px;
  cursor: pointer;
  background-image: url(../img/pfeil-down.svg);
  background-position: 97% center;
  background-repeat: no-repeat;
  background-size: 15px;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  font-size: 14px;
  line-height: 24px;
}
@media only screen and (min-width: 1100px) {
  form select {
    font-size: 19px;
    line-height: 32px;
  }
}
@media only screen and (min-width: 1100px) {
  form select {
    background-size: 20px;
    padding: 0 25px;
    background-position: 96% center;
  }
}
form p:last-of-type {
  margin-bottom: 0;
}
form p:has(.wpcf7-acceptance) {
  margin-top: 40px;
}
@media only screen and (min-width: 1100px) {
  form p:has(.wpcf7-acceptance) {
    margin-top: 3.4375rem;
  }
}
form .wpcf7-list-item {
  margin: 0;
  display: block;
}
form .wpcf7-list-item label {
  font-weight: 400;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
}
form .wpcf7-list-item label [type=checkbox], form .wpcf7-list-item label [type=radio] {
  position: relative;
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  margin-right: 15px;
  height: 34px;
  width: 34px;
  min-width: 34px;
  background-color: transparent;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #1a1a1a;
}
@media only screen and (max-width: 699px) {
  form .wpcf7-list-item label [type=checkbox], form .wpcf7-list-item label [type=radio] {
    height: 20px;
    width: 20px;
    min-width: 20px;
    align-self: flex-start;
    margin-top: 5px;
    margin-right: 12px;
  }
}
form .wpcf7-list-item label input[type=checkbox]::before {
  content: "";
  width: 24px;
  height: 24px;
  -webkit-clip-path: polygon(21% 40%, 21% 40%, 8% 54%, 25% 68%, 36% 77%, 47% 65%, 48% 64%, 64% 47%, 75% 35%, 93% 13%, 81% 4%, 36% 54%);
  clip-path: polygon(21% 40%, 21% 40%, 8% 54%, 25% 68%, 36% 77%, 47% 65%, 48% 64%, 64% 47%, 75% 35%, 93% 13%, 81% 4%, 36% 54%);
  transform: scale(0);
  background-color: #1a1a1a;
}
@media only screen and (max-width: 699px) {
  form .wpcf7-list-item label input[type=checkbox]::before {
    width: 15px;
    height: 15px;
  }
}
form .wpcf7-list-item label input[type=checkbox]:checked::before {
  transform: scale(1);
}
form .wpcf7-list-item label input[type=checkbox] + .wpcf7-list-item-label {
  font-size: 14px;
  line-height: 24px;
}
@media only screen and (min-width: 1100px) {
  form .wpcf7-list-item label input[type=checkbox] + .wpcf7-list-item-label {
    font-size: 19px;
    line-height: 32px;
  }
}
form .wpcf7-submit {
  margin-top: 17px;
}
form label {
  display: flex;
  flex-wrap: wrap;
  font-size: 14px;
  line-height: 24px;
}
@media only screen and (min-width: 1100px) {
  form label {
    font-size: 19px;
    line-height: 32px;
  }
}
form label .wpcf7-form-control-wrap {
  width: 100%;
}
form label input[type=text],
form label input[type=email],
form label input[type=password],
form label input[type=tel],
form label input[type=search],
form label textarea,
form label input[type=date],
form label select {
  margin-top: 5px;
}
form .wpcf7-not-valid-tip {
  font-size: 14px;
  line-height: 24px;
}
@media only screen and (min-width: 1100px) {
  form .wpcf7-not-valid-tip {
    font-size: 19px;
    line-height: 32px;
  }
}
form .wpcf7-file {
  width: 100%;
  border: 1px solid #1a1a1a;
  border-radius: 2px;
  margin-top: 5px;
  padding: 12px;
}
form .wpcf7-file::-webkit-file-upload-button {
  visibility: hidden;
  width: 0;
}
form .wpcf7-file::before {
  content: "Datei hochladen";
  -webkit-user-select: none;
  color: #E2001A;
}
form .span.wpcf7-form-control-wrap.file-resume {
  color: #E2001A;
}
form .lb {
  display: inline-block;
  margin-bottom: 5px;
}
@media only screen and (min-width: 700px) {
  form .fields-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  form .fields-wrapper span.wpcf7-form-control-wrap[data-name=anrede] {
    margin-bottom: 25px;
  }
}
@media only screen and (max-width: 699px) {
  form .fields-wrapper {
    margin-bottom: 18px;
  }
}

#breadcrumbs {
  display: flex;
  flex-wrap: wrap;
}
#breadcrumbs a {
  text-decoration: none;
}
#breadcrumbs span {
  font-size: 14px;
  line-height: 24px;
  position: relative;
  padding-right: 10px;
}
@media only screen and (min-width: 1100px) {
  #breadcrumbs span {
    font-size: 19px;
    line-height: 32px;
  }
}
#breadcrumbs span .fa {
  position: absolute;
  font-size: 14px;
  top: 4px;
  right: 5px;
}
@media only screen and (max-width: 1099px) {
  #breadcrumbs span .fa {
    font-size: 12px;
    top: 1px;
  }
}

#skip-button {
  transform: translateY(-101%);
  transition: transform 0.3s;
  position: absolute;
  z-index: 13;
  border-radius: 0 0 8px 0;
  outline: none;
}

#skip-button:focus {
  transform: translateY(0%);
}

body {
  color: #1a1a1a;
}

.main-container {
  margin-bottom: 80px;
}
@media only screen and (min-width: 1100px) {
  .main-container {
    margin-bottom: 9.6875rem;
  }
}
@media only screen and (min-width: 1700px) {
  .main-container {
    margin-bottom: 100;
  }
}

h1 {
  margin: 0 0 15px 0;
}
@media only screen and (min-width: 1100px) {
  h1 {
    margin: 0 0 20px 0;
  }
}

h2, .h2 {
  margin: 0 0 15px 0;
}
@media only screen and (min-width: 1100px) {
  h2, .h2 {
    margin: 0 0 25px 0;
  }
}
h2:has(+ div:not(.page-excerpt)), .h2:has(+ div:not(.page-excerpt)) {
  margin: 0 0 20px 0;
}
@media only screen and (min-width: 1100px) {
  h2:has(+ div:not(.page-excerpt)), .h2:has(+ div:not(.page-excerpt)) {
    margin: 0 0 45px 0;
  }
}

h3, .h3, h4, .h4 {
  margin: 0 0 10px 0;
}
@media only screen and (min-width: 1100px) {
  h3, .h3, h4, .h4 {
    margin: 0 0 12px 0;
  }
}
h3:has(+ div:not(.page-excerpt)), .h3:has(+ div:not(.page-excerpt)), h4:has(+ div:not(.page-excerpt)), .h4:has(+ div:not(.page-excerpt)) {
  margin: 0 0 15px 0;
}
@media only screen and (min-width: 1100px) {
  h3:has(+ div:not(.page-excerpt)), .h3:has(+ div:not(.page-excerpt)), h4:has(+ div:not(.page-excerpt)), .h4:has(+ div:not(.page-excerpt)) {
    margin: 0 0 20px 0;
  }
}

h1, h2 {
  -webkit-hyphens: auto;
          hyphens: auto;
  overflow-wrap: anywhere;
  word-break: auto-phrase;
}

p, .widget {
  margin: 0 0 20px 0;
}
@media only screen and (min-width: 1100px) {
  p, .widget {
    margin: 0 0 25px 0;
  }
}

a, a:visited, a:focus {
  color: #E2001A;
  text-decoration: none;
  font-weight: 400;
}
a:hover, a:visited:hover, a:focus:hover {
  color: #E2001A;
  text-decoration: underline;
}

b, strong {
  font-weight: 500;
}

video {
  width: 100%;
  display: block;
  height: auto;
}

/* removes tap blinking on ios devices */
* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

#site-header {
  width: 100%;
  height: 80px;
}
@media only screen and (max-width: 1099px) {
  #site-header {
    height: 60px;
  }
}
#site-header #site-logo {
  position: absolute;
  top: 0;
  left: 3.75rem;
  z-index: 11;
}
@media only screen and (max-width: 1099px) {
  #site-header #site-logo {
    left: 20px;
  }
}
#site-header #site-logo img {
  display: block;
  width: auto;
  height: 80px;
}
@media only screen and (max-width: 1099px) {
  #site-header #site-logo img {
    height: 60px;
  }
}

.main-nav-toggle {
  z-index: 13;
  background-color: #E2001A;
  position: fixed;
  right: 0;
  top: 0;
  padding: 0;
  height: 80px;
  width: 180px;
  border: none;
  border-radius: 0;
  color: white;
}
@media only screen and (min-width: 1100px) {
  .main-nav-toggle {
    display: flex;
    align-items: center;
    padding-left: 2.1875rem;
  }
}
@media only screen and (max-width: 1099px) {
  .main-nav-toggle {
    width: 60px;
    height: 60px;
    padding-left: 0;
  }
  .main-nav-toggle .nav-text {
    display: none;
  }
}
.main-nav-toggle:hover {
  background-color: #ce0920;
}
.main-nav-toggle .nav-bars,
.main-nav-toggle .nav-bars::after {
  background-color: white;
  width: 40px;
  height: 4px;
  border-radius: 3px;
  position: absolute;
  transition-property: transform;
  transition-duration: 0.1s;
  transition-timing-function: ease;
}
@media only screen and (max-width: 1099px) {
  .main-nav-toggle .nav-bars,
  .main-nav-toggle .nav-bars::after {
    width: 28px;
    height: 4px;
  }
}
.main-nav-toggle .nav-bars {
  display: block;
  top: calc(50% - 9px);
  right: 25px;
}
@media only screen and (max-width: 1099px) {
  .main-nav-toggle .nav-bars {
    right: calc(50% - 14px);
    top: calc(50% - 8px);
  }
}
.main-nav-toggle .nav-bars::after {
  content: "";
  display: block;
  top: 13px;
}
@media only screen and (max-width: 1099px) {
  .main-nav-toggle .nav-bars::after {
    top: 12px;
  }
}
.main-nav-toggle.is-active {
  background: transparent;
}
.main-nav-toggle.is-active .nav-bars {
  transform: translate3d(0, 5px, 0) rotate(45deg);
}
.main-nav-toggle.is-active .nav-bars::after {
  transform: translate3d(0, -13px, 0) rotate(-90deg);
}
@media only screen and (max-width: 1099px) {
  .main-nav-toggle.is-active .nav-bars::after {
    transform: translate3d(0, -12px, 0) rotate(-90deg);
  }
}
.main-nav-toggle.is-active .nav-text {
  display: none;
}

#site-navigation {
  position: fixed;
  right: 0;
  top: 0;
  height: 100vh;
  width: 0;
  background: #6f686d;
  z-index: 12;
  overflow-x: hidden;
  transition: 0.5s;
  scrollbar-color: #6f686d;
}
#site-navigation.active {
  width: 34.375rem;
}
@media only screen and (max-width: 1099px) {
  #site-navigation.active {
    width: 100%;
    max-width: 400px;
  }
}
#site-navigation .menu-main-container {
  padding: 40px 3.75rem 40px 3.75rem;
}
@media only screen and (max-width: 1099px) {
  #site-navigation .menu-main-container {
    padding: 30px;
    padding-top: 20px;
  }
}
#site-navigation .menu-main-container #primary-menu {
  padding: 0;
  margin: 0;
}
#site-navigation .menu-main-container #primary-menu li {
  list-style: none;
}
#site-navigation .menu-main-container #primary-menu li a {
  color: white;
  outline: none;
}
#site-navigation .menu-main-container #primary-menu li.menu-item-has-children {
  position: relative;
}
#site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu {
  display: none;
  margin: 0;
  padding: 0;
}
#site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu li a {
  letter-spacing: 0.05px;
  font-weight: 400;
  font-size: 16px;
  line-height: 26px;
}
@media only screen and (min-width: 1100px) {
  #site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu li a {
    font-size: 23px;
    line-height: 36px;
    letter-spacing: 0.07px;
  }
}
#site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu li a:hover {
  transition: transform 300ms;
  transform: translate3d(10px, 0, 0);
}
@media only screen and (max-width: 699px) {
  #site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu li a {
    font-size: 19px;
    line-height: 30px;
  }
}
@media only screen and (max-width: 699px) and (min-width: 1100px) {
  #site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu li a {
    font-size: 28px;
    line-height: 40px;
  }
}
#site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu li:not(:last-child) {
  margin-bottom: 3px;
}
@media only screen and (max-width: 699px) {
  #site-navigation .menu-main-container #primary-menu li.menu-item-has-children .sub-menu li:not(:last-child) {
    margin-bottom: 5px;
  }
}
#site-navigation .menu-main-container #primary-menu li.menu-item-has-children.sub-menu-opened .sub-menu {
  display: block;
}
#site-navigation .menu-main-container #primary-menu > li {
  margin-bottom: 15px;
  border-bottom: 2px solid white;
  padding-bottom: 19px;
}
@media only screen and (max-width: 1099px) {
  #site-navigation .menu-main-container #primary-menu > li {
    padding-bottom: 12px;
    margin-bottom: 12px;
  }
}
#site-navigation .menu-main-container #primary-menu > li:last-of-type {
  margin-bottom: 0;
}
#site-navigation .menu-main-container #primary-menu > li a {
  text-decoration: none;
  display: block;
  font-weight: 400;
  font-size: 23px;
  line-height: 32px;
  text-wrap: nowrap;
}
@media only screen and (min-width: 1100px) {
  #site-navigation .menu-main-container #primary-menu > li a {
    font-size: 26px;
    line-height: 38px;
  }
}
#site-navigation .menu-main-container #primary-menu > li:first-of-type {
  padding-bottom: 3.125rem;
}
@media only screen and (max-width: 1099px) {
  #site-navigation .menu-main-container #primary-menu > li:first-of-type {
    padding-bottom: 25px;
  }
}
#site-navigation .menu-main-container #primary-menu > li:first-of-type a {
  letter-spacing: 0.05px;
  font-weight: 400;
  font-size: 16px;
  line-height: 26px;
  font-weight: 400;
}
@media only screen and (min-width: 1100px) {
  #site-navigation .menu-main-container #primary-menu > li:first-of-type a {
    font-size: 23px;
    line-height: 36px;
    letter-spacing: 0.07px;
  }
}
@media only screen and (max-width: 1099px) {
  #site-navigation .menu-main-container #primary-menu > li:first-of-type a {
    font-size: 21px;
    line-height: 30px;
  }
}
#site-navigation .menu-main-container #primary-menu > li.menu-item-has-children .sub-menu {
  margin-top: 15px;
}
@media only screen and (max-width: 699px) {
  #site-navigation .menu-main-container #primary-menu > li.menu-item-has-children .sub-menu {
    margin-top: 20px;
  }
}
#site-navigation .menu-main-container #primary-menu > li.menu-item-has-children > a {
  position: relative;
}
#site-navigation .menu-main-container #primary-menu > li.menu-item-has-children > a:after {
  position: absolute;
  content: "";
  top: calc(50% - 5px);
  right: 0;
  transition: 0.01s;
  width: 18px;
  height: 10px;
  cursor: pointer;
  background-image: url(../img/dropdown.svg);
  background-repeat: no-repeat;
  background-size: contain;
}
@media only screen and (max-width: 1099px) {
  #site-navigation .menu-main-container #primary-menu > li.menu-item-has-children > a:after {
    width: 16px;
    height: 8px;
    top: calc(50% - 4px);
  }
}
@media only screen and (max-width: 699px) {
  #site-navigation .menu-main-container #primary-menu > li.menu-item-has-children > a:after {
    right: 0;
  }
}
#site-navigation .menu-main-container #primary-menu > li.menu-item-has-children.sub-menu-opened > a:after {
  transform: rotate(180deg);
  width: 20px;
  height: 11px;
}
@media only screen and (max-width: 1099px) {
  #site-navigation .menu-main-container #primary-menu > li.menu-item-has-children.sub-menu-opened > a:after {
    width: 18px;
    height: 9px;
  }
}
#site-navigation .nav-search {
  padding: 0 3.75rem;
  padding-bottom: 3.75rem;
}
@media only screen and (max-width: 1099px) {
  #site-navigation .nav-search {
    padding: 20px 30px;
  }
}
#site-navigation::-webkit-scrollbar {
  width: 1px;
}
#site-navigation::-webkit-scrollbar-track, #site-navigation::-webkit-scrollbar-thumb, #site-navigation::-webkit-scrollbar-thumb:hover {
  background: #6f686d;
}
#site-navigation::-webkit-scrollbar-button {
  display: none;
}

#page-topbar {
  margin-bottom: 50px;
}
@media only screen and (min-width: 1100px) {
  #page-topbar {
    margin-bottom: 4.6875rem;
  }
}
@media only screen and (max-width: 1099px) {
  #page-topbar .page-intro {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media only screen and (max-width: 699px) {
  #page-topbar .page-intro {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media only screen and (min-width: 1100px) {
  #page-topbar .page-intro {
    padding-left: 18.75rem;
    padding-right: 18.75rem;
  }
}
#page-topbar.slim, #page-topbar.wide {
  padding-top: 7.5rem;
  border-top: 1px solid #E2001A;
}
@media only screen and (max-width: 1099px) {
  #page-topbar.slim, #page-topbar.wide {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media only screen and (max-width: 699px) {
  #page-topbar.slim, #page-topbar.wide {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media only screen and (min-width: 1100px) {
  #page-topbar.slim, #page-topbar.wide {
    padding-left: 18.75rem;
    padding-right: 18.75rem;
  }
}
#page-topbar.slim h1, #page-topbar.wide h1 {
  margin: 0 0 20px 0;
}
@media only screen and (max-width: 1099px) {
  #page-topbar.slim, #page-topbar.wide {
    padding-top: 40px;
    margin-bottom: 40px;
  }
  #page-topbar.slim h1, #page-topbar.wide h1 {
    margin-bottom: 15px;
  }
}
#page-topbar.slim .page-intro, #page-topbar.wide .page-intro {
  padding: 0;
}
@media only screen and (max-width: 1099px) {
  #page-topbar.wide {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media only screen and (max-width: 699px) {
  #page-topbar.wide {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media only screen and (min-width: 1100px) {
  #page-topbar.wide {
    padding-left: 7.5rem;
    padding-right: 7.5rem;
  }
}
#page-topbar .main-img-wrapper {
  margin-bottom: 25px;
}
#page-topbar .main-img-wrapper .main-img img {
  display: block;
  width: 100%;
}
#page-topbar .main-img-wrapper .desktop-img.resp {
  overflow: hidden;
}
#page-topbar .page-excerpt {
  font-weight: 400;
  letter-spacing: 0;
}
#page-topbar .page-excerpt p {
  margin: 0;
}
#page-topbar .mobile-img {
  display: none;
}
@media only screen and (max-width: 1099px) {
  #page-topbar .mobile-img {
    display: block;
  }
  #page-topbar .desktop-img {
    display: none;
  }
}

@media only screen and (max-width: 1099px) {
  .home #page-topbar .page-intro {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media only screen and (max-width: 699px) {
  .home #page-topbar .page-intro {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media only screen and (min-width: 1100px) {
  .home #page-topbar .page-intro {
    padding-left: 18.75rem;
    padding-right: 18.75rem;
  }
}
.home #page-topbar h1 {
  color: #E2001A;
}

#single-post #page-topbar .single-page-image {
  margin-bottom: 40px;
}
@media only screen and (min-width: 1100px) {
  #single-post #page-topbar .single-page-image {
    margin-bottom: 4.0625rem;
  }
}
#single-post.offline .page-excerpt {
  display: none;
}

.cookies-container {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  color: white;
  font-size: 14px;
  line-height: 24px;
  padding: 15px 7.5rem;
  align-items: center;
  justify-content: space-between;
  z-index: 2;
}
@media only screen and (min-width: 1100px) {
  .cookies-container {
    font-size: 19px;
    line-height: 32px;
  }
}
.cookies-container .cookies-buttons {
  display: flex;
}
.cookies-container .cookies-buttons .button-primary-sm {
  margin-left: 10px;
}
@media only screen and (max-width: 699px) {
  .cookies-container {
    flex-wrap: wrap;
  }
  .cookies-container > div {
    width: 100%;
  }
  .cookies-container > div:first-child {
    margin-bottom: 15px;
  }
  .cookies-container .cookies-buttons .button-primary-sm:first-child {
    margin-left: 0;
  }
}
.cookies-container::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background-color: #3E3E3E;
  z-index: 0;
  opacity: 0.9;
  z-index: -1;
}

footer {
  background-color: #6f686d;
  color: white;
  font-size: 14px;
  line-height: 24px;
  padding-top: 3.125rem;
}
@media only screen and (min-width: 1100px) {
  footer {
    font-size: 19px;
    line-height: 32px;
  }
}
@media only screen and (max-width: 699px) {
  footer {
    padding-top: 20px;
  }
}
footer a, footer a:hover, footer a:visited {
  color: white;
  text-decoration: underline;
}
footer a:hover, footer a:hover:hover, footer a:visited:hover {
  color: #E2001A;
}
footer p {
  margin-bottom: 0;
}
footer .footer-top-block {
  padding-bottom: 1.875rem;
  border-bottom: 1px solid white;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
@media only screen and (max-width: 1099px) {
  footer .footer-top-block {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media only screen and (max-width: 699px) {
  footer .footer-top-block {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media only screen and (min-width: 1100px) {
  footer .footer-top-block {
    padding-left: 7.5rem;
    padding-right: 7.5rem;
  }
}
@media only screen and (max-width: 1099px) {
  footer .footer-top-block {
    padding-bottom: 30px;
  }
}
@media only screen and (max-width: 699px) {
  footer .footer-top-block {
    grid-template-columns: 1fr;
  }
  footer .footer-top-block .widgets-wrapper {
    margin-bottom: 30px;
  }
}
footer .footer-top-block figure {
  margin: 0;
}
footer .footer-top-block #location-dropdown {
  width: 100%;
  background-color: white;
  margin-bottom: 20px;
  padding: 5px;
  border-radius: 2px;
}
footer .footer-top-block #location-dropdown option {
  color: #1a1a1a;
}
footer .footer-top-block .wp-social-link {
  border-radius: unset;
}
footer .footer-top-block .wp-social-link a {
  width: 40px;
  height: 40px;
}
footer .footer-top-block .wp-social-link svg {
  display: none;
}
footer .footer-top-block .wp-social-link.wp-social-link-youtube {
  background: url(../img/youtube.png) no-repeat;
  background-size: contain;
}
footer .footer-top-block .wp-social-link.wp-social-link-linkedin {
  background: url(../img/linkedin.png) no-repeat;
  background-size: contain;
}
footer .footer-top-block .wp-block-group {
  margin: 20px 0;
}
footer .footer-top-block .wp-block-group ul {
  margin: 0;
  margin-top: 10px;
}
footer .footer-bottom-block {
  padding: 30px 0;
}
@media only screen and (min-width: 1100px) {
  footer .footer-bottom-block {
    padding: 1.875rem 0;
  }
}
@media only screen and (max-width: 1099px) {
  footer .footer-bottom-block {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media only screen and (max-width: 699px) {
  footer .footer-bottom-block {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media only screen and (min-width: 1100px) {
  footer .footer-bottom-block {
    padding-left: 7.5rem;
    padding-right: 7.5rem;
  }
}
@media only screen and (min-width: 700px) {
  footer .footer-bottom-block {
    display: flex;
    align-items: center;
  }
}
@media only screen and (max-width: 1099px) {
  footer .footer-bottom-block {
    flex-wrap: wrap;
  }
}
@media only screen and (min-width: 700px) {
  footer .footer-bottom-block .menu-footer-container {
    margin-left: auto;
  }
}
@media only screen and (max-width: 699px) {
  footer .footer-bottom-block .menu-footer-container {
    margin-top: 10px;
  }
}
footer .footer-bottom-block .menu-footer-container #secondary-menu {
  margin: 0;
  padding: 0;
  display: flex;
}
footer .footer-bottom-block .menu-footer-container #secondary-menu li {
  list-style: none;
}
footer .footer-bottom-block .menu-footer-container #secondary-menu li a {
  padding-left: 30px;
}
@media only screen and (max-width: 699px) {
  footer .footer-bottom-block .menu-footer-container #secondary-menu li a {
    padding-left: 0;
    padding-right: 15px;
  }
}