*{
    box-sizing: border-box;
}
body{
    font-family: 'Roboto', "Helvetica Neue", sans-serif;
    line-height: 1;
    background: url(/assets/img/bannerweb.png);
    background-color: #454696;
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    color: rgba(0,0,0,0.87);
    height: 100vh;
}
.contenedor{
    height: 100%;
    display: grid;
    align-items: center;
}
main{
    border-radius: .25rem;
    box-shadow: 0 5px 5px -3px rgba(82,63,104,0.06), 0 8px 10px 1px rgba(82,63,104,0.042), 0 3px 14px 2px rgba(82,63,104,0.036);
    background-color: white;
    /* position: relative;
    top: 20px; */
    padding: 1.5rem;
    width: 25rem;
    margin: 0 auto;
}
.logo{
    text-align: center; 
    margin-bottom: 1rem;
}
header{
    text-align: center; 
    margin-bottom: 1.5rem;
}
img {
    width: 15rem;
    max-width: 100%;
    height: auto;
    vertical-align: super;
}
h1{
    font-size: 1.13em;
    margin: 0;
}
h2{
    font-size: 0.75em;
    color: rgba(0,0,0,0.54);
}
form input{
    border: 1px solid rgba(0,0,0,0.54);
    width: 100%;
    padding: 1rem 2rem 1rem 2rem;
    border-radius: 4px;
    margin-bottom: 1rem;
    outline: none;
    font-size: 1rem;
}
input:focus{
    border: 1px solid rgb();
    box-shadow: 0 0 2px #454696;
}
.ingresar{
    background-color: #454696;
    color: white;
    box-shadow: 0 3px 1px -2px rgba(82,63,104,.06), 0 2px 2px 0 rgba(82,63,104,.042), 0 1px 5px 0 rgba(82,63,104,.036);
    border: none;
    width: 100%;
    padding: 0 16px;
    border-radius: 4px;
    overflow: visible;
    transform: translate3d(0, 0, 0);
    font-size: 14px;
    font-weight: 500;
    padding: 1rem;
    margin-top: 1rem;
}
span{
    font-size: 0.75rem;
}
a{
    text-decoration: none;
    color: black;
    font-size: 1rem;
}
span a:hover{
    color: #454696;
}
strong{
    color: #454696;
    display: block;
    margin-bottom: 1rem;
}
.icono_principal{
    width: 45%;
    height: 67%; 
    color: #454696;
    margin: 1rem;
    text-align: center;

    border-radius: 0.5rem;
    padding-top: 1rem;
    font-size: 1.5rem;
}
.servicios_principal{
    width: 100%;
    display: flex;
    justify-content: center; 
    align-items: center;
    /* margin: 1rem; */
}