html,
body {
  background-image: url('../images/bg.jpg');
  background-size: cover;
  background-repeat: no-repeat;
  min-height: 100vh;
  font-family: 'Numans', sans-serif;
  background-color: black;
}

.wrapper {
  clear: both;
  max-width: 1920px;
  margin: 0px auto;
  padding: 0px 0px 0px;
}

.center {
  display: block;
  margin-left: auto;
  margin-right: auto;
  height: 150px;
  width: 284px;
}

.login {
  width: 295px;
  padding-top: 40px;
  margin-left: auto ;
  margin-right: auto ;
}

.login__heading {
  display: block;
  margin: .25em auto .75em;
  text-align: center;
  text-transform: uppercase;
}

.login__form {
  font-size: 1em;
}

.login__item {
  display: block;
  /* Fallback */
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
}

.input-group2 {
  position: relative;
  align-items: stretch;
  width: 100%;
}

.login__item + .login__item {
  margin-top: 14px;
}

.login__input {
  float: right;
  display: block;
  /* Fallback */
  display: flex;
  justify-content: space-between;
  flex: 5 1 auto;
  min-height: 52px;
  margin: 0;
  padding: .7em .775em .6em;
  color: #333;
  /* Fallback */
  color: rgba(0, 0, 0 ,.6666);
  line-height: 1.2;
  background-color: #eee;
  border: 3px solid #aaa;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  -webkit-transition: border .25s ease-in-out, background .25s ease-in-out;
  transition: border .25s ease-in-out, background .25s ease-in-out;
}

.login__input:focus, .login__input:hover, .login__input:active {
  color: #000;
  background-color: #fff;
  border-color: #cb0a0a;
}

.login__input::-webkit-input-placeholder {
  color: rgba(0, 0, 0, .4);
}

.login__input:-ms-input-placeholder {
  color: rgba(0, 0, 0, .4);
}

.login__input::placeholder {
  color: rgba(0, 0, 0, .4);
}

.login__label {
  float: left;
  display: block;
  /* Fallback */
  display: flex;
  order: -1;
  justify-content: space-between;
  flex: 1 1 auto;
  min-height: 3em;
  margin: 0;
  padding: .675em .3375em;
  color: #333;
  /* Fallback */
  color: rgba(0, 0, 0 ,.6666);
  line-height: 1.2;
  text-align: center;
  background-color: #aaa;
  border: 3px solid #aaa;
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
  -webkit-transition: border .25s ease-in-out, background .25s ease-in-out;
  transition: border .25s ease-in-out, background .25s ease-in-out;
  cursor: pointer;
}

.login__input:focus ~ .login__label, 
.login__input:hover ~ .login__label, 
.login__input:active ~ .login__label {
  border-color: #cb0a0a;
  background-color: #cb0a0a;
}

/* IcoMoon.io */
.icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  stroke-width: 0;
  stroke: currentColor;
  fill: currentColor;
}

.icon-user {
  width: .7142857142857142em;
}

.icon-lock {
  width: .6428571428571428em;
}

.login__icon {
  display: inline-block;
  margin-right: 0;
  min-width: 20px;
  width: 20px;
  margin-left: 0;
  font-size: 30px;
}

.login__description {
  /* Visually hidden */
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  clip: rect(0, 0, 0, 0);
  border: 0;
  overflow: hidden;
}

.login__submit {
  display: block;
  width: 100%;
  margin: 0;
  padding: .5em .5em .575em;
  color: #eee;
  /* Fallback */
  color: rgba(255, 255, 255 ,.875);
  font-weight: bold;
  font-size: 21px;
  line-height: 1.2;
  text-transform: uppercase;
  background-color: #cb0a0a;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#cb0a0a) , to(#cb0a0a));
  background-image: linear-gradient(to bottom, #cb0a0a 0% , #cb0a0a 100%);
  border: none;
  border-radius: 5px;
  -webkit-transition: background .25s ease-in-out;
  transition: background .25s ease-in-out;
  cursor: pointer;
}

.login__submit:focus, .login__submit:hover {
  background-color: #d44;
  color: #fff;
  background-image: linear-gradient(to bottom, #0a037c 0% , #0a037c 100%);
}

.login__submit:active {
  background-color: #b22;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#0a037c) , to(#d44));
  background-image: linear-gradient(to bottom, #0a037c 0% , #0a037c 100%);
}

form label.error {
  color: #000;
  position: absolute;
  font-size: 0.75em;
  top: 100%;
  text-align: center;
  flex: 0 0 0;
  right: 0;
  left: 0;
}

.main, .footer {
  clear: both;
  margin: 10px auto;
}
.err {
  width: 100%;
}