html {
    height: 100%;
    box-sizing: border-box;
}

*, *:before, *:after {
    box-sizing: inherit;
}

body {
    /*background:#fff url('/images/hexagons.png') no-repeat right top;*/
    color:#000;
    position: relative;
    margin: 0;
    padding: 0;
    min-height: 100%;
}

body:after {
    content: ' ';
    display: block;
    height: 60px;
}

.h1, .h2, .h3, .h4, .h5, .h6,
h1, h2, h3, h4, h5, h6 {
    color: #000;
}

.h1, h1{ font-size: 24px; font-weight: 700; }
.h2, h2{ font-size: 18px; font-weight: 700; }
.h3, h3{ font-size: 16px; font-weight: 700; }
.h4, h4{ font-size: 14px; font-weight: 700; }
.h5, h5{ font-size: 14px; font-weight: 400; }
.h6, h6{ font-size: 12px; font-weight: 400; }

.orange{
    color:  #e57f44;
}

.red{
    color:  #de001f;
}

.bold{
    font-weight: bold;
}

.capitalize-first::first-letter{
    text-transform: uppercase;
}

p{ font-size: 14px; font-weight: 400; }

p.lead{ font-size: 14px !important; font-weight: 700; }

hr{ border-top: 1px solid #aaa; }

.relative { position: relative; }

.btn-orange{
    color: #fff;
    background-color: #e57f44;
    box-shadow:  inset 0 -2px 0 0 rgba(0,0,0,.2);
    -webkit-box-shadow: inset 0 -2px 0 0 rgba(0,0,0,.2);
}
.btn-orange:active,
.btn-orange:focus,
.btn-orange:hover{
    background-color: #e98348;
    color: #fff;
}

.btn-default.focus,
.btn-default:focus,
.btn-default:hover {
    background-color: #f0f0f0;
}

.btn-transparent{
    color: #333 !important;
    border:1px solid #e57f44;
    border-radius:2px;
    background-color: none;
    box-shadow: none;
    -webkit-box-shadow: none;
}
.btn-transparent:hover{
    color: #fff !important;
    background-color: #e57f44;
    border:1px solid transparent;
}
.btn-transparent:active,
.btn-transparent:focus{
    color: #fff !important;
    background-color: #cc723d;
    border:1px solid transparent;
}

.btn-blue{
    color: #333 !important;
    border:1px solid #1082BE;
    border-radius:2px;
    background-color: none;
    box-shadow: none;
    -webkit-box-shadow: none;
    min-width: 175.42px;
}
.btn-blue:hover{
    color: #fff !important;
    background-color: #1082BE;
    border:1px solid transparent;
}

.btn-white{
    color: #333;
    border:1px solid #ccc;
    border-radius:2px;
    background-color: white;
    box-shadow: none;
    -webkit-box-shadow: none;
}
.btn-white:hover{
    color: #222 !important;
    border:1px solid #888;
}
.btn-white:active,
.btn-white:focus{
    color: #333;
    border:1px solid #bbb;
    box-shadow: none;
}





.jumbotron{
    background: -moz-linear-gradient(left, #ac403f 0%, #cb8048 100%);
    background: -webkit-linear-gradient(left, #ac403f 0%,#cb8048 100%);
    background: linear-gradient(to right, #ac403f 0%,#cb8048 100%);
    -webkit-border-radius: 2px !important;
    -moz-border-radius: 2px !important;
    border-radius: 2px !important;
}

textarea { resize: none; }


.inline{ display:inline; }

.inline-block{ display:inline-block; }

.block{ display:block; }

.label-check{
    font-weight: 100 !important;
}

.margin-right-10{
    margin-right: 10px;
}



#botoes {
    width: 52%;
    float: right;
}

#botoes .btn {
    width: 90px;
    margin-left: 5px;
}

#botoes #btn-delete,
#botoes #btn-edit-creative{
    margin-bottom: 5px;
}

#btn-delete{
    margin-left: 5px;
}


/* nova tabela com sorting sem datatable */
.sortable th{
    -webkit-user-select: none;
    -moz-user-select: none;
    -khtml-user-select: none;
    -ms-user-select: none;
}
.sortable th:not(.no-sort){
    cursor: pointer;
    background-image: url('/images/sort_both.png');
    background-repeat: no-repeat;
    background-position: center right;
}

.sorting {
    background-image: url('/images/sort_both.png');
}
.sorting_asc {
    background-image: url('/images/sort_asc.png') !important;
}
.sorting_desc {
    background-image: url('/images/sort_desc.png') !important;
}
.sorting_asc_disabled {
    background-image: url('/images/sort_asc_disabled.png') !important;
}
.sorting_desc_disabled {
    background-image: url('/images/sort_desc_disabled.png') !important;
}



.table-loader{
    max-width: 280px;
    margin: 0 auto;
}

.table-loader-lg{
    max-width: 380px;
    margin: 0 auto;
}

.alert-loader::before{
    /* Por motivo desconhecido, o spinner no bootstrap uol está
    rodando ao contrário então precisa disso pra corrigir. */
    animation-direction: reverse !important;
}




.datepicker table tr td.disabled, .datepicker table tr td.disabled:hover {
    color: #ccc !important;
}

.dataTables_wrapper{
    margin: 0 auto;
}




.skeleton{
    border-radius: 40px;
    background-color: #e8e8e8;
    padding: 0px 5px;
    margin-right: 10px;
}

.skeleton:before{
    content: ' ';
}


.skeleton-xs{
    padding-left: 30px;
    padding-right:30px;
}

.skeleton-md{
    padding-left: 70px;
    padding-right:70px;
}

.skeleton-lg{
    padding-left: 100px;
    padding-right:100px;
}

footer {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 20px 0px;
    margin-top: 30px;
    text-align: center;
}



footer p {
    margin: 0;
}

#footer-bar {
    background: #EAEAEA;
    width: 100%;
    min-height: 80px;
    margin-bottom: 20px;
    line-height: 80px;
    text-align: right;
    padding: 0px 25px;
}

#footer-bar .btn {
    margin-left: 15px;
}

@media (max-width: 444px){
    #footer-bar {
        text-align: center;
        padding: 15px;
        line-height: 40px;
    }
    #footer-bar .btn {
        margin: 0px;
    }
}



.top-dropdowns{
    max-width: 1160px;
    margin: 0 auto;
}

/* Override de estilo do widget */
@media (min-width: 1200px){
     .navbar-brand {
        padding-top: 10px !important;
    }
}
@media (max-width: 1199px){
    .uolheader .navbar .uol-navbar .navbar-brand {
        padding: 12px 0 0 0;
    }
    .uolheader .navbar .uol-navbar .navbar-brand img {
        height: 36px;
        width: auto;
    }
    .uolheader .navbar .navbar-toggle {
        padding: 0 22px;
    }
}



section{
    border:1px solid rgba(0,0,0,0);
    clear: both;
}





/* BIG DISPLAY ------------------------------------------------------------ */

.big-display.item-3 .big-display-content {
    max-width: 440px;
}

.owl-dots {
    margin-top: -40px;
    text-align: center;
    position: relative; z-index: 2;
}

.owl-dots .owl-dot {
    -webkit-box-shadow: 0px 0px 5px 0px rgba(0,0,0,.50);
    -moz-box-shadow: 0px 0px 5px 0px rgba(0,0,0,.50);
    box-shadow: 0px 0px 5px 0px rgba(0,0,0,.50);
    margin: 0 4px;
    border-radius: 100%;
    height: 19px; width: 19px;
    background: rgba(255, 255, 255, .38) !important;
    outline: 0;
}

.owl-dots .owl-dot.active {
    background: rgba(255, 255, 255, 1) !important;
}

.big-display{
    position: relative;
}

.big-display-img-1 {
    content: url('/images/big-display_item_1.jpg');
}

.big-display-img-2 {
    content: url('/images/big-display_item_2.jpg');
}

.big-display-img-3 {
    content: url('/images/big-display_item_3.jpg');
}

.big-display-content {
    position: absolute;
    display: block;
    top: calc(50% - 115px);
    right: calc( (100vw - 1160px) / 2);
    max-width: 450px;
}

.big-display-content.left {
    left: calc( (100vw - 1160px) / 2) !important;
}

.big-display-content h2{
    color: #000;
    font-size: 34px;
    font-weight: 500;
}

@media only screen and (max-width: 1199px) {
    .big-display.item-3 .big-display-content {
        max-width: 440px;
    }

    .big-display{
        min-height: 390px;
        display: inline-block;
        margin-top: 60px;
        width: 100%;
    }

    .big-display-content {
        max-width: 370px;
        right: calc( (100vw - 960px) / 2);
    }

    .big-display-content.left {
        left: calc( (100vw - 960px) / 2) !important;
    }

    .big-display-content h2{
        font-size: 28px;
    }
}
@media only screen and (max-width: 900px) {
    .owl-dots .owl-dot.active {
        background: rgba(0, 0, 0, .38) !important;
    }

    .big-display-img-1 {
        content: url('/images/banner_1_mobile.png');
    }

    .big-display-img-2 {
        content: url('/images/banner_2_mobile.png');
    }

    .big-display-img-3 {
        content: url('/images/banner_3_mobile.png');
    }

    .big-display{
        text-align: center;
        min-height: calc((100vw / 903) * 386);
    }

    .big-display-content{
        position: absolute;
        text-align: center;
        display: inline-block;
        top: calc(50% - 148px);
        max-width: 590px !important;
        right: calc( (100vw - 636px) / 2);
        padding: 40px;
    }

    .big-display-content.left {
        left: calc( (100vw - 590px) / 2) !important;
    }

    .big-display-content h2{
        font-size: 38px;
    }
}

@media only screen and (max-width: 480px) {
    .big-display{
        text-align: center;
        min-height: 210px;
        background-size: cover;
        background-position: center top ;
    }

    .big-display-content {
        max-width: 312px !important;
        padding: 0 20px;
        top: calc(50% - 90px);
        right: calc( (100vw - 320px) / 2);
    }

    .big-display.item-3 .big-display-content {
        padding-top: 20px;
    }

    .big-display-content.left {
        margin-left: 134px !important;
    }

    .big-display-content h2{
        font-size: 20px;
    }

    .btn.btn-orange.btn-lg {
        padding: 7px 19px;
        font-size: 14px;
        line-height: 1.4;
        border-radius: 2px;
    }
}




/* IMPULSIONE ---------------------------------------------------------------- */


.impulsione{
    text-align: center;
    background-color: #FFF;
    padding: 55px 50px 28px;
}

.impulsione h3{
    font-size: 34px;
    font-weight: 300;
    color: #444444;
}

.impulsione h3 img{
    height: 30px;
    width: auto;
}

.impulsione p{
    font-size: 16px;
    color: #777;
}

@media only screen and (max-width: 900px) {
    .impulsione{
        padding: 25px 20px;
    }
    .impulsione h3{
        font-size: 25px;
    }
    .impulsione p, .impulsione .btn{
        display:none;
    }
}


/* LOGOS ------------------------------------------------------------------------- */
.logos{
    position:relative;
    /* background-color: #E5E4E3; */
    text-align: center;
    padding:0;
    margin-bottom: 69px;
}

.logos .logos-wrapper{
    width:100%;
    max-height: 202px;
    transition: all .5s ease-out;
    overflow: hidden;
}
.logos .logos-wrapper.show-logos{
    height: auto;
}

.logos .logos-wrapper .logos-content div {
    display: inline-block;
    width: 160px;
    height: 80px;
    background-color: #fff;
    margin: 11px;
}

.logos .logos-wrapper .logos-content div img{
    width: 160px;
    height: 80px;
    opacity: .7;
    filter: gray; /* IE5+ */
    -webkit-filter: grayscale(1); /* Webkit Nightlies & Chrome Canary */
    transition: all .4s;
    -webkit-transition: all .4s;
}

.logos .logos-wrapper div img:hover {
    opacity: 1;
    filter:none; /* IE5+ */
}

.logos .btn {
    background: transparent;
    border: 1px solid #414042;
    color: #414042;
    width: 130px;
}


@media only screen and (max-width: 900px) {
    /* .logos{
        overflow-y: none;
        overflow-x: scroll;
    } */
}

/* FORMATOS ----------------------------------------------------------------- */
.formats{
    background-image: url("/images/format_background.png") !important;
    background-color: #F8F8F8;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: right;
    padding: 50px 50px;
}

.formats-div{
    padding-left: calc((100% - 1180px)/2);
    padding-right: calc((100% - 1180px)/2);
}

.format-title{
    font-size: 34px;
    color: #444444;
    padding-left: 20px;
    padding-bottom: 20px;
    max-width: 600px;
}

.format-div{
    padding-left: 20px;
    padding-bottom: 20px;
}

.format-imgs{
    width: 76px;
    height: 70px;
    float: left;
    margin-right: 15px;
}

.format-type{
    font-size: 18px;
    margin-bottom: 10px;
}

.format-desc{
    color: #777777;
    max-width: 535px;
}

.format-new {
    color: #FFFFFF;
    background-color: #E57F44;
    margin-right: 10px;
    padding: 3px 10px;
}

@media only screen and (max-width: 1024px) {
    .formats{
        background-image: none !important;
        background-color: #F8F8F8;
        background-repeat: no-repeat;
        background-size: contain;
        background-position: right;
        padding: 50px 50px;
    }
}

@media only screen and (max-width: 320px) {
    .format-type{
        min-width: 215px;
    }

    .format-type > strong{
        display: block;
        margin-top: 5px;
    }
}

/* KEYPOINTS ---------------------------------------------------------------- */


.keypoints{
    text-align: center;
    background-color: #fff;
    padding: 40px 50px;
}

.keypoints h3{
    font-size: 38px;
    font-weight: 500;
    color: #777;
}

.keypoints h3 strong{
    color: #444;
    font-weight: 500;
}

.keypoints .line{
    display: block;
    padding: 100px calc((100% - 1180px)/2);
    clear: both;
}

.keypoints .side-content{
    text-align: left;
    float: left;
    max-width: 400px;
    padding: 20px;
}

    .side-content h4{
        color: #C93C3C;
        text-transform: uppercase;
        font-size: 13px;
        font-weight: 500;
        margin-bottom: 5px;
    }
    .side-content p{
        font-size: 15px;
        font-weight: 500;
        color: #777;
    }
    .side-content p.high{
        font-size: 22px;
        line-height: 22px;
        font-weight: 500;
        color: #444;
        margin-bottom: 8px;
    }

.keypoints .side-image{
    text-align: center;
    float: left;
    width: 760px;
}

.keypoints .side-image img{
    max-width: 570px;
    width: 100%;
}

@media only screen and (max-width: 1180px) {

    .keypoints{
        padding: 20px 10px;
    }

    .keypoints h3{
        font-size: 20px;
    }

    .keypoints .line{
        padding: 60px 10px 0;
        display:flex;
        flex-flow: column;
    }

    .keypoints .side-image{
        order:1;
        width: 100%;
    }
    .keypoints .side-content{
        padding:15px 0 0 0;
        order:2;
    }

}



/* COMO FUNCIONA ---------------------------------------------------------------- */


.como-funciona{
    margin-top: 40px;
    background-image: url('/images/como-funciona.png');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    min-height: 400px;
    background-color: #272b2b;
    text-align: center;
    padding: 20px 20px 0 20px;
}

.como-funciona h3{
    color: #fff;
    font-weight: 500;
    font-size: 30px;
    margin-bottom: 5px;
}
.como-funciona p{
    color: #fff;
    font-weight: 500;
    margin-bottom: 60px;
}

.icons-wrapper{
    max-width:1200px;
    margin: 0 auto;
}

.icon-box{
    display: block;
    float: left;
    width: 25%;
    text-align: center;
}

.icon-box img{
    max-height: 80px;
    margin-bottom: 20px;
}
.icon-box p{
    font-size: 20px;

}


@media only screen and (max-width: 1000px) {

    .como-funciona{
        background-image: url('/images/como-funciona-mobile.png');
        background-size: auto 100%;
        padding: 20px 10px 0 10px;
    }

    .icon-box{
        width: 50%;
        padding: 10px;
    }

    .icon-box img{
        max-height: 60px;
        margin-bottom: 20px;
    }
    .icon-box p{
        font-size: 16px;
        margin-bottom: 30px;

    }


}




/* COMECE AGORA ---------------------------------------------------------------- */

.comece{
    padding: 60px 20px;
    text-align: center;
}

.comece h3{
    font-size: 36px;
    font-weight: 500;
    color: #444;
    margin-bottom:25px;
}


@media only screen and (max-width: 1000px) {

    .comece{
        padding: 10px 10px;
        text-align: center;
    }
    .comece h3{
        font-size: 24px;
    }

}


/* FOOTER ---------------------------------------------------------------- */

footer{
    background-color: #E3E3E3;
    position: relative !important;
    padding: 30px 60px;
    margin-top: 0;
}

footer ul{
    list-style: none;
    float:left;
}

footer ul li{
    display: inline-block;
    margin: 10px 10px 0 0;
}

footer ul li a{
    font-size: 14px;
    color: #777;
    text-decoration: none;
}
footer ul li a:hover{
    color: #444;
}


footer .pull-right span{
    margin-right: 20px;
}

.copy{
    text-align: center;
    margin: 30px 20px -30px;
}


@media only screen and (max-width: 1000px) {

    footer{
        padding: 30px 10px;
        text-align: center;
    }

    footer ul li{
        display: inline-block;
        margin: 10px 10px 0;
    }

    footer .pull-right span{
        display: inline-block;
        margin: 20px 0 20px;
    }

}




/* Overrides */
.uolheader .side-bar .side-bar-menu .product-menu>li {
    padding: 0px !important;
}

.side-bar-menu ul{
    padding-top: 15px !important;
}

.side-bar-menu ul  {
    padding-top: 15px !important;

}
.side-bar-menu ul a {
    font-size: 18px;
    color: #555;
}

.btn-transparent-custom{
    border: 1px solid #E57F44 !important;
    margin: 10px 15px !important;
    text-align: center !important;
}

.btn-orange-custom{
    background-color: #E57F44 !important;
    margin: 10px 15px !important;
    text-align: center !important;
    color: #fff !important;
}

.footer-login-content {
    background: #EAEAEA;
    width: 100%;
    min-height: 80px;
    margin-bottom: 20px;
    line-height: 80px;
    text-align: right;
    padding: 0px 25px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.footer-login-content ul{
    padding: 0 20px;
}

.help-email {
    padding: 0 10px;
    text-align: center;
}

.footer-login-content .btn {
    margin-left: 15px;
}

.footer-login-content .btn-blue{
    color: #333 !important;
    border:1px solid #1082BE !important;
    border-radius:2px !important;
}

.footer-login-content .btn-transparent{
    color: #333 !important;
    border:1px solid #e57f44 !important;
    border-radius:2px;
}

.footer-login-content .d-flex{
    display: flex;
    align-items: center;
}

.d-flex-btn{
    display: flex;
}

.footer-login-content .btn.btn-blue{
    margin-left: 30px;
}

.footer-login-content .mail {
    margin-top:-2px;
    padding-left: 10px;
}

.footer-login-content .phone{
    margin-top:-2px;
    padding-left: 20px;
}

.footer-login-content .tel{
    font-size: 14px;
    color: #666666;
}

.content-footer{
    display: flex;
}

@media(max-width: 1302px){
    .footer-login-content > ul{
        padding: 0;
    }
    .footer-login-content .btn.btn-blue,.footer-login-content .btn{
        margin-left: 5px;
    }
    .footer-login-content .phone{
        padding-left: 10px;
    }
    .footer-login-content .help-email{
        padding: 0;
    }

}


@media(max-width: 1199px){
    .footer-login-content{
        line-height: 30px;
        flex-direction: column;
    }

    .footer-login-content .d-flex{
        flex-direction: column;
        justify-content: center;
    }

    .footer-login-content .btn.btn-blue, .footer-login-content .btn{
        margin-left: 15px;
        margin-bottom: 20px;
    }

    .content-footer{
        flex-direction: column;
    }
}

@media (max-width: 600px){
    .d-flex-btn{
        flex-direction: column;
    }
    .footer-login-content .btn.btn-blue, .footer-login-content .btn{
        margin-left: 0;
        margin-bottom: 20px;
    }
}


@media (max-width: 444px){
    .footer-login-content {
        text-align: center;
        padding: 15px;
        line-height: 30px;
        flex-direction: column;
    }
    .footer-login-content .tel{
        font-size: 12px;
    }
    .footer-login-content .btn.btn-blue{
        margin: 10px 0px 10px;
    }
    .footer-login-content .btn {
        margin: 0px;
        width: 184px;
    }
    footer{
        position: initial;
    }
}