/*PADRÃO DE CORES
BG TITULOS: #DF0714
BTN: #2B2378 / HOVER: #191356
*/
*, *:after, *:before {
    margin: 0;
    padding: 0;
    font-size: 1rem;
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
}

html {
    height: 100%;
    font-size: 1rem;
    background-color: #EFF1F3;
    font-family: 'Open Sans', sans-serif;
}

/* GERAL */
.ds-none{
    display: none;
}

.required{
    color: #CF000F;
    font-weight: normal;
}

.vanDesignForm {
    display: none;
}

/*MENSAGENS DO SISTEMA*/
.msg{
    padding: 10px;
    background: #F6F7F8;
    font-size: 1rem;
    margin-bottom: 15px;
    text-align: center;
    width: 100%;
    display: block;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
}

.msg strong{
    font-size: 0.875rem;
}

.msg::before {
    display: none;
}

.msg .svg-inline--fa {
    font-size: 2rem;
    display: block;
    text-align: center;
    margin: 5px auto 8px auto;
}

.msg-ok {
    background-color: #CEEAD5;
    color: #154D20;
    border: 2px solid #BBE2C4;
}

.msg-info {
    background-color: #cce5ff;
    color: #004085;
    border: 2px solid #b8daff;
}

.msg-alert, .msg-load {
    color: #856404;
    background-color: #fff3cd;
    border: 2px solid #ffeeba;
}

.msg-no {
    border: 2px solid #f5c6cb;
    color: #721c24;
    background-color: #f8d7da;
}

.msg-ok::before{
    font-family: "Font Awesome 5 Solid";   content: "\f058";
}

.msg-info::before{
    font-family: "Font Awesome 5 Solid";   content: "\f05a";
}

.msg-alert::before{
    font-family: "Font Awesome 5 Solid";   content: "\f06a";
}

.msg-no::before{
    font-family: "Font Awesome 5 Solid";   content: "\f057";
}

#debugaForm{
    display: none;
}
/*FORMULARIOS DO SISTEMA*/
.header-logo img{
    width: 100%;
    max-width: 500px;
    display: block;
    margin: 0 auto;
    margin-bottom: 30px;
}
.header-form h1{
    font-size: 1.4rem;
    text-align: center;
}

.header-form p{
    text-align: center;
}

.header-form em{
    display: block;
    text-align: center;
    font-size: 0.8rem;
    color: #721c24;
    background: #F7F8F9;
    padding: 5px 0;
}
.box-sessao .box-inputs #debugaCep{
    display: none;
    margin-top: -15px;
}

p{
    margin: 1rem 0;
}

.radius {
    border-radius: 5px;
    -moz-border-radius: 5px;
    -webkit-border-radius: 5px;
}

.container {
    max-width: 900px;
    width: 100%;
    margin: 20px auto;
    background: #fff;
    padding: 2rem;
}

.logo{
    text-align: center;
    margin-bottom: 30px;
}

.box-sessao {
    margin-bottom: 2rem;
}

.box-sessao h1 {
    color: #fff;
    background: #DF0714;
    font-size: 1.5rem;
    margin: 20px 0;
    padding: 5px 10px;
    border: 0 solid rgba(0,0,0,.5);
    border-bottom-width: .3rem;
    font-weight: normal;
}

.box-inputs {
    background: #F7F8F9;
    padding: 1rem;
}

.box-inputs label {
    display: block;
    font-weight: bold;
    margin-bottom: 5px;
}

.box-inputs input[type="text"], .box-inputs input[type="number"] ,.box-inputs input[type="email"], .box-inputs select {
    display: block;
    width: 100%;
    padding: .75rem;
    margin-bottom: 30px;
    border: none;
    border-radius: 5px;
    -moz-border-radius: 5px;
    -webkit-border-radius: 5px;
    -webkit-box-shadow: 0 1px 5px rgba(0, 0, 0, .2);
    -moz-box-shadow: 0 1px 5px rgba(0, 0, 0, .2);
    box-shadow: 0 1px 5px rgba(0, 0, 0, .2);
    background-color: #FFF;
}

.fileUpload {
    position: relative;
    overflow: hidden;
    margin: 10px;
}
.fileUpload input.upload {
    position: absolute;
    top: 0;
    right: 0;
    margin: 0;
    padding: 0;
    font-size: 20px;
    cursor: pointer;
    opacity: 0;
    filter: alpha(opacity=0);
}

.box-inputs .input-erro{
    box-shadow: 0 1px 5px rgba(0, 0, 0, .2);
    -webkit-box-shadow: 0 1px 5px rgba(0, 0, 0, .2);
    -moz-box-shadow: 0 1px 5px rgba(0, 0, 0, .2);
}

.box-inputs select:not([size]):not([multiple]) {
    height: calc(2.25rem + 8px);
}

.box-inputs em{
    display: block;
    margin: -25px 0 25px 5px;
    font-size: 0.85rem;
}

.box-inputs .sub-titulo{
    background: #6F010D;
    padding: 10px;
    color: #FFF;
    margin-bottom: 10px;
}

.box-inputs em strong{
    font-size: 0.85rem;
}

.box-mult-inputs{
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.item-mult-inputs-2{
    flex-basis: calc(50% - 15px);
}

.item-mult-inputs-3{
    flex-basis: calc(33% - 15px);
}

.input-cep{
    width: 50% !important;
    min-width: 120px;
    display: inline-block !important;
}

.btn-produto{
    color: #2B2378;
}

.btn-produto:hover{
    color: #191356;
}

.a-bnt{
    display: inline-block;
    padding: 4px 10px;
    margin-left: 5px;
    margin-top: -5px;
    background: #2B2378;
    border-radius: 10px;
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    color: #FFF;
    font-weight: bold;
    cursor: pointer;
    border: 1px solid rgba(0,0,0,.2);
    border-bottom-width: 0.2625rem;
    text-decoration: none;
    text-transform: uppercase;
}

.a-bnt:disabled{
    opacity: .4;
    cursor: default;
}

.btn{
    padding: 10px 30px;
    display: block;
    margin: 0 auto 0 auto;
    background: #2B2378;
    font-weight: bold;
    text-transform: uppercase;
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    color: #FFF;
    cursor: pointer;
    border: 1px solid rgba(0,0,0,.2);
    border-bottom-width: 0.2625rem;
}

.btn:hover, .a-bnt:hover {
    background:#191356 ;
}

.dev{
    width: 100%;
    margin: 40px auto 20px auto;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dev p{
    font-size: 0.875rem;
    color: #888;
    margin-right: 10px;

}

@media (max-width: 650px){
    .header-form h1{
        font-size: 1.2rem;
        text-align: center;
    }

    .box-mult-inputs{
        display: block;
    }

    .box-sessao h1 {
        font-size: 1.3rem;
    }

    .btn-produto{
        color: #FFF;
        display: block;
        background: #2B2378;
        margin-top: -15px;
        text-align: center;
        border-radius: 10px;
        margin-bottom: 30px;
    }


    .container {
        padding: 0.875rem;
        margin: 0;
    }

    .item-radio{
        display: block;
        margin: 5px 0;
    }

    .btn{
        margin: 0 auto 1rem auto;
    }
}

