html,body, .section{
    width:100%;
    height: 100%;
    overflow-x: hidden;
}

.sub-menu {
    width: 100%;
}

.fp-tableCell {
    display: flex;
    align-items: center;
    justify-content: center;
}

.invisible {
    opacity:0;
}

.elcomgate-inner-logo {
    position: absolute;
    top: 0px;
    right: 0px;
}

.elcomgate-inner-logo img {
    width: 50%;
    height: auto;
}

.top-products-wrapper {
    display: flex;
    flex-direction: row;
    margin-top: 20px;
}

.product-box {
    display: flex;
    justify-content: space-around;
    align-items: center;
    border: 1px solid #8080FF;
    padding: 10px;
    height: 100px;
    margin: 5px;
}
.product-box p {
    padding-right: 15px;
    color: #8080FF;
}
.product-box img {
    height: 80px;
    width: auto;
}
/* .js .main-navigation ul, .main-navigation .menu-item-has-children > a > .icon, .main-navigation .page_item_has_children > a > .icon, .main-navigation ul a > .icon {
    display: block;
}

.sub-menu {
    display: none;
} */

.sub-menu {
    display: none;
}

body {
    font-family: 'Roboto', sans-serif;
}

/**
* NAV
*/
.admin-bar .site-navigation-fixed.navigation-top {
    top: 0px;
}

.site-navigation-fixed.navigation-top {
    position: absolute;
    top: 0px;
}

.navigation-top {
    background: rgba(255,255,255,0.88);
    height: 100px;
    position: absolute;
    top:0px;
    width: 100%;
    z-index: 1;
}

.navigation-top .current-menu-item > a, .navigation-top .current_page_item > a {
    color: #627178;
}

.navigation-top a {
    font-weight: normal;
    font-size: 14px;
    padding: 15px 25px;
    color: #627178;
    text-decoration: none;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
}

.navigation-top a:hover {
    color: #8080ff;
}

.main-navigation {
    margin-top:15px;
}

.menu-top-menu-container {
    margin-top: 5px;
    display: inline-block;
    vertical-align: middle;
}

.main-navigation ul {
    text-align: right;
}

.top-menu-shop-section {
    display: inline-block; 
    vertical-align:middle; 
    text-align:center; 
    padding-left: 15px; 
    padding-right: 50px;
}

.hero-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    color: #fff;font-size: 4.5em; letter-spacing: 3px;
}

.hero-desc {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
    color: #fff;margin-bottom:60px; font-size: 1.45em; opacity: 0.6;
}

.trusted-by {
    font-family: 'Roboto', sans-serif;
    font-weight: 700;
}

.roboto-regular {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
}

.montserrat-bold {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
}

.section-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
}

.section-desc {
    font-family: 'Roboto', sans-serif;
    font-weight: 400;
}

.section-text {
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
}

.top-menu-shop-section .phone-number {
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
}

.main-navigation ul li:hover > ul, .main-navigation ul li.focus > ul {
    text-align: center;
}

.main-navigation ul li.menu-item-has-children::before, .main-navigation ul li.menu-item-has-children::after, .main-navigation ul li.page_item_has_children::before, .main-navigation ul li.page_item_has_children::after {
    right: 5em;
}

.main-navigation ul ul a {
    width: auto;
    /* padding: 10px 45px; */
}

/**
* EXPERIENCE SECTION
**/
#experience-section .section-text {
    font-size: 1.6em;
    margin-top: 30px;
    margin-bottom: 30px;
}

.call-us-text {
    color:#fff; 
    margin-bottom: 0px; 
    font-size: 2em;
    font-weight: 200;
}

.phone-no-big {
    color:#fff; 
    font-size: 5em; 
    font-weight: 700; 
    margin-bottom: 0px; 
}

.product-list-box {
    padding: 10px; 
    overflow: hidden; 
    padding-bottom:20px; 
    height: 200px;
}

/**
* INNOVATION SECTION
*/

#innovation-section .wrapper {
    width: 70%; 
    padding-top: 50px; 
}

#innovation-section .side-image {
    width: 100%; 
    height: auto; 
    margin: 0 auto;
}

/**
* FOOTER
**/
.footer-link {
    display: flex; 
    order:1; 
    flex: 3; 
    justify-content:space-around; 
    align-items:center; 
    color: #fff; 
}

.footer-logo {
    display: flex; 
    order:2; 
    flex: 1; 
    justify-content:center; 
    align-items:center; 
    margin-bottom: 30px;
}

/**
* GENERIC
*/

#box {
    width: 50px;
    height: auto;
    position: absolute;
    top: 100px;
    left: 100px;
    z-index: 10;
}

.gradient-bg {
    background: #8080ff; /* For browsers that do not support gradients */
    background: -webkit-linear-gradient(left, #8080ff, #7adcf2); /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(left, #8080ff, #7adcf2); /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(left, #8080ff, #7adcf2); /* For Firefox 3.6 to 15 */
    background: linear-gradient(left, #8080ff, #7adcf2); /* Standard syntax */
}

.btn-gradient {
    background: #8080ff; /* For browsers that do not support gradients */
    background: -webkit-linear-gradient(left, #8080ff, #7adcf2); /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(left, #8080ff, #7adcf2); /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(left, #8080ff, #7adcf2); /* For Firefox 3.6 to 15 */
    background: linear-gradient(left, #8080ff, #7adcf2); /* Standard syntax */
    display: block !important;
    padding: 10px 40px !important;
    color: #fff !important;
    font-size: 14px;
    font-weight: 400;
    text-decoration: none !important;
    font-family: 'Montserrat', sans-serif;
}

.btn-border-white {
    display: inline-block !important;
    padding: 8px 25px !important;
    color: #fff !important;
    font-size: 14px;
    font-weight: 400;
    text-decoration: none !important;
    background: none;
    border: 1px solid #fff;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    font-family: 'Montserrat', sans-serif;
}

.btn-border-white:hover {
    background: #fff;
    color: #8080ff !important;
}

.btn-border-gradient {
    border: 2px solid transparent;
    border-image: linear-gradient(to right, #8080ff 0%, #7adcf2 100%);
    border-image: -moz-linear-gradient(to right, #8080ff 0%, #7adcf2 100%);
    border-image: -o-linear-gradient(to right, #8080ff 0%, #7adcf2 100%);
    border-image: -webkit-linear-gradient(to right, #8080ff 0%, #7adcf2 100%);
    padding: 8px 25px !important;
    color: #627178 !important;
    font-size: 14px;
    display: inline-block;
    background: transparent;
    border-image-slice: 1;
    text-decoration: none !important;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    font-family: 'Montserrat', sans-serif;
    font-weight: 400;
}

.btn-border-gradient:hover {
    background: #8080ff; /* For browsers that do not support gradients */
    background: -webkit-linear-gradient(left, #8080ff, #7adcf2); /* For Safari 5.1 to 6.0 */
    background: -o-linear-gradient(left, #8080ff, #7adcf2); /* For Opera 11.1 to 12.0 */
    background: -moz-linear-gradient(left, #8080ff, #7adcf2); /* For Firefox 3.6 to 15 */
    background: linear-gradient(left, #8080ff, #7adcf2); /* Standard syntax */
    color: #fff !important;
}

.fp-slides {
    display: flex;
    flex: 5;
}

.carousel-inner .item {
    height: 100%;
}

.client-wrapper {
    display: flex; 
    flex-direction: row; 
    justify-content: center; 
    align-items:center; 
    flex: 1; 
    background: #fff;
}

.label-section {
    display: flex; flex: 1; justify-content:center; align-items:center;
}

.logo-section {
    display: flex; flex: 5; justify-content:space-around; align-items:center;
}

.flex-row {
    flex-direction: row;
}

.overall-title {
    padding-top: 120px; 
    padding-left: 100px; 
    position:relative;
}

.overall-title .title {
    margin:0px; color:#ccc; font-size: 22px;
}

.overall-title .desc {
    margin: 0px; padding-top: 0px;
}

.section-wrapper-1 {
    position: absolute; 
    right: 40px; 
    bottom: 150px; 
    z-index:3; 
    width: 300px; 
    text-align: right;
}

.innovation-title {
    font-size: 4em; line-height: 1em; color: #627178;
}

.innovation-desc {
    font-size: 14px; line-height: 20px; margin-top: 15px; margin-bottom: 25px; color: #627178;
}

.shape-bg1 {
    position: absolute; 
    top:0px; 
    right:0px; 
    width: 100%; 
    height: 100%; 
    background-repeat: no-repeat ; 
    background-position:center center !important;
    
}

.section-wrapper-2 {
    position: absolute; 
    right: 40px; 
    top: 150px; 
    z-index:3; 
    width: 400px; 
    text-align: right;
}

.shape-bg2 {
    position: absolute; 
    top:0px; 
    right:0px; 
    width: 100%; 
    height: 100%; 
    background-repeat: no-repeat; background-position: center center !important;
}

.section-wrapper-3 {
    position: absolute; 
    right: 40px; 
    bottom: 150px; 
    z-index:3; 
    width: 310px; 
    text-align: right;
}

.shape-bg3 {
    position: absolute; 
    top:0px; 
    right:0px; 
    width: 100%; 
    height: 100%; background-repeat: no-repeat; background-position-x: 100%; background-position: center center !important;
}

.section-wrapper-4 {
    position: absolute; 
    left: 40px; 
    top: 150px; 
    z-index:3; 
    width: 300px; 
    text-align: left;
}

.shape-bg4 {
    position: absolute; top:0px; left:0px; width: 100%; height: 100%; background-position: center center;
}

.section-wrapper-5 {
    position: absolute; 
    left: 40px; 
    bottom: 150px; 
    z-index:3; 
    width: 300px; 
    text-align: left;
}

.shape-bg5 {
    position: absolute; top:0px; left:0px; width: 100%; height: 100%; background-position: center center !important;
}

.project-wrapper {
    width: 70%; padding-top: 50px; 
}

.project-flex {
    display: flex; flex-direction: column; justify-content: flex-end; align-items:flex-end; flex: 1;
}

.project-flex .top-row {
    display: flex; flex:1; flex-direction: row; justify-content: flex-end; align-items: flex-end;
}

.project-flex .bottom-row {
    display: flex; flex:1; flex-direction: row; justify-content: flex-end; align-items: center; margin-top:20px;
}

.project-box {
    width: 200px; height: auto; margin: 5px;
}

.project-img {
    width: 200px; height: auto; padding-bottom: 10px;
}

.big-project-box {
    width: 250px; height: auto; 
}

.big-project-img {
    width: 250px; height: auto; padding-bottom: 10px;
}

.project-title {
    padding:30px; text-align:right; padding-right:30px;
}

.project-title .desc {
    color: #afb8bd; font-size: 12px;
} 

.project-title .title {
    color:#627178; font-size: 3em; line-height: 1em; width: 325px;
}

.social-sharing-bar {
    display: flex; 
    flex-direction: row; 
    justify-content: center; 
    align-items:center; 
    flex: 0.3; 
    background: #f3f7fa; 
    position: fixed; 
    width: 100%; 
    bottom: 0px; 
    left: 0px; 
    z-index: 999; 
    padding: 5px;
}

#belt1 {
    width: 600px;
    height: auto;
    position: absolute;
    left: 100px;
    top: 80px;
    opacity: 0;
    animation-delay: 0.3s;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    transform: scale(1, 1);
    transform-origin: top left;
}

#belt2 {
    width: 600px; 
    height: auto; 
    position: absolute; 
    left: 225px; 
    top: 0px; 
    opacity:0;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    transform: scale(1, 1);
    transform-origin: top left;
}

#belt3 {
    width: 600px; 
    height: auto; 
    position: absolute; 
    left: 355px; 
    top: 0px; 
    opacity:0;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    transform: scale(1, 1);
    transform-origin: top left;
}

#belt4 {
    width: 750px; 
    height: auto; 
    position: absolute; 
    /* left:550px;  */
    right: 0px;
    top: 0px; 
    opacity:0;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    transform: scale(1, 1);
    transform-origin: top left;
}

#belt5 {
    width: 200px; 
    height: auto; 
    position: absolute; 
    right:20%; 
    top: 0px; 
    opacity:0;
    -webkit-transition: all 0.3s ease-in;
    -moz-transition: all 0.3s ease-in;
    -o-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
    z-index:0;
    transform: scale(1, 1);
    transform-origin: top left;
}

#flow1-side {
    position: absolute; 
    left: 37%; 
    top:40%; 
    width: 100px;
}

#flow2-side1 {
    position: absolute; 
    left: 27%; 
    top:21%; 
    width: 80px;
    z-index: 15;
}

#flow2-side2 {
    position: absolute; 
    left: -5%; 
    top:43%; 
    width: 160px;
    z-index: -1;
}

#flow3-side {
    position: absolute;
    left: 11%;
    top: 15%;
    width: 250px;
    z-index: 5;
}

#flow3-cover1 {
    position: absolute;
    left: 21%;
    top: 30%;
    width: 107px;
    z-index: 6;
    opacity:1;
}

#flow3-cover2 {
    position: absolute;
    left: 44%;
    top: 31.8%;
    width: 11px;
    z-index: 6;
    opacity:1;
}

#flow4-side {
    position: absolute;
    right: 32%;
    top: 13%;
    width: 500px;
    z-index: 5;
}

#flow5-side {
    position: absolute;
    right: 43%;
    top: 65%;
    width: 65px;
    z-index: 5;
}

#flow5-side2 {
    position: absolute;
    right: -47%;
    top: 45%;
    width: 205px;
    z-index: 5;
}

.site-content-contain {
    padding-top: 100px;
}

.home .site-content-contain {
    padding-top:0px;
}

.wpcf7-form {
    padding: 20px;
    padding-bottom: 20px;
    background: #fff;
    border-radius: 5px;
    padding-bottom: 0px;
    box-shadow: 0px 0px 15px rgba(0,0,0,0.3);
    margin-top: 50px;
}

#quote-page h1 {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: 3em;
    color: #333;
}

#quote-page p {
    font-family: 'Roboto', sans-serif;
}

form, form label, form input {
    font-family: 'Roboto', sans-serif;
}

.archive .product-column {
    height: 300px;
    overflow: hidden;
    border: 1px solid #ccc;
    margin: 5px;
    padding: 10px;
}

.tabcontent tr {
    border: 0px;
    border-bottom: 0px;
}

.entry-header .entry-title {
    font-size: 2.2em !important;
    font-family: 'Montserrat', san-serif !important;
}

.entry-content p {
    font-family: 'Roboto', sans-serif;
}

@media (min-width: 2024px) { 
    #belt1 {
        transform: scale(1.2,1.2);
        transform-origin: top left;
    }

    #belt2 {
        transform: scale(1.2,1.2);
        transform-origin: top left;
    }

    #belt3 {
        transform: scale(1.2,1.2);
        transform-origin: top left;
    }

    #belt4 {
        transform: scale(1.2,1.2);
        transform-origin: top right;
    }

    #belt5 {
        transform: scale(1.2,1.2);
        transform-origin: top left;
    }
}

/* Medium devices (1024px and down) */
@media (max-width: 1024px) { 
    .top-menu-shop-section {
        padding-right: 10px;
        padding-left: 10px;
    }

    .navigation-top a {
        padding: 15px 25px;
    }

    .top-menu-shop-section {
        background: rgba(255,255,255,0.85);
        position: absolute;
        right: -1px;
        top: 84px;
        padding: 10PX;
        padding-left: 0px;
        padding-top: 0px;
        padding-bottom: 0px;
        padding-right: 38px;
    }

    .top-menu-shop-section a, .top-menu-shop-section p {
        display: inline-block !important;
    }

    #belt1 {
        transform: scale(0.85,0.85);
        transform-origin: top left;
    }

    #belt2 {
        transform: scale(0.85,0.85);
        transform-origin: top left;
    }

    #belt3 {
        transform: scale(0.85,0.85);
        transform-origin: top left;
    }

    #belt4 {
        transform: scale(0.85,1);
        transform-origin: top right;
    }

    #belt5 {
        transform: scale(0.85,0.85);
        transform-origin: top left;
    }

}

@media (max-width: 896px) { 
    #belt1 {
        transform: scale(0.75,0.75);
        transform-origin: top left;
    }

    #belt2 {
        transform: scale(0.75,0.75);
        transform-origin: top left;
    }

    #belt3 {
        transform: scale(0.75,0.75);
        transform-origin: top left;
    }

    #belt4 {
        transform: scale(0.75,1);
        transform-origin: top right;
    }

    #belt5 {
        transform: scale(0.75,0.75);
        transform-origin: top left;
    }
}

@media (max-width: 784px) { 
    .top-menu-shop-section {
        padding-right: 10px;
        padding-left: 10px;
    }

    .navigation-top a {
        padding: 15px 25px;
    }

}

/* Small devices (tablets, 768px and up) */
@media (max-width: 768px) { 
    .product-list-box {
        height: 250px;
    }
    .top-products-wrapper {
        display: flex;
        flex-direction: column;
        margin-top: 20px;
    }

    
    .elcomgate-inner-logo img {
        width: 30%;
        height: auto;
    }

    .site-content-contain {
        padding-top:0px;
    }
    .fp-section {
        overflow: hidden;
    }
    .navigation-top {
        height: auto;
    }

    .call-us-text {
        margin-bottom: 0px; 
        font-size: 1.2em;
    }

    .phone-no-big {
        font-size: 2em; 
        margin-bottom: 0px; 
    }

    #innovation-section .wrapper {
        width: 100%; 
        padding-top: 0px; 
    }

    #innovation-section .side-image {
        width: 33%; 
        height: auto; 
        margin: 0 auto;
    }

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

    .footer-link {
        order: 2;
    }

    .footer-logo {
        order: 1;
    }

    .overall-title {
        padding-left: 20px;
        padding-top: 20px;
    }

    .overall-title .title {
        font-size: 14px;
    }

    .overall-title .desc {
        font-size: 22px;
    }

    .hero-title {
        font-size: 2.5em;
    }

    .hero-desc {
        font-size: 1em;
        text-align:center;
    }

    #belt1 {
        transform-origin: top left;
        width: 600px;
        left: -80px;
        top: 65px;
        transform: scale(0.65,0.65);
    }

    .shape-bg1 {
        background-size: cover;
        bottom: 0px;
        z-index: 9;
        left: 0px;
        background-repeat: no-repeat;
        background-position: center center;
        background-size: 224% 100% !important;
        background-position: -364px -00px !important;
    }

    .section-wrapper-1 {
        right: 10px;
        width: 200px;
    }

    .section-title {
        font-size: 16px;
    }
    
    .section-desc {
        font-size: 11px;
    }

    #belt2 {
        transform-origin: top left;
        left: 11px;
        top: 0px;
        transform: scale(0.65,0.75);
    }

    #belt4 {
        transform-origin: top right;
        left: 0px;
    }

    #belt5 {
        transform: scale(0.65,0.65);
        transform-origin: top left;
        right: 0%;
    }

    #belt3 {
        left: -35px;
    }

    #belt4 {
        left:23px;
    }

    .shape-bg2 {
        background-repeat: no-repeat;
        background-position: -335px !important;
    }

    .shape-bg3 {
        background-position: -450px center !important;
    }

    .shape-bg5 {
        background-position: center center !important;
    }

    .section-wrapper-2 {
        right: 10px;
        top: 10px;
        width: 200px;
    }

    .section-wrapper-3 {
        right: 10px;
        width: 200px;
    }

    .section-wrapper-4 {
        left: 10px;
        top: 10px;
        width: 200px;
    }

    .section-wrapper-5 {
        left: 10px;
        width: 200px;
    }

    
    .social-sharing-bar {
        padding-left: 20px;
        padding-right: 20px;
        text-align:center;
    }

    .innovation-title {
        font-size: 2em;
    }

    .innovation-desc {
        font-size: 12px;
    } 

    .project-wrapper {
        width: 100%;
    }

    .project-flex .top-row {
        justify-content: flex-end;
        align-items: center;
    }

    .project-flex {
        justify-content: center;
        align-items: center;
    }

    .project-title {
        padding: 0px;
        padding-right: 20px;
    }

    .project-title .title {
        font-size: 2em;
        line-height: 1em;
        width: 155px;
    }

    .big-project-box {
        width: 200px;
        height: auto;
    }

    .big-project-img {
        width: 200px;
        height: auto;
    }

    .project-flex .bottom-row {
        justify-content: space-around;
        flex-wrap: wrap;
    }

    .phone-no-big img {
        width: 30px !important;
    }

    .project-box {
        width: auto;
        height: auto;
    }

    .project-box p {
        text-align: center;
    }

    .project-img {
        width: 150px;
        height: 150px;
    }

    .client-wrapper {
        flex-direction: column;
        padding: 20px;
    }

    .navbar-collapse {
        width: 100%;
        margin: 0px;
        text-align: left;
        padding: 0px;
        background: transparent none repeat scroll 0% 0%;
    }

    .menu-top-menu-container {
        margin: 0px;
        padding: 0px;
        background: transparent;
        overflow-x: hidden;
        width: 100%;
    }

    .navbar.fixed-top {
        margin: 0px;
        position: fixed;
        top: 0px;
        left: 0px;
        width: 100%;
        height: auto;
        background: rgba(255,255,255,0.85);
    }

    .navbar-nav {
        width: 100%;
        padding: 0px;
        margin: 0px;
        background: transparent;
    }

    .main-navigation ul {
        background: transparent;
        padding: 0px;
    }

    .navbar-nav .menu-item {
        text-align: left;
        padding: 5px;
        border-bottom: 0px;
    }

    .navbar-nav ul.sub-menu {
        background: transparent;
    }

    .navbar-nav ul.sub-menu li a {
        padding: 5px 20px;
    }

    .dropdown-toggle {
        right: 0px;
        top: 10px;
    }

    .js .menu-toggle {
        display: inline-block; 
        vertical-align: middle;
    }

    .js .menu-toggle .icon {
        width: 20px;
        height: 20px;
        vertical-align: middle;
        padding: 0px;
        margin: 0px;
        top: 0px;
    }

    .navbar .custom-logo-link {
        display: inline-block;
        width: 180px;
        vertical-align: middle;
        padding: 0px;
    }

    .navbar #solid_shop {
        font-size: 16px;
        display: block !important;
        width: 150px;
        text-align: center;
        margin: 20px 30px;
        margin-top: 20px;
        margin-top: 10px;
    }

    .navbar .phone-number {
        font-size: 12px;    
        font-weight: 900;
        text-align: right;
        vertical-align: middle;
        float: right;
        padding-top: 5px;
        padding-right: 10px;
    }
}
