@charset "UTF-8";
.dummy {
  color: #ff31f1 !important;
}

/*
====================================
共通
====================================
*/
.orb {
  font-family: "Orbitron", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

html {
  overflow-y: initial;
  font-size: 10px;
  letter-spacing: 0.075em;
}

body {
  overflow-x: hidden;
  font-feature-settings: "palt";
  background-color: #fff;
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.p {
  font-size: 1.6rem;
  line-height: 1.8;
}

main {
  overflow: hidden;
  overflow-y: initial;
}

.wrapper {
  padding-left: 16px;
  padding-right: 16px;
  margin-left: auto;
  margin-right: auto;
  max-width: 1100px;
}

.pc {
  display: block;
}

.pc-tb {
  display: block;
}

.tb-sp {
  display: none;
}

.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .pc-tb {
    display: none;
  }
  .tb-sp {
    display: block;
  }
  .sp {
    display: block;
  }
  .p {
    font-size: 1.3rem;
    line-height: 1.7;
  }
  .wrapper {
    padding-left: 16px;
    padding-right: 16px;
  }
}
.m_sectiontitle {
  position: relative;
  text-align: center;
}
.m_sectiontitle .jpn {
  font-size: 4rem;
  line-height: 1.3;
  letter-spacing: 0.1em;
  font-weight: 900;
}
.m_sectiontitle .eng {
  position: relative;
  font-family: "Orbitron", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
  font-size: 2rem;
  letter-spacing: 0.075em;
  color: #089C7E;
  display: block;
  margin-top: 8px;
}
.m_sectiontitle .eng::after {
  content: "";
  display: block;
  width: 106px;
  height: 28px;
  position: absolute;
  bottom: -45px;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../img/title-arrow.svg);
  background-size: contain;
}
.m_sectiontitle--white .jpn {
  color: #fff;
}
.m_sectiontitle--white .eng {
  color: #fff;
}
.m_sectiontitle--white .eng::after {
  background-image: url(../img/title-arrow-white.svg);
}

.m_lowerpage-header {
  position: relative;
  z-index: 0;
  height: 450px;
  width: 100%;
}
.m_lowerpage-header::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0.5;
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.5));
}
.m_lowerpage-header::after {
  content: "";
  display: block;
  width: 40%;
  height: 100%;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  background-image: url(../img/lowerheader/logo.svg);
  background-size: cover;
  background-position: left center;
  background-repeat: no-repeat;
}
.m_lowerpage-header .content {
  position: absolute;
  z-index: 2;
  left: 0;
  bottom: 32px;
  padding-left: 32px;
  height: auto;
  width: 100%;
}
.m_lowerpage-header .content .jpn {
  font-size: 4.8rem;
  line-height: 1.3;
  color: #fff;
  letter-spacing: 0.1em;
}
.m_lowerpage-header .content .eng {
  font-size: 2.4rem;
  line-height: 1.3;
  color: #089C7E;
}

.cta {
  margin-top: 150px;
  background-color: #089C7E;
  position: relative;
  padding-top: 100px;
  padding-bottom: 100px;
}
.cta .heading {
  position: relative;
  z-index: 2;
  margin-bottom: 80px;
}
.cta .content .desc {
  margin-bottom: 24px;
  color: #fff;
  font-size: 1.6rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  text-align: center;
}
.cta .content .link {
  width: 500px;
  margin-left: auto;
  margin-right: auto;
}
.cta .content .link a {
  display: block;
  transform: translateX(-8%);
}
.cta .content .link a img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.cta .content .link .time {
  margin-top: 8px;
  font-size: 1.6rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  font-weight: 600;
  text-align: center;
  color: #fff;
  display: block;
}
.cta--sidebar {
  margin-top: 0px;
  padding-top: 24px;
  padding-bottom: 24px;
}
.cta--sidebar .heading {
  margin-bottom: 32px;
}
.cta--sidebar .heading .m_sectiontitle .jpn {
  font-size: 1.6rem;
}
.cta--sidebar .heading .m_sectiontitle .eng {
  margin-top: 2px;
  font-size: 1.3rem;
}
.cta--sidebar .heading .m_sectiontitle .eng::after {
  width: 65px;
  height: 10.5px;
  bottom: -18px;
}
.cta--sidebar .content .link {
  width: 100%;
}
.cta--sidebar .content .link a {
  transform: translateX(-2%);
}
.cta--sidebar .content .link .time {
  margin-top: 4px;
  font-size: 1.1rem;
  line-height: 1.3;
}

@media screen and (max-width: 768px) {
  .m_sectiontitle .jpn {
    font-size: 2.4rem;
  }
  .m_sectiontitle .eng {
    font-size: 1.6rem;
    margin-top: 8px;
  }
  .m_sectiontitle .eng::after {
    width: 76px;
    height: 20px;
    bottom: -32px;
  }
  .m_sectiontitle--white .jpn {
    color: #fff;
  }
  .m_sectiontitle--white .eng {
    color: #fff;
  }
  .m_sectiontitle--white .eng::after {
    background-image: url(../img/title-arrow-white.svg);
  }
  .m_lowerpage-header {
    height: 75vw;
  }
  .m_lowerpage-header .content {
    bottom: 16px;
    padding-left: 16px;
  }
  .m_lowerpage-header .content .jpn {
    font-size: 2.8rem;
  }
  .m_lowerpage-header .content .eng {
    font-size: 1.6rem;
    margin-top: 4px;
  }
  .cta {
    margin-top: 40px;
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .cta .heading {
    margin-bottom: 56px;
  }
  .cta .content .desc {
    margin-bottom: 12px;
    font-size: 1.4rem;
    line-height: 2;
  }
  .cta .content .link {
    margin-top: 24px;
    width: 80%;
  }
  .cta .content .link a {
    transform: translateX(-3%);
  }
  .cta .content .link .time {
    margin-top: 4px;
    font-size: 1.3rem;
    line-height: 1.8;
  }
  .cta--sidebar {
    margin-top: 0px;
    padding-top: 24px;
    padding-bottom: 24px;
  }
  .cta--sidebar .heading {
    margin-bottom: 32px;
  }
  .cta--sidebar .content .link {
    width: 80%;
  }
  .cta--sidebar .content .link a {
    transform: translateX(-5%);
  }
  .cta--sidebar .content .link .time {
    margin-top: 4px;
    font-size: 1.1rem;
    line-height: 1.3;
  }
}
/* =========================================
   CF7 メッセージ用カスタマイズ
========================================= */
.wpcf7 form .wpcf7-response-output {
  margin-top: 16px;
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 400;
  border: none; /* デフォルトの枠線を消す */
}

.wpcf7-response-output {
  display: block;
  padding: 12px 16px;
  margin-left: auto !important;
  margin-right: auto !important;
  max-width: 700px;
  font-size: 1.6rem !important;
  text-align: center !important;
}

/* 成功メッセージ */
.wpcf7 form.sent .wpcf7-response-output {
  background-color: #e6f7ec;
  color: #2e7d32;
  border: none !important;
}

/* 送信エラー */
.wpcf7 form.failed .wpcf7-response-output {
  background-color: #fdecea;
  color: #c62828;
  border: none !important;
}

/* バリデーションエラー */
.wpcf7 form.invalid .wpcf7-response-output {
  background-color: #fff4e5;
  color: #ff6f00;
  border: none !important;
}/*# sourceMappingURL=style.css.map */