.login {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100vw;
  height: 100vh;
  background: #f5f5f5;
}

.login-form {
  width: 100%;
  max-width: 400px;
  background: #fff;
  padding: 32px;
}

@media screen and (max-width: 960px) {
  .login-form {
    padding: calc( 32px * 0.75);
  }
}

@media screen and (max-width: 640px) {
  .login-form {
    padding: calc( 32px * 0.5);
  }
}

.login-ttl {
  margin-bottom: 24px;
  text-align: center;
}

@media screen and (max-width: 960px) {
  .login-ttl {
    margin-bottom: calc( 24px * 0.75);
  }
}

@media screen and (max-width: 640px) {
  .login-ttl {
    margin-bottom: calc( 24px * 0.5);
  }
}

.login-field {
  margin-bottom: 24px;
  border-radius: 4px;
}

@media screen and (max-width: 960px) {
  .login-field {
    margin-bottom: calc( 24px * 0.75);
  }
}

@media screen and (max-width: 640px) {
  .login-field {
    margin-bottom: calc( 24px * 0.5);
  }
}

.login-field__row:not(:nth-last-of-type(1)) {
  margin-bottom: 16px;
}

@media screen and (max-width: 960px) {
  .login-field__row:not(:nth-last-of-type(1)) {
    margin-bottom: calc( 16px * 0.75);
  }
}

@media screen and (max-width: 640px) {
  .login-field__row:not(:nth-last-of-type(1)) {
    margin-bottom: calc( 16px * 0.5);
  }
}

.login-btn {
  width: 100%;
}

.login-btn button {
  width: 100%;
  height: 40px;
  background: #999;
  border-radius: 2px;
  color: #fff;
  font-size: 1.4rem;
  text-align: center;
  line-height: 40px;
  -webkit-transition: 0.3s ease-out;
  transition: 0.3s ease-out;
  cursor: pointer;
}

.login-btn button:hover {
  background: #4a9;
}

/*# sourceMappingURL=../../maps/pages/login.css.map */
