/*----------------------------------------
  login
----------------------------------------*/
body{
  background-color: var(--color-primary-dark);
}

#wrapper{
  background-color: var(--color-primary);
  /* height: 100vh; */
  width: 50vw;
  min-width: 600px;
  margin: 0 auto;
  border-radius: 8px;

  position: fixed;
  top: 50%; /* 上下中央に配 */
  left: 50%;
  transform: translate(-50%, -50%); /* 中央揃え */
  text-align: center;
  padding: 10px 0 20px 0;
}

.logo{
  width: 300px;
}

h1{
  color: var(--color-fc-ttl-secondary);
  font-weight: normal;
  padding: 0 0 10px 0;
  font-size: 22px;
  position: unset;
}

input[type=password], input[type=email]{
  margin: 5px auto;
}

input[type=submit]{
  background-color: var(--color-primary-dark);
}

/*** header flash-err ***/
.flash-message{
  top: 55px;
}


@media screen and (max-width: 750px) {
  body{
    background-color: var(--color-primary);
  }

  #wrapper{
    width: 100vw;
    min-width: unset;
    border-radius: 0;
    padding: 5vw 0 7vw 0;
    margin-top:-5vw;
  }

  .logo{
    width: 60vw;
  }

  h1{
    font-size: 7vw;
    font-weight: normal;
    padding: 3vw;
  }

  input[type=password], input[type=email]{
    margin: 2vw auto;
  }

  .flash-message{
    top: 5vw;
  }

}
