@font-face { font-family: 'Bosch Sans'; src: url('../fonts/BoschSans-Bold.eot?#iefix') format('embedded-opentype'), url('../fonts/BoschSans-Bold.woff2') format('woff2'), url('../fonts/BoschSans-Bold.woff') format('woff'), url('../fonts/BoschSans-Bold.ttf') format('truetype'), url('../fonts/BoschSans-Bold.svg#BoschSans-Bold') format('svg'); font-weight: bold; font-style: normal; font-display: swap; }

@font-face { font-family: 'Bosch Sans'; src: url('../fonts/BoschSans-Regular.eot'); src: url('../fonts/BoschSans-Regular.eot?#iefix') format('embedded-opentype'), url('../fonts/BoschSans-Regular.woff2') format('woff2'), url('../fonts/BoschSans-Regular.woff') format('woff'), url('../fonts/BoschSans-Regular.ttf') format('truetype'), url('../fonts/BoschSans-Regular.svg#BoschSans-Regular') format('svg'); font-weight: normal; font-style: normal; font-display: swap; }


html { scroll-behavior: smooth; }
img { max-width: 100%; }

a { text-decoration: none; color: #000; }

.mt80 { margin-top: 80px !important; }

.grayBg { background-color: #c1c7cc; }
.main { }
section { min-height: 100vh; font-family: 'Bosch Sans', sans-serif; color: #000; overflow: hidden; position: relative; }

section .container { padding: 2em 4em; position: relative; z-index: 9; }

.countNmbr { display: inline-block; font-size: 330px; font-weight: bold; position: absolute; bottom: 0; left: 0px; z-index: 0; line-height: 230px; color: #C1C7CC; }

.grayBg .countNmbr { color: #FFF; }


.bigTitle { font-size: 3em; font-weight: bold; padding: 30px 0px; line-height: 1.2em; }

.bigTitle span{font-size: .7em; font-weight: bold; padding: 30px 0px; line-height: 1.2em;}

.expVdo { cursor: pointer; width: 90%; margin: auto; position: relative; overflow: hidden; border-radius: var(--bs-border-radius-xl) !important; padding-bottom: 10px; }

.numberBlocks { padding: 0px; max-width: 845px; margin: auto; color: #013b69; }



.block_1 .blockTitle { font-size: 15px; text-transform: uppercase; }

.block_1 .numberBlock { font-size: 170px; font-weight: bold; width: 225px; float: left; line-height: .8; }

.block_1 .iconBlock { width: 105px; float: left; text-transform: uppercase; font-size: 16px; font-weight: bold; }

.block_2 .blockTitle { font-size: 15px; text-transform: uppercase; }

.block_2 .numberBlock { font-size: 170px; font-weight: bold; width: 210px; float: left; line-height: .8; letter-spacing: -10px; }

.block_2 .iconBlock { width: 180px; float: left; text-transform: uppercase; font-size: 15px; text-align: center; }

.block_3 .iconBlock { width: 140px; float: left; padding-right: 5px; }

.block_3 .numberBlock { width: 150px; float: left; }

.block_3 .cstmNmbr { position: relative; }

.block_3 .cstmNmbr b { font-size: 140px; font-weight: bold; line-height: .8; }

.block_3 .cstmNmbr span { font-size: 33px; display: inline-block; transform: rotate(-90deg); position: absolute; top: 30px; right: 0; font-weight: bold; }

.btmBlkTtl { font-size: 16px; font-weight: bold; }

.btmBlkTtl span { display: block; font-weight: normal; font-size: 13px; }

.block_4 .iconBlock { width: 150px; float: left; }

.block_4 .blockTitle { width: 325px; float: left; font-size: 105px; font-weight: bold; line-height: 1em; }

.block_4 .blockTitle span { display: block; font-size: 25px; line-height: 1em; font-weight: normal; }

.secTtl { font-size: 34px; font-weight: bold; line-height: 1.2em; }

.testimHeading .userpic { width: 140px; float: left; }

.testimHeading .secTtl { width: calc(100% - 140px); float: left; padding-left: 15px; }

.testimHeading { display: flex; align-items: center; }


/*Side Navigation*/
.sideNav { height: 400px; width: 90px; position: fixed; left: 20px; top: calc(50vh - 200px); z-index: 2; }

.sideNav .navlist { padding-left: 0; position: absolute; right: 0; height: 100%; background-color: #d8dcdf; width: 12px; border-radius: 20px; margin: 0; }

.sideNav .navlist a { padding: 0px; position: absolute; width: 10px; height: 10px; background-color: #FFF; border-radius: 50%; display: block; cursor:pointer }

.sideNav .navlist a span { position: absolute; top: -7px; left: 26px; color: #013b69; font-weight: bold; opacity: 0; transition: .3s; }


.sideNav .navlist a:nth-child(1) { top: 16.66%; }

.sideNav .navlist a:nth-child(2) { top: 33.32%; }

.sideNav .navlist a:nth-child(3) { top: 49.98%; }

.sideNav .navlist a:nth-child(4) { top: 66.64%; }

.sideNav .navlist a:nth-child(5) { top: 83.3%; }


.slide1 .sideNav .navlist a:nth-child(1) { background-color: #013b69; width: 15px; height: 15px; left: -2px; }

.slide2 .sideNav .navlist a:nth-child(2) { background-color: #013b69; width: 15px; height: 15px; left: -2px; }

.slide3 .sideNav .navlist a:nth-child(3) { background-color: #013b69; width: 15px; height: 15px; left: -2px; }

.slide4 .sideNav .navlist a:nth-child(4) { background-color: #013b69; width: 15px; height: 15px; left: -2px; }

.slide5 .sideNav .navlist a:nth-child(5) { background-color: #013b69; width: 15px; height: 15px; left: -2px; }

.slide1 .sideNav .navlist a:nth-child(1) span { opacity: 1; }

.slide2 .sideNav .navlist a:nth-child(2) span { opacity: 1; }

.slide3 .sideNav .navlist a:nth-child(3) span { opacity: 1; }

.slide4 .sideNav .navlist a:nth-child(4) span { opacity: 1; }

.slide5 .sideNav .navlist a:nth-child(5) span { opacity: 1; }


.btn.btn-outline-primary { border: 1px solid #000; color: #000; font-size: 20px; max-width: 275px; background-color: rgba(1, 59, 105, 0); transition: .3s; }

.btn.btn-outline-primary:hover { color: #fff; background-color: rgba(1, 59, 105, 1); transition: .3s; }









.navTtl { width: 50px; text-align: center; position: absolute; left: 0; font-size: 24px; top: 0; height: 100%; }
.navTtl span { display: inline-block; transform: rotate(-90deg); width: 150px; position: absolute; top: 190px; left: -40px; }

.block_1, .block_2, .block_3, .block_4 { padding-left: 12px; padding-right: 12px; float: left; }

.block_1 { width: 400px; }
.block_2 { width: 435px; }
.block_3 { width: 320px; }
.block_4 { width: 515px; }




/*------------------------------------------------------------------------------*/
.block_4 .iconBlock { width: 150px; float: left; }

.block_4 .blockTitle { width: 325px; float: left; font-size: 105px; font-weight: bold; line-height: 1em; }

.block_4 .blockTitle span { display: block; font-size: 25px; line-height: 1em; font-weight: normal; }

.secTtl { font-size: 30px; font-weight: bold; line-height: 1.2em; }

.secText { color: #000000; font-size: 1.8rem; font-weight: 500; margin: 0; }

.secText-1 { font-size: 1.2rem; font-weight: 500; line-height: 1.5em; }

.boschbadge { padding: 5px; font-size: 2rem; font-weight: bold; }

/*******************************
          Buttons
 ******************************/
.btn-outline-secondary { --bs-btn-color: #013b69; --bs-btn-border-color: #013b69; --bs-btn-hover-color: #fff; --bs-btn-hover-bg: #013b69; --bs-btn-hover-border-color: #013b69; --bs-btn-focus-shadow-rgb: 108, 117, 125; --bs-btn-active-color: #fff; --bs-btn-active-bg: #013b69; --bs-btn-active-border-color: #013b69; --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125); --bs-btn-disabled-color: #013b69; --bs-btn-disabled-bg: transparent; --bs-btn-disabled-border-color: #013b69; --bs-gradient: none; }

/*******************************
          Custom Width
 ******************************/
.secWidth { width: 90%; max-width: 90%; margin: auto; }

/*******************************
          Testimonial
 ******************************/
.testimHeading .userpic { width: 140px; float: left; }

.testimHeading .secTtl { width: calc(100% - 140px); float: left; padding-left: 15px; }

.testimHeading { display: flex; align-items: center; }

.testimcarousel p { color: #000000; font-size: 1rem; position: relative; display: flex; padding: 15px 0 0; align-items: flex-start; justify-content: start; margin: 0; }

.testimcarousel .blockquote-footer { color: #000000; font-weight: bold; margin-left: 23px; }

.testimcarousel .blockquote-footer::before { display: none }

.testimcarousel .blockquote-footer cite { display: block; font-style: normal; text-transform: uppercase; }

.testimcarousel p:before { content: "\201C"; color: #013b69; font-size: 3rem; position: relative; top: -18px; left: 0; font-weight: bold; }

.testimcarousel p:after { content: "\201D"; color: #013b69; font-size: 3rem; position: absolute; bottom: -50px; right: 50px; font-weight: bold; }

/*******************************
          Section
 ******************************/

.secContent .secText span { color: #013b69; font-weight: bold; }

/*******************************
          Tabs
 ******************************/
 .boschtabs {width: 90%; max-width: 90%; margin: auto;}
.boschtabs .tabitem { margin: 10px; flex: 1; text-align: center; transition: all .3s ease-in-out; width: calc(14.28% - 20px); min-width: 105px;}

.boschtabs .tabLink { display: flex; flex-direction: column; justify-content: center; align-items: center; color: #013b69; font-weight: bold; width: 100px; border-bottom: 4px solid #eff1f2; border-radius: 0; transition: transform 0.2s; filter: brightness(100%) contrast(100%) saturate(100%) blur(0px) hue-rotate(0deg); }

.boschtabs .tabLink .brandIcon img { height: 35px; }

.boschtabs .tabLink .brandName { text-transform: uppercase; line-height: 1rem; font-size: 0.8rem; margin-top: 0.5rem; }

.tabitem:hover .tabLink,
.tabitem:active .tabLink,
.tabitem:visited .tabLink,
.tabitem .tabLink.active { border-bottom: 4px solid #0f6089; }

.tabitem:hover .tabLink,
.tabitem:active .tabLink,
.tabitem:visited .tabLink { transform: scale(1.1); }

.nav-pills .tabLink.active { color: #013b69; font-weight: bold; background-color: transparent; }

#pills-tabContent { text-align: center; }

/*******************************
        lightboxContainer
 ******************************/
.lightboxContainer { position: relative; display: inline-block; overflow: hidden; }

.lightboxContainer:after { content: url("../../assets/images/play-button.png"); z-index: 999; position: absolute; top: 50%; left: 50%; margin-left: -32px; margin-top: -32px; opacity: 0.8; }

.lightboxContainer:hover:after { opacity: 1; }

.lightboxContainer .full-image { width: 100%; position: relative; transition: all .3s; }

.lightboxContainer:hover .full-image { width: 100%; position: relative; transform: scale(1.1); }

.full-contents { display: flex; flex-direction: column; align-items: flex-start; gap: 13px; position: absolute; z-index: 100; left: 32px; bottom: 32px; max-width: 593px; }

.lightboxContainer .headline { background-color: #003e64; color: #fff; display: inline; font-size: 28px; font-weight: 700; line-height: 37px; letter-spacing: -.05em; text-transform: uppercase; padding: 8px 12px; text-align: left; /*width: 50%;
    position: absolute;
    top: 10%;
    left: 50%;
    transform: translate(-50%, -50%);*/ }

.lightboxContainer p { background-color: #003e64; display: inline-block; font-size: 12px; font-weight: 400; line-height: 18px; letter-spacing: -.06em; padding: 4px 12px; color: #fff; margin: 0; /*position: absolute;
    top: 220px;
    left: 50px;*/ }


/* Video Popup */
.video-popup { position: fixed; top: 0; right: 0; bottom: 0; left: 0; display: flex; justify-content: center; align-items: center; z-index: 9999999; background: rgba(0, 0, 0, .7); cursor: pointer; display: none !important; }

.video-popup.show-video { display: flex !important; }

.iframe-wrapper { position: relative; /*width:90%;
height:95%;*/ width: 80%; height: 95%; }
.iframe-wrapper iframe, .iframe-wrapper video { width: 100%; height: 100%; }

.iframe-wrapper .close-video { content: ''; position: absolute; width: 30px; height: 30px; top: 0px; right: -10px; background: url(../images/close-notification.png) #fff; border-radius: 50%; background-size: cover; }
.show-video { display: block !important; top: 0; left: 0; width: 100%; height: 100%; }

.playVdo {  display: inline-block;  position: absolute;  bottom: 18px;  right: 10px;}

.expBg:before { content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-1.png'); background-repeat: no-repeat; position: absolute; top: 17%; right: 0; background-position: top right; z-index: -5; }
.expBg:after { content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-2.png'); background-repeat: no-repeat; position: absolute; bottom: -6%; right: 0; background-position: bottom right; z-index: -5; }
#slide2.pageSlide .container:after, #slide5 .container:before { content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-3.png'); background-repeat: no-repeat; position: absolute; top: 0; right: 0; background-position: top right;  z-index: -5;}
.bg-4:after, .lastSlide:after { content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-4.png'); background-repeat: no-repeat; position: absolute; bottom: -6%; right: 0; background-position: bottom right; z-index: -5; }
.expVdo .show-video, .expVdo2 .show-video { position: absolute;background-color: #013b69; }
.expVdo3 .show-video{ position: absolute;background-color: #fff;}
.expVdo3, .expVdo2, .expVdo {position: relative;}
.bg-4 { padding-top: 30px; }
#slide3 .container:before { content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-5.png'); background-repeat: no-repeat; position: absolute; top: -2%; right: 0; background-position: top right; z-index: -5; }
.bg-6:before { z-index: -2; content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-1.png'); background-repeat: no-repeat; position: absolute; bottom: -5%; right: 0; background-position: bottom right; z-index: -5; }
#slide4 .container.shortTitle:before { content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-5.png'); background-repeat: no-repeat; position: absolute; top: -4%; right: 0; background-position: top right; z-index: -5; }
#slide4 .boschtabs:before { content: ""; display: block; height: 100%; width: 100%; background-image: url('../images/bg-1.png'); background-repeat: no-repeat; position: absolute; bottom: -5%; right: 0; background-position: bottom right; z-index: -5; }
#slide5 .container:before { top: -13%; }
.lastSlide .secHeading { text-align: right; }
.lastSlide:after { background-image: url('../images/last-bg.png'); background-position: bottom left; left: 23%; bottom: 0; }
.lastSlide .secTtl { font-size: 25px; }

.interIframe { width: 100%; height: 400px;}
.modal-title{font-weight: bold;}
.modal-title span{display: block; font-size: 14px; font-weight: normal;}
.form-group label{font-size: 14px; font-weight: bold;  margin-bottom: 8px;}
.modal-dialog form{width: 100%;}
.modal-header{align-items: start;}
.thnkYou{position: fixed;
    width: 100%;
    z-index: 99;
    padding: 20px;
    background-color: rgba(0, 0, 0, 0.5);
    text-align: center;
    max-width: 100%;
    margin: auto;
    left: 0;
    right: 0;
    top: 0;
    border-radius: 0px;
    font-size: 27px;
    color: #FFF;
    bottom: 0;}
    .closenow {
        font-size: 14px;
        display: inline-block;
        padding: 10px 25px;
        background-color: #000;
        border-radius: 3px;
        text-transform: uppercase;
        letter-spacing: 1px;
        margin-top: 0px;
        cursor: pointer;
        color: #FFF;
        border:1px solid #000;
      }
      .closenow:hover{ background-color: transparent!important; color: #000 !important;}


.messagePop {
    display: block;
    width: 100%;
    max-width: 400px;
    margin: auto;
    background-color: #FFF;
    color: #000;
    top: 0;
    bottom: 0;
    position: absolute;
    height: 231px;
    padding: 40px;
    left: 0;
    right: 0;
    border-radius: 15px;
  }
  .messagePop p{color: #000;
    line-height: 1.2;
    font-weight: bold;
    font-size: 30px;}

input[type="submit"]{border: 1px solid #000!important;
    border-radius: 0;
    font-size: 16px;
    line-height: 1.2;
    font-size: 14px;
    display: inline-block;
    padding: 10px 25px;
    background-color: #000;
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 0px;
    cursor: pointer;
    color: #FFF;
    font-weight: bold;}

    input[type="submit"]:hover {background-color: transparent!important; color: #000 !important;}




    .form-group {
        margin-bottom: 15px;
      }
/*responsive*/
@media screen and (min-width: 1400px) {
 .expBg::after { bottom: -8%; }
 .bg-4:after { bottom: 0%; }
 .bg-4:before { content: ""; display: block; height: 100%; width: 100%; background-image: url(../images/bg-3.png); background-repeat: no-repeat; position: absolute; bottom: -2%; right: 0; background-position: bottom right; }
}

@media screen and (max-width: 1279px) {

    .expBg:before { display:none;}
    .expBg:after { display:none; }
    #slide2.pageSlide .container:after, #slide5 .container:before {display:none; }
    .bg-4:after, .lastSlide:after { display:none;}
    #slide3 .container:before { display:none;}
    .bg-6:before { display:none; }
    #slide4 .container.shortTitle:before {display:none;}
    #slide4 .boschtabs:before { display:none;}
    #slide5 .container:before {display:none; }
    .lastSlide:after { display:none;}

}
@media screen and (min-width: 1024px) and (max-width: 1279px) {

.countNmbr{font-size: 170px;     line-height: 130px;}
.secText-1{font-size: 1rem;}
.secTtl { font-size: 23px;}
.bigTitle {font-size: 2em;}
.boschtabs .tabitem{padding:5px; margin: 5px !important;}
.boschtabs .tabLink{padding:5px;}
section .container { padding: 2em 2em;}
.sideNav {width: 30px;}
.navTtl{font-size: 18px;width: 18px;}
.navTtl span{left: -75px; line-height: 1;}
.secText{font-size: 1.4rem;}
.btn.btn-outline-primary {font-size: 16px;}
}
@media screen and (max-width: 1023px) {
.animated {transform: none !important; opacity: 1!important;}
.block_1 {width: 300px;}
.block_2 {width: 335px;}
.block_3 {width: 220px;}
.block_4 {width: 415px;}


}

@media screen and (min-width: 768px) and (max-width: 1023px) {
#slide1 {align-items: center; display: flex;}
#slide1 .bigTitle {text-align: center;}
    .countNmbr{font-size: 170px;     line-height: 130px;}
    .secText-1{font-size: 0.8rem;}
    .secTtl { font-size: 23px;}
    .bigTitle {font-size: 2em;}
    .boschtabs .tabitem{padding:5px; margin: 5px !important;}
    .boschtabs .tabLink{padding:5px;}
    section .container { padding: 2em 2em;}
    .sideNav {width: 30px;}
    .navTtl{font-size: 18px;width: 18px;}
    .navTtl span{left: -75px; line-height: 1;}
    .secText{font-size: 1.2rem;}
    .btn.btn-outline-primary {font-size: 16px;width: 100%;}
    .block_1 .blockTitle { font-size: 14px;}
    .block_2 .blockTitle { font-size: 17px;}
    .block_1 .numberBlock { font-size: 125px;  width: 160px;}
    .block_1 .iconBlock {width: 80px; font-size: 12px;}
    .block_2 .numberBlock { font-size: 120px;  width: 135px;}
    .block_2 .iconBlock { width: 155px; font-size: 16px;}
    .block_3 .iconBlock {width: 80px;}
    .block_3 .numberBlock {width: 115px;}
    .block_3 .cstmNmbr span { font-size: 32px;}
    .block_3 .cstmNmbr b { font-size: 101px;}
    .btmBlkTtl { font-size: 14px;}
    .btmBlkTtl span{font-size: 11px;}
    .block_4 .blockTitle { width: 270px;  font-size: 86px;}
    .block_4 .blockTitle span {  font-size: 18px;}
    .block_4 .iconBlock { width: 115px;}
    }
    @media screen and (max-width: 767px) {

        #slide1 {align-items: center; display: flex;}
        #slide1 .bigTitle {text-align: center;}
        .countNmbr{font-size: 100px; line-height: 69px;}
        .secText-1{font-size: 0.8rem;}
        .secTtl { font-size: 23px;}
        .bigTitle {font-size: 2em; text-align:center;}
        .boschtabs .tabitem{padding:0px; margin: 3px !important; width: calc(50% - 6px);}
        .boschtabs .tabLink{padding:5px;}
        section .container { padding: 2em 1em;}
        section > .container {padding-bottom: 90px;}
        .sideNav {display: none;}
        .block_1, .block_2, .block_3, .block_4{width: 100%; margin-bottom: 15px; display: flex;    justify-content: center;    flex-direction: column;    align-items: center;}
        .secText{font-size: 1.2rem;}
        .btn.btn-outline-primary {font-size: 16px;width: 100%;}
        .block_1 .blockTitle { font-size: 14px;}
        .block_2 .blockTitle { font-size: 17px;}
        .block_1 .numberBlock { font-size: 125px;  width: 160px;}
        .block_1 .iconBlock {width: 80px; font-size: 12px;}
        .block_2 .numberBlock { font-size: 120px;  width: 135px;}
        .block_2 .iconBlock { width: 130px; font-size: 16px;}
        .block_3 .iconBlock {width: 115px;}
        .block_3 .numberBlock {width: 115px;}
        .block_3 .cstmNmbr span { font-size: 25px; top: 22px;}
        .block_3 .cstmNmbr b { font-size: 101px;}
        .btmBlkTtl { font-size: 14px;}
        .btmBlkTtl span{font-size: 11px;}
        .block_4 .blockTitle { width: 200px; font-size: 63px;}
        .block_4 .blockTitle span {  font-size: 14px;}
        .block_4 .iconBlock { width: 80px;}
        .secWidth {width: 100%;max-width: 100%; margin-bottom: 20px;}
        .mt80 { margin-top: 20px !important;}
        #slide2 .secHeading {margin-top:15px;}
        .secHeading, .secContent  {width: 100%!important; text-align: center!important;}
        .mobRev{flex-direction: column-reverse;}
        .secHeading{margin-top:15px;}
        .boschtabs {width: 100%; max-width: 100%; margin: auto;}
    }
      @media screen and (max-width: 1024px) { 
       section { min-height: auto!important; }
      }

    /* boschtabs */
    @media screen and (max-width: 767px) {
     .lightboxContainer {
      display: flex;
      flex-direction: column-reverse;
     }
    .full-contents {
      position: initial;
     }
    }