@charset "UTF-8";
/*-------------------------
全ページ共通部分
-------------------------*/
body.page,
body .section,
body .lp01,
body .site-header,
body [class*=_btn],
body footer,
body h1,
body h2,
body h3,
body h4,
body h5, body button, body input, body optgroup, body select, body textarea {
  font-family: "Noto Sans JP", sans-serif !important;
  font-optical-sizing: auto;
  font-style: normal;
}
body .footer,
body figure {
  margin: 0;
}

/***固定ページ*********/
.contact {
  width: min(1226px, 100%);
  margin: 0 auto -15px;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .contact {
    margin-bottom: -32px;
  }
}
@media screen and (max-width: 1023px) {
  .contact .section_header {
    padding: 0 21px;
  }
}
.contact .section_header .page-title {
  font-weight: 700;
  font-size: 24px;
  line-height: 30px;
  color: #6a9abf;
}
.contact .contact_wrap {
  width: 100%;
  margin: 40px auto 84px;
}
@media screen and (max-width: 1023px) {
  .contact .contact_wrap {
    margin: 14px auto 42px;
    padding: 0 21px;
  }
}
.contact .contact_wrap .contact_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  gap: 134px;
}
@media screen and (max-width: 1023px) {
  .contact .contact_wrap .contact_box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0px;
  }
}
.contact .contact_wrap .contact_box .contact_left {
  max-width: 582px;
}
@media screen and (max-width: 1023px) {
  .contact .contact_wrap .contact_box .contact_left {
    max-width: 100%;
    margin-bottom: 32px;
  }
}
.contact .contact_wrap .contact_box .contact_left .contact_img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 582px;
  height: 341px;
  -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.2509803922);
          box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.2509803922);
}
@media screen and (max-width: 1023px) {
  .contact .contact_wrap .contact_box .contact_left .contact_img {
    width: 100%;
    height: 205px;
  }
}
.contact .contact_wrap .contact_box .contact_left .contact_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.contact .contact_wrap .contact_box .contact_left .contact_title {
  font-weight: 700;
  font-size: 20px;
  line-height: 30px;
  text-align: left;
  letter-spacing: 0.1rem;
  color: #1b364b;
  margin: 32px 0;
}
@media screen and (max-width: 1023px) {
  .contact .contact_wrap .contact_box .contact_left .contact_title {
    font-size: 16px;
    line-height: 25px;
    letter-spacing: 0.05rem;
  }
}
.contact .contact_wrap .contact_box .contact_left .contact_txt {
  font-weight: 400;
  font-size: 16px;
  line-height: 30px;
  letter-spacing: 0.1rem;
  color: #000;
}
.contact .contact_wrap .contact_box .contact_left .contact_txt span {
  color: #ff9902;
  font-weight: 700;
  font-size: 18px;
}
.contact .contact_wrap .contact_box .contact_left .contact_txt ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  padding-left: 20px;
  color: #ff9902;
  font-weight: 700;
  line-height: 30px;
  font-size: 18px;
}
@media screen and (max-width: 1023px) {
  .contact .contact_wrap .contact_box .contact_left .contact_txt ul li {
    font-size: 14px;
    line-height: 25px;
    margin-bottom: 11px;
    letter-spacing: 0;
  }
}
.contact .contact_wrap .contact_box .contact_left .contact_txt ul li::before {
  content: "•";
  position: absolute;
  left: 0;
  font-size: 16px;
}
.contact .contact_wrap .contact_box .contact_right {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding-top: 1rem;
  gap: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 1023px) {
  .contact .contact_wrap .contact_box .contact_right {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-bottom: 42px;
  }
}

.privacy-policy {
  padding: 0;
}
.privacy-policy .section_header {
  width: min(839px, 100%);
  margin: 0 auto;
}
.privacy-policy .section_header .page-title {
  text-align: center;
  font-weight: 700;
  font-size: 32px;
  line-height: 30px;
  margin-bottom: 78px;
}
@media screen and (max-width: 1023px) {
  .privacy-policy .section_header .page-title {
    font-size: 24px;
  }
}
.privacy-policy .container {
  width: min(1200px, 85%);
  margin: 0 auto;
  max-width: 100%;
}
.privacy-policy .container .post_item {
  font-weight: 400;
  font-size: 16px;
  line-height: 2.2rem;
  letter-spacing: 14%;
  text-align: left;
}
@media screen and (max-width: 1023px) {
  .privacy-policy .container .post_item {
    font-size: 14px;
    text-align: left;
    letter-spacing: 0.14rem;
  }
}
.privacy-policy .container .post_item h2 {
  font-size: 24px;
  font-weight: 700;
}
.privacy-policy .container .post_item h3 {
  margin-top: 1.5rem;
  font-size: 20px;
  font-weight: 700;
}
.privacy-policy .container .post_item .top_btn {
  margin: 78px auto 206px;
}
@media screen and (max-width: 1023px) {
  .privacy-policy .container .post_item .top_btn {
    margin: 52px auto 70px;
  }
}

.thanks,
.error404 {
  padding: 0;
}
.thanks .section_header,
.error404 .section_header {
  width: min(839px, 100%);
  margin: 0 auto;
}
.thanks .section_header .page-title,
.error404 .section_header .page-title {
  text-align: center;
  font-weight: 700;
  font-size: 24px;
  line-height: 30px;
  color: #6a9abf;
  margin-bottom: 78px;
}
@media screen and (max-width: 1023px) {
  .thanks .section_header .page-title,
  .error404 .section_header .page-title {
    font-size: 16px;
  }
}
.thanks .container,
.error404 .container {
  width: min(839px, 100%);
  margin: 0 auto;
}
.thanks .container .post_item,
.error404 .container .post_item {
  font-weight: 400;
  font-size: 16px;
  line-height: 30px;
  letter-spacing: 14%;
  text-align: center;
}
@media screen and (max-width: 1023px) {
  .thanks .container .post_item,
  .error404 .container .post_item {
    font-size: 14px;
    text-align: left;
    letter-spacing: 0.14rem;
  }
}
.thanks .container .post_item .top_btn,
.error404 .container .post_item .top_btn {
  margin: 78px auto 206px;
}
@media screen and (max-width: 1023px) {
  .thanks .container .post_item .top_btn,
  .error404 .container .post_item .top_btn {
    margin: 52px auto 70px;
  }
}

.custom-404 {
  padding: 0;
}
.custom-404 .section_header .page-title {
  font-size: 64px;
}
@media screen and (max-width: 1023px) {
  .custom-404 .section_header .page-title {
    font-size: 40px;
  }
}
@media screen and (max-width: 1023px) {
  .custom-404 .container .post_item {
    font-weight: 400;
    text-align: center;
  }
}