@charset "UTF-8";
/*============= VARIABLES =============*/
/*$color-two: #bbcf00;*/
:root {
  --em-per-pixels: calc(1em / 16);
  --rem-per-pixels: calc(1rem / 16);
  --max-width-xl: 120rem;
  --max-width-l: 100rem;
  --max-width-m: 100rem;
  --max-width-s: 60rem;
  --max-width-xs: 40rem;
  --max-width-xxs: 30rem;
  --vert-whitespace: 5rem;
  --wide-whitespace: 5rem;
  --desktop-whitespace: 5rem;
  --laptop-whitespace: 5rem;
  --mobile-whitespace: 3.75rem;
  --desktop-width: 100rem;
  --laptop-width: 80rem;
  --tablet-width: 64rem;
  --portrait-width: 60rem;
  --mobile-width: 40rem;
  --gap-col: calc(var(--vert-whitespace) / 2);
  --gap-row: calc(var(--vert-whitespace) / 2);
  --gap-hdl: 1.5625rem;
  --gap-txt: 0.9375rem;
  --black: #1a1a18;
  --black-rgb: 26, 26, 24;
  --darkgrey: #333;
  --darkgrey-rgb: 51, 51, 51;
  --grey: #777;
  --grey-rgb: 119, 119, 119;
  --lightgrey: #efefef;
  --lightgrey-rgb: 239, 239, 239;
  --white: #fff;
  --white-rgb: 255, 255, 255;
  --blue: #1a70b8;
  --blue-rgb: 26, 112, 184;
  --green: #a4c74e;
  --green-rgb: 164, 199, 78;
  --color-bg: var(--white);
  --color-bg-rgb: var(--white-rgb);
  --color-txt: var(--grey);
  --color-txt-rgb: var(--grey-rgb);
  --color-one: var(--blue);
  --color-one-rgb: var(--blue-rgb);
  --color-one-light: #92bcdd;
  --color-one-light-rgb: 179, 217, 247;
  --color-two: var(--green);
  --color-two-rgb: var(--green-rgb);
  --color-two-light: #c3ea61;
  --color-two-light-rgb: 195, 234, 97;
  --color-two-dark: #82b30a;
  --color-two-dark-rgb: 130, 179, 10;
  --color-error: #e42343;
  --main-font: "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-serif: Garamond, Baskerville, "Baskerville Old Face", "Hoefler Text", "Times New Roman", serif;
  --font-regular: quicksand-regular;
  --font-bold: quicksand-bold;
  --font-running-text: opensans-regular;
  --font-running-text-bold: opensans-bold;
  --font-condensed: pathway;
  --font-serif: droidserif-italic;
  --font-serif-bold: droidserif-bolditalic;
  --font-script: arsilon;
  --font-size-xl: 2.8125rem;
  --line-height-xl: 3.4375rem;
  --font-size-l: 2.5rem;
  --line-height-l: 3.125rem;
  --font-size-m: 1.875rem;
  --line-height-m: 2.5rem;
  --font-size-s: 1.375rem;
  --line-height-s: 2rem;
  --font-size-xs: 1rem;
  --line-height-xs: 1.625rem;
  --font-size-xxs: 0.875rem;
  --line-height-xxs: 1.5rem;
  --nav-font-size: 1.125rem;
  --nav-line-height: 2rem;
  --border-radius-min: 0.3125rem;
  --border-radius-std: 0.625rem;
  --border-radius-mid: 1.25rem;
  --border-radius-min: calc(5 * var(--rem-per-pixels));
  --border-radius-std: calc(10 * var(--rem-per-pixels));
  --border-radius-mid: calc(20 * var(--rem-per-pixels));
  --period-one: 500ms;
  --period-two: 750ms;
  --period-three: 1000ms;
  --cubic-bezier: cubic-bezier(0.165, 0.84, 0.44, 1);
  --text-shadow: 1px 3px 8px rgba(0, 0, 0, 0.5);
  --nav-height: calc(120 * var(--rem-per-pixels)); }

@media only screen and (max-width: 100rem) {
  :root {
    --vert-whitespace: var(--desktop-whitespace);
    --font-size-xl: 2.5rem;
    --line-height-xl: 3.125rem;
    --font-size-l: 2.1875rem;
    --line-height-l: 2.8125rem;
    --font-size-m: 1.5625rem;
    --line-height-m: 2.1875rem; } }

@media only screen and (max-width: 90rem) {
  :root {
    --nav-height: 80px; } }

@media only screen and (max-width: 80rem) {
  :root {
    --vert-whitespace: var(--laptop-whitespace); } }

@media only screen and (max-width: 80rem) {
  :root {
    --vert-whitespace: var(--laptop-whitespace);
    --font-size-xl: 2.125rem;
    --line-height-xl: 2.75rem;
    --font-size-l: 1.75rem;
    --line-height-l: 2.375rem;
    --font-size-m: 1.5rem;
    --line-height-m: 2.125rem; } }

@media only screen and (max-width: 60rem) {
  :root {
    --vert-whitespace: var(--mobile-whitespace);
    --gap-col: 5%; } }

@media only screen and (max-width: 40rem) {
  --gap-hdl: var(--gap-txt);
  --font-size-xl: 1.5rem;
  --line-height-xl: 2.125rem;
  --font-size-l: 1.375rem;
  --line-height-l: 2rem;
  --font-size-m: 1.25rem;
  --line-height-m: 1.875rem;
  --font-size-s: 1.125rem;
  --line-height-s: 1.625rem;
  --font-size-xs: 0.875rem;
  --line-height-xs: 1.5rem;
  --nav-font-size: 0.875rem;
  --nav-line-height: 1.25rem; }

@keyframes ani-width {
  0% {
    width: 0; }
  100% {
    width: 100%; } }

@keyframes ani-bar {
  0% {
    transform: translate3d(-100%, 0, 0); }
  100% {
    transform: translate3d(0, 0, 0); } }

@keyframes scale-pulse {
  0% {
    transform: scale(1);
    opacity: 1; }
  100% {
    transform: scale(1.5);
    opacity: 0; } }

/*==================== FONTS ====================*/
@font-face {
  font-family: "quicksand-regular";
  src: url("../fonts/quicksand/Quicksand-Regular.woff2") format("woff2"), url("../fonts/quicksand/Quicksand-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: "quicksand-bold";
  src: url("../fonts/quicksand/Quicksand-Bold.woff2") format("woff2"), url("../fonts/quicksand/Quicksand-Bold.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: "opensans-regular";
  src: url("../fonts/opensans/opensans.woff2") format("woff2"), url("../fonts/opensans/opensans.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: "opensans-italic";
  src: url("../fonts/opensans/opensans-italic.woff2") format("woff2"), url("../fonts/opensans/opensans-italic.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: "opensans-bold";
  src: url("../fonts/opensans/opensans-bold.woff2") format("woff2"), url("../fonts/opensans/opensans-bold.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: "opensans-bolditalic";
  src: url("../fonts/opensans/opensans-bolditalic.woff2") format("woff2"), url("../fonts/opensans/opensans-bolditalic.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: "droidserif-italic";
  src: url("../fonts/droidserif/DroidSerif-Italic-webfont.woff") format("woff");
  font-style: normal;
  font-weight: 200; }

@font-face {
  font-family: "droidserif-bolditalic";
  src: url("../fonts/droidserif/DroidSerif-BoldItalic-webfont.woff") format("woff");
  font-style: normal;
  font-weight: 600; }

@font-face {
  font-family: "arsilon";
  src: url("../fonts/arsilon/arsilon.woff2") format("woff2"), url("../fonts/arsilon/arsilon.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

.blue-text {
  color: #1a70b8 !important; }

.green-text {
  color: #a4c74e !important; }

.txt-green {
  color: #a4c74e; }

.txt-blue {
  color: #1a70b8; }

.txt-black {
  color: #424242; }

.txt-grey {
  color: #777; }

.txt-lightgrey {
  color: #efefef; }

.txt-white {
  color: #fff; }

h1,
h2 {
  float: left;
  width: 100%;
  clear: both;
  margin-bottom: var(--gap-hdl); }

h3,
h4,
h5,
h6,
p,
figcaption,
blockquote,
address,
article li,
.teaser-info li,
.cat-title {
  float: left;
  width: 100%;
  clear: both;
  margin-bottom: var(--gap-txt); }

article .column p + :is(h1, h2, h3, h4, h5, h6, ul, ol),
ul + :is(h1, h2, h3, h4, h5, h6),
ol + :is(h1, h2, h3, h4, h5, h6) {
  margin-top: var(--gap-txt); }

h1,
h2,
h3 {
  font-family: var(--font-regular);
  display: block; }

h1,
h2,
h3,
#main h1 *,
#main h2 *,
#main h3 * {
  color: #1a70b8; }

h1 strong,
h2 strong,
h3 strong,
h4 strong,
h5 strong,
h6 strong {
  font-family: var(--font-bold);
  font-weight: 800; }

h1 q,
h2 q,
h3 q,
h4 q,
h5 q,
h6 q {
  font-size: inherit;
  letter-spacing: normal; }

h1,
#pageheader h2 {
  font-size: 2.8125rem;
  line-height: 1.125em; }

h2,
.slide .caption h1,
.slide blockquote p {
  font-size: 2.1875rem;
  line-height: 1.125em; }

h3,
.toggle h2,
.headline p,
blockquote p {
  font-size: 1.875rem;
  line-height: 1.25em; }

.teaserboards header h3,
.teaser-title h3,
h4,
h5,
h6,
.title p {
  font-size: 1.375rem;
  line-height: 1.125em; }

p,
figcaption,
article li,
.teaser-info li {
  font-family: var(--font-running-text), Arial, "Helvetica Neue", Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1.5em; }

figcaption strong,
article ul li strong,
p strong {
  font-family: var(--font-running-text-bold); }

article a,
.caption p a,
.hint-win a,
form a {
  position: relative;
  display: inline-block;
  color: #777;
  text-decoration: none;
  outline: none;
  -webkit-appearance: none !important;
  -moz-appearance: none; }

article a,
.caption p a,
.hint-win a {
  text-decoration: underline; }

h1 a:after,
h2 a:after,
h3 a:after {
  content: none; }

article .button a::after {
  content: none; }

.caption h2 a,
.caption h3 a {
  text-decoration: underline; }

b,
strong,
p b,
p strong {
  font-weight: 600; }

blockquote *,
cite,
cite *,
em,
em *,
.serif,
.serif *,
#main .slide a.caption-wrapper .wrapper-s * {
  margin-bottom: 0;
  font-family: droidserif-italic, Garamond, Baskerville, "Baskerville Old Face", "Hoefler Text", "Times New Roman", serif; }

blockquote {
  position: relative;
  width: 100%;
  clear: both;
  width: 100%;
  display: block; }

.column blockquote {
  float: left; }

blockquote *,
cite,
cite * {
  margin-bottom: 0;
  font-family: var(--font-script), Garamond, Baskerville, "Baskerville Old Face", "Hoefler Text", "Times New Roman", serif; }

blockquote strong {
  font-family: droidserif-bolditalic;
  font-weight: 600; }

blockquote span *:first-child:before,
blockquote span *:last-child:after,
blockquote strong *:first-child:before,
blockquote strong *:last-child:after,
blockquote p *:first-child:before,
blockquote p *:last-child:after,
blockquote a:first-child:before,
blockquote a:last-child:after {
  content: none; }

.herotext {
  font-size: 1.5rem !important;
  line-height: 1.25em !important; }

.erw blockquote,
.erw blockquote * {
  color: #1a70b8; }

.kin blockquote,
.kin blockquote * {
  color: #a4c74e; }

.serif,
.serif * {
  font-family: var(--font-serif); }

.handwriting,
.handwriting * {
  font-family: var(--font-script);
  font-weight: 100; }

h3 .handwriting {
  font-size: 1.5rem;
  line-height: 1.375em; }

address {
  display: block; }

#main .slide a.caption-wrapper .wrapper-s * {
  font-size: 3.2vh;
  text-align: center; }

@media only screen and (max-width: 1600px) {
  h1,
  #pageheader h2,
  .slide .caption h2 {
    font-size: 2.5rem;
    line-height: 1.125em; }
  h2,
  .slide blockquote p {
    font-size: 1.875rem;
    line-height: 1.125em; }
  h3,
  .toggle h2,
  .headline p {
    font-size: 1.5rem;
    line-height: 1.25em; }
  h4,
  h5,
  h6,
  .teaserlist .teaser-item.vacancy header h4 {
    font-size: 1.125rem;
    line-height: 1.25em; } }

@media only screen and (max-width: 1152px) {
  h1,
  #pageheader h2,
  .slide .caption h2 {
    font-size: 1.875rem;
    line-height: 1.125em; }
  h2,
  .slide blockquote p {
    font-size: 1.625rem;
    line-height: 1.125em; }
  h3,
  .toggle h2,
  .headline p,
  .title p,
  blockquote p,
  h4,
  h5,
  h6 {
    font-size: 1.375rem;
    line-height: 1.25em; }
  p,
  article li,
  .teaser-info li {
    font-size: 1rem;
    line-height: 1.375em; } }

@media only screen and (max-width: 40rem) {
  h1,
  #pageheader h2,
  .slide .caption h2 {
    font-size: 1.875rem;
    line-height: 1.125em; }
  h2,
  blockquote h1 {
    font-size: 1.5rem;
    line-height: 1.125em; }
  h3,
  .toggle h2,
  .headline p,
  .title p,
  blockquote p,
  h4,
  h5,
  h6 {
    font-size: 1.25rem;
    line-height: 1.25em; }
  p,
  article li,
  .teaser-info li {
    font-size: 1rem;
    line-height: 1.375em; }
  .herotext {
    font-size: 1rem !important;
    line-height: 1.375em !important; } }

@media only screen and (max-width: 480px) {
  h1,
  #pageheader h2,
  .slide .caption h2 {
    font-size: 1.5rem;
    line-height: 1.125em; }
  h2 {
    font-size: 1.25rem;
    line-height: 1.125em; }
  h3,
  .toggle h2,
  .headline p,
  .title p,
  h4,
  h5,
  h6 {
    font-size: 1.125rem;
    line-height: 1.25em; }
  p,
  article li,
  .teaser-info li,
  blockquote p {
    font-size: 0.875rem;
    line-height: 1.375em; }
  .herotext {
    font-size: 0.875rem !important;
    line-height: 1.375em !important; } }

@font-face {
  font-family: "superduperfont";
  src: url("../fonts/superduperfont/superduperfont.eot?g0uw8c");
  src: url("../fonts/superduperfont/superduperfont.eot?g0uw8c#iefix") format("embedded-opentype"), url("../fonts/superduperfont/superduperfont.ttf?g0uw8c") format("truetype"), url("../fonts/superduperfont/superduperfont.woff?g0uw8c") format("woff"), url("../fonts/superduperfont/superduperfont.svg?g0uw8c#superduperfont") format("svg");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: "font-awesome-5-free";
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url("../fonts/fontawesome/fa-regular-400.eot");
  src: url("../fonts/fontawesome/fa-regular-400.eot?#iefix") format("embedded-opentype"), url("../fonts/fontawesome/fa-regular-400.woff2") format("woff2"), url("../fonts/fontawesome/fa-regular-400.woff") format("woff"), url("../fonts/fontawesome/fa-regular-400.ttf") format("truetype"), url("../fonts/fontawesome/fa-regular-400.svg#fontawesome") format("svg"); }

.far:before,
time:before,
.author:before {
  display: inline-block;
  margin-right: 6px;
  font-family: "font-awesome-5-free";
  font-weight: 400; }

.author:before,
.fa-user:before {
  content: "\f007"; }

time:before,
.fa-calendar:before {
  content: "\f133"; }

.fa-calendar-alt:before {
  content: "\f073"; }

/**
 * FormBuilder Basic Framework
 *
 * This SCSS file is meant to be a starting point for your own form styling 
 * 
 */
.InputfieldColumnWidthsInit,
.pw-content.content {
  margin: 0 !important;
  padding: 0 !important; }

.FormBuilder,
.FormBuilder input,
.FormBuilder textarea,
.FormBuilder select,
.FormBuilder button,
.FormBuilder .ui-widget {
  box-sizing: border-box;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  font-size: 16px;
  line-height: 1.5em; }

.FormBuilder .alert {
  padding: 10px var(--gap-hdl); }

.FormBuilder .alert-error {
  background: red;
  color: #fff; }

.FormBuilder .alert-success {
  background: var(--blue);
  color: #fff; }

.FormBuilder.InputfieldForm {
  padding: 0 !important;
  margin: 0 !important; }

@media only screen and (max-width: 40rem) {
  .FormBuilder.InputfieldForm,
  .FormBuilder.InputfieldForm *::before,
  .FormBuilder.InputfieldForm *::after {
    --gap-hdl: 0.625rem; } }

.FormBuilder.InputfieldForm input:not([type="radio"]):not([type="checkbox"]):not([type="file"]):not([type="range"]),
.FormBuilder.InputfieldForm select:not([multiple]) {
  margin: 0;
  box-sizing: border-box;
  height: 40px;
  max-width: 100%;
  width: 100%;
  padding: 0 10px;
  vertical-align: middle;
  display: inline-block; }

.FormBuilder.InputfieldForm input:not([type="radio"]):not([type="checkbox"]):not([type="file"]):not([type="range"]):focus,
.FormBuilder.InputfieldForm select:not([multiple]):focus {
  background: white; }

.FormBuilder.InputfieldForm select[multiple],
.FormBuilder.InputfieldForm textarea {
  padding: 5px 10px; }

.FormBuilder.InputfieldForm select[multiple]:focus,
.FormBuilder.InputfieldForm textarea:focus {
  background: white; }

.FormBuilder.InputfieldForm select:not([multiple]):not([size]) {
  -webkit-appearance: none;
  appearance: none;
  padding-right: 40px;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg%20width%3D%2224%22%20height%3D%2216%22%20viewBox%3D%220%200%2024%2016%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%0A%20%20%20%20%3Cpolygon%20fill%3D%22%23666%22%20points%3D%2212%201%209%206%2015%206%22%20%2F%3E%0A%20%20%20%20%3Cpolygon%20fill%3D%22%23666%22%20points%3D%2212%2013%209%208%2015%208%22%20%2F%3E%0A%3C%2Fsvg%3E%0A");
  background-repeat: no-repeat;
  background-position: 100% 50%; }

.FormBuilder.InputfieldForm select:not([multiple]):not([size])::-ms-expand {
  display: none; }

.FormBuilder.InputfieldForm select:not([multiple]):not([size]) option {
  color: #444; }

.FormBuilder.InputfieldForm input[type="file"] {
  line-height: 1; }

.FormBuilder.InputfieldForm .input-error {
  color: red;
  font-size: smaller; }

.FormBuilder.InputfieldForm .Inputfield {
  margin: 0 0 var(--gap-hdl) 0 !important; }

.FormBuilder.InputfieldForm .Inputfield .InputfieldHeader {
  display: block;
  font-weight: 600;
  padding-bottom: 0.25em; }

.FormBuilder.InputfieldForm .notes,
.FormBuilder.InputfieldForm .description {
  margin-bottom: 0.5em;
  margin-top: 0;
  opacity: 0.6; }

.FormBuilder.InputfieldForm .notes {
  font-size: smaller; }

.FormBuilder.InputfieldForm fieldset.InputfieldFieldset {
  padding: 0 !important;
  border: unset !important;
  background: transparent !important; }

.FormBuilder.InputfieldForm fieldset::before {
  background: unset !important; }

.FormBuilder.InputfieldForm fieldset.InputfieldFieldset legend {
  padding: var(--gap-txt) var(--gap-hdl);
  background-color: var(--lightgrey); }

.FormBuilder.InputfieldForm fieldset.InputfieldFieldset > legend + .InputfieldContent {
  margin: 0 !important;
  padding: 0 var(--gap-hdl) !important; }

.FormBuilder.InputfieldForm fieldset.InputfieldFieldset > .InputfieldContent > .description {
  margin: 0; }

.InputfieldFieldset > .InputfieldContent > p.notes {
  margin: 0; }

.FormBuilder.InputfieldForm .InputfieldFormBuilderFile {
  padding: 25px;
  padding-bottom: 12.5px;
  border: 1px solid #ddd;
  background: #fbfbfb; }

.FormBuilder.InputfieldForm .InputfieldFormBuilderForm {
  margin-bottom: 0; }

.FormBuilder.InputfieldForm .InputfieldFormBuilderForm > .InputfieldHeader:not(.InputfieldHeaderHidden) {
  margin-bottom: 10px; }

.FormBuilder.InputfieldForm .InputfieldFormBuilderForm > .InputfieldHeader:not(.InputfieldHeaderHidden) + .InputfieldContent label.InputfieldHeader {
  font-weight: normal; }

.FormBuilder.InputfieldForm fieldset.InputfieldFormBuilderForm {
  padding-top: 20px;
  margin: 20px 0;
  border-color: #eee;
  border-width: 1px; }

.FormBuilder.InputfieldForm fieldset.InputfieldFormBuilderForm legend {
  color: #777;
  font-weight: bold;
  text-transform: uppercase;
  padding: 0 5px; }

.FormBuilder.InputfieldForm .InputfieldFormBuilderForm + .InputfieldFormBuilderForm {
  padding-top: 20px; }

.FormBuilder.InputfieldForm .InputfieldFormBuilderPageBreak {
  margin-bottom: 20px; }

/*.FormBuilder.InputfieldForm .InputfieldCheckbox > .InputfieldContent,
.FormBuilder.InputfieldForm .InputfieldCheckboxes > .InputfieldContent,
.FormBuilder.InputfieldForm .InputfieldRadios > .InputfieldContent {
  padding-top: 5px;
}*/
.FormBuilder.InputfieldForm .InputfieldCheckbox .pw-no-select,
.FormBuilder.InputfieldForm .InputfieldCheckboxes .pw-no-select,
.FormBuilder.InputfieldForm .InputfieldRadios .pw-no-select {
  position: relative;
  top: 2px; }

.FormBuilder.InputfieldForm .InputfieldToggle .InputfieldToggleGroup label {
  height: 40px;
  line-height: 40px;
  padding-top: 0;
  padding-bottom: 0;
  vertical-align: middle; }

.FormBuilder.InputfieldForm .InputfieldStateRequired > .InputfieldHeader:first-child:after {
  color: red;
  content: "*"; }

.FormBuilder.InputfieldForm #wrap_Inputfield- {
  display: none; }

.InputfieldForm .InputfieldSubmit {
  padding: 0 var(--gap-hdl) !important; }

.FormBuilder.InputfieldForm .InputfieldSubmit button {
  font-weight: bold; }

.FormBuilder.InputfieldForm .InputfieldSubmit button:hover {
  opacity: 1; }

.FormBuilder.InputfieldForm .InputfieldColumnWidth > .InputfieldHeaderHidden::before {
  display: block;
  content: " "; }

.Inputfields > .Inputfield > .InputfieldContent:before,
.Inputfields > .Inputfield > .InputfieldContent:after,
.InputfieldForm:after,
.pw-clearfix:before,
.pw-clearfix:after {
  content: "";
  display: table;
  border-collapse: collapse; }

.Inputfields > .Inputfield > .InputfieldContent:after,
.InputfieldForm:after,
.pw-clearfix:after {
  clear: both; }

.pw-clearfix {
  min-height: 0; }

/*========= CUSTOM FORM STYLES =========*/
.FormBuilder,
.FormBuilder * {
  box-sizing: border-box; }

.FormBuilder,
.FormBuilder input,
.FormBuilder textarea,
.FormBuilder select,
.FormBuilder .ui-widget {
  font-family: var(--font-running-text); }

/*-------- FORM FIELDS --------*/
.Inputfield {
  position: relative;
  float: left;
  width: 50%;
  margin: 0 1.25% 15px 1.25%;
  display: block;
  clear: none; }

#wrap_Inputfield_qualifikation,
#wrap_Inputfield_message {
  width: 100%; }

label,
.InputfieldCheckbox .InputfieldContent label,
.InputfieldHeader,
.InputfieldContent {
  position: relative;
  float: left;
  width: 100%;
  height: auto;
  padding: 0;
  display: block; }

.InputfieldCheckbox label {
  display: flex !important;
  flex-flow: row nowrap;
  gap: 10px !important; }

.InputfieldHeader {
  height: auto;
  padding-bottom: 2px;
  font-family: var(--font-bold);
  font-size: var(--font-size-xs);
  line-height: 1.25em;
  font-weight: normal;
  color: var(--blue);
  text-align: left; }

.Inputfield_title,
.InputfieldCheckbox,
.InputfieldSubmit {
  width: 97.5% !important; }

.InputfieldSubmit button {
  border-radius: 22px; }

.InputfieldSubmit {
  margin-bottom: 0; }

.InputfieldContent {
  width: 100%;
  display: block; }

.FormBuilder .Inputfield .InputfieldContent,
.FormBuilder .Inputfield .InputfieldHeader {
  float: left !important; }

.Inputfield input[type="text"],
.Inputfield input[type="number"],
.Inputfield input[type="password"],
.Inputfield input[type="email"],
.Inputfield textarea,
.Inputfield select {
  width: 100%;
  padding: 0 10px;
  display: block;
  border: 1px solid var(--color-txt);
  color: var(--blue);
  background: transparent !important;
  outline: none;
  border-radius: var(--border-radius-min); }

.Inputfield textarea {
  padding: 10px; }

.FormBuilder.InputfieldForm .notes,
.FormBuilder.InputfieldForm .description {
  opacity: 1;
  padding-bottom: 0;
  margin-bottom: 0; }

.FormBuilder.InputfieldForm .InputfieldStateRequired > .InputfieldHeader:first-child:after {
  color: red;
  content: "*";
  margin-left: 2px; }

.InputfieldCheckboxes {
  margin: 20px 0 10px 0 !important; }

.InputfieldCheckboxes ul,
.InputfieldCheckboxes li,
.InputfieldCheckboxes label,
.InputfieldCheckboxes span {
  position: relative;
  float: left;
  width: 100%;
  display: block; }

.InputfieldCheckboxes li {
  margin-top: 10px; }

.InputfieldCheckboxes label {
  height: auto; }

.InputfieldCheckboxes span {
  padding-left: 30px;
  line-height: 20px; }

.InputfieldText {
  width: 50%; }

.InputfieldTextarea {
  width: 100%; }

.InputfieldMarkup {
  width: 100%; }

input[type="range"] {
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  -webkit-appearance: none;
  appearance: none;
  outline: none; }

input[type="range"]::-webkit-slider-thumb {
  padding: 0;
  border: none;
  background: transparent;
  -webkit-appearance: none;
  appearance: none;
  outline: none; }

input[type="range"],
input[type="range"]:focus {
  width: 100%;
  outline: none; }

input[type="range"]::-webkit-slider-runnable-track {
  width: 100%;
  height: 4px;
  display: block;
  background: var(--color-txt);
  border-radius: 2px;
  border: none;
  cursor: pointer; }

input[type="range"]::-moz-range-track {
  width: 100%;
  height: 4px;
  display: block;
  background: var(--color-txt);
  border-radius: 2px;
  border: none;
  cursor: pointer;
  appearance: none; }

input[type="range"]::-ms-track {
  width: 100%;
  height: 4px;
  display: block;
  background: var(--color-txt);
  border-radius: 2px;
  border: none;
  cursor: pointer; }

input[type="range"]:focus::-webkit-slider-runnable-track {
  background: var(--blue); }

input[type="range"]:focus::-moz-range-track {
  background: var(--blue); }

input[type="range"]:focus::-ms-track {
  background: var(--blue); }

input[type="range"]::-webkit-slider-thumb {
  width: 30px;
  height: 30px;
  margin-top: -13px;
  display: block;
  border-radius: 10px;
  background-color: #fff;
  border: 1px solid var(--color-txt);
  cursor: pointer; }

input[type="range"]::-moz-range-thumb {
  width: 30px;
  height: 30px;
  margin-top: -13px;
  display: block;
  border-radius: 10px;
  background-color: #fff;
  border: 1px solid var(--color-txt);
  cursor: pointer; }

input[type="range"]::-ms-thumb {
  width: 30px;
  height: 30px;
  margin-top: 0;
  display: block;
  border-radius: 10px;
  background-color: #fff;
  border: 1px solid var(--color-txt);
  cursor: pointer; }

fieldset:nth-child(odd) input[type="range"]::-webkit-slider-thumb {
  background-color: #efefef; }

fieldset:nth-child(odd) input[type="range"]::-moz-range-thumb {
  background-color: #efefef; }

fieldset:nth-child(odd) input[type="range"]::-ms-thumb {
  background-color: #efefef; }

input[type="range"]:focus::-webkit-slider-thumb {
  border-color: var(--blue); }

input[type="range"]:focus::-moz-range-thumb {
  border-color: var(--blue); }

input[type="range"]:focus::-ms-thumb {
  border-color: var(--blue); }

.InputfieldCheckbox.InputfieldStateRequired > .InputfieldContent > label > span.pw-no-select:after {
  content: none; }

input[type="date"]::-webkit-calendar-picker-indicator {
  background-color: transparent; }

input[type="date"]::-moz-calendar-picker-indicator {
  background-color: transparent; }

input[type="date"]::-ms-calendar-picker-indicator {
  background-color: transparent; }

input[type="date"]::-webkit-clear-button {
  display: none; }

input[type="date"]::-moz-clear-button {
  display: none; }

input[type="date"]::-ms-clear-button {
  display: none; }

input[type="date"]::-webkit-inner-spin-button {
  display: none; }

input[type="date"]::-moz-inner-spin-button {
  display: none; }

input[type="date"]::-ms-inner-spin-button {
  display: none; }

input[type="number"] {
  max-width: 100px; }

input[type="number"]::-webkit-inner-spin-button {
  display: none; }

input[type="number"]::-moz-inner-spin-button {
  display: none; }

input[type="number"]::-ms-inner-spin-button {
  display: none; }

input:focus,
textarea:focus {
  color: var(--blue);
  border-color: var(--blue); }

/*---------- CHECKBOX ----------*/
input[type="checkbox"] {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 24px;
  min-width: 24px;
  height: 24px;
  padding: 0;
  margin: 0;
  color: var(--color-txt);
  border: 1px solid var(--color-txt);
  border-radius: 5px;
  cursor: pointer;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none; }

.InputfieldCheckbox input[type="checkbox"] {
  top: 7px !important;
  margin: 0; }

.InputfieldCheckbox .pw-no-select {
  padding-left: 0; }

input[type="checkbox"]::after {
  content: "";
  position: absolute;
  top: 0;
  left: -3px;
  width: 24px;
  height: 24px;
  font: 28px/24px superduperfont;
  text-align: center;
  font-weight: 700;
  color: var(--color-txt); }

input[type="checkbox"]:checked::after {
  color: var(--color-txt); }

input[type="checkbox"]:focus::after {
  color: var(--blue); }

input[type="checkbox"]:checked::after {
  content: ""; }

/*---------- SUBMIT MESSAGE ----------*/
.FormBuilderErrors,
.FormBuilder p.alert-success {
  width: 100%;
  height: auto;
  background-color: var(--blue);
  transition: all 350ms ease; }

.FormBuilderErrors p,
.FormBuilder p.alert-success {
  float: none;
  padding: 0 80px;
  max-width: 100rem;
  margin: 0 auto;
  display: block;
  font-family: var(--font-regular);
  font-size: 1.5rem;
  line-height: 28px;
  font-style: normal;
  color: #fff;
  background: transparent; }

.FormBuilder p.alert-success {
  max-width: none;
  padding-top: 15px;
  padding-bottom: 15px;
  text-align: center;
  background-color: var(--blue); }

@media only screen and (max-width: 1024px) {
  .FormBuilderErrors p,
  .FormBuilder p.alert-success {
    padding-left: 5%;
    padding-right: 5%; } }

select::-ms-expand {
  display: none; }

.InputfieldPage,
.InputfieldContent,
.InputfieldSelect {
  position: relative; }

.InputfieldPage,
.InputfieldSelect {
  float: left; }

.FormBuilder .InputfieldPage .InputfieldContent::after,
.FormBuilder .InputfieldSelect .InputfieldContent::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
  width: 40px;
  height: 40px;
  display: block;
  font: 24px/40px superduperfont;
  color: var(--color-txt);
  text-align: center;
  font-weight: 100;
  border-radius: 0 5px 5px 0;
  border-left: 1px solid var(--color-txt); }

.pw-no-select {
  top: auto;
  float: left;
  min-height: 25px;
  padding-left: 30px;
  color: var(--color-txt); }

.pw-no-select a {
  text-decoration: underline !important; }

select:focus::-ms-value {
  background-color: transparent; }

::-webkit-input-placeholder {
  color: var(--color-one); }

::-moz-placeholder {
  color: var(--color-one); }

:-ms-input-placeholder {
  color: var(--color-one); }

:-moz-placeholder {
  color: var(--color-one); }

form fieldset {
  float: left;
  width: 100%;
  padding-top: var(--gap-hdl);
  display: block;
  border: none;
  background-color: rgba(var(--lightgrey-rgb), 0.5); }

.InputfieldFieldset legend {
  float: left;
  width: 100%;
  margin-bottom: var(--gap-hdl);
  display: block;
  font-family: var(--font-bold);
  font-size: var(--font-size-l);
  line-height: var(--line-height-l);
  font-weight: 700;
  color: var(--blue);
  letter-spacing: 0.04em;
  text-align: center; }

label,
input,
textarea,
select {
  width: 100%;
  display: block;
  transition: all 350ms ease; }

label,
input,
textarea,
.InputfieldCheckboxes,
.InputfieldForm .description,
.InputfieldForm .notes {
  font-family: var(--font-regular); }

input,
textarea,
select {
  color: var(--color-txt) !important; }

input:focus,
textarea:focus,
select:focus,
.InputfieldSelect .InputfieldContent:focus::after {
  color: var(--blue) !important;
  border-color: var(--blue) !important; }

.Inputfield,
.InputfieldContent {
  width: 100%;
  display: block; }

.InputfieldCheckboxes ul li label {
  padding-left: 35px;
  white-space: normal; }

.InputfieldCheckboxes li input {
  position: relative;
  margin-left: -35px; }

label,
.InputfieldContent p {
  float: left;
  padding-bottom: 5px;
  display: block; }

label,
.InputfieldContent p,
.InputfieldContent a {
  margin: 0;
  font-size: var(--font-size-xs);
  letter-spacing: 0.04em;
  color: var(--blue); }

.InputfieldContent a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.125rem; }

.Inputfield .notes,
.Inputfield .description {
  opacity: 1; }

.InputfieldContent a::after {
  background-color: var(--blue); }

label .error {
  float: none;
  padding-left: 5px;
  display: inline-block;
  font-family: var(--font-bold); }

.InputfieldStateRequired > .InputfieldHeader:first-child:after,
.InputfieldStateRequired > .InputfieldHeader:first-child:after {
  color: var(--blue); }

label span {
  float: left;
  display: block; }

label strong {
  font-family: var(--font-bold);
  font-size: 1.125em; }

input,
textarea,
select {
  padding: 0 10px;
  font-size: 1.125em;
  letter-spacing: 0.04em;
  color: var(--color-txt);
  border: 1px solid var(--color-txt);
  background: transparent;
  outline: none;
  border-radius: 0; }

/*.InputfieldSelect .InputfieldContent,
.InputfieldSelect select { width: auto; }*/
.InputfieldSelect {
  width: 100%; }

.InputfieldPage select,
.InputfieldSelect select {
  width: 100%;
  padding-right: 50px; }

input,
select {
  height: 40px;
  line-height: 40px;
  letter-spacing: 0.04em; }

select {
  position: relative;
  z-index: 2;
  padding-right: 30px;
  display: block;
  background: transparent; }

select option {
  position: relative;
  z-index: 2; }

input[type="radio"],
input[type="checkbox"] {
  position: relative;
  z-index: 3;
  width: 24px;
  height: 24px;
  padding: 0; }

select,
option,
input[type="radio"],
input[type="checkbox"],
input[type="date"] {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none; }

input[type="checkbox"] {
  position: absolute;
  top: 5px;
  left: 0;
  float: left;
  width: 24px;
  height: 24px;
  padding: 0;
  margin: 0 10px 0 0;
  display: block; }

input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  font: 24px/24px superduperfont;
  display: block; }

input[type="date"] {
  max-width: 200px; }

input[type="date"]::-webkit-clear-button {
  display: none; }

input[type="date"]::-moz-clear-button {
  display: none; }

input[type="date"]::-ms-clear-button {
  display: none; }

input[type="date"]::-webkit-inner-spin-button {
  display: none; }

input[type="date"]::-moz-inner-spin-button {
  display: none; }

input[type="date"]::-ms-inner-spin-button {
  display: none; }

input[type="number"] {
  max-width: 100px; }

input[type="number"]::-webkit-inner-spin-button {
  display: none; }

input[type="number"]::-moz-inner-spin-button {
  display: none; }

input[type="number"]::-ms-inner-spin-button {
  display: none; }

textarea {
  padding-top: 10px;
  padding-bottom: 10px;
  line-height: 1.375em; }

input:focus,
textarea:focus {
  color: var(--blue);
  border-color: var(--blue); }

.field .info * {
  margin-bottom: 0; }

.error {
  /*float: right;*/
  display: inline-block;
  font-style: italic;
  color: #d83529; }

.form-fieldset .field {
  float: left;
  width: 50%;
  padding-bottom: 20px;
  display: block; }

.form-fieldset .field:nth-child(odd) {
  padding-right: 20px; }

.form-fieldset .field:nth-child(even) {
  padding-left: 20px; }

.form-fieldset button {
  margin-top: 10px; }

@media only screen and (max-width: 512px) {
  .Inputfields {
    width: 100%;
    margin-left: 0; }
  .Inputfield {
    width: 100%;
    margin: 0 0 15px 0;
    margin-left: 0; }
  form .Inputfield {
    width: 100% !important; }
  .InputfieldFormWidths .InputfieldColumnWidth > .InputfieldHeader,
  .InputfieldFormWidths .InputfieldColumnWidth > .InputfieldContent {
    padding: 0; } }

.FormBuilderErrors,
.FormBuilder p.success {
  width: 100%;
  height: auto;
  background-color: var(--blue);
  transition: all 350ms ease; }

.FormBuilderErrors p,
.FormBuilder p.success {
  float: none;
  padding: 0 var(--gap-hdl);
  max-width: unset;
  margin: 0 auto;
  display: block;
  font-family: var(--font-regular);
  font-size: var(--font-size-m);
  line-height: var(--line-height-m);
  /*text-align: center;*/
  font-style: normal;
  color: #fff;
  background: transparent; }

.FormBuilder p.success {
  max-width: none;
  padding: 15px 40px;
  text-align: center;
  background-color: var(--blue); }

.FormBuilder.InputfieldForm button {
  position: relative;
  height: 2.75rem;
  padding: 0 25px;
  display: inline-block;
  font-family: var(--font-bold);
  color: #fff !important;
  letter-spacing: 0.1em;
  font-size: 1.125rem;
  line-height: 2.75rem;
  text-transform: uppercase;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  overflow: hidden !important;
  outline: none;
  border: none;
  background-color: var(--blue);
  background-image: linear-gradient(to right, #1a70b8, #1a70b8 70%);
  /*background-image: linear-gradient(to right, rgba(var(--blue-rgb),1), rgba(var(--color-one-rgb),1) 70%);*/
  border-radius: 22px;
  overflow: hidden;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  backface-visibility: hidden; }

.InputfieldForm .InputfieldStateCollapsed {
  position: absolute;
  top: -2000px;
  left: -2000px;
  height: 0;
  overflow: hidden; }

@media (hover: hover) and (pointer: fine) {
  .FormBuilder.InputfieldForm button {
    filter: grayscale(1); }
  .FormBuilder.InputfieldForm button:hover {
    filter: grayscale(0); } }

@media only screen and (max-width: 720px) {
  .InputfieldFieldset legend {
    position: relative;
    z-index: 2; }
  form fieldset {
    position: relative;
    width: 100% !important;
    padding: 20px 0 0 0;
    background-color: transparent !important; }
  form fieldset::before {
    content: "";
    position: absolute;
    top: 0;
    left: -25%;
    width: 150%;
    height: 100%;
    display: block;
    background-color: var(--lightgrey) !important; }
  .Inputfields .InputfieldCheckboxes li {
    width: 100% !important; } }
