::selection {
    color: #fff;
    background: #f676b2; /* Safari */
}

::-moz-selection {
    color: #fff;
    background: #f676b2; /* Firefox */
}

/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
input[type=number] {
  -moz-appearance: textfield;
}

* {
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
}

body {
    background: url('../images/bg.png');
    font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
    font-weight: 300;
    text-align: left;
    text-decoration: none;
    height: 500px;
}

#wrapper {
    /* Center wrapper perfectly */
    /*width: 300px;*/
    height: 400px;
    margin: 130px auto;
}

#submit_button:disabled {
    background-color: lightblue;
    color: gray;
    user-select: none;
    filter: brightness(80%);
    cursor: not-allowed;
}

.login-form {
    width: 310px;
    margin: 0 auto;
    position: relative;

    background: #f3f3f3;
    border: 1px solid #fff;
    border-radius: 5px;

    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
    -moz-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
    -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

.login-form .header {
    padding: 40px 30px 30px 30px;
}

.login-form .header h1 {
    font-family: 'Bree Serif', serif;
    font-weight: 300;
    font-size: 28px;
    line-height: 34px;
    color: #414848;
    text-shadow: 1px 1px 0 rgba(256, 256, 256, 1.0);
    margin-bottom: 10px;
}

.login-form .header span {
    font-size: 11px;
    line-height: 16px;
    color: #678889;
    text-shadow: 1px 1px 0 rgba(256, 256, 256, 1.0);
}

/*******************
CONTENT
*******************/

.login-form .content {
    padding: 0 30px 25px 30px;
}

/* Input field */
.login-form .content .input {
    width: 188px;
    padding: 15px 25px;

    font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
    font-weight: 400;
    font-size: 14px;
    color: #9d9e9e;
    text-shadow: 1px 1px 0 rgba(256, 256, 256, 1.0);

    background: #fff;
    border: 1px solid #fff;
    border-radius: 5px;

    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.50);
    -moz-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.50);
    -webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.50);
}

.login-form .content .password, .login-form .content .pass-icon {
    margin-top: 25px;
}

.login-form .content .input:hover {
    background: #f1edfd;
    color: #414848;
}

.login-form .errornote {
    color: #ff2f50;
}

.login-form .content .input:focus {
    background: #e6e2f5;
    color: #414848;

    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.25);
    -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.25);
}

.sms-info {
    margin-top: 10px;
    margin-bottom: 10px;
    color: gray
}

.sms-info-no-top {
    margin-top: 0px;
    margin-bottom: 0px;
    color: gray
}

.href_sms {
    text-decoration: none;
    border-bottom: 1px dashed;
    cursor: pointer;
    color: blue
}

.user-icon, .pass-icon, .sms-icon {
    margin-bottom: -19px;
    width: 46px;
    height: 47px;
    display: inline-block;
    left: 0;
    padding-right: 2px;
    z-index: -1;

    -moz-border-radius-topleft: 5px;
    -moz-border-radius-bottomleft: 5px;
    -webkit-border-top-left-radius: 5px;
    -webkit-border-bottom-left-radius: 5px;
}

.user-icon {
    background: rgba(65, 72, 72, 0.75) url(../images/user-icon.png) no-repeat center;
}

.pass-icon {
    background: rgba(65, 72, 72, 0.75) url(../images/pass-icon.png) no-repeat center;
}

.sms-icon {
    background: rgba(65, 72, 72, 0.75) url(../images/sms-icon.png) no-repeat center;
}

.content input:focus + div {
    left: -46px;
}

/* Animation */
.input, .button, .register {
    transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
}

.login-form .footer {
    padding: 25px 30px 40px 30px;
    overflow: hidden;

    background: #F7EFFF;
    border-top: 1px solid #fff;

    box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.15);
    -moz-box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.15);
    -webkit-box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.15);
}

.login-form .sub_footer {
    padding: 2px 3px 2px 3px;
    overflow: auto;

    background: #F7EFFF;
    border-top: 1px solid #fff;

    box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.15);
    -moz-box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.15);
    -webkit-box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.15);
}

/* Login button */
.login-form .footer .button {
    float: right;
    padding: 11px 25px;

    font-family: 'Bree Serif', serif;
    font-weight: 300;
    font-size: 18px;
    color: #fff;
    text-shadow: 0px 1px 0 rgba(0, 0, 0, 0.25);

    background: #9956e1;
    border: 1px solid #7c6cd5;
    border-radius: 5px;
    cursor: pointer;

    box-shadow: inset 0 0 2px rgba(256, 256, 256, 0.75);
    -moz-box-shadow: inset 0 0 2px rgba(256, 256, 256, 0.75);
    -webkit-box-shadow: inset 0 0 2px rgba(256, 256, 256, 0.75);

    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -khtml-border-radius: 5px;

}

.login-form .footer .button.button-decline {
    background: gray;
    border: 1px solid gray;
}

.login-form .footer .button:hover {
    background: #a18dd3;
    border: 1px solid rgba(256, 256, 256, 0.75);

    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
    -moz-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
    -webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
}

.login-form .footer .button:focus {
    position: relative;
    bottom: -1px;

    background: #a382e9;

    box-shadow: inset 0 1px 6px rgba(256, 256, 256, 0.75);
    -moz-box-shadow: inset 0 1px 6px rgba(256, 256, 256, 0.75);
    -webkit-box-shadow: inset 0 1px 6px rgba(256, 256, 256, 0.75);
}

.oauth2-desc {
    font-size: 12px;
    color: gray;
}

.oauth2-desc ul {
    list-style: disc;
    padding: 15px 0 0 15px;
}

.password-control {
    position: absolute;
    top: 40px;
    right: 20px;
    display: inline-block;
    width: 20px;
    height: 20px;
    background: url('../images/view.svg') 0 0 no-repeat;
    opacity: 0.5;
}

.password-control.view {
    background: url('../images/no-view.svg') 0 0 no-repeat;
}

.login-form .content .input.password {
    padding-right: 40px;
}
