/*======== General Site CSS ========*/

html{
  font-size:62.5%;
  font-family: 'Roboto', sans-serif;
}
html, body{
  padding:0px;
  margin:0px;
  min-width:320px;
  background:var(--ebs-grey-color);
}

body{
  font-size:1rem;
}
h1,h2,h3{
  margin-top:0px;
}
:root{
  --mobile-head-height: 56px;
  --mobile-slideout-width: 24rem;
  --mobile-menuitem-padding: 1.6rem;
  --ebs-accent-color: #306054;
  --ebs-accent-color-highlight: #387062;
  --ebs-accent-color-dark: #204239;
  --ebs-white-color: #fff;
  --ebs-grey-color: #f4f4f4;
}
p{
  line-height: 2.4rem;
}
a:link{
  color:#418271;
}
a:visited{
  color:var(--ebs-accent-color-dark);
}
a:hover{
  color:#4d9b87;
}
a.anchor_margin {
  height: 0;
  width:0;
  position: relative;
  display: block;
  top:-110px;
}
#site_container{
  position:relative;
  width:100%;
  font-size:1.6rem;
}
.white_bg{
  background:var(--ebs-white-color);
}
.center_container{
  position:relative;
  width:130rem;
  margin-left:auto;
  margin-right:auto;
}
.center_container--menu{
  position:relative;
  margin-left:auto;
  margin-right:auto;
  width:100%;
  max-width:130rem;
  display:flex;
  justify-content:center;
  align-items: center;
  -webkit-transition: padding 300ms ease;
     -moz-transition: padding 300ms ease;
       -o-transition: padding 300ms ease;
          transition: padding 300ms ease;
}
.center_container--head{
  position:relative;
  width:130rem;
  margin-left:auto;
  margin-right:auto;
  display:flex;
  flex-flow: row nowrap;
}
#head_container{
  position:relative;
  width:100%;
  padding-top:1rem;
  box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
  z-index:5;
  padding-bottom:5px;
}
#logo_container{
  flex:1;
  display:flex;
  align-items:center;
}
#head_right{
  flex:1;
  text-align:right;
}
#head_right a{
  text-decoration:none;
}
#logo-img{
  display:block; /* remove line height space below image (usually there for tail of y and p, etc)*/
  height:4.8rem;
}
#mobile-logo-img-white{
  display:block; /* remove line height space below image (usually there for tail of y and p, etc)*/
  width:90px;
  margin-right:20px;
}
#billboard_container{
  position:relative;
  height:300px;
  background:var(--ebs-grey-color);
  width:100%;
}
#cont_container{
  position:relative;
  background:var(--ebs-grey-color);
  border-bottom:0.1rem solid rgb(0,0,0,0.3);
  padding-bottom:6.4rem;
  padding-top:3.2rem;
}
#foot_container{
  position:relative;
  height:500px;
  background:var(--ebs-grey-color);
  padding-top:1.6rem;
}
#head_right p{
  padding:0rem;
  margin:0rem;
}
.pseudo_break:before{
  content:"";
  white-space: pre;
}
a.styled_button{
  text-decoration: none;
  background: var(--ebs-accent-color);
  display:inline-block;
  height: 3.6rem;
  line-height:3.6rem;
  text-align: center;
  padding-left:1rem;
  padding-right:1rem;
  color:#eaeaea;
  margin-top:1.6rem;
}
.styled_button:hover{
  background: var(--ebs-accent-color-highlight);
}
.styled_button:active{
  background: var(--ebs-accent-color-dark);
}
#bill_center{
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  text-align:center;
  display:flex;
  flex-direction:row;
  justify-content:center;
}
.billHomeText--container{
  display:flex;
  flex-direction:row;
  background-color:rgba(255,255,255,0.8);
  width:100rem;
  margin-left:auto;
  margin-right:auto;
}
#bill_logo--container{
  width:30rem;
  padding:4rem 0 4rem 4rem;
}
#bill_logo{
  height:100%;
  width:100%;
  object-fit: contain;
}
#bill_text_cont{
  text-align:left;
  position:relative;
  display:inline-block;
  margin-left:auto;
  margin-right:auto;
  max-width:100%;
  padding:1.6rem;
  background-color:rgba(255,255,255,0.8);
}
#bill_text_cont > h6, #bill_text_cont > h1{
  font-size:5rem;
  padding:0;
  margin:0;
  color: #306054;
}
#bill_text_cont > h6 span:first-child, #bill_text_cont > h1 span:first-child{
  font-size:7.8rem;
}
.content_row{
  display:flex;
  flex-direction:row;
  border-width:0 0.1rem 0.1rem 0.1rem;
  border-color:rgb(0,0,0,0.3);
  border-style:solid;
  padding:3.2rem;
}
.cardRowContainer{
  display:flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0 -1rem;
}
.content_col{
  flex-basis:51rem;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  background:var(--ebs-white-color);
  border-width:0.1rem;
  border-color:rgb(0,0,0,0.3);
  border-style:solid;
  padding:3.2rem;
  margin: 0 1rem;
}
.content_col > div:first-child{
  flex-grow:0;
  flex-shrink:0;
  flex-basis: 38rem;
  text-align:center;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
}
.content_col > div:first-child > a > img{
  width:100%;
  height:100%;
  max-width:50rem;
  object-fit: contain;
}
.content_col > div:nth-child(2){
  flex-grow:1;
  flex-shrink:0;
  margin-top:4rem;
}
#content_first_row{
  border-top:0.1rem solid rgb(0,0,0,0.3);
}
.content_row div:last-child{
  flex-grow:1;
  padding-left:3.2rem;
  text-align:center;
}
.content_row div:first-child{
  flex-basis:62%;
  text-align:left;
  padding-left:0;
}
.content_single_column div:last-child{
  padding-left:0;
  text-align:left;
}
.flexgrid_content_row{
  border-width:0 0.1rem 0.1rem 0.1rem;
  border-color:rgb(0,0,0,0.3);
  border-style:solid;
  padding:3.2rem;
}
.gallery_container{
  display:flex; 
	flex-direction:row; 
	flex-wrap:wrap; 
	justify-content:flex-start; 
	width:100%;
}
.gallery_object{
	width:207px;
	text-align:center;
	margin: 1.5rem 7rem 1.5rem 0;
}
.gallery_object a{
  text-decoration:none;
}
.gallery_thumb{
	width:207px;
  height:138px;
	margin:auto; 
	display:inline-block;
}
.matomo-iframe{
  border: 0;
  width:100%;
  height:200px;
}
a.anchor-margin {
  height: 0;
  width:0;
  position: relative;
  display: block;
  top:-9rem;
}
/*======== General Site CSS End ========*/
/*======== products CSS ========*/
.product_spec_ul{
  padding:0px;
  margin:0px;
  margin-left:1.7rem;
}
.spareParts--table{
  border-collapse: collapse;
  border-spacing: 0;
  table-layout: fixed;
  width: 100%;
  font-size:1.5rem;
  word-wrap : break-word;
}
.spareParts--table td{
  width:33%;
  vertical-align:top;
}
.spareParts--table th{
  width:33%;
  vertical-align:top;
}
.spareParts--table > tbody > tr:nth-child(even) {
  background:var(--ebs-grey-color);
}
/*======== products CSS End ========*/
/*======== Desktop Menu stuff ========*/
#head_nav{
  flex:1 1 30%; /* give the navigation 50% of the space from the header before space is split between logo and right column, this way it has enough space and is always perfectly centered */
  z-index:1;
  display:flex;
  justify-content:center;
  align-items:flex-end;
}
#menu{
  top:0px;
  width:100%;
  color:var(--ebs-white-color);
}
#menu > .center_container--menu > ul{
  padding:0px;
  margin:0px;
  list-style:none;
  height:100%;
  vertical-align: bottom;
  align-self:flex-end;
}
#menu > .center_container--menu > ul > li, #menu > .center_container--menu > ul > a{
  position:relative;
/*  background:var(--ebs-accent-color); */
  float:left;
  margin:0 1rem 0 1rem;
  padding:1rem;
  width:11rem;
  text-align:center;
  z-index:5; /*part 1 of making the dropdowns always behind other menu items when you hover over them (dropshadows don't appear on top of other menu items)*/
/*  color:var(--ebs-white-color); */
  color:var(--ebs-accent-color-dark);
  font-size: 2rem;
  text-decoration:none;
}
#menu > .center_container--menu > ul > li:hover{
  background:var(--ebs-accent-color);
  color: var(--ebs-white-color);
  cursor:pointer;
  z-index:4; /*part 2 of making the dropdowns always behind other menu items when you hover over them (dropshadows don't appear on top of other menu items)*/
}
#menu > .center_container--menu > ul > li .menu_gap_color_fill{
  display:inline-block;
  visibility:hidden;
	position: absolute;
  top:100%;
  left:0px;
  background:var(--ebs-accent-color);
	width: 100%;
  height:5px;
  z-index:1;
  -webkit-transition: visibility 300ms;
     -moz-transition: visibility 300ms;
       -o-transition: visibility 300ms;
          transition: visibility 300ms;
}
#menu > .center_container--menu > ul > li:hover *{
  visibility:visible;
}
#menu > .center_container--menu > ul > li:hover > div ul{
  box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
}
#menu > .center_container--menu > ul > li:hover .submenu ul li{
  max-height:150px;
}

#menu > .center_container--menu > ul > li > a{
  color:var(--ebs-white-color);
  text-decoration:none;
}
#menu > .center_container--menu > ul > li.menu_top_level_link:hover, #menu > .center_container--menu > ul > a.menu_top_level_link:hover{
  background:var(--ebs-accent-color-highlight);
  color: var(--ebs-white-color);
}
#menu > .center_container--menu > ul > li.menu_top_level_link:active, #menu > .center_container--menu > ul > a.menu_top_level_link:active{
  background:var(--ebs-accent-color-dark);
}
.submenu{
  position:absolute;
  top:calc(100% + 5px);
  left:50%;
  width:300px;
  margin-left:-150px;
  background:var(--ebs-accent-color);
  visibility:hidden;
  text-align:left;
}
.submenu a{
  text-decoration:none;
  color:var(--ebs-white-color);

}
.submenu > ul{
  position:relative;
  margin:0px;
  padding:0px;
  list-style:none;
}
.submenu > ul > li{
  font-size: 1.6rem;
  position:relative;
  width:100%;
  background:var(--ebs-accent-color);
  overflow-y:hidden;
	visibility:hidden;
  max-height:0px;
  padding:0px;
  -webkit-transition: max-height 300ms ease, visibility 300ms;
     -moz-transition: max-height 300ms ease, visibility 300ms;
       -o-transition: max-height 300ms ease, visibility 300ms;
          transition: max-height 300ms ease, visibility 300ms;
}
.submenu > ul > li:hover{
  background:var(--ebs-accent-color-highlight);
}
.submenu > ul > li:active{
  background:var(--ebs-accent-color-dark);
}
.submenu > ul > li span{
  display:block;
  padding:2rem;
}
#sticky_logo{
  height:4.8rem;
}
.foot_row{
  display:flex;
  flex-direction:row;
  flex-wrap:nowrap;
  justify-content:space-between; 
  padding-left:1.6rem;
  padding-right:1.6rem;
}
.foot_row a{
  text-decoration:none;
}
.foot_left, .foot_right{
  flex-grow:1;
}
.foot_right{
  text-align:right;
}
#head__langSelection-container{
  flex-grow:1;
  display:flex;
  flex-direction:row;
  justify-content:flex-end;
  align-items:flex-end;
  padding-bottom:1rem;
}
/*======== Desktop Menu stuff end ========*/

/*======== Mobile Head Stuff ========*/
#mobile_head_container{
  display:none;
  position:fixed;
  top:0px;
  left:0px;
  width:100%;
  z-index:10;
  background:var(--ebs-accent-color);
  height: var(--mobile-head-height);
}
#mobile_head_container_spacer{
  position:relative;
  display:none;
  height: var(--mobile-head-height);
}
#mobile-head__langSelection-container{
  flex-grow:1;
  display:flex;
  padding-left:2rem;
}
/*======== Mobile Head Stuff end ========*/
/*======== Mobile Menu ========*/
#mobile_slideout{
  position:fixed;
  left:calc(-1 * var(--mobile-slideout-width));
  top:0px;
  height:100%;
  width:var(--mobile-slideout-width);
  background:var(--ebs-white-color);
  z-index:12;
  -webkit-transition: left 300ms cubic-bezier(.4,0,.2,1);
     -moz-transition: left 300ms cubic-bezier(.4,0,.2,1);
       -o-transition: left 300ms cubic-bezier(.4,0,.2,1);
          transition: left 300ms cubic-bezier(.4,0,.2,1);
}
#slideout_logo_container{
  padding:16px;
  margin-bottom:40px;
}






.mobileNav ul ul{
  font-size:13px;
}

.mobileNav > ul > li a{
  display:inline-block;
  width:calc(100% - (2 * var(--mobile-menuitem-padding)));
  font-size:1.4rem;
  line-height:2.4rem;
}
.mobileNav > ul > li > ul > li a{
  width:100%;
}
.mobileNav ul li a:hover{
  background:#e0e0e0;
}
.mobileNav span{
	cursor:pointer;
	list-style-type:none;
	text-decoration:none;
}
.mobileNav > ul{
	list-style-type:none;
	padding-left:0px;
	margin:0px;
	font-size:2.0rem;
}
.mobileNav ul a{
	list-style-type:none;
	color:#666;
	text-decoration:none;
}
.mobileNav ul li ul{
  padding-left:0px;
}
.mobile_submenu{
	display:none;
  background:#c6c6c6;
  list-style:none;
}
.mobileNav ul li:nth-child(odd) {
font-weight: normal;
}
.header-container{
  position:relative;
  z-index:10;
  background:#e3e3e3;
  /*transition: all 0.3s cubic-bezier(.25,.8,.25,1);*/
}
/*.header-container:hover {
  box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);
}*/
.header-wrapper{
  display:flex;
  width:1243px;
  margin-right:auto;
  margin-left:auto;
}
.mobile-head-spacer{
  height:0px;
}
.mobile_submenu > li > a{
  display:block;
  width:100%;
  padding:10px 0px 10px 0px !important;
}
.mobile_submenu > li > a::before{
  content:" ";
  height:100%;
  padding:0 0 0 24px;
}
.logo{
  width:246px;
  margin:10px 0px 10px 0px;
}
.mobile-logo{
  width:146px;
  margin:10px 0px 10px 0px;
}
.mobile_submenu_item{
  display:inline-block;
  width:calc(100% - (2 * var(--mobile-menuitem-padding)));
  font-size:1.4rem;
  line-height:2.4rem;
  padding:var(--mobile-menuitem-padding);
  color:#666;
}
.mobile_submenu_item:hover{
  background:#e0e0e0;
}
.billboard-container{
  position:relative;
  background:#f5f5f6;
}










#mobile_logo-img{
  display:block; /* remove line height space below image (usually there for tail of y and p, etc)*/
  width:150px;
}
#mobile_slideout.active{
  left:0px;
}
#mobile_slideout_cover{
  visibility:hidden;
  position:fixed;
  top:0px;
  left:0px;
  width:100%;
  height:100%;
  background:rgba(0,0,0,0);
  z-index:11;
  -webkit-transition: background 300ms cubic-bezier(.4,0,.2,1), visibility 300ms cubic-bezier(.4,0,.2,1);
     -moz-transition: background 300ms cubic-bezier(.4,0,.2,1), visibility 300ms cubic-bezier(.4,0,.2,1);
       -o-transition: background 300ms cubic-bezier(.4,0,.2,1), visibility 300ms cubic-bezier(.4,0,.2,1);
          transition: background 300ms cubic-bezier(.4,0,.2,1), visibility 300ms cubic-bezier(.4,0,.2,1);
}
#mobile_slideout_cover.active{
  visibility:visible;
    background:rgba(0,0,0,0.5);
}
#mobile_slide_btn{
  cursor: pointer;
  padding:1.6rem;
  width:18px;
}
#hamb_bar1, #hamb_bar2, #hamb_bar3{
    width: 2rem;
    height: 2px;
    background-color: var(--ebs-white-color);
    margin: 0.3rem 0;
    transition: 0.4s;
}
/*======== Mobile Menu end ========*/
/*======== Rotating words ========*/
.rot_wrds{
	display: inline;
  padding-inline-start:0px;
}
#bill-space{
  padding-left:0.2rem;
}
.rot_wrds_item{
	position: absolute;
  font-size:7.8rem;
	opacity: 0;
	overflow: hidden;
	-webkit-animation: rotateWord 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 1;
     -moz-animation: rotateWord 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 1;
       -o-animation: rotateWord 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 1;
	        animation: rotateWord 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 1;
}
#rot_wrds_end{
  position: absolute;
  font-size:7.8rem;
	opacity: 0;
	overflow: hidden;
	-webkit-animation: rotateWord_end 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 6s forwards;
     -moz-animation: rotateWord_end 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 6s forwards;
       -o-animation: rotateWord_end 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 6s forwards;
	        animation: rotateWord_end 14s cubic-bezier(0.175, 0.885, 0.320, 1.275) 6s forwards;
}
.rot_wrds_item_2 {
  -webkit-animation-delay: 3s;
     -moz-animation-delay: 3s;
       -o-animation-delay: 3s;
	        animation-delay: 3s;
}
@-webkit-keyframes rotateWord {
  0% {opacity: 0; transform: translateY(-40px); }
  2% { opacity: 0; transform: translateY(-40px); }
	5% { opacity: 1; transform: translateY(0px);}
  20% { opacity: 1; transform: translateY(0px); }
	27% { opacity: 0; transform: translateY(40px); }
  100% { opacity: 0; transform: translateY(-40px);}
}
@-moz-keyframes rotateWord {
  0% {opacity: 0; transform: translateY(-40px); }
  2% { opacity: 0; transform: translateY(-40px); }
	5% { opacity: 1; transform: translateY(0px);}
  20% { opacity: 1; transform: translateY(0px); }
	27% { opacity: 0; transform: translateY(40px); }
  100% { opacity: 0; transform: translateY(-40px);}
}
@-o-keyframes rotateWord {
  0% {opacity: 0; transform: translateY(-40px); }
  2% { opacity: 0; transform: translateY(-40px); }
	5% { opacity: 1; transform: translateY(0px);}
  20% { opacity: 1; transform: translateY(0px); }
	27% { opacity: 0; transform: translateY(40px); }
  100% { opacity: 0; transform: translateY(-40px);}
}
@keyframes rotateWord {
  0% {opacity: 0; transform: translateY(-40px); }
  2% { opacity: 0; transform: translateY(-40px); }
	10% { opacity: 1; transform: translateY(0px);}
  20% { opacity: 1; transform: translateY(0px); }
	27% { opacity: 0; transform: translateY(40px); }
  100% { opacity: 0; transform: translateY(-40px);}
}
@keyframes rotateWord_end {
  0% {opacity: 0; transform: translateY(-40px); }
  2% { opacity: 0; transform: translateY(-40px); }
	10% { opacity: 1; transform: translateY(0px);}
  100% { opacity: 1; transform: translateY(0px); }
}
/*======== Rotating words end ========*/
/*======== Media queries  ========*/
@media only screen and (max-width: 599px) { /* phones */
  .center_container{
    width:100%;
  }
  .center_container--head{
    width:100%;
  }
  #head_container{
    display:none;
  }
  #mobile_head_container{
    display: flex;
    align-items:center;
    justify-content:space-between;
    flex-wrap: nowrap;
  }
  #mobile_head_container_spacer{
    display: block;
  }
  #bill_text_cont > h6, #bill_text_cont > h1{
  font-size:3rem;
  }
  #bill_text_cont > h6 span:first-child, #bill_text_cont > h1 span:first-child{
    font-size:4.5rem;
  }
  .rot_wrds span{
    font-size:4.5rem;
  }
  #rot_wrds_end{
    font-size:4.5rem;
  }
  #bill-space{
    padding-left:0.1rem;
  }
  .foot_row{
    display:block;
	position:relative;
  }
  .foot_right{
	padding-top:1.6rem;
  }
  .content_row{
    flex-direction:column-reverse;
  }
  .content_row div:first-child{
    flex-basis:100%;
  }
  .content_row div:last-child{
    flex-grow:1;
    padding-left:0rem;
    padding-bottom:1.6rem;
  }
  .content_row div:last-child img{
    max-width:100%;
  }
  .matomo-iframe{
    height:300px;
  }
  .content_col{
    flex-basis:100%;
    border-width:0 0.1rem 0.1rem 0.1rem;
    margin:0;
  }
  .cardRowContainer{
    margin: 0;
  }
  .content_col > div:first-child{
    flex-basis: 0;
  }
  .content_col:first-child{
    border-width:0.1rem;
  }
  #bill_logo--container{
    display:none;
  }
  .elap_list_img{
    max-width:100%;
  }
}
@media only screen and (min-width: 600px) and (max-width:899px) { /* tablet portrait */
  .center_container{
    width:100%;
  }
  .center_container--head{
    width:100%;
  }
  #head_container{
    display:none;
  }
  #mobile_head_container{
    display: flex;
    align-items:center;
    justify-content:space-between;
    flex-wrap: nowrap;
  }
  #mobile_head_container_spacer{
    display: block;
  }
  #bill_text_cont > h6, #bill_text_cont > h1{
  font-size:4rem;
  }
  #bill_text_cont > h6 span:first-child, #bill_text_cont > h1 span:first-child{
    font-size:6.2rem;
  }
  .rot_wrds span{
    font-size:6.2rem;
  }
  #rot_wrds_end{
    font-size:6.2rem;
  }
  #bill-space{
    padding-left:0.1rem;
  }
  .foot_row{
    display:block;
	position:relative;
  }
  .foot_right{
	padding-top:1.6rem;
  }
  .content_row{
    flex-direction:column-reverse;
  }
  .content_row div:first-child{
    flex-basis:100%;
  }
  .content_row div:last-child{
    flex-grow:1;
    padding-left:0rem;
    padding-bottom:1.6rem;
  }
  .content_row div:last-child img{
    max-width:100%;
  }
  .content_col{
    flex-basis:100%;
    border-width:0 0.1rem 0.1rem 0.1rem;
    margin:0;
  }
  .content_col:first-child{
    border-width:0.1rem;
  }
  .content_col > div:first-child{
    flex-basis: 0;
  }
  #bill_logo--container{
    max-width:22rem;
    padding: 4rem 0 4rem 2rem;
  }
  .cardRowContainer{
    margin: 0;
  }
}
@media only screen and (min-width: 900px) and (max-width:1199px) { /* tablet landscape */
  .center_container{
    width:84rem;
  }
  .center_container--head{
    width:84rem;
  }
  .center_container--menu{
    max-width:84rem;
  }
  #sticky_logo{
    height:4.8rem;
  }
  #head_nav{
    flex:1 1 35%;
  }
  #menu > .center_container--menu > ul > li, #menu > .center_container--menu > ul > a{
    width:8.4rem;
    padding:0.6rem;
    font-size:1.3rem;
  }
  .pseudo_break:before{
    content:"\A";
    white-space: pre;
  }
  .content_col{
    flex-basis:20rem;
  }
  .content_col > div:first-child{
    flex-basis: 17rem;
  }
  .bill--container{
    width:70rem;
  }
  #bill_logo--container{
    width:22rem;
    padding: 4rem 0 4rem 3rem;
  }
}
@media only screen and (min-width: 1200px) and (max-width:1799px) { /* small desktop */
  .center_container{
    width:118rem;
  }
  .center_container--head{
    width:118rem;
  }
  .center_container--menu{
    max-width:118rem;
  }
  .content_col{
    flex-basis:32rem;
  }
  .content_col > div:first-child{
    flex-basis: 25rem;
  }
  .bill--container{
    width:90rem;
  }
}
