@charset "UTF-8";
/* CSS Document */
.spmask {
  display: block;
}

.sponly {
  display: none;
}

@media (max-width: 767px) {
  .spmask {
    display: none;
  }
  .sponly {
    display: block;
  }
}
/*-------Contents------------*/
.contact {
  position: relative;
  width: 100%;
  background-color: #fff;
}
.contact .lead {
  width: 100%;
  margin: -2rem auto 2rem;
  text-align: center;
}
.contact .lead p {
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .contact .lead p {
    line-height: 1.8;
  }
}

.contactBox {
  display: block;
  max-width: 95rem;
  margin: 0 auto;
}
@media (max-width: 1370px) {
  .contactBox {
    width: 100%;
  }
}
.contactBox #mail_form {
  padding-block: 2rem;
}
@media (max-width: 1370px) {
  .contactBox #mail_form {
    padding-block: 0;
  }
}
.contactBox dl {
  display: flex;
  align-items: center;
  -moz-column-gap: 3rem;
       column-gap: 3rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .contactBox dl {
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 2rem;
  }
}
.contactBox dl.top {
  align-items: flex-start;
}
.contactBox dl:last-of-type {
  margin-bottom: 3rem;
}
.contactBox dt {
  width: 20rem;
  font-size: max(1.4rem, 14px);
  font-family: "Noto Sans jp";
}
@media screen and (max-width: 767px) {
  .contactBox dt {
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 767px) {
  .contactBox dd {
    width: 100%;
  }
}
.contactBox dd input {
  border: solid 1px var(--line);
  border-radius: 6rem;
  padding-block: 1rem;
  padding-left: 2rem;
  font-size: max(1.4rem, 14px);
  font-family: "Noto Sans jp";
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .contactBox dd input {
    padding-left: 1rem;
    padding-block: 0.6rem;
  }
}
.contactBox dd input#name {
  width: 45rem;
}
@media screen and (max-width: 767px) {
  .contactBox dd input#name {
    width: 100%;
  }
}
.contactBox dd input#mail_address, .contactBox dd input#mail_address_confirm {
  width: 60rem;
}
@media screen and (max-width: 767px) {
  .contactBox dd input#mail_address, .contactBox dd input#mail_address_confirm {
    width: 100%;
  }
}
.contactBox dd textarea {
  width: 60rem;
  border: solid 1px var(--line);
  border-radius: 2rem;
  padding-block: 1rem;
  padding-left: 1rem;
  font-size: max(1.4rem, 14px);
  font-family: "Noto Sans jp";
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .contactBox dd textarea {
    width: 100%;
  }
}
.contactBox .sendBtnBox {
  display: flex;
  justify-content: center;
  margin-bottom: 6rem;
}
@media screen and (max-width: 767px) {
  .contactBox .sendBtnBox {
    text-align: center;
  }
}
.contactBox .sendBtnBox input {
  width: 18rem;
  padding-block: 1rem;
  text-align: center;
  border: solid 1px #252525;
  background-color: #252525;
  color: #fff;
  cursor: pointer;
  transition: 0.3s;
  font-size: max(1.4rem, 14px);
}
@media (hover: hover) and (pointer: fine) {
  .contactBox .sendBtnBox input:hover {
    background-color: #fff;
    color: #252525;
    border: solid 1px var(--line);
  }
}
.contactBox .sendBtnBox .rev {
  width: 18rem;
  padding-block: 1rem;
  text-align: center;
  border: solid 1px #252525;
  background-color: #252525;
  color: #fff;
  cursor: pointer;
  transition: 0.3s;
  font-size: max(1.4rem, 14px);
}
@media (hover: hover) and (pointer: fine) {
  .contactBox .sendBtnBox .rev:hover {
    background-color: #fff;
    color: #252525;
    border: solid 1px var(--line);
  }
}
.contactBox .sendBtnBox02 {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  width: 100%;
  margin-bottom: 6rem;
}
.contactBox .sendBtnBox02 input[type=button], .contactBox .sendBtnBox02 input[type=submit] {
  width: 28%;
  padding-block: 1rem;
  text-align: center;
  border: solid 1px var(--line);
  border-radius: 2rem;
  background-color: #fff;
  cursor: pointer;
  transition: 0.3s;
  font-size: max(1.4rem, 14px);
}
.contactBox .sendBtnBox02 input[type=button] {
  background: #9b9b9b;
  border: solid 1px #9b9b9b;
  color: #fff;
}
.contactBox .sendBtnBox02 input[type=submit] {
  background: #252525;
  border: solid 1px #252525;
  color: #fff;
}
.contactBox .sendBtnBox02 input[type=button]:hover {
  background: #fff;
  border: solid 1px #9b9b9b;
  color: #9b9b9b;
}
.contactBox .sendBtnBox02 input[type=submit]:hover {
  background: #fff;
  border: solid 1px #252525;
  color: #252525;
}

.confirm-table {
  max-width: 75rem;
  margin: 0 auto;
}
.confirm-table dt {
  width: 16rem;
  font-size: max(1.4rem, 14px);
}
@media screen and (max-width: 767px) {
  .confirm-table dt {
    width: 100%;
  }
}
.confirm-table dd {
  width: 59rem;
  font-size: max(1.4rem, 14px);
  font-family: "Noto Sans jp";
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .confirm-table dd {
    width: 100%;
  }
}

.errorBox {
  color: red;
  margin-bottom: 3rem;
  overflow-x: hidden;
}
.errorBox pre {
  white-space: pre-wrap; /* 改行は維持しつつ折り返し可に */
  overflow-wrap: anywhere; /* 長い単語/メール等も強制改行 */
  word-break: break-word; /* 互換用の保険 */
  max-width: 100%;
  line-height: 1.8;
}

.completeBox {
  width: 75rem;
  margin: 0 auto 8rem;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .completeBox {
    width: 100%;
    text-align: left;
    margin-bottom: 6rem;
  }
}
.completeBox .text {
  margin-bottom: 6rem;
}
@media screen and (max-width: 767px) {
  .completeBox .text {
    margin-bottom: 4rem;
  }
}
.completeBox .text p {
  font-family: "Noto Sans jp";
  letter-spacing: 0.04em;
  line-height: 2.2;
}
@media screen and (max-width: 767px) {
  .completeBox .text p {
    line-height: 1.8;
  }
}
/*# sourceMappingURL=style.css.map */