 @supports (-webkit-overflow-scrolling: touch) {
	html,
	body {
	  position: relative;
	  overflow: scroll;
	}
}

body {
	margin: 0;
}

html, body {
  overflow-x:hidden
}

div[class*='textstyle']{
	font-family: "RobotoLight script=all", "Adobe Blank" !important;
}
span[class*='textstyle']{
	font-family: "RobotoLight script=all", "Adobe Blank" !important;
}
text{
	font-family: "RobotoLight script=all", "Adobe Blank" !important;
}
tspan{
 font-family: "RobotoLight script=all", "Adobe Blank" !important;
}

#menu_42787e73_pane {
	padding-left: 30px;
}

@font-face {
  font-family: 'RobotoRegular script=all';
  src:  url(fonts/Roboto/Roboto-Regular.woff2) format('woff2'),
        url(fonts/Roboto/Roboto-Regular.woff) format('woff');
}

@font-face {
  font-family: 'RobotoLight script=all';
  src:  url(fonts/Roboto/Roboto-Light.woff2) format('woff2'),
        url(fonts/Roboto/Roboto-Light.woff) format('woff');
}

@font-face {
  font-family: 'RobotoThin script=all';
  src:  url(fonts/Roboto/Roboto-Thin.woff2) format('woff2'),
        url(fonts/Roboto/Roboto-Thin.woff) format('woff');
}

.quote {
  position: relative;
  z-index: 1;
}

.quote.top::before,
.quote.bottom::after {
  background: inherit;
  content: '';
  display: block;
  height: 50%;
  left: 0;
  position: absolute;
  right: 0;
  z-index: -1;
  -webkit-backface-visibility: hidden; // for Chrome Windows
}

.quote.top::before {
  top: 0;
  transform: skewY(3deg);
  transform-origin: 100% 0;
}

.quote.bottom::after {
  bottom: 0;
  transform: skewY(-3deg);
  transform-origin: 100%;
}

.nicescroll-rails{
	z-index: 1000 !important;
}

body {
overflow-x:hidden;
}

h1, .h1 {
  font-family: "RobotoThin script=all", "Adobe Blank";
  font-size: 3.2rem;
  line-height: 3.5rem;
  margin: 0 !important;
  padding: 1rem 0.5rem 0.5rem 0.5rem !important;
	text-align: center;
}

h1.borderless, .h1.borderless, h2.borderless, .h2.borderless {
  margin: 0;
  padding: 0;
}

h2, .h2 {
  font-family: "RobotoThin script=all", "Adobe Blank";
  font-size: 1.6rem;
  line-height: 1.5rem;
	margin: 0 !important;
  padding: 1rem 0.5rem 0.5rem 0.5rem !important;
	text-align: left;
}

h3, .h3 {
  font-family: "RobotoThin script=all", "Adobe Blank";
  font-size: 1.8rem;
  line-height: 2.3rem;
	font-weight: normal;
  margin: 0.5rem 0 1rem 0 !important;
  padding: 0 0.5rem !important;
	text-align: center;
}

h4, .h4 {
  font-family: "RobotoThin script=all", "Adobe Blank";
  font-size: 1.1rem;
  line-height: 1.3rem;
	font-weight: normal;
  margin: 0 0 -.5rem 0 !important;
  padding: 0 0.5rem !important;
	text-align: center;
}

p, .p {
  font-family: "RobotoLight script=all", "Adobe Blank";
  font-size: 1.15rem;
  line-height: 1.6rem;
  margin: 0.5rem 0 1rem 0;
  padding: 0 0.5rem;
	text-align: left;
}

h1 .highlight,
.h1.highlight,
h2 .highlight,
.h2.highlight {
	text-transform: uppercase;
	color: rgb(255,217,0);
}

.title {
  font-family: "RobotoRegular script=all", "Adobe Blank";
  margin: 0;
  padding: 0;
}
.title .thin {
  font-family: "RobotoThin script=all", "Adobe Blank";
  margin: 0;
  padding: 0;
}

.zitat p,
.zitat h3 {
	font-style: italic;
	text-align: center;
}

.zitat h3 {
	font-size: 2rem;
}

.footer h1 {
	font-size: 1rem;
	line-height: 1.2rem;
	text-align: left;
	/* color: rgb(150,150,150); */
}

.footer p {
	font-size: 0.9rem;
	line-height: 1.2rem;
	text-align: left;
}

a, .a {
	text-decoration: none;
}

a,
a:visited,
a:active {
	color:#FFD900;
}

a:hover { color:#FEF09C; }

a.anchor {
    display: block;
    position: relative;
    top: -5rem;
    visibility: hidden;
}

.tinnyText {
	font-family: "RobotoRegular script=all", "Adobe Blank";
	font-size: 0.8rem;
	line-height: 1rem;
	text-align: center;
	color: rgb(150,150,150);
}

.videoTitle .title {
  font-size: 3.8vw;
  line-height: 4vw;
}

.pictureTitle .title {
  font-size: 3.5vw;
  line-height: 4.5vw;
}

@media only screen and (min-width: 1500px) {
	.videoTitle .title {
    font-size: 50px;
		line-height: 48px;
	}
	.pictureTitle .title {
	  font-size: 60px;
	  line-height: 69px;
	}
}

.spacer.middle {
	margin: 2rem;
}

.spacer.large {
	margin: 5rem;
}

/* ********************************** */

.topBar {
	background-color: #333;
  position: fixed;
  z-index: 100;
  width: 100%;
	display: inline-flex;
	justify-content: space-between;
	height: 3.4rem;
}

.topLogo img {
	margin: 0.5rem;
	width: 250px;
	margin-right: 1.5rem;
}

.topnav {
  overflow: hidden;
}

.topnav a {
  float: right;
  display: block;
  color: #f2f2f2;
  text-align: center;
  padding: 0.2rem 0.7rem;
  text-decoration: none;
	font-family: "RobotoLight script=all", "Adobe Blank";
  font-size: 1.2rem;
  line-height: 3.0rem;
}

.topnav.lang {
	position: absolute;
	right: 0;
}
.topnav.lang a{
	color: grey;
}

.topnav.lang a.activeLanguage {
	color: white;
}

.topnav.lang a {
  float: left;
}
.topnav li:hover > a{
  background-color: rgba(255,217,0,0.6);
  color: black;
	transition: color 1000ms ease, background-color 1000ms ease;
}

/* .topnav a:visited {
  color: white;
} */

.topnav a.active {
  background-color: rgb(255,217,0);
  color: black ;
	transition: color 1000ms ease, background-color 1000ms ease;
}

.topnav .icon {
  display: none;
}

@media screen and (max-width: 1150px) {
	h2, .h2 {
		font-size: 1.4rem;
		line-height: 1.8rem;
		/* text-align: center; */
	}
}

@media screen and (max-width: 768px) {
	h2, .h2 {
		text-align: center;
	}
}

@media screen and (max-width: 768px) {
  /*.topnav a:not(:first-child) {display: none;}*/
  .topnav a.icon {
    float: left;
    display: block;
  }
	.topnav.responsive {position: relative;}
	.topnav.responsive .icon {
		position: absolute;
		left: 0;
		top: 0;
	}
	.topnav.responsive a {
		float: none;
		display: block;
		height: 3.2rem;
		text-align: center;
		margin: auto;
	}
	h1, .h1 {
		font-size: 1.6rem;
		line-height: 2.2rem;
	}
	h3, .h3 {
		font-size: 1.2rem;
		line-height: 1.6rem;
	}
	p, .p {
		font-size: 1rem;
		line-height: 1.4rem;
	}
	.topLogo img {
		margin: 1rem 0;
		width: 170px;
		margin-right: 0.1rem;
	}
}

/* ********************************** */

button {
  border-radius: 0.5rem;
	border: 0;
  margin: 1rem;
  width: 100%;
  max-width: 20rem;
  height: 60px;
  background-color: rgb(255,217,0);
  font-family: "RobotoLight script=all", "Adobe Blank";
  font-size: 1.3rem;
  line-height: 1.4rem;
  transition: color 1000ms ease, background-color 1000ms ease;
  display: block;
  margin: auto;
}

button:hover {
    background-color: black;
    color: rgb(255,217,0);
}

.backgroundVideoFull {
  width: 100%;
}

.videoBoxAuto {
  vertical-align: bottom;
  position: relative;
  display: inline-block;
  width: 100%;
  background: none;
}

.dynamicTitle {
	position: absolute;
	width: 100%;
	z-index: 2;
	display: flex;
	justify-content: flex-end;
}


.videoTitle .dynamicTitle {
	left: 0;
}

.textContainer {
  color: white;
  display: flex;
}

.leftTextBlock {
  text-align: right;
  margin-right: 1.2rem;
}

.rightTextBlock {
  color: rgb(255,217,0);
  margin-right: 0.5rem;
}

@media only screen and (min-width: 768px) {
	.backgroundVideoFull {
    min-width: 1920px;
	}
	.videoTitle .dynamicTitle {
    bottom: 249px;
		max-width: 1400px;
	}
	.pictureTitle .dynamicTitle {
		right: 18vw;
		bottom: 171px;
	}
	.pic_beeWork {
		width: 400px;
		height: 400px;
	}
}

@media only screen and (max-width: 767px) {
	.backgroundVideoFull {
    min-width: 825px;
		overflow: hidden;
	}
	.videoTitle .dynamicTitle {
		left: 0;
		bottom: 101px;
		max-width: 600px;
	}
	.pictureTitle .dynamicTitle {
		left: 0;
		bottom: 70px;
	}
	.videoTitle .title {
		font-size: 5.5vw;
		line-height: 5.5vw;
		padding-right: 5vw;
	}
	.pictureTitle .title {
		font-size: 8vw;
		line-height: 10vw;
		padding-right: 5vw;
	}
	.rightTextBlock {
		display: none;
	}
	.leftTextBlock {
		margin-right: 0.2rem;
	}
	.pic_beeWork {
		width: 280px;
		height: 280px;
	}
}

@media only screen and (max-width: 400px) {
	.videoTitle .title {
		font-size: 1.4rem;
		line-height: 1.6rem;
		padding-right: 0;
	}
}

.outerBox {
  position: relative;
  padding: 10rem 0.5rem 8rem 0.5rem;
	display: flex;
	justify-content: center;
	flex-direction: row;
}

.outerBox.grey {
	background-color:rgb(76,76,76);
	color: white;
}

.outerBox.lightGrey {
	background-color:rgb(100,100,100);
	color: white;
}

.outerBox.darkGrey {
	background-color: #333;
	color: white;
}

.outerBox.footer {
	background-color: #333;
	color: white;
	padding-top: 2.5rem;
}

.outerBox.pictureTitle,
.outerBox.videoTitle {
	padding: 0;
}

#picProductInitiatives {
	width: 1000;
	height: 815;
}

#picProductVision {
	width: 800;
	/* height: 466; */
}

.outerBox.static {
	display: block;
}

.outerBox.first {
	padding-top: 3.6rem;
}

.outerBox.flat {
  padding: 2rem 0;
}

.outerBox.topFrameless {
	padding-top: 0;
}

.outerBox.bottomFrameless {
	padding-bottom: 0;
}

.innerBox {
	max-width: 1200px;
	display: block;
}

.innerBox.large {
	max-width: 1600px;
}

.innerBox.small {
	max-width: 900px;
}

.innerBox.tinny {
	max-width: 600px;
}

.innerBox.frame {
	margin:0.5rem;
	padding: 0.5rem;
}

.innerBox.vertCenter {
	margin: auto;
}

.outerBox.vertRight {
	justify-content: flex-end;
}

.outerBox.vertLeft {
	justify-content: flex-start;
}

.outerBox.reverse {
	flex-direction: column-reverse;
}

.innerBox.horizontalTop {
	margin-top: 0;
}

.innerBox.column {
	max-width: 50rem;
}

.innerBox.boxButton,
.innerBox.boxGrey {
	background-color: rgb(247,247,247);
	border-radius: 1rem;
}

.innerBox.boxButton:hover {
	background-color: rgb(255,217,0);
}

.cssVision .svg {
	width: 40rem;
  height: 40rem;
	margin: auto;
	display: flex;
	margin-top: 0;
	margin-bottom: 0;
}

.video-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

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

.backgroundPic {
  position: absolute;
	z-index: 10;
	opacity:  0.5;
}

.picCenter {
	display: flex;
	margin: auto;
}

.cssTargetGroup img,
.cssAdvantages img {
	padding: 0.5rem;
  min-width: 4.5rem;
}

.core-nav{
	position: absolute !important;
    z-index: 10000;
}

.core-content{
	min-height: inherit !important;
}

.core-nav-toggle{
	height: 54px;
}

@media only screen and (min-width: 1151px) {
	.innerBox.flex1151 {
	  display: flex;
	}
	#company {
		margin-left: 0.5rem;
	}
}

@media only screen and (min-width: 768px) {
	.innerBox.flex768 {
	  display: flex;
	}
}

@media only screen and (max-width: 1150px) {
	.cssVision .svg {
		width: 55vw;
	}
	.innerBox.mobileHide,
	.backgroundPic.mobileHide {
		display: none;
	}
	/* .innerBox {
		text-align: center;
	} */
	.innerBox.flex1151.column img {
			margin: auto;
			display: flex;
			margin-top: 0;
			margin-bottom: 0;
	}
	.innerBox.flex1151.column {
		flex-direction: column;
		padding: 0.5rem;
	}
}

@media only screen and (max-width: 767px) {
	.outerBox {
		padding: 3rem 0.5rem;
	}
	.innerBox.column {
		max-width: 100%;
	}
	.cssVision .svg {
		width: 100%;
	}
	#picProductInitiatives,
	#picProductVision {
		width: 100%;
		height: auto;
	}
	.innerBox.frame {
		padding: 0.5rem 0;
		margin: 0;
	}
	.spacer.large {
		margin: 1rem;
	}
  .cssTargetGroup img,
  .cssAdvantages img {
    min-width: 100%;
  }
  .innerBox.block {
    text-align: center;
  }
}
