/*******************************************/
/* Standard-HTML zurücksetzen
/*******************************************/

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,textarea,p,
blockquote,th,td {margin:0; padding:0; }
table { border-collapse:collapse; border-spacing:0; }
fieldset,img { border:0; }
address,caption,cite,code,dfn,strong,th,var { font-style:normal; font-weight:normal; }
ol,ul { list-style:none; }
caption,th { text-align:left; }
h1,h2,h3,h4,h5,h6 { font-size:100%; font-weight:normal; }
abbr,acronym { border:0; }
html {font-size: 62.5%;}
strong {font-weight: bold;}
a {text-decoration: none;}
a:active, a:focus {outline: 0;}

/*******************************************/
/* Globale-Tags
/*******************************************/

body {
    font-family: 'Fira Sans Condensed', sans-serif;
    font-weight: 300;
    font-size: 15px;
    color: #3f3f3f;
    line-height: 1.35em;
    background-color: white;
}

a:hover {
    text-decoration: none;
}

p {
    padding-bottom: 0.7em;
}

strong, b {

    font-weight: 500;
    font-size: 1em;
}

h1 {
    font-size: 2em;
    margin-bottom: 0.7em;
    line-height: 130%;
    font-weight: 600;
    color: black;
}

h1.listhead {
    padding: 0 25px;

    font-size: 2.4em;
    margin-bottom: 0.7em;
    line-height: 130%;
    font-weight: 600;
    color: black;
    text-align: center;
}

h1.listhead a {
    color: black;
}

.box h1 {
    color: black;
}

h2 {
    font-size: 1.2em;
    margin-bottom: 0.5em;
    line-height: 120%;
    color: black;
    font-weight: 500;
}

h2.listhead {
    text-align: center;
    padding-bottom: 0.5em;
    margin-bottom: 1.5em;
    border-bottom: 1px solid #bfbfbf;
}

h2.home-divider {
    font-size: 2.4em;
    margin-bottom: 0.7em;
    line-height: 130%;
    font-weight: 500;
    letter-spacing: 3px;
    color: black;
    text-align: center;
    text-transform: uppercase;
}

h3 {
    font-weight: 500;
    margin-bottom: 0.5em;
    color: black;
}

h4 {
    color: #808080;
    margin-bottom: 0.5em;
    font-size: 1.2em;

    font-weight: 500;}

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

/* Site
--------------------------------------------------------------
--------------------------------------------------------------*/

div#site {
    position: relative;
    margin: 0 auto;
    padding-left: 10px;
    padding-right: 10px;
    margin-top: 25px;
}


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

div#header {
    width: 100%;
    height: 280px;
    background-color: white;
    background-repeat: no-repeat;
    background-image: url(images/header_background.jpg);
    background-position: center top;
    background-size: cover;
    overflow: hidden;
}

div#header div {
    width: 1020px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

div#header h1 {
    position: absolute;
    width: 250px;
    top: 95px;
    left: 0px;
    color: #808080;
    font-size: 32px;
    
    font-weight: 300;
    text-transform: uppercase;
    letter-spacing: 3px;
}

div#header img.bubbles {
    width: 800px;
    left: 315px;
    top: -20px;
    position: absolute;
}

/* Nav (top)
--------------------------------------------------------------
--------------------------------------------------------------*/
div.sticky-wrapper {
    height: 50px;
}

nav#topnav {
    font-size: 0.9em;
    width: 100%;
    z-index: 100;
}

nav#topnav div.nav-inner {
    margin-left: auto;
    margin-right: auto;
}

nav#topnav a.language {
    display: inline-block;
    width: 16px;
    height: 16px;
    box-sizing: content-box;
    background-repeat: no-repeat;
    background-size: cover;
    margin-top: 15px;
    float: right;
    margin-right: 5px;
}

div.language-selection {
    float: left;
    margin-bottom: 20px;
}

nav#topnav a.language-de {
/*
    background-image: url('images/de.png');
*/
}

nav#topnav a.language-en {
/*
    background-image: url('images/en.png');
*/
    margin-right: 10px;
}

nav#topnav ul.navbar-nav>li>a {
    padding: 15px 0px;
    color: #333333;
}

nav#topnav ul.navbar-nav>li>a span {
    border-left: 1px dotted #bfbfbf;
    padding: 5px 10px;
}

nav#topnav ul.navbar-nav>li:first-child>a span {
    border-left: none;
}

nav#topnav ul.navbar-nav>li>a.selected {
    color: #000000;
}

nav#topnav ul.navbar-nav>li ul.dropdown-menu>li>a.selected {
    font-weight: 500;
}

.navbar-default {
    background: white;
    border-bottom: 1px solid #e7e7e7;
    box-shadow: none;
}

.navbar-default .navbar-collapse,
.navbar-default .navbar-form {
    border: none;
}

nav#topnav ul li a {
    font-weight: 500;
    font-size: 1.15em;
}

nav#topnav ul li ul li a {
    font-weight: 400;}

nav#topnav ul li.active a {
    font-weight: 500;}

nav#topnav form.search {
    margin-top: 10px;
    margin-bottom: 2px;
    margin-left: 25px;
}

#searchField {
    padding: 2px;
    padding-left: 10px;
    padding-right: 10px;
    height: auto;
    border-radius: 15px;
    margin-top: 2px;
    margin-bottom: 2px;
    width: 18em;
    letter-spacing: 0;
    font-weight: 500;}

nav#topnav form.search button[type="submit"] {
    border: none;
    color: white;
    background: transparent;
    font-size: 1.3em;
    display: block;
    float: right;
}

nav#topnav form.search button i {
    margin: 4px;
}

nav#topnav a#navbar-logo {
    float: left;
    margin-top: 8px;
    margin-left: 20px;
    margin-right: 20px;
    width: 230px;
}

nav#topnav a#navbar-logo img {
    width: 100%;
}

/* Slider
--------------------------------------------------------------
--------------------------------------------------------------*/

.swiper-wrapper {
    width: 100%;
    margin: 0 auto;
    align-items: stretch;
    flex-basis: auto;
    height: auto;
}
.swiper-container {
    overflow: hidden;
    width: 100%;
}

.swiper-slide {
    width: 100%;
    display: flex;
    flex-direction: column-reverse;
    flex-basis: auto;
    align-items: stretch;
    overflow: hidden;
}

#slider .swiper-slide {
}

.swiper-slide img {
    margin: auto !important;
    display: block;
    width: 100%;
}
.swiper-slide .overlay {
    font-weight: 500;
    background-color: rgba(0,0,0,0.3);
    color: #FFFFFF;
    font-size: 30px;
    position: absolute;
    bottom: 70px;
    right: calc((100vw - 80%) / 2);
    padding: 14px 10px;
}
.swiper-slide .overlay span {
    display: block;
    font-size: 36px;
    font-weight: bold;
    line-height: 130%;
}
.swiper-button-prev {
    background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='utf-8'%3F%3E%3Csvg version='1.1' id='Ebene_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 150 265' style='enable-background:new 0 0 150 265;' xml:space='preserve'%3E%3Cg%3E%3Cpolygon style='fill:%23FFFFFF;' points='124.9,13.3 144.8,33.1 44.8,133 144.8,233 124.9,252.8 5.2,133 '/%3E%3C/g%3E%3C/svg%3E ");
}
.swiper-button-next {
    background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='utf-8'%3F%3E%3Csvg version='1.1' id='Ebene_1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0px' y='0px' viewBox='0 0 150 265' style='enable-background:new 0 0 150 265;' xml:space='preserve'%3E%3Cg%3E%3Cpolygon style='fill:%23FFFFFF;' points='25.1,252.8 5.2,233 105.2,133 5.2,33.1 25.1,13.3 144.8,133 '/%3E%3C/g%3E%3C/svg%3E%0A");
}

.swiper-pagination-bullet {
    width: 14px;
    height: 14px;
    text-align: center;
    line-height: 14px;
    font-size: 12px;
    color: #d8d8d6;
    opacity: 1;
    background: rgba(255,255,255,0.8);
}

.swiper-pagination-bullet-active {
    color:#fff;
    background: #FFFFFF;
}

/* Content
--------------------------------------------------------------
--------------------------------------------------------------*/
div#contentwrapper {
    position: relative;
    margin-top: 20px;
    padding-left: 10px;
    padding-right: 10px;
    padding-bottom: 20px;
}

div#globalcontent div.body {
    margin-top: 10px;
}


/* Footer
--------------------------------------------------------------
--------------------------------------------------------------*/

div#footer {
    height: 100px;
    margin-left: auto;
    margin-right: auto;
    padding: 10px;
    border-top: 1px solid #888888;
    font-size: 0.9em;
    color: #676767;
    max-width: 1440px;
}

div#footer div.body {
    height: 100px;
    width: 98%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 25px;

}

div#footer div.body div.logo_left {
    float: left;
    margin-right: 25px;
    width: 160px;
    margin-bottom: 25px;
}

div#footer div.body div.logo_right {
    float: right;
    margin-left: 25px;
    margin-bottom: 25px;
    width: 160px;
}

div#footer div.body div.logo_left a img {
    width: 140px;
}

div#footer div.body div.logo_right a img {
    width: 160px;
}

div#footer div.body div.center {
    width: 420px;
    margin-right: auto;
    margin-left: auto;
    min-height: 50px;
}

div#footer div.body ul {
    float: left;
    margin-bottom: 35px;
    width: 130px;
}

div#footer div.body ul:first-child {
    width: 100px;
}

div#footer div.body ul li {
    float: left;
    margin-right: 10px;
    width: 100%;
}

div#footer div.body ul li h4 {
    font-size: 1em;
    font-family: 'Fira Sans Condensed', sans-serif;
    font-weight: 500;}

div#footer div.body a {
    color: #676767;
    border-bottom: 1px dotted transparent;
}
div#footer div.body p a:hover,
div#footer div.body ul li a:hover {
    color: #676767;
    border-bottom: 1px dotted #7f7f7f;
}


/* Context
--------------------------------------------------------------
--------------------------------------------------------------*/

div.widecontent {
    width: 100%;
    float: left;
    padding-left: 10px;
    padding-right: 10px;
}

div.content {
    width: 68%;
    float: left;
    padding-left: 10px;
    padding-right: 10px;
}

div.box {
    width: 100%;
    float: left;
    margin-bottom: 20px;
    padding: 0px;
}

div.context {
    width: 32%;
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    position: relative;
}

div.context div.box {
    width: 100%;
    float: left;
    padding: 0px;
    padding-bottom: 20px;
    margin-bottom: 0px;
    border-left: 1px solid #efefef;
}

div.context div.box div.body {
    float: left;
    width: 100%;
    padding: 20px;
}

div.context div.box div.body h3 {
    margin-top: 0;
}

/*******************************************/
/* Global (Box)
/*******************************************/

div.product_list {
    width: 100%;
    margin-bottom: 2em;
    float: left;
}

div.industry_list {
    float: left;
    width: 100%;
    margin-bottom: 2em;
}

div.flex {
    float: left;
    padding-left: 25px;
    padding-right: 25px;
}

div.triplet {
    float: left;
    width: 30.3333%;
    box-sizing: border-box;
    height: 330px;
    background-color: white;
    border-radius: 5px;
    cursor: pointer;
    overflow: hidden;
    margin-left: 1.5%;
    margin-right: 1.5%;
    margin-bottom: 3%;
}

div.pollteaser {
    float: left;
    width: 22%;
    box-sizing: border-box;
    cursor: pointer;
    margin-left: 1.5%;
    margin-right: 1.5%;
    margin-bottom: 3%;
}

div.pollteaser img {
    width: 100%;
}

div.pollteaser h2 {
    text-align: center;
    margin: 10px 0;
}

div.pollteaser h2 a {
    color: black;
}

div.triplet div.banner_image {
    width: 100%;
    height: 200px;
    background-size: cover;
    background-repeat: no-repeat;
}

ul.minigallery {
    width: 100%;
    height: 190px;
    box-sizing: border-box;
    padding: 0px;
}

.minigalleryimage {
    display: block;
    box-sizing: border-box;
    margin: 5px;
    height: 80px;
    background-size: cover;
    background-repeat: no-repeat;
    border: 1px solid #e5e5e5;
}

.minigalleryimage:nth-child(4n) {
    margin-right: 0;
}

div.triplet h2 {
    padding: 8px;
    padding-left: 5px;
    margin-bottom: 5px;
}

div.triplet h2 a {
    color: black;
}

div.triplet div.text {
    padding: 10px 0;
}

div.flex div.box {
    height: 280px;
    overflow: hidden;
    cursor: pointer;
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
    padding: 0;
}

div.banderole {
    position: absolute;
    top: 20px;
    right: -45px;
    width: 150px;
    background-color: white;
    padding-top: 3px;
    padding-bottom: 3px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
    text-align: center;
    font-weight: 500;
    box-shadow: 0 0 10px rgba(0,0,0,0.4);
    color: black;
}

div.flex div.box div.image {
    height: 205px;
    width: 100%;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    border: 1px solid #e5e5e5;
    border-radius: 3px;
}

div.flex div.box div.image-missing-de {
    background-image: url(/styles/images/missing-image-de.png);
    background-size: 125px 125px;
    background-repeat: no-repeat;
    background-position: center center;
}

div.flex div.box div.image-missing-en {
    background-image: url(/styles/images/missing-image-en.png);
    background-size: 125px 125px;
    background-repeat: no-repeat;
    background-position: center center;
}

div.flex div.box div.text {
    background-color: white;
    height: 75px;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    color: black;
}
div.company_list {
    display: flex;
    flex-direction: row;
    flex-basis: auto;
    flex-wrap: wrap;
    width: 100%;
}

div.company_list div.flex div.box div.image {
    height: 140px;
}

div.company_list div.flex div.box div.text {
    height: 95px;
}

div.flex div.box div.text h2 {
    padding: 10px 0px 5px 0;
    font-weight: 500;
    margin-bottom: 0;
    color: black;
}

div.flex div.box div.text h2 a {
    color: black;
}

div.flex div.box div.text p {
    margin-top: 0;
    margin-bottom: 0;
}

div.flex div.banner {
    height: 280px;
    overflow: hidden;
    background-color: white;
    cursor: pointer;
    border: 1px solid white;
    border-radius: 5px;
    position: relative;
    padding: 0;
    width: 100%;
    float: left;
    margin-bottom: 25px;
    box-shadow: 0 0 15px rgba(135, 135, 135, 0.6);
}

div.flex div.banner {
    text-align: center;
}

div.flex div.banner h4 {
    font-weight: 300;
    letter-spacing: 1px;
    font-size: 0.9em;
    color: #808080;
    text-transform: uppercase;
    margin-top: 10px;
}


a.imagebox {
    position: relative;
    float: left;
    display: block;
    width: 100px;
    height: 100px;
    margin-bottom: 16px;
    margin-right: 16px;
    background-color: white;
    cursor: pointer;
    background-repeat: no-repeat;
    background-size: cover;
    border: 1px solid #e5e5e5;
    border-radius: 0;
}

div.body div.contentimage {
    margin-top: 0px;
    margin-left: 20px;
    margin-bottom: 20px;
    float: right;
    width: 300px;
    cursor: pointer;
    position: relative;
}

div.body div.contentimage div.video_play_button {
    position: absolute;
    width: 128px;
    height: 83px;
    background-image: url(images/video-play-button.png);
    background-size: 128px 83px;
    background-repeat: no-repeat;
    right: 0;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto auto auto auto;
}


div.contentimage .gallerymain {
    border: 1px solid #bfbfbf;
    padding: 0;
    margin-bottom: 10px;
    width: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

img.standalone {
    border: 1px solid #bfbfbf;
    padding: 0;
    margin-bottom: 20px;
    width: 100%;
    float: left;
}

div.contentimage div.mainwrapper {
    position: relative;
}

div.contentimage div.gallerythumb {
    width: 33.33%;
    float: left;
    padding-bottom: 10px;
    padding-right: 10px;
}

div.contentimage div.gallerythumb a {
    border: 1px solid #bfbfbf;
    padding: 0;
    float: left;
    height: 75px;
    width: 100%;
    background-size: cover;
}

div.tabbable div.tab-content {
    background: #ffffff;
    border: 1px solid #dddddd;
    border-top: none;
}

div.tabbable div.tab-content div.tab-pane {
    padding: 20px;
    padding-top: 20px;
}

.box.product_poll {

}

.box.product_poll img {
    max-width: 100%;
}

.box.product_poll h3 a {
    color: black;
}

/*****************************
FancyBox-Mod
*****************************/

.fancybox {
    /*position: relative;*/
}

.fancybox-nav span {
    visibility: visible;
}

.fancybox-next {
    right: -60px;
}

.fancybox-prev {
    left: -60px;
}

input, textarea, select {
    font-weight: 500;
}