body{
  background: #F3F3F3;
}

button, input, .btn {
  transition: all .3s ease
}

a{
  color: #20A0FF;
}

.page-base {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: stretch;
  min-height: 100vh;
}

#main-center {
  flex: 1 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
}

.form-base{
  background: #FFFFFF;
  padding: 20px 30px;
  border-radius: 4px;
}

input.form-control{
  border: 1px solid #d1d1d1;
  height: 36px;
  background: none;
  box-shadow: none;
  outline: none;
}

input.form-control:focus{
  box-shadow: none;
  outline: none;
  border-color: #20A0FF;
}

img.captcha{
  width: 100%;
  height: 36px;
}

button.btn:focus,button.btn:active{
  box-shadow: none;
  outline: none;
}

button.btn.btn-submit{
  border-radius: 2px;
  background: #20A0FF;
  color: #FFFFFF;
  height: 36px;
}

button.btn.btn-captcha{
  border-radius: 2px;
  background: #475669;
  color: #FFFFFF;
  height: 36px;
}

.blue-title{
  color: #20A0FF;
}

a.gray-href{
  color: #888888;
}

a.gray-href:hover{
  text-decoration: none;
}

font.second{
  color: #FF4949;
  font-size: 2em;
}

label.error{
  color: #FF4949;
  position: absolute;
  font-weight: 500;
  display: block;
  font-size: 12px;
  transition: all .3s ease;
}

input.form-control.error{
  border-color: #FF4949 !important;
}

.err-msg{
  margin: 0px;
  font-size: 12px;
  color: #FF4949;
  background: rgba(255, 73, 73, 0.1);
  border: #FF4949 1px solid;
  padding: 10px;
  margin-bottom: 5px;
  border-radius: 4px;
}

.login-state-box{
  background: #FFFFFF;
  border-radius: 4px;
  overflow: hidden;
}

.login-state-box .detail{
  padding: 36px;
  font-size: 14px;
}

.login-state-box .cas-user{
  background: #7F8FA3;
  padding: 36px 36px;
  text-align: center;
  color: rgba(255, 255, 255, .8);
}

.login-state-box .cas-user img{
  height: 80px;
  width: 80px;
  border-radius: 50%;
}

.info-base{
  background: #FFFFFF;
  padding: 20px 30px;
}

.result-logo{
  font-size: 50px;
  color: #FFFFFF;
}

.error-box{
  padding: 100px 0px;
}

.error-box .icon{
  text-align: center;
  margin-bottom: 16px;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: flex-end;
  font-size: 32px;
  color: #0073aa;
}

.error-box .icon img{
  height: 100px;
}

.error-box .desc{
  font-size: 14px;
  line-height: 36px;
  color: #262626;
  text-align: center;
}
