
:root {
    --color-red-o: rgba(167, 36, 48,.7);
    --color-red: rgb(167, 36, 48);
    --color-grey-o: rgba(90, 90, 90,.8);
    --color-grey: rgb(90, 90, 90);
    --color-lightgrey: rgb(234, 234, 234);
    --font: 'Source Sans 3', sans-serif;
}

html {

}

strong, b {
    font-weight: 600;
}

body {
    font-size: 16px;
    font-family: var(--font);
    font-weight: 400;
    min-height: 100%;
    line-height: 145%;
    color: #666666;
}

button, input, textarea {
    font-family: var(--font);
    font-weight: 400;
    font-size: 16px;
}

input::-webkit-input-placeholder { /* Chrome/Opera/Safari */
    color: #808080;
}
input::-moz-placeholder { /* Firefox 19+ */
    color: #808080;
}
input:-ms-input-placeholder { /* IE 10+ */
    color: #808080;
}
input:-moz-placeholder { /* Firefox 18- */
    color: #808080;
}

button {
    cursor: pointer;
}

a {
    color: inherit;
}

.w-100 {
    width: 100%;
}

/*h1[id]:before,
h2[id]:before,
h3[id]:before,
h4[id]:before,
h5[id]:before,
a[id]:before {
    display: block;
    content: " ";
    margin-top: -85px;
    height: 85px;
    visibility: hidden;
}*/

div.content a.fancybox {
    border: medium none;
}

a.document {
 line-height: 30px;
}
/*******************************************/
/* Fixed Buttons
/*******************************************/
.fixed_buttons {
    position: fixed;
    right: -110px;
    top: 30%;
    padding: 10px 0 5px 15px;
    background-color: var(--color-red);
    border-top-left-radius: 15px;
    border-bottom-left-radius: 15px;
    z-index: 999;
    color: #FFFFFF;
    text-transform: uppercase;
    -moz-transition: all 0.5s ease;
    transition: all 0.5s ease;
    display: flex;
    flex-basis: auto;
    flex-direction: column;
    flex-wrap: nowrap;
}
.fixed_buttons:hover {
    right: 0;
}

.fixed_buttons a {
    display: flex;
    flex-basis: auto;
    flex-direction: row;
    flex-wrap: nowrap;
    margin-bottom: 8px;
}
.fixed_buttons a i {
    display: inline-block;
    padding-right: 10px;
}
.fixed_buttons a span {
    display: inline-block;
    line-height: 22px;
    width: 100%;
    padding-right: 15px;
}
.fixed_buttons .glyphicons:before {
    padding: 0 2px 0 2px;
    font-size: 22px;
}

/*
a.download.pdf {
    border: medium none;
    display: block;
    padding: 10px 0 10px 50px;
    background-image: url(/styles/images/icons/pdf.svg);
    background-size: contain;
    background-position: left center;
    background-repeat: no-repeat;
}

a.download.pdf span{
    border-bottom: 2px dotted var(--color-red);
}
*/

h1, h2 {
    color: var(--color-red);
    margin-bottom: 30px;
    font-size: 28px;
    line-height: 130%;
    font-family: var(--font);
    font-weight: 600;
    position: relative;
}


h1 {
    margin-top: 50px;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
}
.title {

}
.title:after {
    content: "";
    display: block;
    width: 100px;
    height: 2px;
    background-color: var(--color-red);
    position: absolute;
    bottom: -2px;
    left: calc(50% - 50px);
}
.cart .title:after {
    display: none;
}
h1.shop {
    margin-top: 30px;
}

h2.team_divider {
    font-family: var(--font);
    font-size: 24px;
    font-weight: 600;
}

h2.shop-divider {
    font-size: 28px;
    border-bottom: 1px solid var(--color-red);
    margin-top: 1em;
}

h2.shop-divider + p.description {
    margin-top: -20px;
}

h5.prehead {
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 15px;
    font-family: var(--font);
}

h3 {
    font-weight: 600;
    color: var(--color-red);
    margin-bottom: 0.5em;
    font-size: 1.1em;
}

hr {
    border: none;
    border-top: 1px solid var(--color-red);
}

video {
    max-width: 100%;
}

button,
a.button {
    background-color: var(--color-red);
    color: white !important;
    display: inline-block;
    padding: 8px 50px;
    font-size: 16px;
    font-family: var(--font);
    font-weight: 600;
    position: relative;
    margin-top: 0.6em;
    border: none;
    margin-right: 15px;
    line-height: 100%;
    border-radius: 5px;
}

.preh1 {
    margin-top: 50px;
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.preh1 + h1 {
    margin-top: 0px;
}
/*
button:after,
a.button:after {
    position: absolute;
    display: inline-block;
    content:"";
    top: 0;
    right: -10px;
    width: 0;
    height: 0;
    border-top: 30px solid var(--color-red);
    border-right: 10px solid transparent;
}
 */

button span.glyphicons,
a.button span.glyphicons {

}

p {
    margin-bottom: 0.6em;
}

p.success-msg {
    font-size: 1.2em;
}


.body a,
a.underlined,
a.agb {
    color: var(--color-red);
    border-bottom: 2px dotted var(--color-red);
}

.story_body h3 a ,
.body h3 a {
    border-bottom: none;
}

.story_body ul ,
.body ul {
    margin-left: 1.5em;
    margin-bottom: 1em;
}

.story_body ul li ,
.body ul li {
    position: relative;
    display: block;
}

.story_body ul li:before ,
.body ul li:before {
    display: inline-block;
    content: '>';
    font-family: var(--font);
    color: var(--color-red);
    position: relative;
    margin-left: -20px;
    margin-right: 10px;
    font-size: 20px;
    vertical-align: -1px;
}
.story_gallery {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    flex-basis: auto;
    width: calc(100% + 30px);
    margin-left: -30px;
}
.story_gallery a {
    width: calc(100% - 30px);
    margin-left: 30px;
    margin-bottom: 30px;
}
.maps iframe{
    width: 100%;
    pointer-events: none;
    height: 350px;
}
div.responsive-video {
    position: relative;
    padding-bottom: 56.25%; /* Default for 1600x900 videos 16:9 ratio*/
    padding-top: 0px;
    height: 0;
    overflow: hidden;
    background-size: cover;

}

div.responsive-video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

div.content {
    position: relative;
    clear: both;
    width: 100%;
    padding: 0 20px;
}

section.divider {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
    height: 350px;
}

.flex {
    display: flex;
    flex-direction: column;
}

.half {
    margin-bottom: 2em;
    display: block;
    width: 100%;
}

.fourth {
    margin-bottom: 2em;
    display: block;
    width: 50%;
}

.body-context.body {
    padding-top: 35px;
}

div.product-price {
    border-top: 1px solid var(--color-red);
    float: right;
    width: 100%;
    position: relative;
}
div.product-price:last-child {
    border-bottom: 1px solid var(--color-red);
    margin-bottom: 30px;
}

div.product-price h3 {
    margin-top: 30px;
}
div.product-price span {
    display: block;
    float: left;
    margin: 13px 0;
    font-weight: 600;
    color: black;
    font-size: 18px;

}

div.product-price button {

}

img.product-image {
    float: left;
    margin: 0 30px 30px 0;
}

img.product-image.flavor {
    margin: 30px 30px 30px 0;
}
ul.product-categories {
    margin-left: 0;
    margin-bottom: 30px;
}
ul.product-categories li {
    display: inline-block;
}
ul.product-categories li:before {
    margin: 0 10px 0 0;
}
ul.product-categories li:first-of-type:before {
    content: "";
    margin: 0;
}
ul.product-categories li:before {
    content: ", ";
}
ul.wj-share-buttons  {
    margin-top: 10px;
}
ul.wj-share-buttons li {
    display: inline-block;
}
ul.wj-share-buttons li a {
    width: 32px;
    height: 32px;
}
ul.wj-share-buttons li:last-of-type a {
    margin-right: 0;
}

div.jobseeker .item {
    margin-bottom: 25px;
}

div.grid {
    display: flex;
    flex-flow: row wrap;
}

div.grid.shop {
    margin-left:-20px;
}

div.grid.shop figure img {
    display: block;
    width: 100%;
}
article .story_component .story_body.individual {
    width: 100%;
    margin-left: 0;
}
.individual .body {
    text-align: left;
}
.individual figure {
    position: relative;
    width: 100%;
    padding: 0;
    margin: 0;
    overflow: hidden;
    float: left;
    margin-bottom: 10px;
    border: 1px solid #dadada;
}
.individual figure img {
    display: block;
    width: 100%;
}
div.grid.shop .item {
    position: relative;
    display: block;
    font-size: 14px;
    margin-left: 20px;
    width: calc(50% - 20px);
    margin-bottom: 20px;
}

div.grid.shop.category .item  h3{
    padding: 10px 15px;
    background-color: var(--color-grey-o);
    color: #FFFFFF;
    position: absolute;
    bottom: 0;
    margin-bottom: 0;
    width: 100%;
}

div.grid .item.menuletter-form {
    width: 100%;
}

div.grid .item {
    margin-bottom: 2em;
    border-bottom: medium none;
}
div.grid.news .item {
    margin-top: 10px;
    margin-bottom: 0;
}
div.grid.news .item .button {
    margin-bottom: 20px;
}

div.grid.cooperation {
    align-items: stretch;
}

div.grid.cooperation .item {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    aspect-ratio: 450 / 300;
    margin-bottom: 35px;
}

div.grid.cooperation .item figure {
    border: none;
    transition: all 0.5s ease 0s;
    height: 100%;
    width: 100%;
}

div.grid.cooperation .item figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

div.grid.cooperation .item .text .icon-flip {
    display: none;
}

div.grid.cooperation .item .text {
    padding: 10px;
    background-color: #EFEEEF;
    border: 1px solid #BBBABB;
    text-align: center;
    position: relative;
}

div.grid.cooperation .item .text .coop-logo {
    width: 50%;
    margin: 8px auto 30px auto;
    transition: all 1s ease 0s;
    mix-blend-mode: multiply;
}

div.grid .item img {
    width: 100%;
    display: block;
}

div.grid.mini-shop {
    margin-top: 50px;
    margin-left: -10px;
}

div.grid.mini-shop-top {
    display: none;
}

div.grid.mini-shop .item {
    margin-bottom: 0;
    width: calc(33.33% - 10px);
    margin-left: 10px;
    border-bottom: 10px solid white;
}
div.grid.mini-shop-top .item img{
    border-bottom: 10px solid white;
}

div.grid.mini-shop .item.selected img {
    border-bottom: 10px solid var(--color-red);
}

div.grid.mini-shop .item h3 {
    font-weight: 400;
    font-size: 12px;
    line-height: 120%;
}

div.grid figure {
    position: relative;
    width: 100%;
    padding: 0;
    margin: 0;
    overflow: hidden;
    float: left;
    margin-bottom: 10px;
    border: 1px solid #dadada;
}
div.grid.shop figure {
    margin-bottom: 0;
}

div.grid figure .triangle {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 60px;
    border-bottom: 350px solid rgba(196, 41, 50, 0.8);
    border-left: 30px solid transparent;
    opacity: 0;
    transition: 0.5s;
}

.pattern-item {
    display: inline-block;
}

.pattern-choose {
    border: 3px solid transparent;
    position: relative;
    margin-right: 10px;
    margin-top: 10px;
    cursor: pointer;
    display: inline-block;
}

.pattern-choose.selected {
    border: 3px solid var(--color-red);
    position: relative;
}
.pattern-choose.selected:after {
    background-color: var(--color-red);
    color: #FFFFFF;
    content: "✓";
    position: absolute;
    right: -10px;
    bottom: -10px;
    border-radius: 50%;
    padding: 4px 5px 2px 5px;
    font-size: 22px;
}
.pattern-choose .product-image.pattern {
    margin: 0;
    display: block;
    width: 105px;
}

.pattern-name {
    font-size: 14px;
    line-height: 110%;
}

.pattern-no {
    font-size: 14px;
    line-height: 110%;
}

a.pattern-hires {
    position: absolute;
    right: 5px;
    top: 5px;
}

a.pattern-hires i {
    font-size: 16px;
    color: var(--color-red);
    background-color: #FFFFFF;
    border-radius: 50%;
    padding: 6px 0;
    width: 30px;
    height: 30px;
    text-align: center;
}

.product-price h3 span {
    display: inline;
    float: none;
}

.square {
    display: block;
    text-align: center;
    width: 90%;
    height: 90%;
    padding: 50px;
    margin: 5%;
    font-size: 16px;
    background-color: rgba(235, 235, 235, 1);
}

.square span.glyphicons {
    font-size: 30px;
    color: var(--color-red);
    margin-bottom: 5px;
}

.square strong {
    font-weight: 400;
}
.square a.button {
    margin-top: 10px;
}

.order_history .square {
    line-height: 32px;
    padding: 30px 0 10px 0;
}

.order_history .square a.button {
    margin: 10px 10px 10px 10px;
}

/*
div.grid div.item figure:hover .triangle {
    opacity: 1;
}

div.grid div.item.bistro figure:hover .triangle {
    opacity: 0;
}
*/

div.grid.team,
div.grid.team_new,
div.grid.glass_pattern {
    width: 100%;
    margin-left: -15px;
}

div.grid.team_anchors {
    width: 100%;
}


div.grid.team_anchors .item {
    width: calc(50% - 15px);
    margin-bottom: 0;
}

div.grid.glass_pattern .item {
    width: calc(33.33% - 15px);
    margin-left: 15px;
}

div.grid.team .item {
    width: calc(50% - 15px);
    margin-left: 15px;
}

div.grid.team_new .item {
    width: calc(50% - 15px);
    margin-left: 15px;
}

div.grid.team_new .item.full {
    width: calc(100% - 15px);
    margin-left: 15px;
}

div.grid.team_new .item h3 {
    margin-bottom: 0;
    font-size: initial;
}

.team_anchors ul {
    margin-left: 1.5em;
}

.team_anchors ul li {
    position: relative;
}

.team_anchors ul li:before {
    display: block;
    content: '>';
    var(--font)var(--font);
    color: var(--color-red);
    position: absolute;
    left: -20px;
    font-size: 20px;
    padding-top: 2px;
}

.team_anchors ul li a {
    color: var(--color-red);
    font-weight: 600;
}

div.grid figure span.icon {
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center;
    width: 150px;
    height: 75px;
    left: 0;
    bottom: 15px;
}

div.grid figure span.sold-out {
    background-color: var(--color-grey);
    border-top-left-radius: 100%;
    bottom: 0;
    color: #ffffff;
    display: block;
    font-size: 13px;
    font-weight: 400;
    height: 57px;
    line-height: 110%;
    padding-right: 6px;
    padding-top: 20px;
    position: absolute;
    right: 0;
    text-align: right;
    width: 90px;
}

div.grid figure span.price {
    background-color: rgba(196, 41, 50, 0.9);
    border-top-left-radius: 100%;
    bottom: 0;
    color: #ffffff;
    display: block;
    font-size: 13px;
    font-weight: 400;
    height: 57px;
    line-height: 110%;
    padding-right: 6px;
    padding-top: 20px;
    position: absolute;
    right: 0;
    text-align: right;
    width: 68px;
}

div.grid figure span.price.product {
    padding-top: 10px;
}

div.grid figure span.price strong {
    padding-top: 2px;
    font-size: 15px;
    display: block;
}

/*
div.grid figure span.icon.consol {
    background-image: url(/styles/images/logo-consol-sm.png);
}

div.grid figure span.icon.bistro {
    background-image: url(/styles/images/logo-consol-bistro.png);
}

div.grid figure span.icon.glas {
    background-image: url(/styles/images/logo-consol-glas.png);
}

div.grid figure span.icon.office {
    background-image: url(/styles/images/logo-consol-office.png);
}

div.grid figure span.icon.papier {
    background-image: url(/styles/images/logo-consol-papier.png);
}

div.grid figure span.icon.textil {
    background-image: url(/styles/images/logo-consol-textil.png);
}
*/

div.grid figure img {
    width: 100%;
    float: left;
}
div.grid.team_new a div.mailto,
div.grid.team a div.mailto {
    bottom: 8px;
    color: #ffffff;
    font-size: 20px;
    position: absolute;
    right: 10px;
}

div.grid.downloads .item{
    width:100%;
    margin-bottom: 1em;
}
div.menu {
    padding-bottom: 20px;
}

div.grid.day{
    margin-left: -15px;
    padding-top: 15px;
    flex-direction: column;
}

div.grid.day:first-of-type{
    border: none;
    padding-top: 0;
}
div.grid.day .item {
    width:100%;
    margin-left: 15px;
    margin-bottom: 0;
}

div.grid.boom {
    width: calc(100% + 30px);
    margin-left: -30px;
}

div.grid.boom .item {
    width: calc(100% - 30px);
    margin-left: 30px;
}
div.gallery {
    width: 100%;
    float: left;
    display: flex;
    flex-flow: row wrap;
    margin-bottom: 30px;
}


div.gallery a.fancybox {
    width: calc( 33.33% - 5px);
    margin-right: 5px;
}
div.gallery a.fancybox:first-child {
    width: calc( 100% - 5px);
}
div.gallery a.fancybox img {
    width:100%;
}
.content-image {
    margin: 0;
    width: calc(50% - 15px);
}
.content-image.left {
    margin: 0 30px 30px 0;
    float: left;
}
.content-image.right {
    margin: 0 0 30px 30px;
    float: right;
}

.story_body a.fancybox img{
    width: 100%;
    display: block;
}
.anchor-nav a{
    display: inline-block;
    position: relative;
    margin-left: 20px;
    margin-right: 10px;

}
.anchor-nav a:after {
    display: inline-block;
    content: '>';
    font-family: var(--font);
    color: var(--color-red);
    position: absolute;
    left: -15px;
    font-size: 20px;
    margin-top: 0px;
}
.anchor-nav a:hover {
    color: var(--color-red);
}

form.newsletter-subscribe {
    width: 100%;
}

form.add_to_cart {
    width: 100%;
    float:right;
    text-align: right;
}

p.sold-out {
    width: 100%;
    float:right;
    text-align: right;
    color: black;
    font-weight: bold;
}

span.validatormessage {
    color: var(--color-red);
    font-size: 12px;
    margin-top: -18px;
    display: block;
    font-weight: 400;
}

p.form-field-info-mini {
    color: var(--color-red);
    font-size: 12px;
    margin-top: -18px;
    display: block;
    font-weight: 400;
}

/* remove standard-styles */
input[type="file"]{
    display: none;
}
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    /* appearance: none; */
    border-radius: 0;
}

/* hide browser-styling (arrow) in IE10 */
select::-ms-expand {
    display:none;
}

.lt-ie10 select {
    background-image: none;
}

input,
textarea, select {
    font-family: var(--font);
    font-size: 16px;
    color: black;
    background-color: #d9d9d9;
    border: none;
    border-bottom: 2px solid var(--color-red);
    height: 35px;
    width: 100%;
    padding: 3px 10px;
    margin-bottom: 15px;
    /*  -webkit-box-shadow: inset 0 0 2px 0 rgba(213,213,213,0.6);
      -moz-box-shadow: inset 0 0 2px 0 rgba(213,213,213,0.6);
      box-shadow: inset 0 0 2px 0 rgba(213,213,213,0.6);*/
    text-align: center;
}
select {
    text-align-last: center;
}
input[type="file"] {
    background-color: transparent;
    border: none;
}
input[type="radio"] {
    position: relative;
    -webkit-appearance: none;
    appearance: none;
    background-color: #fff;
    margin: 0;
    font: inherit;
    color: rgba(0,0,0,0.5);
    width: 16px;
    height: 16px;
    border: 1px solid rgba(0,0,0,0.5);
    border-radius: 50%;
    padding: 0;
    vertical-align: -2px;
}
.radio-label {

}

input[type="radio"]::before {
    position: absolute;
    content: "";
    left: 2px;
    top: 2px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    transform: scale(0);
    transition: 120ms transform ease-in-out;
    background-color: var(--color-red);
}

input[type="radio"]:checked::before {
    transform: scale(1);
}

span.currency {
    display: inline-block;
    color: #FFFFFF;
    background-color: var(--color-red);
    font-weight: 600;
    height: 35px;
    line-height: 35px;
    vertical-align: -1px;
    padding: 0 6px;
}

form.orderform input, form.orderform textarea, form.orderform select {
    margin-bottom: 15px;
}

form label{
    width: 100%;
    float: left;
    margin-bottom: 5px;
}
form label.fileupload{
    margin-top: 15px;
    margin-bottom: 15px;
}
form#supportformular .support_purpose {
    margin-top: 0;
    margin-bottom: 30px;
    display: flex;
    flex-direction: column;
    flex-basis: auto;
    flex-wrap: nowrap;
}
form#supportformular .grid {
    width: 100%;
    margin-left: 0;
}

form#supportformular .support_purpose div.text {
    display: inline-block;
    margin-left: 0;
    width: 100%;
    text-align: center;
}

form#supportformular .support_purpose h3 {
    margin-bottom: 0.1em;
}

form#supportformular .support_purpose img {
    display: inline-block;
    width: 70%;
    margin-bottom: 0;
    margin-right: auto;
    margin-left: auto;
}/*
form#supportformular .support_purpose.selected img {
    border-bottom: 10px solid var(--color-red);
}
*/
form#supportformular input {
    width: 100%;
}

form#supportformular textarea {
    width: 100%;
    height: 190px;
}
form#supportformular .support_purpose i {
    margin-right: 4px;
    display: none;
}
form#supportformular .support_purpose.selected i {
    display: inline-block;
}

form#supportformular .support_purpose.selected a.button {
    background-color: rgb(66, 137, 14);
    border-bottom: none;
}
form#supportformular .support_purpose.selected a.button:after {
    border-top: 30px solid rgb(66, 137, 14);
}
form#supportformular .support_purpose a.button span:after {
    content: "Auswählen";
}
form#supportformular .support_purpose.selected a.button span:after {
    content: "Ausgewählt";
}


form label:first-of-type{
    margin-top: 0;
}
/*
form label#label_firstname {
    margin-top: 15px;
}*/

form#supportformular label#label_firstname {
    margin-top: 0;
}

form#supportformular .support-amount {
    display: flex;
    flex-direction: row;
    flex-basis: auto;
    flex-wrap: nowrap;
}
form#supportformular .support-amount div {
    width: calc(50% - 7.5px);
}
form#supportformular .support-amount div:first-of-type {
    margin-right: auto;
    margin-left: auto;
}

form#supportformular input#option_amount,
form#supportformular select#amount {
    width: calc(100% - 44px);
}
form#supportformular input#option_amount {
    margin-top: 0;
}
.invoice.grid,
form.grid {
    display: flex;
    flex-direction: row;
    flex-basis: auto;
    flex-wrap: wrap;
    width: calc(100% + 15px);
    margin-left: -15px;
}
.invoice .item.half,
form.grid .item.half {
    padding: 0;
    margin-left: 15px;
}

form.grid .item.half p {
    margin-left: 0;
}

form.grid .item.half .label{
    width: 100%;
}

form.grid .grid.w-100 {
    display: flex;
    flex-direction: row;
    flex-basis: auto;
    flex-wrap: wrap;
    width: calc(100% + 15px);
}
form.grid p {
    margin-left: 15px;
    width: calc(100% - 15px);
}
form.grid .button,
form.grid .checkbox.small {
    margin-left: 15px;
}
.payment_types {
    display: flex;
    flex-direction: row;
    flex-basis: auto;
    flex-wrap: wrap;
    width: calc(100% + 15px);
    margin-left: -15px;
}
form div.checkbox {
    float: left;
    margin-bottom: 15px;
    width: 100%;
}

form div.small {
    width: 100%;
    padding-top: 5px;
}

form input.error, form textarea.error {
    border: 1px solid #CC0000;
}

form input.checkbox-type {
    width: 60%;
}

form input[type="checkbox"] {
    margin-left: 0;
}

label.checkbox input {
    display: none;
}

label.checkbox span {
    border: 2px solid var(--color-red);
    display: inline-block;
    float: left;
    font-size: 22px;
    height: 18px;
    margin-right: 10px;
    margin-top: 2px;
    position: relative;
    width: 18px;
}

label.checkbox p {
    margin-left:15px;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
}

[type=checkbox]:checked + span:before {
    content: '\2714';
    position: absolute;
    color: var(--color-red);
    top: -5px;
    left: 1px;
}

[type=checkbox]:checked + label.checkbox span {
    border: 0.5px solid var(--color-red);
}

select.quantity{
    width: 60px;
    margin-right: 5px;
    margin-bottom: 15px;
}

::-webkit-input-placeholder { /* WebKit, Blink, Edge */
    color:    #333333;
}
:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
    color:    #333333;
    opacity:  1;
}
::-moz-placeholder { /* Mozilla Firefox 19+ */
    color:    #333333;
    opacity:  1;
}
:-ms-input-placeholder { /* Internet Explorer 10-11 */
    color:    #333333;
}

textarea {
    height: 120px;
    margin-bottom: 15px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="currency"]:focus,
input[type="number"]:focus,
input[type="text"]:focus,
textarea:focus,
select:focus {
    border: 1px solid var(--color-red);
}

input[type="text"]:first-of-type, select:first-of-type, input[type="number"] {
    margin-top: 0;
}

select {
    background: rgba(217, 217, 217, 1) url("/styles/images/select-arrow.png") no-repeat scroll right center / 23px auto;
}

select:focus {
    background: rgba(217, 217, 217, 1) url("/styles/images/select-arrow-active.png") no-repeat scroll right center / 23px auto;
}

select#country {
    background: rgba(217, 217, 217, 1);
}

label.required {
    font-weight: 600;
}

.missingalv {
    color: var(--color-red);
    font-weight: 600;
}

/*******************************************/
/* Header-Bereich
/*******************************************/


header {
    position: relative;
    width: 100%;
}
article header {
    height: unset;
    position: relative;
    text-align: center;
    background-color: transparent;
    z-index: 1;
}

header div.content {
    padding: 0 15px;
}

header #logo,
header #jubi,
header nav.main {
    display: none;
}
#scroll-header .jubi {
    width: 60px;
    display: inline-block;
    margin-left: 15px;
}

#scroll-header .jubi img,
header #jubi img {
    width: 100%;
    display: block;
}
.header-img {
    margin-top: 85px;
    height: 292px;
    background-size: cover;
    background-repeat: no-repeat;
}

.map-wrapper {
    margin-top: 140px;
}

main {
    margin-top: 0px;
}

article.single,
section {
    margin-bottom: 35px;
    display: flex;
    flex-direction: column;
    flex-basis: auto;
    flex-wrap: nowrap;
}

section.cart {
    background-color: var(--color-red);
    color: white;
    padding: 10px 0;
    text-align: center;
    margin-top: 0;
    margin-bottom: 15px;
}

section.cart a {
    font-weight: 600;
    color: white;
}

section.cart span.glyphicons:before{
    padding: 3px 8px;
}


section.invert {
    background-color: #595959;
    color: white;
    padding: 20px 0;
}

section.invert p,
section.invert a,
section.invert h3,
section.invert h2 {
    color: white;
}

section.invert h2 {
    border-bottom: none;
}

/*******************************************/
/* Inhalts-Bilder
/*******************************************/

.image-wrapper img {
    margin-bottom: 0 !important;
}

.image-wrapper p {
    color: rgba(0, 0, 0, 0.5);
    font-size: 14px;
    font-style: italic;
    font-weight: 400;
    line-height: 16px;
}

.fr-dib {
    width: auto;
    max-width: 100%;
    display: block;
    float: none;
    margin: 20px 0 20px 0;
}

.fr-dii {
    display: inline-block;
    width: auto;
    max-width: 100%;
}


a.document img.icon_attachment {
    width: 30px;
    float: left;
    margin-top: 2px;
    margin-right: 4px;
}

div.body-context img.page_cntxt {
    width: 100%;
    margin-bottom: 1em;
}
div.spacer {
    margin-top: 85px;
}
/*******************************************/
/* Responsive-Navigation
/*******************************************/

div#sidr {
    left: auto;
    right: -260px;
}

div#scroll-header {
    display: block;
    position: fixed;
    background-color: rgba(255, 255, 255, 0.8);
    top: 0;
    width: 100%;
    padding: 10px;
    z-index: 99;
}

div#scroll-header div.overlay {
    position: absolute;
    left: 10px;
    top: 0;
    padding: 15px 20px;
    background-color: white;
}

div#scroll-header a.logo {

}

div#scroll-header a.logo img {
    width: 200px;
}

div#scroll-header a#offcanvas-menu {
    display: block;
    float: right;
    width: 50px;
    border-radius: 8px;
}

a#offcanvas-menu span.bar {
    float: left;
    display: block;
    width: 60%;
    margin-left: 20%;
    margin-top: 7px;
    height: 0;
    border-bottom: 3px solid var(--color-red);
    -webkit-transition: all 0.5s ease 0s;
    -moz-transition: all 0.5s ease 0s;
    -ms-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
}

#offcanvas-menu.toggled span:first-child {
    transform: translateY(8px) rotate(45deg);
}

#offcanvas-menu.toggled span {
    transform-origin: center center 0;
}

#offcanvas-menu.toggled span:nth-child(2) {
    opacity: 0;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -ms-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

#offcanvas-menu.toggled span:last-child {
    transform: translateY(-12px) rotate(-45deg);
}

.sidr-open #sidr-body-overlay {
    display: block;
}
#sidr-body-overlay {
    background-color: rgba(0, 0, 0, 0.2);
    bottom: 0;
    display: none;
    height: 100%;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 999998;
}
.sidr .glyphicons:before {
    padding: 16px 8px;
}
.sidr ul li span {
    padding: 0;
}
.sidr ul li a span {
    display: inline-block;
}
/*******************************************/
/* Slides
/*******************************************/

.swiper-wrapper {
    position: relative;
    width: 100%;
    margin: 85px auto 0 auto;
    align-items: stretch;
    flex-basis: auto;
    height: auto;
    overflow: visible;
}
.swiper-slide {
    position: relative;
    display: flex;
    flex-direction: column;
    flex-basis: auto;
    align-items: stretch;
    height: auto;
}

.swiper-slide img {
    width: 100%;
    margin: auto !important;
    display: block;
    aspect-ratio: 440 / 320;
}

.swiper-slide .slide-text p {
   display: none;
}
.swiper-slide .slide-text strong {
    color: rgba(255,255,255,1);
    margin-bottom: .5em;
    margin-top: auto;
    font-size: 26px;
}

.swiper-slide .slide-text {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    padding: 20px 40px 20px 40px;
    background-color: rgba(30,30,30,.3);
    display: flex;
    flex-direction: column;
}
.swiper-slide .slide-text .button {
    margin-bottom: 20px;
    margin-right: auto;
}
.swiper-nav {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    flex-basis: auto;
    margin-top: 10px;
    margin-bottom: 15px;
}

.swiper-pagination {
    position: relative;
    text-align: center;
    margin-top: 5px;
}

.swiper-pagination-bullet {
    width: 14px;
    height: 14px;
    opacity: 1;
    background: var(--color-red);
    border-radius: 100%;
    margin: 0 5px 0 0 !important;
}

.swiper-pagination-bullet-active {
    background: #666666;
}
.swiper-button-next {
    margin-right: auto;
    margin-left: 15px;
}

.swiper-button-prev {
    margin-left: auto;
    margin-right: 2px;
}
.swiper-button-next,
.swiper-button-prev {
    position: relative;
    display: inline-block;
    height: 15px;
    top: 0;
    margin-top: 4px;
}

.swiper-button-next:after,
.swiper-button-prev:after {
    color: #666666;
    font-size: 15px;
}

/*******************************************/
/* Story
/*******************************************/

section.article .content,
article .content {
    text-align: center;
}

article .story_banner  {
    position: relative;
    background-color: var(--color-lightgrey);
    margin: 2em 0;
}

article .story_video  {
    position: relative;
    background-color: var(--color-lightgrey);
    margin: 2em 0;
}

article .story_fullscreen_image .image_container {
    width: 100%;
    height: auto;
}
article .story_image .content_image,
article .story_banner .content_image {
    width: 100%;
    margin: 0;
}
article .content_image {
    width: 50%;
    margin: 0 auto;
}
article .content_image img {
    display: block;
    width: 100%;
}

article .services .content_image figure img {
    aspect-ratio: 1 / 1;
}

article .story_anniversary .story_body a.sponsor {
    display: inline-block;
    width: 25%;
    margin: 0 30px  ;
}
article .story_anniversary .story_body a.sponsor img {
    display: block;
    width: 100%;
    margin: 0;
}

article .story_banner .story_body {
    height: 100%;
    width: 100%;
    position: relative;
    z-index: 80;
    background-color: var(--color-grey-o);
    color: #FFFFFF;
    padding: 20px;
}
article .story_banner .story_body .prehead {
    color: rgba(255, 255, 255, 0.8);
    font-weight: 400;
    font-size: 20px;
}
article .story_banner .story_body h2 {
    color: #FFFFFF;
}
article .story_banner .story_body.left {
    left: 0;
    text-align: left;
    display: flex;
    flex-direction: column;
    flex-basis: auto;
    flex-wrap: nowrap;
}
article .story_banner .story_body.left span.prehead {
    margin-top: auto;
}
article .story_banner .story_body.left .button {
    margin-right: auto;
}
article .story_banner .story_body.right span.prehead {
    margin-top: auto;
}
article .story_banner .story_body.right .button {
    margin-right: 0;
    margin-left: auto;
}
article .story_banner .story_body.right {
    right: 0;
    text-align: right;
    display: flex;
    flex-direction: column;
    flex-basis: auto;
    flex-wrap: nowrap;
}


article .story_video .story_body {
    background-color: var(--color-grey-o);
    color: #FFFFFF;
    padding: 20px;
}
article .story_video .story_body .prehead {
    color: rgba(255, 255, 255, 0.8);
    font-weight: 400;
    font-size: 20px;
}
article .story_video .story_body h2 {
    color: #FFFFFF;
}
article .story_video .story_body.left {
    left: 0;
    text-align: left;
    display: flex;
    flex-direction: column;
    flex-basis: auto;
    flex-wrap: nowrap;
}

article .story_intro {
    position: relative;
    width: 100%;
}
article .story_body p a {
    color: var(--color-red);
}
article .story_body h2.title {
    text-align: center;
}
article .story_body.left,
article .story_body.right {
    text-align: center;
}
article .story_body .text-image {
    width: 100%;
    display: block;
    margin: 0 0 30px 0;
}
article .story_body .text-image img {
    width: 100%;
    display: block;
}
article .story_list .story_body,
article .story_component .story_body,
article .story_links .story_body,
article .story_intro .story_body {
    display: flex;
    flex-direction: row;
    flex-basis: auto;
    flex-wrap: wrap;
    width: calc(100% + 30px);
    margin-left: -30px;
}
article .story_component .story_body .content_image,
article .story_intro .story_body .content_image {
    margin: 2em auto 1em auto;
}
article .story_intro .story_body .content_image img {
    border-radius: 50%;
    aspect-ratio: 1 / 1;
}

article .story_list .story_body .list_item,
article .story_component .story_body .products,
article .story_component .story_body a:not(.button),
article .story_links .story_body a,
article .story_links .story_body div,
article .story_intro .story_body a {
    display: flex;
    flex-direction: column;
    flex-basis: auto;
    flex-wrap: nowrap;
    width: calc(100% - 30px);
    margin-left: 30px;
}
article .story_component .story_body .products a.button{
    margin: 10px auto 10px auto;
}
article .story_component .story_body .products h2,
article .story_component .story_body a h2,
article .story_links .story_body a h2,
article .story_links .story_body div h2,
article .story_intro .story_body a h2 {
    font-size: 18px;
    font-weight: 400;
    margin-bottom: 10px;
}

article .story_links .story_body div .icon,
article .story_links .story_body a .icon {
    background-color: var(--color-lightgrey);
    border-radius: 50%;
    height: 80px;
    width: 80px;
    margin: 2em auto 1em auto;
    display: flex;
}
article .story_links .story_body div .icon img,
article .story_links .story_body a .icon img {
    width: 50%;
    margin: auto;
}
article .story_links .story_body div .icon span,
article .story_links .story_body a .icon span{
    color: var(--color-grey);
    line-height: 80px;
    text-align: center;
    font-size: 40px;
    margin: auto;
}

article .story_links .story_body .content_image img {
    height: 80px;
    width: 80px;
    margin: 2em auto 1em auto;
}
article .story_links .story_body .content_image img.big {
    display: block;
    width: 90%;
    height: auto;
    margin: 2em auto 1em auto;
}
.story_component,
.story_list,
.story_links,
.text-section {
    margin: 2em auto 1em auto;
}

article .story_list .story_body .list_item {
    position: relative;
    text-align: left;
    border-bottom: 1px solid var(--color-lightgrey);
    margin-bottom: 1em;
}

article .story_list .story_body .list_item .icon {
    cursor: pointer;
}

article .story_list .story_body .list_item h3 {
    padding-right: 30px;
}
article .story_list .story_body {
    margin-top: 2em;
}
article .story_list .story_body .list_item .list_item_body {
    position: relative;
    text-align: left;
    /*visibility: collapse;*/ /*darstellungsfehler in firefox*/
    height: 0;
    opacity: 0;
    padding: 0 20px;
    transition: height 1s linear 0s, opacity 0.4s ease-in-out 0s;
}

article .story_list .story_body .list_item.open .list_item_body {
    visibility: visible;
    height: auto;
    opacity: 1;
}
article .story_component .story_body.jobs {
    text-align: left;
}
article .story_component .story_body.jobs a {
    position: relative;
}
article .story_component .story_body.jobs .icon,
article .story_list .icon {
    background-color: var(--color-lightgrey);
    color: var(--color-red);
    width: 30px;
    height: 30px;
    text-align: center;
    border-radius: 50%;
    position: absolute;
    line-height: 31px;
    top: 0;
    right: 0;
    margin: 0;
    transform: rotate(90deg);
    transition: all 0.5s ease 0s;
    transform-origin: center center;
}

article .story_list .list_item.open .icon {
    transform: rotate(180deg);
    transform-origin: center center;
}

article .story_list .list_item .icon span {
    transition: all 0.5s ease 0s;
}
.story_image {
    margin: 2em auto 4em auto;
}
.story_image_link {
    display: block;
    position: relative;
}
.button.issuu:after {
    display: block;
    position: absolute;
    content: " ▶︎";
    color: var(--color-red);
    background-color: var(--color-lightgrey);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    text-align: center;
    font-size: 25px;
    line-height: 42px;
    vertical-align: 1px;
    top: -4px;
    right: -4px;
}
article .story_quote {
    position: relative;
   /* background-color: var(--color-lightgrey);*/
    margin: 2em 0;
    padding: 1.3em 0 1em 0;
}
.quote:before {
    color: var(--color-red);
    content: open-quote;
    font-size: 5.8em;
    line-height: 0.1em;
    margin-right: 0.1em;
    vertical-align: -0.3em;
    display: inline-block;
}

.quote {
    font-size: 1.3em;
    font-style: italic;
    line-height: 135%;
    quotes: "“" "”";
    width: 100%;
    position: relative;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
    display: inline-block;
    margin: 30px auto;
    text-align: center;
    padding: .2em 20px;
}
.quote blockquote {
    display: inline-block;
}
.quote .author {
    margin-top: 15px;
    font-size: .8em;
    font-style: normal;
    display: block;
}
#quote-slider .swiper-wrapper {
    margin-top: 0;
}
#quote-slider .swiper-pagination {
    margin-left: 18px;
}

.podcast-list div.grid .item {
    margin-bottom: 50px;
}

.podcast-list div.grid .item .text h2 {
   margin-bottom: 15px;
}

.podcast-list div.grid .item .text a {
    display: block;
    margin-top: 15px;
    font-size: 18px;
    line-height: 40px;
    margin-right: 20px;
}

.podcast-list div.grid .item .text a img {
    width: 30px;
    display: inline-block;
    margin-right: 10px;
    vertical-align: -8px;
}

.podcast-list div.grid .item .text a span {
    display: inline-block;
}

#section-293 table td {
    margin-bottom: 2px;
    border-bottom: 1px dotted #808080;
    padding: 5px 10px;
}

@media (max-width: 720px) {
    #section-293 table {
        width: auto !important;
        margin: 10px auto !important;
    }
    #section-293 table td {
        width: auto !important;
    }

    #section-293 table td:last-child {
        width: 50px !important;
    }
}

/*******************************************/
/* Footer
/*******************************************/

footer {
    float: left;
    width: 100%;
    margin-top: 15px;
    padding: 0 15px;
    background-color: var(--color-grey);
    color: #fff;
    font-size: 14px;
}

footer div.content {
    padding-top: 15px;
    padding-bottom: 15px;
}

footer div.grid .item img.iso_cert {
    margin-top: 1em;
    width: 50%;
}

footer h2 {
    font-family: var(--font);
    font-size: 20px;
    font-weight: 600;
}

footer div.content a,
footer div.content h3,
footer div.content h2,
footer div.content p {
    color: #fff;
}

footer div.content p a {
    color: #fff;
    font-weight: 600;
}

footer div.grid {
    margin-bottom: 2em;
}

footer div.grid .item {
    width: calc( 100% - 15px);

}

#boom-1,
#boom-2,
#boom-3,
#boom-4,
#boom-5 {
    display: none;
    position: absolute;
    left: -50px;
    top: -400px;
    width: 700px;
}

#boom-4 {
    top: -300px;
}

#boom-5 {
    top: -200px;
}


footer ul.social-nav {
    background-color: var(--color-lightgrey);
    padding: 5px;
    display: inline-block;
}

footer ul.social-nav li {
    display: inline-block;
}


footer ul.social-nav li a {
    color: var(--color-red);
}

footer ul.social-nav li a {
    margin-left: 4px;
    margin-right: 4px;
    color: var(--color-red);
}

footer ul.social-nav li a span {
    font-size: 20px;
}

footer ul.social-nav li:first-of-type a span {
    padding-left: 3px;
    padding-top: 1px;
}

footer ul.social-nav li:first-of-type a {
    color: var(--color-red);
    font-weight: 600;
    line-height: 24px;
    margin-right: 10px;
}

footer ul.social-nav li a {
    font-weight: 200;
    font-size: 14px;
}


footer ul.social-nav li a i.glyphicons {
    vertical-align: -5px;
    color: var(--color-red);
    font-size: 20px;
}


.toTop {
    border-radius: 100%;
    bottom: 40px;
    display: none;
    height: 30px;
    position: fixed;
    right: 50px;
    width: 30px;
    font-size: 33px;
    overflow: visible;
    z-index: 999;
    background-color: #FFFFFF;
    color: var(--color-red);
}
.toTop span {
    margin-left: -2px;
    margin-top: -2px;
}