@charset "UTF-8";
html body main section.contact-page .contact-page__subvisual {
  background-image: url(../../images/contact/contact-bg.webp);
  background-size: cover;
  background-position: center;
  padding: 10rem 0 5rem;
}
@media screen and (max-width: 767px) {
  html body main section.contact-page .contact-page__subvisual {
    padding: 4rem 1rem 3rem;
    background-image: url(../../images/contact/contact-bg-sp.webp);
  }
}
html body main section.contact-page .contact-page__subvisual .contact-page__main-message {
  font-size: 3.4rem;
  color: #2D70AF;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.588;
  text-align: center;
  padding-bottom: 7rem;
}
@media screen and (max-width: 767px) {
  html body main section.contact-page .contact-page__subvisual .contact-page__main-message {
    font-size: 1.7rem;
    letter-spacing: 0;
    line-height: 1.529;
    padding-bottom: 3rem;
  }
}
html body main section.contact-page .contact-page__subvisual .contact-page__sub-message {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  line-height: 2.222;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 1rem;
}
@media screen and (max-width: 767px) {
  html body main section.contact-page .contact-page__subvisual .contact-page__sub-message {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}
html body main section.contact-page .contact-method.bg-color {
  background-color: rgba(45, 112, 175, 0.05);
  padding: 10rem 1rem;
}
@media screen and (max-width: 767px) {
  html body main section.contact-page .contact-method.bg-color {
    padding: 5rem 1rem;
  }
}
html body main section.contact-page .contact-method .flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
}
@media screen and (max-width: 767px) {
  html body main section.contact-page .contact-method .flex {
    display: block;
  }
}
html body main section.contact-page .reason {
  padding: 10rem 0;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason {
    padding: 6rem 0;
  }
}
html body main section.contact-page .reason .reason__title {
  color: #2D70AF;
  font-size: 3rem;
  letter-spacing: 0.1em;
  font-weight: 700;
  text-align: center;
  margin-bottom: 14rem;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__title {
    margin-bottom: 4rem;
  }
}
@media screen and (max-width: 767px) {
  html body main section.contact-page .reason .reason__title {
    font-size: 2rem;
  }
}
html body main section.contact-page .reason .reason__title .damion {
  font-size: 9.1rem;
}
@media screen and (max-width: 767px) {
  html body main section.contact-page .reason .reason__title .damion {
    font-size: 6.4rem;
  }
}
html body main section.contact-page .reason .reason__list {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__list {
    justify-content: space-evenly;
  }
}
html body main section.contact-page .reason .reason__list .reason__item {
  flex-basis: 33.3333333333%;
  position: relative;
  max-width: 346px;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__list .reason__item {
    flex-basis: 45%;
  }
  html body main section.contact-page .reason .reason__list .reason__item:nth-child(n+3) {
    margin-top: 4rem;
  }
}
html body main section.contact-page .reason .reason__list .reason__item:nth-child(odd) {
  background-color: #2D70AF;
}
html body main section.contact-page .reason .reason__list .reason__item:nth-child(odd) .reason__item-number {
  background-color: #2D70AF;
}
html body main section.contact-page .reason .reason__list .reason__item:nth-child(even) {
  background-color: #38AF88;
}
html body main section.contact-page .reason .reason__list .reason__item:nth-child(even) .reason__item-number {
  background-color: #38AF88;
}
html body main section.contact-page .reason .reason__list .reason__item:nth-child(n+4) {
  margin-top: 8rem;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__list .reason__item:nth-child(n+4) {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__list .reason__item:nth-child(3) .reason__item-image {
    position: absolute;
    bottom: 0;
  }
}
html body main section.contact-page .reason .reason__list .reason__item:nth-child(5) .reason__item-image, html body main section.contact-page .reason .reason__list .reason__item:nth-child(6) .reason__item-image {
  position: absolute;
  bottom: 0;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__list .reason__item:nth-child(5) .reason__item-image, html body main section.contact-page .reason .reason__list .reason__item:nth-child(6) .reason__item-image {
    position: static;
  }
}
html body main section.contact-page .reason .reason__list .reason__item .reason__item-number {
  width: 64px;
  height: 64px;
  border-radius: 64px;
  color: #fff;
  font-size: 5.1rem;
  border: 6px solid #fff;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -32px;
  line-height: 45px;
  text-align: center;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__list .reason__item .reason__item-number {
    width: 30px;
    height: 30px;
    font-size: 2.3rem;
    border: 3px solid #fff;
    line-height: 20px;
    top: -15px;
  }
}
html body main section.contact-page .reason .reason__list .reason__item .reason__item-heading {
  color: #fff;
  font-size: 3rem;
  text-align: center;
  font-weight: 700;
  line-height: 1.333;
  padding: 11rem 0 8rem;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .reason .reason__list .reason__item .reason__item-heading {
    font-size: 1.4rem;
    padding: 4rem 0 3rem;
  }
}
html body main section.contact-page .support {
  display: flex;
  align-items: stretch;
  min-height: 450px;
  background-image: url(../../images/common/bg-stripe-bl.svg);
  margin-bottom: 15rem;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .support {
    display: block;
    min-height: auto;
    margin-bottom: 5rem;
  }
}
html body main section.contact-page .support .support__item {
  flex: 1;
}
html body main section.contact-page .support .support__item.support__image-wrapper {
  width: 100%;
}
html body main section.contact-page .support .support__item.support__image-wrapper img {
  object-fit: cover;
  width: 100%;
  min-height: 450px;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .support .support__item.support__image-wrapper img {
    min-height: auto;
  }
}
html body main section.contact-page .support .support__item.support__text {
  padding: 9rem 1rem 0;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .support .support__item.support__text {
    padding: 3rem 1rem;
  }
}
html body main section.contact-page .support .support__item.support__text .support__text-small {
  text-align: center;
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 2;
  padding-bottom: 4rem;
}
@media screen and (max-width: 1199px) {
  html body main section.contact-page .support .support__item.support__text .support__text-small {
    font-size: 1.6rem;
    line-height: 1.875;
    padding-bottom: 2rem;
  }
}
html body main section.contact-page .support .support__item.support__text .support__text-big {
  text-align: center;
  font-size: 4.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.5;
  color: #2D70AF;
}
@media screen and (max-width: 1199px) {
  html body main section.contact-page .support .support__item.support__text .support__text-big {
    font-size: 3.6rem;
  }
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .support .support__item.support__text .support__text-big {
    font-size: 2.8rem;
    line-height: 1.429;
  }
}
html body main section.contact-page .contact-contents h2 {
  font-size: 3rem;
  color: #2D70AF;
  text-align: center;
  padding-bottom: 5rem;
  font-weight: 700;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .contact-contents h2 {
    font-size: 2rem;
  }
}
html body main section.contact-page .contact-contents h2 + p {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.889;
  max-width: 900px;
  margin: 0 auto 7rem;
}
@media screen and (max-width: 991px) {
  html body main section.contact-page .contact-contents h2 + p {
    font-size: 1.6rem;
    line-height: 1.875;
    margin: 0 auto 5rem;
  }
}
html body main section.form-page h2 {
  text-align: center;
  font-weight: bold;
  font-size: 3rem;
  letter-spacing: 0.1em;
  color: #3878B4;
}
@media screen and (max-width: 767px) {
  html body main section.form-page h2 {
    font-size: 2rem;
  }
}
html body main section.form-page .form-description {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2.222;
  text-align: center;
  padding: 6rem 0 7rem;
}
@media screen and (max-width: 991px) {
  html body main section.form-page .form-description {
    font-size: 1.6rem;
    line-height: 1.875;
    text-align: left;
    padding: 3rem 0 4rem;
  }
}
@media screen and (max-width: 991px) {
  html body main section.form-page .form-wrapper .wrapper {
    padding: 0;
  }
}
html body main section.form-page .form-wrapper form {
  background-color: #E5EEF5;
  padding: 6rem 7rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 991px) {
  html body main section.form-page .form-wrapper form {
    padding: 4rem 1rem;
  }
}
@media screen and (max-width: 767px) {
  html body main section.form-page .form-wrapper form {
    margin-bottom: 1rem;
  }
}
html body main section.form-page .form-wrapper form input, html body main section.form-page .form-wrapper form textarea, html body main section.form-page .form-wrapper form select {
  width: 100%;
}
html body main section.form-page .form-wrapper form input[type=text],
html body main section.form-page .form-wrapper form input[type=email],
html body main section.form-page .form-wrapper form input[type=tel],
html body main section.form-page .form-wrapper form input[type=url],
html body main section.form-page .form-wrapper form input[type=number],
html body main section.form-page .form-wrapper form textarea,
html body main section.form-page .form-wrapper form select {
  background-color: #fff;
  padding: 0.5rem 1rem;
  transition: outline-color 100ms;
  border: 1px solid #D5D5D5;
  outline: 2px solid transparent;
  appearance: none;
}
html body main section.form-page .form-wrapper form input[type=text]:active,
html body main section.form-page .form-wrapper form input[type=email]:active,
html body main section.form-page .form-wrapper form input[type=tel]:active,
html body main section.form-page .form-wrapper form input[type=url]:active,
html body main section.form-page .form-wrapper form input[type=number]:active,
html body main section.form-page .form-wrapper form textarea:active,
html body main section.form-page .form-wrapper form select:active,
html body main section.form-page .form-wrapper form input[type=text]:focus,
html body main section.form-page .form-wrapper form input[type=email]:focus,
html body main section.form-page .form-wrapper form input[type=tel]:focus,
html body main section.form-page .form-wrapper form input[type=url]:focus,
html body main section.form-page .form-wrapper form input[type=number]:focus,
html body main section.form-page .form-wrapper form textarea:focus,
html body main section.form-page .form-wrapper form select:focus {
  outline-color: #6EC3A9;
}
html body main section.form-page .form-wrapper form .form-item {
  padding-bottom: 2rem;
}
html body main section.form-page .form-wrapper form .form-item > p {
  line-height: 0;
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  html body main section.form-page .form-wrapper form .form-item .form-item-inner {
    display: block;
  }
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner.flex-top {
  align-items: flex-start;
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-title {
  display: flex;
  align-items: center;
  justify-content: end;
  width: 30%;
}
@media screen and (max-width: 767px) {
  html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-title {
    justify-content: left;
    width: 100%;
  }
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-title p {
  font-weight: 600;
  font-size: 1.8rem;
  letter-spacing: 0;
  white-space: nowrap;
}
@media screen and (max-width: 991px) {
  html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-title p {
    font-size: 1.6rem;
  }
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-title::after {
  content: "任意";
  background-color: #707070;
  color: #fff;
  font-weight: 500;
  padding: 0.5rem 1.5rem;
  margin: 0 1.5rem;
  white-space: nowrap;
}
@media screen and (max-width: 991px) {
  html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-title::after {
    margin: 0 1rem;
    font-size: 1.4rem;
  }
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-title.required::after {
  content: "必須";
  background-color: #3878B4;
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content {
  width: 70%;
}
@media screen and (max-width: 767px) {
  html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content {
    width: 100%;
    margin-top: 1rem;
  }
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content .wpcf7-checkbox .wpcf7-list-item.first {
  margin: 0 0 0 0.5rem;
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content .wpcf7-checkbox .wpcf7-list-item label {
  display: flex;
  align-items: center;
  cursor: pointer;
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content .wpcf7-checkbox .wpcf7-list-item label input[type=checkbox] {
  width: auto;
  transform: scale(1.5);
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content .wpcf7-checkbox .wpcf7-list-item label input[type=checkbox] {
    transform: scale(1.25);
  }
}
html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label {
  font-size: 1.8rem;
  font-weight: 600;
  margin-left: 1rem;
}
@media screen and (max-width: 767px) {
  html body main section.form-page .form-wrapper form .form-item .form-item-inner .form-item-content .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label {
    font-size: 1.4rem;
    font-weight: 500;
  }
}
html body main section.form-page .form-wrapper form .form-item.form-privacy {
  text-align: center;
  padding-bottom: 4.5rem;
}
@media screen and (max-width: 767px) {
  html body main section.form-page .form-wrapper form .form-item.form-privacy {
    padding-bottom: 3rem;
  }
}
html body main section.form-page .form-wrapper form .form-item.form-privacy .form-item-inner {
  display: block;
}
html body main section.form-page .form-wrapper form .form-item.form-privacy .form-item-inner .form-item-content {
  font-size: 1.6rem;
  font-weight: 500;
  margin: 0 auto;
}
html body main section.form-page .form-wrapper form .form-item.form-privacy .form-item-inner p {
  font-size: 1.4rem;
  letter-spacing: 0;
  line-height: 2;
  margin-top: 1rem;
}
html body main section.form-page .form-wrapper form .form-submit input[type=submit] {
  background-color: #3878B4;
  color: #fff;
  border: 2px solid #3878B4;
  font-weight: 600;
  font-size: 1.8rem;
  padding: 1rem 2rem;
  max-width: 200px;
  text-align: center;
  margin: 0 auto;
  display: block;
  transition: 250ms;
}
html body main section.form-page .form-wrapper form .form-submit input[type=submit]:hover {
  background-color: #fff;
  color: #3878B4;
}
html body main section.form-page .center-text {
  text-align: center;
  margin-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  html body main section.form-page .center-text {
    margin-bottom: 5rem;
  }
}
html body main section.form-page .contact-method .flex {
  justify-content: space-evenly;
}
html body main section.form-page .wpcf7 form.sent .wpcf7-response-output {
  display: none !important;
}
@media screen and (max-width: 767px) {
  html body main section.thanks-page > .wrapper {
    padding: 0;
  }
}
html body main section.thanks-page .thanks-message {
  background-color: #E5EEF5;
  padding: 7rem 10rem;
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  html body main section.thanks-page .thanks-message {
    padding: 4rem 1.8rem;
    margin-top: 5rem;
  }
}
html body main section.thanks-page .thanks-message p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2.222;
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  html body main section.thanks-page .thanks-message p {
    font-size: 1.6rem;
    letter-spacing: 0.04em;
    margin-bottom: 2.5rem;
    line-height: 1.875;
  }
}
html body main section.thanks-page .thanks-message p:last-child {
  margin-bottom: 0;
}
html body main section.thanks-page .back-top {
  margin: 4rem 0;
}
@media screen and (max-width: 767px) {
  html body main section.thanks-page .back-top {
    margin: 3rem 0;
  }
}
html body main section.thanks-page .back-top a {
  background-color: #3878B4;
  color: #fff;
  border: 2px solid #3878B4;
  font-weight: 600;
  font-size: 1.8rem;
  padding: 1rem 2rem;
  max-width: 200px;
  text-align: center;
  margin: 0 auto;
  display: block;
  transition: 250ms;
}
html body main section.thanks-page .back-top a:hover {
  background-color: #fff;
  color: #3878B4;
}
html body main section.thanks-page .ps {
  font-size: 1.8rem;
  line-height: 2.222;
  text-align: center;
  margin-bottom: 7rem;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  html body main section.thanks-page .ps {
    font-size: 1.6rem;
    text-align: left;
    line-height: 1.875;
    padding: 0 1.8rem;
    letter-spacing: 0.04em;
    margin-bottom: 4rem;
  }
}
html body main section.thanks-page .contact-method .flex {
  justify-content: space-evenly;
}
html body main section.form-thanks-page .contact-method .form-none {
  display: none;
}
html body.page-form .pagetop {
  right: 10px;
  bottom: 100px;
}

/*# sourceMappingURL=contact.css.map */
