/* general */
@font-face {
    font-family: 'robotolight';
    src: url('../fonts/roboto-light.eot');
    src: url('../fonts/roboto-light.eot?#iefix') format('embedded-opentype'),
        url('../fonts/roboto-light.woff2') format('woff2'),
        url('../fonts/roboto-light.woff') format('woff'),
        url('../fonts/roboto-light.ttf') format('truetype'),
        url('../fonts/roboto-light.svg#robotolight') format('svg');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'robotoregular';
    src: url('../fonts/roboto-regular.eot');
    src: url('../fonts/roboto-regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/roboto-regular.woff2') format('woff2'),
        url('../fonts/roboto-regular.woff') format('woff'),
        url('../fonts/roboto-regular.ttf') format('truetype'),
        url('../fonts/roboto-regular.svg#robotoregular') format('svg');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'robotoblack';
    src: url('../fonts/roboto-black.eot');
    src: url('../fonts/roboto-black.eot?#iefix') format('embedded-opentype'),
        url('../fonts/roboto-black.woff2') format('woff2'),
        url('../fonts/roboto-black.woff') format('woff'),
        url('../fonts/roboto-black.ttf') format('truetype'),
        url('../fonts/roboto-black.svg#robotoblack') format('svg');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'bebas_neueregular';
    src: url('../fonts/bebasneue.eot');
    src: url('../fonts/bebasneue.eot?#iefix') format('embedded-opentype'),
        url('../fonts/bebasneue.woff2') format('woff2'),
        url('../fonts/bebasneue.woff') format('woff'),
        url('../fonts/bebasneue.ttf') format('truetype'),
        url('../fonts/bebasneue.svg#bebas_neueregular') format('svg');
    font-weight: normal;
    font-style: normal;
}
html, body{
    width: 100%;
    overflow-x: hidden
}
.container-fluid{
    max-width: 100%;
    width: 1320px;
}
h1, h2, .title{
    color: #999999;
    font-family: 'robotolight';
    font-size: 40px;
    text-transform: uppercase;
    font-weight: normal;
    margin: 40px 0;
}
h3{
    font-family: 'robotoblack';
    font-weight: normal;
    color: #344f9e;
    font-size: 30px;
    margin-top: 0;
    text-transform: uppercase;
}
h4{
    font-family: 'robotoblack';
    font-weight: normal;
    color: #344f9e;
    font-size: 20px;
    margin-top: 0;
    text-transform: uppercase
}
p, span{
    font-family: 'robotolight';
}
p{
    font-size: 16px;
    color: #333333;
}
b{
    font-family: 'robotoblack';
}
a:hover{
    text-decoration: none;
}
a.hover-opacity:hover , .hover-opacity a:hover{
    opacity: .7;
}
.uppercase{
    text-transform: uppercase
}
.text-center{
    text-align: center;
}
.transition , a , 
.btn-left i, 
.btn-right i , 
.box-prod-link p:hover , 
.carousel-indicators li, 
ul.menu-prod li.li-title:after{
    -webkit-transition: all .5s ease;
    -moz-transition: all .5s ease;
    -ms-transition: all .5s ease;
    -o-transition: all .5s ease;
    transition: all .5s ease;
}
.bg-gray{
    background-color: #eee;
}
.no-padding{
    padding: 0
}
/* end general */

/* header */
.navbar-toggle{
    display: block;
}
.navbar>.container-fluid .navbar-brand{
    padding: 0;
    height: auto;
    margin-top: 31px;
    margin-left: 0;
}
.navbar-toggle .sr-only{
    border: 0;
    clip: auto;
    color: #353f4b;
    font-family: 'robotoregular';
    font-size: 15px;
    overflow: visible;
    right: 130px;
    text-transform: uppercase;
    position: absolute;
}
.navbar-default{
    background: #fff;
    border: none;
    margin-bottom: 0;
}
.navbar-default .navbar-toggle{
    background: #181b2b;
    border-radius: 0;
    padding: 26px 24px 27px 24px;
    margin: 36px 0;
    border-color: #181b2b;
}
.navbar-default .navbar-toggle:hover{
    border-color: #ddd;
}
.navbar-default .navbar-toggle .icon-bar {
    background-color: #1fa5ff;
    width: 20px;
}
.navbar-toggle .icon-bar+.icon-bar {
    margin-top: 5px;
}
.sidenav {
    height: 100%;
    width: 0;
    position: fixed;
    z-index: 1;
    top: 0;
    right: 0;
    background: #ededed;
    overflow-x: hidden;
    padding-top: 37px;
    text-align: right;
    z-index: 999;
}
.sidenav ul{
    float:  right;
    padding-left: 50px;
    width: 100%;
}
.sidenav ul li{
    list-style: none;
}
.sidenav a {
    padding: 13px 0;
    text-decoration: none;
    font-size: 17px;
    text-transform: uppercase;
    color: #353f4b;
    display: block;
}
.sidenav ul li a {
    border-bottom: solid 1px #bebebe;
}
.sidenav ul li.active a , .sidenav ul li a:hover{
    border-color: #5d9eff;
    color: #5d9eff;
}
.sidenav ul li.active a{
    font-weight:    bold;
}

.sidenav a:hover, .offcanvas a:focus{
    color: #f1f1f1;
}

.sidenav .closebtn {
    border: solid 3px #5d9eff;
    float:  right;
    font-size: 36px;
    padding: 7px;
    width: 71px;
    text-align: center;
}
.sidenav .closebtn:hover{
    background: #ddd;
    color: #353f4b;
}
.box-header {
    left: 50%;
    margin-left: -190px;
    position: absolute;
    top: 53px;
    width: 530px;
}
.box-header > a {
    display: inline-block;
    padding-right: 55px;
    position: relative
}
.box-header > a:after{
    position: absolute;
    top: 0;
    right: 25px;
    height: 38px;
    background: #d2d2d2;
    content: '';
    width: 1px;
}
.box-header p{
    float: right;
    font-family: 'robotoregular';
    line-height: 15px;
    margin: 5px 0
}
.box-header p a{
    color: #000;
    font-size:  13px;
}
/* end header */

/* home */
#slide-home{
    height: 480px;
    padding-bottom: 35px;
}
.carousel-control{
    width: 20%;
}
.carousel-control.left, .carousel-control.right{
    background: #344f9e;
    bottom: 35px;
    opacity: 1;
    text-shadow: none;
    top: auto;
}
.btn-left , .btn-right{
    background: #344f9e;
    color: #1fa5ff;
    font-size: 28px;
    height: 50px;
    padding: 7px;
    text-align: center;
}
.btn-left:hover, .btn-right:hover, .btn-left:focus, .btn-right:focus{
    color: #fff;
}
.btn-left:hover i{
    margin-left: -15px;
}
.btn-right:hover i{
    margin-right: -15px;
}
.carousel-indicators{
    bottom: 0;
    margin-bottom: 0;
    margin-top: 0;
}
.carousel-indicators li , .carousel-indicators .active{
    background: #b3b3b3;
    border: none;
    border-radius: 0;
    height: 5px;
    margin: 0 3px;
    width: 100px;
}
.carousel-indicators .active , .carousel-indicators li:hover {
    background-color: #395eab;
}
.carousel-inner{
    height: 445px;
}
.carousel-inner>.item{
    background: #ccc;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: auto 100% ;
    height: 480px;
    width: 100%
}
.carousel-inner>.item a{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    text-align: center;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
}
.box-prod a{
    display: inline-block;
    position: relative;
    max-width: 100%;
}
.box-prod a .box-prod-link{
    background: rgba(0,0,0,.5);
    bottom: 0;
    left: 0;
    opacity: 0;
    position: absolute;
    right: 0;
    top: 0;
}
.box-prod a .box-prod-link:hover{
    opacity: 1
}
.box-prod p{
    font-size: 17px;
    margin: 30px 0;
}
.box-prod-link p{
    background: #3c64b1;
    color: #fff;
    display: block;
    font-size: 40px;
    left: 50%;
    line-height: 60px;
    margin-left: -30px;
    margin-top: -30px;
    position: absolute;
    text-align: center;
    top: 50%;
    width: 60px;
}
.box-prod-link p:hover{
    color: #1fa5ff;
}
.box-home-serv {
    margin-top: 80px;
    padding-bottom: 60px;
    padding-top: 30px;
}
.box-home-serv .box-serv{
    padding-bottom: 80px;
}
.btn-plus{
    background: #3c64b1;
    color: #fff;
    display: block;
    font-size: 40px;
    line-height: 45px;
    text-align: center;
    width: 45px;
}
.box-home-serv .box-serv p{
    margin: 0;
    min-height: 200px;
}
.btn-plus:hover , .btn-plus:active{
    color: #1fa5ff;
}
.btn-green , .form-control.btn-green{
    background: #4ba029;
    color: #ffffff;
    font-family: 'robotoregular';
    font-size: 17px;
    margin-bottom: 50px;
    padding: 13px;
}
.btn-green:hover{
    background: #449026;
    color: #fff;
}
/* end home */

/* servicos */
.box-page-title{
    background-color: #1d4ea2;
}       
.box-page-title h2{
    color: #fff;
    display: inline-block;
    font-size: 30px;
    margin: 30px 0;
}
.box-page-title ul.breadcrumb{
    float: right;
    margin: 40px 0px;
}
.box-page-title ul li{
    color: #fff;
    display: inline-block;
    font-size: 15px;
    padding-right: 18px;
    position: relative
}
.box-page-title ul li a{
    color: #fff;
}
.box-page-title ul li:after{
    position: absolute;
    top: 0;
    right: 5px;
    content: '/';
}
.box-page-title ul li:last-child{
    padding-right: 0;
}
.box-page-title ul li:last-child:after{
    display: none;
}
.box-page-serv .box-page-title{
    margin-bottom: 0;
}
.box-page-serv .box-serv {
    padding-top: 65px;
    padding-bottom: 50px;
}
.box-page-serv .box-serv p{
    margin-bottom: 0;
}
.box-page-serv .box-serv:nth-child(odd) {
    background-color: #eee;
}  
.box-page-serv .box-serv:nth-child(even) {
    background-color:#fff;
} 
.custom-list{
    padding-left: 0;
    list-style: none;
}
.custom-list li{
    font-family: 'robotolight';
    font-size: 16px;
    margin-bottom: 10px;
    padding-left: 15px;
    position: relative;
}
.custom-list li:before{
    background: #1d4ea2;
    border-radius: 50%;
    content: '';
    display: block;
    height: 4px;
    left: 0;
    position: absolute;
    top: 10px;
    width: 4px;
}
/* end servicos */

/* produtos */
.box-page-title{
    margin-bottom: 65px;
}
ul.menu-prod{
    list-style: none;
    margin-top: 0;
    padding-left: 0;
    font-size: 17px;
}
ul.menu-prod li.li-title{
    color: #344f9e;
    font-family: 'robotoblack';
}
ul.menu-prod li a , ul.menu-prod li.li-title{
    background: #ededed;
    border-bottom: solid 5px #fff;
    display: block;
    padding: 13px
}
ul.menu-prod li a:hover , ul.menu-prod li.active a{
    background: #344f9e;
    color: #fff;
}
ul.menu-prod li.active a{
    font-family: 'robotoblack';
}
.box-page-prod .box-prod > p{
    margin-bottom: 0;
    height: 100px;
}
.paginacao{
    margin: auto;
    margin-bottom: 50px;
}
.paginacao li{
    display: inline-block;
    margin: 2.5px;
}
.paginacao li a{
    background: #4ba029;
    color: #fff;
    display:    block;
    line-height: 40px;
    width: 40px;
}
.paginacao li a:hover{
    background: #449026;
}
.paginacao .active, .paginacao .active a {
    background: #344F9E;
    color: #fff;
    display:    block;
    line-height: 40px;
    width: 40px;
}
/* end produtos */

/* desc prodtos */
.box-page-prod-desc h3{
    margin-bottom: 55px;
}
.box-page-prod-desc p{
    margin-top: 0;
}
.img-desc-prod , .desc-prod{
    padding-bottom: 50px;
}
.desc-prod {
    padding-left: 35px;
}
.box-page-prod-desc .btn-orc{
    margin-top: 50px;
}
/* end desc prodtos */

/* empresa */
.box-page-empresa h4:not(:first-child){
    margin-top: 60px;
}
.box-img {
    float: left;
    width: 20%;
    padding: 15px;
}
.box-empresa-fotos {
    margin: 45px 0 50px 0;
    padding: 50px 0;
}
/* end empresa */

/* orçamento */
.form-control{
    background: #dbdbdb;  
    border: none;
    border-radius: 0;
    box-shadow: none;
    color: #666666;
    font-family: 'robotoregular';
    font-size: 16px;
    height: 55px;
    padding: 15px;
}
.form-group{
    margin-bottom: 10px;
}
.box-page-form h3{
    font-size: 25px;
    line-height: 30px;
    margin-bottom: 45px;
}
textarea.form-control{
    height: 115px
}
.form-control.btn-green{
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 1px;
    margin-bottom: 0;
}
 .wpcf7-submit {
     background: #4ba029;
    color: #ffffff;
    font-family: 'robotoregular';
    font-size: 17px;
    margin-bottom: 50px;
    padding: 13px;
}
.wpcf7-submit:hover{
    background: #449026;
    color: #fff;
}
.wpcf7-response-output {
    margin: 10px 0px;
    padding:12px;
}
.wpcf7-mail-sent-ok {
   color: #4F8A10;
  background-color: #DFF2BF;
}
div.wpcf7 .screen-reader-response {
    border: 0 none;
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    margin: 0;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}
::-webkit-input-placeholder { /* Chrome/Opera/Safari */
    color: #666666 !important;
}
::-moz-placeholder { /* Firefox 19+ */
    color: #666666 !important;
}
:-ms-input-placeholder { /* IE 10+ */
    color: #666666 !important;
}
:-moz-placeholder { /* Firefox 18- */
    color: #666666 !important;
}
/* end orçamento */

/* contato */
.box-page-contato .box-page-title{
    margin-bottom: 0;
}
.box-map{
    height: 390px;
    margin-bottom: 70px;
    width: 100%;
}
.box-map iframe{
    width: 100%;
}
hr{
    border-top: 2px solid #dbdbdb;
    margin-bottom: 45px;
}
.box-form-orc{
    margin-bottom: 50px
}
/* end contato */

/* pre footer */
.pre-footer{
    padding-bottom: 60px;
}
.pre-footer p{
    color: #999999;
    float: left;
    font-size: 13px;
    margin: 16px 15px 0 15px;
}
.pre-footer a{
    display: block;
    float: left;
    font-size: 16px;
    line-height: 40px;
    margin-top: 5px;
    text-align: center;
    width: 40px;
}
.pre-footer a.back-to-home{
    background: #dbdbdb;
    color: #395195;
}
.pre-footer a.back-to-home:hover{
    margin-left: -5px;
}
.pre-footer .box-social a{
    color: #fff;
    margin-left: 5px;
}
.pre-footer .box-social a:hover{
    margin-top: 0px;
    margin-bottom: 5px;
}
.pre-footer .box-social a.facebook{
    background: #395195;
}
.pre-footer .box-social a.twitter{
    background: #78c7fd;
}
.pre-footer .box-social a.google-plus{
    background: #06FA03;
}
/* end pre footer */

/* footer */
footer{
    background: #1f212e;
    padding: 70px 0 55px 0;;
}
footer p{
    color: #fff;
}
footer a , footer a:hover{
    color: #fff;
}
.logo-fg img{
    display: block;
    float: right;
    margin-top: 60px;
}
/* end footer */


/*** responsive ***/

@media screen and (max-width: 1360px){
    /* general */
    .container-fluid{
        padding: 0 50px;
    }
    /* end general */

    /* home */
    .box-home-serv .box-serv p {
        margin-bottom: 30px;
        min-height: 10px;
    }
    /* end home */
}
@media screen and (max-width: 1100px){
    /* header */
    .box-header > a{
        display: none;
    }
    .box-header{
        border-left: solid 1px #d2d2d2;
        margin-left: -40px;
        width: 215px;
    }
    /* end header */

    /* home */
    #slide-home{
        height: 320px;
    }
    .carousel-inner, .carousel-inner>.item {
        height: 285px;
    }
    /* end home */

    /* orçamento */
    .box-page-orc .box-page-title ul.breadcrumb{
        float: none;
        margin-top: 0;
        padding: 0;
    }
    /* end orçamento */
}
@media screen and (max-width: 991px){
    /* produtos */
    ul.menu-prod{
        max-height: 55px;
        overflow: hidden;
    }
    ul.menu-prod.open{
        max-height: 440px;
    }
    ul.menu-prod li.li-title{
        cursor: pointer;
    }
    ul.menu-prod li.li-title:after{
        position: absolute;
        top: 20px;
        right: 30px;
        content: '';
        width: 0;
        height: 0;
        border-left: 10px solid transparent;
        border-right: 10px solid transparent;
        border-top: 10px solid #1d4ea2;
    }
    ul.menu-prod.open li.li-title:after{
        -moz-transform: rotate(180deg);
        -webkit-transform: rotate(180deg);
        -o-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
    }
    .box-page-prod h3 , .box-page-prod-desc h3{
        margin-bottom: 60px;
    }
    .desc-prod{
        padding-left: 15px;
    }
    /* end produtos */

    /* empresa */
    .box-page-empresa h4:not(:first-child){
        margin-top: 60px;
    }
    .box-img {
        width: 33.30003%
    }
    /* end empresa */

    /* contato */
    .box-map{
        position: relative
    }
    .box-map:before{
        content: '';
        bottom: 0;
        display: block;
        left: 0;
        position: absolute;
        right: 0;
        top: 0;
    }
    /* end contato */
}
@media screen and (max-width: 767px){
    /* general */
    h1, h2, .title{
        margin-bottom: 20px;
    }
    .box-page-title h2{
        font-size: 25px;
        margin: 25px 0;
    }
    /* end general */

    /* header */
    .navbar-header{
        float: left;
    }
    .container-fluid>.navbar-header{
        margin-left: 0
    }
    .navbar>.container-fluid .navbar-brand{
        margin-top: 20px;
    }
    .navbar-brand>img{
        width: 200px;
    }
    .navbar-default .navbar-toggle{
        margin: 23px 0;
        padding: 17px 15px 18px 15px;
    }
    .navbar-toggle .sr-only{
        display: none
    }
    .sidenav .closebtn {
        padding: 0;
        width: 52px;
        line-height: 46px;
    }
    .sidenav{
        padding-top: 23px;
    }
    .sidenav a {
        padding: 7px 0;
    }
    /* end header */

    /* home */
    #slide-home{
        height: 300px;
    }
    .carousel-inner, .carousel-inner>.item {
        height: 265px;
    }
    .carousel-indicators{
        left: 0;
        margin-left: 0;
        width: 100%;
    }
    .carousel-indicators li, .carousel-indicators .active{
        width: 60px;
    }
    .box-home-serv{
        margin-top: 60px;
        padding-bottom: 5px;
    }
    .box-home-serv .box-serv {
        padding-bottom: 60px;
    }
    .box-serv img{
        margin-bottom: 30px;
    }
    /* end home */

    /* serviços */
    .box-page-serv .box-serv {
        padding-top: 50px;
        padding-bottom: 45px;
    }
    /* end serviços */

    /* produtos */
    .box-page-title {
        margin-bottom: 50px;
    }
    .box-page-prod h3 , .box-page-prod-desc h3{
        margin-bottom: 45px;
        font-size: 23px;
        line-height: 27px;
    }
    .box-page-prod .box-prod p {
        height: auto;
        margin-bottom: 45px;
    }
    .img-desc-prod{
        padding-bottom: 40px;
    }
    .desc-prod {
        padding-bottom: 25px;
    }
    /* end produtos */

    /* empresa */
    .box-page-empresa h4:not(:first-child){
        margin-top: 50px;
    }
    .box-empresa-fotos {
        margin: 35px 0 50px 0;
        padding: 50px 7.5px;
    }
    .box-img {
        padding: 7.5px;
        width: 50%;
    }
    /* end empresa */

    /* orçamento */
    .box-page-form h3 {
        font-size: 21px;
        line-height: 25px;
    }
    /* end orçamento */

    /* contato */
    .box-map{
        margin-bottom: 50px;
    }
    .box-page-contato.box-page-form h3{
        margin-bottom: 30px;
    }
    .box-page-contato.box-page-form form{
        margin-top: 50px;
    }
    hr{
        margin-bottom: 30px;
    }
    /* contato */

    /* footer */
    footer{
        padding: 60px 0 50px 0
    }
    .box-footer{
        margin-bottom: 50px;
    }
    .logo-fg img{
        float:  none;
        margin-top: 50px;
    }
    /* end footer */       
}
@media screen and (max-width: 660px){
    /* home */
    #slide-home{
        height: 230px;
    }
    .carousel-inner, .carousel-inner>.item  {
        height: 195px;
    }
    .carousel-control.left, .carousel-control.right{
        display: none;
    }
    /* end home */
}
@media screen and (max-width: 480px){
    /* general */
    .container-fluid {
        padding: 0 30px;
    }
    /* end general */

    /* header */
    .sidenav ul{
        padding-left: 30px;
    }
    /* end header */

    /* home */
    #slide-home{
        height: 150px;
    }
    .carousel-inner, .carousel-inner>.item {
        height: 115px;
    }
    /* end home */
}
@media screen and (max-width: 360px){
    /* general */
    .container-fluid {
        padding: 0 20px;
    }
    /* end general */

    /* header */
    .sidenav ul{
        padding-left: 20px;
    }
    /* end header */

    /* pré footer */
    .pre-footer a {
        line-height: 35px;
        width: 35px;
    }
    .pre-footer p {
        margin: 14px 5px 0 5px;
    }
    /* end pré footer */
}
/*** end responsive ***/