@charset "utf-8";

.login {
  max-width: 768px;
  margin: 0 auto;
  padding-top: 35px;
  text-align: center;
}

.topLogo {
  width: 200px;
}

.login_title {
  font-family: 'Noto Serif JP', serif;
  font-weight: 600;
  margin: 42px 0 68px;
}

.login_title small {
  font-size: 1.7rem;
  padding-right: .3em;
}

.login_title span:nth-of-type(1) {
  display: block;
  font-size: 2.4rem;
  padding-right: .25em;
}

.login_title span:nth-of-type(2) {
  display: inline-block;
  font-size: 3.6rem;
  letter-spacing: .02em;
  border-top: 1px solid #000;
  margin-top: .2em;
  padding: .3em .5em 0;
}

.login_lead {
  margin: 1.5em 0;
  line-height: 1.5;
}

.login_formBody {
  display: flex;
  gap: 30px 0;
  text-align: left;
  max-width: 400px;
  margin: 0 auto 25px;
}

.login_formBody dt {
  width: 6em;
  font-size: 1.8rem;
  line-height: 3;
}

.login_formBody dd {
  width: calc(100% - 6em);
}

.login_formBody input {
  width: 100%;
  font-size: 2rem;
  padding: 10px 25px;
  background: #f6f6f6;
  border-radius: 100px;
  border: 1px solid #bbb
}

.login form .error {
  display: block;
  line-height: 1.5;
  max-width: 400px;
  margin: -22px auto 25px;
}

@media screen and (max-width: 600px) {
  .login {
    padding-top: 25px;
  }

  .topLogo {
    width: 160px;
  }

  .login_title {
    margin: 35px 0 68px;
  }

  .login_title small {
    font-size: 1.6rem;
  }

  .login_title span:nth-of-type(1) {
    font-size: 2.1rem;
  }

  .login_title span:nth-of-type(2) {
    font-size: 2.8rem;
  }

  .login_lead span.red {
    display: block;
  }

  .login_formBody dt {
    width: 5.75em;
  }

  .login_formBody dd {
    width: calc(100% - 5.75em);
  }
}

@media screen and (max-width: 374px) {
  .login_title span:nth-of-type(1) {
    font-size: 1.9rem;
  }

  .login_title span:nth-of-type(2) {
    font-size: 2.5rem;
  }

  .login_formBody dt {
    font-size: 1.6rem;
  }
}

/* ログインボタン 
-----------------------------------------------*/
.loginBtn {
  max-width: 440px;
  padding-right: 15px;
  margin: 50px auto 70px;
  background: #132a53;
  position: relative;
  cursor: pointer;
}

.loginBtn>input {
  width: 100%;
  height: 62px;
  padding-left: 25px;
  color: #fff;
  background: #132a53;
  border: 0;
  font-size: 2.2rem;
  font-weight: 700;
  letter-spacing: .25em;
  cursor: pointer;
}

.loginBtn::after {
  content: "";
  width: 14px;
  height: 14px;
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  display: inline-block;
  transform: rotate(45deg);
  position: absolute;
  right: 25px;
  top: calc(50% - 7px);
}

@media screen and (max-width: 600px) {
  .loginBtn>input {
    font-size: 2rem;
  }
}
