@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
}

*,
* ::before,
* ::after {
  box-sizing: border-box;
}

body {
  font-family: "Noto Sans JP", "ヒラギノ角ゴPro W3", "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", メイリオ, Meiryo, sans-serif;
  color: #333333;
  background-color: #FAF7F2;
}

.l-container {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}

.l-container::before,
.l-container::after {
  content: "";
  position: absolute;
}

.l-container::before {
  width: 1645px;
  height: 255px;
  top: 109px;
  left: 50%;
  transform: translateX(calc(-50% - 78px));
  z-index: -1;
  background: url(/common/images/common/bg_kv_line_pc.svg) no-repeat center/cover;
  pointer-events: none;
}

.l-container::after {
  width: 722px;
  height: 709px;
  left: 50%;
  transform: translateX(calc(-50% + 429px));
  bottom: 0;
  z-index: -1;
  background: url(/common/images/login_s/bg_tree.svg) no-repeat center/cover;
  pointer-events: none;
}

.l-content {
  height: calc(100% - 61px);
  padding: 119px 20px 120px;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

@media screen and (max-width: 767px) {
  .l-content {
    height: 100%;
    padding: 40px 20px 41px;
  }
  .l-container::before {
    width: 688px;
    height: 107px;
    top: 76px;
    left: 50%;
    transform: translateX(calc(-50% - 60px));
    z-index: -1;
    background: url(/common/images/common/bg_kv_line_pc.svg) no-repeat center/cover;
    pointer-events: none;
  }
  .l-container::after {
    width: 500px;
    height: 388px;
    right: auto;
    left: 50%;
    bottom: 26px;
    transform: translateX(-50%);
    z-index: -1;
    background: url(/common/images/login_s/bg_tree.svg) no-repeat center/cover;
    pointer-events: none;
  }
}

.logo {
  width: 100%;
  max-width: 300px;
  margin: 0 0 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.logo--Main img,
.logo--Sub img {
  width: 100%;
  height: auto;
}

.logo--Main {
  margin-bottom: 8px;
  display: inline-block;
}

.logo--Sub {
  width: 365px;
}

.login__subTitle {
  margin-bottom: 41px;
  color: #333333;
}

@media screen and (max-width: 767px) {
  .logo {
    margin-bottom: 5px;
  }
  .logo--Main {
    width: 195px;
    margin-bottom: -12px;
  }
  .logo--Sub {
    width: 207px;
    margin-top: 16px;
  }
  .login__subTitle {
    margin-bottom: 16px;
  }
}
.loginContent {
  width: 100%;
  max-width: 960px;
  padding-bottom: 40px;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #ffffff;
  box-shadow: 0px 0px 9px rgba(62, 0, 5, 0.1);
  border-radius: 8px;
}

.loginContent + .loginContent {
  margin-top: 40px;
}

.login__errorMessage {
  width: 100%;
  min-height: 61px;
  padding: 10px;
  color: #E60012;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(230, 0, 18, 0.03);
}

.login__lead {
  margin: 41px 0 39px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .login__lead {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.login__form {
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .login__form {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .login__form .c-form__item {
    width: 100%;
    min-width: 295px;
  }
}

.login__form__item + .login__form__item {
  margin-top: 24px;
}

.login__form__button {
  width: 220px;
  min-height: 56px;
  margin-top: 40px;
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .loginContent {
    max-width: 350px;
  }
  .login__errorMessage,
  .login__lead {
    text-align: center;
  }
  .login__break {
    display: block;
  }
  .login__form__button {
    width: 156px;
  }
}
.loginContent--forget {
  padding: 24px 24px 20px;
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid #595551;
}

.login__forget__title {
  margin-bottom: 8px;
  font-size: 18px;
  font-weight: 700;
}

.login__forget__text {
  margin-bottom: 16px;
  font-size: 16px;
  font-weight: 400;
  text-align: center;
}

.login__forget__text--callable {
  margin-bottom: 11px;
  font-size: 12px;
  font-weight: 400;
}

.login__forget__tel {
  font-size: 24px;
  font-weight: 700;
}

.login__forget__tel__link {
  font-size: 24px;
}

.icon-click-before::before {
  content: normal;
}

@media screen and (max-width: 767px) {
  .loginContent--forget {
    padding-bottom: 21px;
  }
  .login__forget__text {
    margin-bottom: 16px;
  }
  .login__forget__text--callable {
    margin-bottom: 10px;
  }
  .icon-click-before::before {
    content: "";
  }
}
.footer {
  width: 100%;
  min-height: 68px;
  margin-top: auto;
  background-color: #595551;
  display: flex;
  justify-content: center;
  align-items: center;
}

.copyright {
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.6;
}

/* Edgeの目アイコンを不可視にする */
input::-ms-reveal,
input::-ms-clear {
    display: none;
}

/* Safari系で鍵アイコンを不可視・不可操作にする */
input[type="password"]::-webkit-credentials-auto-fill-button{
  visibility: hidden;     /* or background-color: transparent; */
  pointer-events: none;
  width: 0;
  margin: 0;
}
/* キャレットと被らないよう右余白を確保（任意） */
input[type="password"]{ padding-right: 2rem; }