@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Noto+Sans+JP:wght@100..900&display=swap");
.pc {
  display: block !important;
  font-size: 0;
}

@media screen and (max-width: 750px) {
  .pc {
    display: none !important;
  }
}

.sp {
  display: none !important;
  font-size: 0;
}

@media screen and (max-width: 750px) {
  .sp {
    display: block !important;
  }
}

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

.clearfix:after {
  display: block;
  content: "";
  clear: both;
}

.clearfix:before {
  display: block;
  content: "";
  clear: both;
}

.clearfix {
  display: block;
}

body {
  width: 100%;
  -webkit-text-size-adjust: 100%;
  font-family: "Inter","Noto Sans JP",sans-serif;
  font-display: swap;
  font-weight: 400;
  font-style: normal;
  font-optical-sizing: auto;
  word-break: break-all;
}

h1, h2, h3, h4, h5, h6, img, p, div, ul, li, dl, dt, dd, figure {
  margin: 0;
  padding: 0;
}

ul, li {
  display: inline-block;
  list-style: none;
}

img {
  max-width: 100%;
  height: auto;
  border: none;
  vertical-align: top;
}

a {
  color: #000;
  text-decoration: none;
}

a.tel {
  pointer-events: none;
}

@media screen and (max-width: 750px) {
  a.tel {
    pointer-events: initial;
  }
}

a.hov:hover {
  transition: 0.2s all;
  opacity: 0.8;
}

@media screen and (max-width: 750px) {
  a.hov:hover {
    opacity: 1;
  }
}

section {
  width: 100%;
}

p {
  font-size: 20px;
  font-weight: 400;
  line-height: 1.7;
  text-align: left;
  letter-spacing: 0.5px;
  color: #052326;
}

main {
  position: relative;
}

/* ---------------------------------------------------- */
/* mainVis
/* ---------------------------------------------------- */
.fv_caseWrap {
  width: 100%;
  background: linear-gradient(90deg, #00e1ad 0%, #052326 100%);
  padding: 10px;
}

@media screen and (max-width: 750px) {
  .fv_caseWrap {
    padding: 2.667vw;
    background: linear-gradient(90deg, #4fe4b3 0%, #08272b 100%);
  }
}

.fv_caseWrap .fv_caseWrap_read {
  text-align: center;
  color: #fff;
  font-size: 30px;
  line-height: 1.4;
  font-weight: 600;
}

@media screen and (max-width: 750px) {
  .fv_caseWrap .fv_caseWrap_read {
    line-height: 1.2;
    font-size: 4.267vw;
    padding-top: .25em;
  }
}

.fv_caseWrap .fv_caseWrap_read span {
  font-size: 45px;
  font-weight: 500;
}

@media screen and (max-width: 750px) {
  .fv_caseWrap .fv_caseWrap_read span {
    font-size: 6.667vw;
  }
}

.mainvisual {
  position: relative;
  background: url("../img/pc/fv_bg.png") center center no-repeat;
  background-size: cover;
  width: 100%;
  overflow: hidden;
  padding: 30px 0;
}

@media screen and (max-width: 750px) {
  .mainvisual {
    padding: 16vw 0;
    background: url("../img/sp/fv_bg.png") center center no-repeat;
    background-size: cover;
  }
}

.mainvisual .fv_inner {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 1700px;
  width: 96%;
  margin: 0 auto;
}

@media screen and (max-width: 750px) {
  .mainvisual .fv_inner {
    flex-direction: column;
  }
}

@media screen and (max-width: 750px) {
  .mainvisual .fv_ttl_wrap {
    width: 89.6vw;
  }
}

.mainvisual .fv_leftCnt {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 75%;
}

@media screen and (max-width: 1150px) {
  .mainvisual .fv_leftCnt {
    flex-direction: column;
  }
  .mainvisual .fv_leftCnt img {
    width: 90%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 750px) {
  .mainvisual .fv_leftCnt img {
    width: 100%;
  }
}

@media screen and (max-width: 1150px) {
  .mainvisual .fv_leftCnt .fv_leftCnt_imgWrap {
    margin-top: 30px;
  }
}

@media screen and (max-width: 750px) {
  .mainvisual .fv_leftCnt .fv_leftCnt_imgWrap {
    margin-top: 10.667vw;
    margin-bottom: 16vw;
    width: 82.667vw;
  }
}

.mainvisual .fv_rightCnt {
  width: 420px;
}

@media screen and (max-width: 750px) {
  .mainvisual .fv_rightCnt {
    width: 100%;
  }
}

.mainvisual .mvImg {
  z-index: -1;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.mainvisual .mvImg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -webkit-transition: -webkit-transform 8s linear;
  transition: -webkit-transform 8s linear;
  transition: transform 8s linear;
  transition: transform 8s linear, -webkit-transform 8s linear;
  animation-name: fadeInAnime;
  animation-duration: 8s;
  animation-fill-mode: forwards;
  animation-timing-function: ease;
}

/* ---------------------------------------------------- */
/* common text */
/* ---------------------------------------------------- */
.ctaWrap {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 20px;
}

@media screen and (max-width: 750px) {
  .ctaWrap {
    margin-top: 6.4vw;
  }
}

.ctaWrap .cta_try {
  width: 48%;
  position: relative;
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_try {
    width: 43.467vw;
  }
}

.ctaWrap .cta_try .addtxt {
  line-height: 1;
  font-size: 16px;
  font-weight: 600;
  align-items: center;
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_try .addtxt {
    font-size: 4.267vw;
    letter-spacing: -1px;
  }
}

.ctaWrap .cta_try .addtxt span {
  font-size: 30px;
  color: #0069b3;
  padding-bottom: 4px;
  padding-right: 4px;
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_try .addtxt span {
    font-size: 8vw;
    padding-bottom: 1.333vw;
    padding-right: 1.333vw;
  }
}

.ctaWrap .cta_try .addtxt:before {
  background-color: #0069b3;
  content: "";
  height: 2px;
  width: 20px;
  margin-right: 5px;
  transform: rotate(70deg);
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_try .addtxt:before {
    height: 0.533vw;
    width: 5.333vw;
    margin-right: 1.333vw;
  }
}

.ctaWrap .cta_try .addtxt:after {
  background-color: #0069b3;
  content: "";
  height: 2px;
  width: 20px;
  margin-left: 5px;
  transform: rotate(-70deg);
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_try .addtxt:after {
    height: 0.533vw;
    width: 5.333vw;
    margin-right: 1.333vw;
  }
}

.ctaWrap .cta_try .cta_tryBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: #00A7BF;
  background: linear-gradient(90deg, #00a7bf 0%, #2f5d8f 100%);
  padding: 8px;
  border-radius: 6px;
  box-shadow: 0px 5px #314d6d;
}

.ctaWrap .cta_try .cta_tryBtn:hover {
  transform: translateY(5px);
  box-shadow: none;
  transition: 0.2s;
}

.ctaWrap .cta_try .cta_tryBtn img {
  width: 20%;
  max-width: 40px;
  margin-right: 5px;
}

@media screen and (max-width: 1150px) {
  .ctaWrap .cta_try .cta_tryBtn img {
    width: 40px;
    margin: initial;
  }
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_try .cta_tryBtn img {
    width: 9.333vw;
    max-width: 100%;
    margin-right: 1.333vw;
  }
}

.ctaWrap .cta_try .cta_tryBtn p {
  color: #fff;
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  font-size: 1.25vw;
}

@media screen and (max-width: 1150px) {
  .ctaWrap .cta_try .cta_tryBtn p {
    font-size: 15px;
  }
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_try .cta_tryBtn p {
    text-align: center;
    font-size: 4.267vw;
    line-height: 1.4;
  }
}

.ctaWrap .cta_download {
  width: 48%;
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_download {
    width: 43.467vw;
  }
}

.ctaWrap .cta_download .cta_downloadBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: #FF4A61;
  background: linear-gradient(90deg, #ff4a61 0%, #b8081d 100%);
  padding: 8px 4px;
  border-radius: 6px;
  box-shadow: 0px 5px #b52220;
}

.ctaWrap .cta_download .cta_downloadBtn:hover {
  transform: translateY(5px);
  box-shadow: none;
  transition: 0.2s;
}

.ctaWrap .cta_download .cta_downloadBtn img {
  width: 20%;
  max-width: 40px;
  margin-right: 5px;
}

@media screen and (max-width: 1150px) {
  .ctaWrap .cta_download .cta_downloadBtn img {
    width: 40px;
    margin: initial;
  }
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_download .cta_downloadBtn img {
    width: 9.333vw;
    max-width: 100%;
    margin-right: 1.333vw;
  }
}

.ctaWrap .cta_download .cta_downloadBtn p {
  color: #fff;
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  font-size: 1.25vw;
}

@media screen and (max-width: 1150px) {
  .ctaWrap .cta_download .cta_downloadBtn p {
    font-size: 15px;
  }
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_download .cta_downloadBtn p {
    text-align: center;
    font-size: 4.267vw;
    line-height: 1.4;
  }
}

.ctaWrap .cta_download .addtxt {
  font-size: 16px;
  font-weight: 700;
  align-items: center;
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_download .addtxt {
    font-size: 4.267vw;
    letter-spacing: -1px;
  }
}

.ctaWrap .cta_download .addtxt span {
  font-size: 20px;
  color: #ed1c24;
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_download .addtxt span {
    font-size: 5.333vw;
  }
}

.ctaWrap .cta_download .addtxt:before {
  background-color: #ed1c24;
  content: "";
  height: 2px;
  width: 20px;
  margin-right: 5px;
  transform: rotate(70deg);
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_download .addtxt:before {
    height: 0.533vw;
    width: 5.333vw;
    margin-right: 1.333vw;
  }
}

.ctaWrap .cta_download .addtxt:after {
  background-color: #ed1c24;
  content: "";
  height: 2px;
  width: 20px;
  margin-left: 5px;
  transform: rotate(-70deg);
}

@media screen and (max-width: 750px) {
  .ctaWrap .cta_download .addtxt:after {
    height: 0.533vw;
    width: 5.333vw;
    margin-right: 1.333vw;
  }
}

.fadeInUp {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fadeInUp.active {
  opacity: 1;
  transform: translateY(0);
}

/* ---------------------------------------------------- */
/* merit  wrap */
/* ---------------------------------------------------- */
.meritWrap {
  padding: 120px 0;
  background: url("../img/pc/merit_bg.png") center center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 750px) {
  .meritWrap {
    padding: 16vw 0 16.267vw;
  }
}

.meritWrap .headingh2 {
  margin-bottom: 70px;
}

@media screen and (max-width: 750px) {
  .meritWrap .headingh2 {
    margin-bottom: 13.333vw;
  }
}

.meritWrap .headingh2 img {
  max-width: 247px;
  width: 30%;
  display: inline-block;
  margin-right: 5px;
}

@media screen and (max-width: 750px) {
  .meritWrap .headingh2 img {
    width: 38.933vw;
    max-width: 100%;
    margin-right: 1.867vw;
  }
}

.meritWrap .headingh2 p {
  font-size: 50px;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0.5px;
}

@media screen and (max-width: 750px) {
  .meritWrap .headingh2 p {
    font-size: 7.733vw;
  }
}

.meritWrap .headingh2 p span {
  display: block;
  color: #268a92;
}

.meritWrap .meritWrap_inner {
  width: 100%;
  margin-top: 70px;
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner {
    margin-top: 25.333vw;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent {
  width: 80%;
  background-color: #fff;
  border-radius: 0 50px 0 0;
  padding: 60px;
  padding-left: calc(17% + 60px);
  box-shadow: 2px 3px 5px rgba(0, 0, 0, 0.1);
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent {
    width: 96%;
    padding: 7.333vw 2.667vw 7.333vw 7.333vw;
  }
}

.meritWrap .meritWrap_inner.second {
  display: flex;
  justify-content: flex-end;
}

.meritWrap .meritWrap_inner.second .meritWrap_innerContent {
  border-radius: 50px 0 0 0;
  padding-left: 60px;
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner.second .meritWrap_innerContent {
    padding-left: 7.333vw;
  }
}

.meritWrap .meritWrap_inner.second .meritWrap_innerContent .meritWrap_innerContent_flex {
  justify-content: flex-start;
}

@media screen and (max-width: 1150px) {
  .meritWrap .meritWrap_inner.second .meritWrap_innerContent .meritWrap_innerContent_flex {
    flex-direction: column-reverse;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

@media screen and (max-width: 1150px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex {
    flex-direction: column;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex .imgCnt {
  max-width: 434px;
  width: 55%;
  margin-top: -110px;
  margin-bottom: -50px;
}

@media screen and (max-width: 1150px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex .imgCnt {
    margin-bottom: -10px;
    width: 100%;
    max-width: 600px;
  }
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex .imgCnt {
    width: 80vw;
    margin-bottom: 2vw;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt {
  max-width: 530px;
  width: 70%;
}

@media screen and (max-width: 1150px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt {
    width: 100%;
    max-width: 600px;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .ttlWrap {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: .75em;
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .ttlWrap {
    display: block;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .ttlWrap .num {
  font-size: 60px;
  line-height: 1;
  color: #268a92;
  padding-right: .15em;
  font-feature-settings: "palt" 1;
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt";
  width: 2em;
  letter-spacing: 0px;
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .ttlWrap .num {
    font-size: 10.133vw;
    display: inline-block;
    width: 1.5em;
    padding-right: 0em;
    vertical-align: middle;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .ttlWrap p {
  width: 100%;
  font-size: 30px;
  font-weight: 600;
  line-height: 1.3;
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .ttlWrap p {
    width: 100%;
    font-size: 5.067vw;
    display: inline-block;
    width: calc(100% - 3.5em);
    vertical-align: middle;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .read {
  font-size: 20px;
}

@media screen and (max-width: 750px) {
  .meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .read {
    font-size: 4.267vw;
  }
}

.meritWrap .meritWrap_inner .meritWrap_innerContent_flex .txtCnt .read span {
  color: #c6a82c;
  font-weight: 600;
}

.meritWrap .meritWrap_inner.first .meritWrap_innerContent .meritWrap_innerContent_flex .txtCnt .num {
  padding-right: 0;
  letter-spacing: 5px;
}

.meritWrap .ctaWrap {
  margin-top: 70px;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap {
    margin-top: 12vw;
  }
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap > div + div {
    margin-left: 2.667vw;
  }
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_try {
    width: 43.467vw;
  }
}

.meritWrap .ctaWrap .cta_try img {
  width: 60px;
  max-width: 100%;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_try img {
    width: 9.333vw;
  }
}

.meritWrap .ctaWrap .cta_try .addtxt {
  font-size: 24px;
  margin-bottom: 5px;
  line-height: 1.3;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_try .addtxt {
    font-size: 4.267vw;
  }
}

.meritWrap .ctaWrap .cta_try .addtxt span {
  font-size: 24px;
  padding-bottom: 0;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_try .addtxt span {
    font-size: 4.267vw;
  }
}

.meritWrap .ctaWrap .cta_try .cta_tryBtn {
  padding: 15px 0;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_try .cta_tryBtn {
    padding: 4vw 0;
  }
}

.meritWrap .ctaWrap .cta_try .cta_tryBtn p {
  font-size: 36px;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_try .cta_tryBtn p {
    font-size: 4.267vw;
  }
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_download {
    width: 43.467vw;
  }
}

.meritWrap .ctaWrap .cta_download img {
  width: 60px;
  max-width: 100%;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_download img {
    width: 9.333vw;
  }
}

.meritWrap .ctaWrap .cta_download .addtxt {
  font-size: 24px;
  margin-bottom: 5px;
  line-height: 1.3;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_download .addtxt {
    font-size: 4.267vw;
  }
}

.meritWrap .ctaWrap .cta_download .addtxt span {
  font-size: 24px;
  padding-bottom: 0;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_download .addtxt span {
    font-size: 4.267vw;
  }
}

.meritWrap .ctaWrap .cta_download .cta_downloadBtn {
  padding: 15px 0;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_download .cta_downloadBtn {
    padding: 4vw 0;
  }
}

.meritWrap .ctaWrap .cta_download .cta_downloadBtn p {
  font-size: 36px;
}

@media screen and (max-width: 750px) {
  .meritWrap .ctaWrap .cta_download .cta_downloadBtn p {
    font-size: 4.267vw;
  }
}

/* ---------------------------------------------------- */
/* problem  wrap */
/* ---------------------------------------------------- */
.problemWrap {
  position: relative;
  padding: 120px 0 0;
  background-color: #e9f3f4;
}

@media screen and (max-width: 750px) {
  .problemWrap {
    padding-top: 16vw;
  }
}

.problemWrap h2 {
  width: 70%;
  max-width: 770px;
  margin: 0 auto;
  margin-bottom: 50px;
}

@media screen and (max-width: 750px) {
  .problemWrap h2 {
    width: 60.267vw;
    margin-bottom: 8vw;
  }
}

.problemWrap .problem_section2 {
  background: #e9f3f4;
  position: relative;
  padding-bottom: 160px;
}

@media screen and (max-width: 750px) {
  .problemWrap .problem_section2 {
    padding-bottom: 29.333vw;
  }
}

.problemWrap .problem_section2:before {
  content: "";
  width: 100%;
  height: 0;
  border-style: solid;
  border-width: 140px 48vw 0 48vw;
  border-color: #e9f3f4 #fff transparent #fff;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

@media screen and (max-width: 750px) {
  .problemWrap .problem_section2:before {
    border-width: 24vw 47vw 0 47vw;
    bottom: -1px;
  }
}

.problemWrap .problem_section2 .problemIco {
  position: absolute;
  content: '';
  left: 0;
  right: 0;
  bottom: -50px;
  margin: auto;
  width: 24%;
  max-width: 240px;
  margin: 0 auto;
  padding-top: 30px;
}

@media screen and (max-width: 750px) {
  .problemWrap .problem_section2 .problemIco {
    width: 42.667vw;
    max-width: 100%;
    padding-top: 9.333vw;
    bottom: -12vw;
  }
}

.problemWrap .problem_section2 .problemAnsTxt {
  position: absolute;
  content: '';
  left: 0;
  right: 0;
  bottom: -210px;
  margin: auto;
  width: 70%;
  max-width: 1015px;
  margin: 0 auto;
  padding-top: 30px;
}

@media screen and (max-width: 750px) {
  .problemWrap .problem_section2 .problemAnsTxt {
    width: 90.667vw;
    max-width: 100%;
    padding-top: 4vw;
    bottom: -52vw;
  }
}

/* ---------------------------------------------------- */
/* about  wrap */
/* ---------------------------------------------------- */
.aboutWrap {
  padding: 320px 0 0;
}

@media screen and (max-width: 750px) {
  .aboutWrap {
    padding-top: 68vw;
  }
}

.aboutWrap .headingh2 span {
  color: #fff;
}

@media screen and (max-width: 750px) {
  .aboutWrap .headingh2 span {
    font-size: 3.733vw;
  }
}

@media screen and (max-width: 750px) {
  .aboutWrap .headingh2 .eng {
    margin-bottom: 2.133vw;
  }
}

.aboutWrap .headingh2 p {
  display: flex;
  align-items: center;
  color: #fff;
  font-size: 50px;
  font-weight: 600;
  line-height: 1;
}

@media screen and (max-width: 750px) {
  .aboutWrap .headingh2 p {
    font-size: 7.733vw;
  }
}

.aboutWrap .headingh2 p img {
  max-width: 248px;
  width: 33%;
  padding-bottom: 12px;
}

@media screen and (max-width: 750px) {
  .aboutWrap .headingh2 p img {
    width: 38.933vw;
    padding-bottom: 1.333vw;
  }
}

.aboutWrap .aboutTitle {
  padding-bottom: 120px;
}

@media screen and (max-width: 750px) {
  .aboutWrap .aboutTitle {
    padding-bottom: 16vw;
  }
}

.aboutWrap .aboutWrap_inner {
  width: 90%;
  background: #00e1ad;
  background: linear-gradient(90deg, #00e1ad 0%, #268a92 100%);
  box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.2);
  border-radius: 0 180px 0 0;
  padding: 120px 0 60px;
}

@media screen and (max-width: 750px) {
  .aboutWrap .aboutWrap_inner {
    padding: 16vw 0;
    width: 98%;
    background: #00e1ad;
    background: linear-gradient(180deg, #00e1ad 0%, #268a92 100%);
  }
}

.aboutWrap .aboutWrap_inner_contentWrap {
  display: flex;
  align-items: center;
  max-width: 1560px;
  margin-top: 50px;
}

@media screen and (max-width: 1150px) {
  .aboutWrap .aboutWrap_inner_contentWrap {
    display: block;
    margin-top: 8vw;
  }
}

.aboutWrap .aboutWrap_inner_contentWrap .imgWrap {
  max-width: 960px;
  width: 60%;
}

@media screen and (max-width: 1150px) {
  .aboutWrap .aboutWrap_inner_contentWrap .imgWrap {
    max-width: 77.333vw;
    width: 100%;
    margin: 0 auto;
  }
}

.aboutWrap .aboutWrap_inner_contentWrap .txtWrap {
  max-width: 550px;
  width: 35%;
  margin-left: 2%;
}

@media screen and (max-width: 1150px) {
  .aboutWrap .aboutWrap_inner_contentWrap .txtWrap {
    max-width: 87.333vw;
    width: 100%;
    margin: 0 auto;
    padding-top: 8vw;
  }
}

.aboutWrap .aboutWrap_inner_contentWrap .txtWrap span {
  background-color: #c6a82c;
  font-weight: 600;
  padding: 0.1em 0.2em;
  margin: 0 0.1em;
  font-feature-settings: "palt" 1;
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt";
  letter-spacing: 0.5px;
}

.aboutWrap .aboutWrap_inner_contentWrap .txtWrap p {
  font-size: 24px;
  line-height: 1.8;
  color: #fff;
  margin-bottom: 1em;
}

.aboutWrap .aboutWrap_inner_contentWrap .txtWrap p:last-child {
  margin-bottom: 0;
}

@media screen and (max-width: 750px) {
  .aboutWrap .aboutWrap_inner_contentWrap .txtWrap p {
    font-size: 4.267vw;
  }
}

/* ---------------------------------------------------- */
/* mechanismm  wrap */
/* ---------------------------------------------------- */
.mechanismmWrap {
  position: relative;
  padding: 120px 0 240px;
  background: url("../img/common/mechanism_bg.png") center center repeat;
  background-size: 72px 72px;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap {
    padding: 16vw 0 32vw;
  }
}

.mechanismmWrap .headingh2 {
  margin-bottom: 60px;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .headingh2 {
    margin-bottom: 8vw;
  }
}

.mechanismmWrap .headingh2 img {
  width: 30%;
  max-width: 248px;
  padding-top: 6px;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .headingh2 img {
    width: 38.933vw;
    padding-top: 0.533vw;
  }
}

.mechanismmWrap .headingh2 p {
  font-size: 50px;
  line-height: 1.4;
  font-weight: 600;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .headingh2 p {
    font-size: 7.733vw;
  }
}

.mechanismmWrap .headingh2 p span {
  color: #268a92;
  font-weight: 600;
}

.mechanismmWrap .mechanismmWrap_content {
  position: relative;
  background-color: #fff;
  border-radius: 10px;
  padding: 50px;
  margin-bottom: 50px;
  box-shadow: 3px 2px 5px rgba(0, 0, 0, 0.18);
}

@media screen and (max-width: 1150px) {
  .mechanismmWrap .mechanismmWrap_content {
    margin-top: 18.667vw;
  }
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_content {
    margin-bottom: 18.667vw;
    padding: 5.333vw;
  }
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl {
  display: flex;
  align-items: center;
  padding-bottom: 20px;
}

@media screen and (max-width: 1150px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl {
    display: block;
    padding-bottom: 3.2vw;
    padding-top: 34.667vw;
  }
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttlnum {
  position: relative;
  max-width: 220px;
  width: 30%;
  position: relative;
  background: #00e1ad;
  background: linear-gradient(90deg, #00e1ad 0%, #052326 100%);
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttlnum {
    width: 33.867vw;
    max-width: 100%;
  }
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttlnum:after {
  position: absolute;
  content: '';
  right: -15px;
  top: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 15px solid transparent;
  border-left: 15px solid transparent;
  border-top: 60px solid #fff;
  border-bottom: 0;
}

@media screen and (max-width: 1150px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttlnum:after {
    border-top: 8vw solid #fff;
  }
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttlnum:after {
    border-top: 10vw solid #fff;
  }
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttlnum p {
  color: #fff;
  font-size: 34px;
  font-weight: 500;
  padding-left: 1em;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttlnum p {
    font-size: 5.333vw;
  }
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttltxt {
  width: 55%;
  line-height: 1.4;
  font-weight: 600;
  font-size: 30px;
  padding-left: 1em;
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttltxt span {
  color: #268a92;
}

@media screen and (max-width: 1150px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttltxt {
    padding-left: 0;
    margin-top: .75em;
  }
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_ttl .ttltxt {
    width: 100%;
    font-size: 6.4vw;
    margin-top: .5em;
    letter-spacing: 0.5px;
  }
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_line {
  display: flex;
  align-items: baseline;
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_line > div:nth-child(1) {
  width: 49%;
  border: 0;
  border-top: 1px solid #333;
  margin: 0;
  padding: 0;
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_line > div:nth-child(2) {
  transform: rotate(-30deg);
  width: 30px;
  border: 0;
  border-top: 1px solid #333;
  margin: 0;
  padding: 0;
  position: relative;
  bottom: -7px;
  right: -2px;
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_line > div:nth-child(3) {
  width: 49%;
  border: 0;
  border-top: 1px solid #333;
  margin: 0;
  padding: 0;
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_read {
  width: 79%;
  padding-top: 40px;
  font-size: 20px;
  font-weight: 400;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_read {
    width: 100%;
    padding-top: 6.133vw;
  }
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_content_read p {
    font-size: 4.267vw;
  }
}

.mechanismmWrap .mechanismmWrap_content .mechanismmWrap_ImgWrap {
  position: absolute;
  right: 5px;
  top: 40px;
  bottom: 0;
  margin: auto;
  max-width: 300px;
  width: 35%;
}

@media screen and (max-width: 1150px) {
  .mechanismmWrap .mechanismmWrap_content .mechanismmWrap_ImgWrap {
    top: -16vw;
    width: 61.333vw;
    right: 0;
    left: 0;
    margin: auto;
    max-width: 100%;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content {
  max-width: 1400px;
  margin: 0 auto;
  width: 94%;
  background: #00e1ad;
  background: linear-gradient(90deg, rgba(0, 225, 173, 0.6) 0%, rgba(38, 138, 146, 0.6) 100%);
  margin-top: 90px;
  padding-top: 45px;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content {
    width: 100%;
    margin-top: 14.667vw;
    padding-top: 8vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .mechanismmWrap_cta_read {
  margin-bottom: 40px;
}

.mechanismmWrap .mechanismmWrap_cta_content .mechanismmWrap_cta_read p {
  font-size: 40px;
  font-weight: 600;
  text-align: center;
  line-height: 1.8;
  color: #fff;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .mechanismmWrap_cta_read p {
    font-size: 5.333vw;
    line-height: 1.6;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .mechanismmWrap_cta_read p span {
  background: #00e1ad;
  background: linear-gradient(90deg, #0fa985 0%, #033a3e 100%);
  font-weight: 600;
  padding: 0.1em 0.2em;
  margin: 0 0.1em;
  font-feature-settings: "palt" 1;
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt";
  letter-spacing: 0.5px;
}

.mechanismmWrap .mechanismmWrap_cta_content .mechanismmWrap_cta_inner {
  width: 100%;
  padding: 10px 0 40px;
  background: #00e1ad;
  background: linear-gradient(90deg, #00e1ad 0%, #268a92 100%);
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .mechanismmWrap_cta_inner {
    padding: 2.667vw 0 8vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap img {
  width: 60px;
  max-width: 100%;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap img {
    width: 9.333vw;
  }
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap > div + div {
    margin-left: 2.667vw;
  }
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try {
    width: 43.467vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .addtxt {
  font-size: 24px;
  color: #fff;
  margin-bottom: 5px;
  line-height: 1.3;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .addtxt {
    font-size: 4.267vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .addtxt span {
  color: #fff;
  font-size: 24px;
  padding-bottom: 0;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .addtxt span {
    font-size: 4.267vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .cta_tryBtn {
  padding: 15px 0;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .cta_tryBtn {
    padding: 4vw 0;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .cta_tryBtn p {
  font-size: 36px;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_try .cta_tryBtn p {
    font-size: 4.267vw;
  }
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download {
    width: 43.467vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .addtxt {
  font-size: 24px;
  color: #fff;
  margin-bottom: 5px;
  line-height: 1.3;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .addtxt {
    font-size: 4.267vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .addtxt span {
  color: #fff;
  font-size: 24px;
  padding-bottom: 0;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .addtxt span {
    font-size: 4.267vw;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .cta_downloadBtn {
  padding: 15px 0;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .cta_downloadBtn {
    padding: 4vw 0;
  }
}

.mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .cta_downloadBtn p {
  font-size: 36px;
}

@media screen and (max-width: 750px) {
  .mechanismmWrap .mechanismmWrap_cta_content .ctaWrap .cta_download .cta_downloadBtn p {
    font-size: 4.267vw;
  }
}

/* ---------------------------------------------------- */
/* introductioneffectimage  wrap */
/* ---------------------------------------------------- */
.introductioneffectimageWrap {
  position: relative;
  padding: 120px 0;
  background: #00e1ad;
  background: linear-gradient(90deg, #00e1ad 0%, #268a92 100%);
  border-radius: 100px 100px 0 0;
  margin-top: -120px;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap {
    padding: 16vw 0;
    margin-top: -16vw;
    background: #00e1ad;
    background: linear-gradient(180deg, #00e1ad 0%, #268a92 100%);
    border-radius: 50px 50px 0 0;
  }
}

.introductioneffectimageWrap .headingh2 {
  margin-bottom: 55px;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .headingh2 {
    margin-bottom: 8vw;
  }
}

.introductioneffectimageWrap .headingh2 span {
  color: #fff;
}

.introductioneffectimageWrap .headingh2 img {
  width: 30%;
  max-width: 248px;
  padding-top: 6px;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .headingh2 img {
    width: 38.933vw;
    padding-top: 0.533vw;
  }
}

.introductioneffectimageWrap .headingh2 p {
  font-size: 50px;
  font-weight: 600;
  line-height: 1.4;
  color: #fff;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .headingh2 p {
    font-size: 7.733vw;
  }
}

.introductioneffectimageWrap .image_detail {
  max-width: 756px;
  margin: 0 auto;
  width: 80%;
  background-color: #fff;
  padding: 12px 20px;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .image_detail {
    width: 100%;
    padding: 4.8vw;
  }
}

.introductioneffectimageWrap .image_detail img {
  width: 30px;
  margin-right: 25px;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .image_detail img {
    width: 8vw;
    margin-right: 4vw;
  }
}

.introductioneffectimageWrap .image_detail .detailTxt p {
  display: inline-block;
  line-height: 1.3;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .image_detail .detailTxt .detailTxt_1 {
    display: block;
  }
}

.introductioneffectimageWrap .image_detail p {
  font-size: 20px;
  font-weight: 400;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .image_detail p {
    font-size: 3.733vw;
  }
}

.introductioneffectimageWrap .image_detail p + p {
  margin-left: 1em;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .image_detail p + p {
    margin-left: 0;
    margin-right: .25em;
  }
  .introductioneffectimageWrap .image_detail p + p:last-child {
    margin-right: 0;
  }
}

.introductioneffectimageWrap .image_detail p span {
  font-size: 28px;
  font-weight: 600;
  padding-right: .1em;
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .image_detail p span {
    font-size: 5.333vw;
  }
}

.introductioneffectimageWrap .imgContentWrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  margin-top: 30px;
}

@media screen and (max-width: 1150px) {
  .introductioneffectimageWrap .imgContentWrap {
    display: block;
  }
}

@media screen and (max-width: 750px) {
  .introductioneffectimageWrap .imgContentWrap {
    margin-top: 8vw;
  }
}

.introductioneffectimageWrap .imgContentWrap .before_after {
  width: 46%;
  max-width: 540px;
}

@media screen and (max-width: 1150px) {
  .introductioneffectimageWrap .imgContentWrap .before_after {
    width: 100%;
    margin: 0 auto 10.667vw;
  }
}

.introductioneffectimageWrap .imgContentWrap .graph {
  width: 48%;
  max-width: 570px;
}

@media screen and (max-width: 1150px) {
  .introductioneffectimageWrap .imgContentWrap .graph {
    width: 100%;
    margin: 0 auto;
  }
}

/* ---------------------------------------------------- */
/* flow  wrap */
/* ---------------------------------------------------- */
.flowWrap {
  position: relative;
  padding: 120px 0 240px;
  background: url("../img/pc/flow_bg.png") center center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 750px) {
  .flowWrap {
    padding: 16vw 0;
    background: url("../img/sp/flow_bg.png") center center no-repeat;
    background-size: cover;
  }
}

.flowWrap h2 {
  font-size: 50px;
  text-align: center;
  font-weight: 600;
  color: #052326;
  margin-bottom: 50px;
}

@media screen and (max-width: 750px) {
  .flowWrap h2 {
    font-size: 7.733vw;
    margin-bottom: 8vw;
  }
}

.flowWrap h2 span {
  color: #268a92;
}

.flowWrap .read {
  position: relative;
  align-items: center;
  display: flex;
  justify-content: center;
  font-size: 30px;
  font-weight: 600;
  text-align: center;
  margin-bottom: 50px;
}

@media screen and (max-width: 1150px) {
  .flowWrap .read {
    font-size: 22px;
    line-height: 1.5;
  }
}

@media screen and (max-width: 750px) {
  .flowWrap .read {
    font-size: 4.267vw;
    margin-bottom: 8vw;
  }
}

.flowWrap .read:before {
  background-color: #c6a82c;
  content: "";
  height: 4px;
  width: 40px;
  margin-right: 5px;
  transform: rotate(70deg);
}

@media screen and (max-width: 750px) {
  .flowWrap .read:before {
    height: 0.933vw;
    width: 13.333vw;
    margin-right: 0vw;
  }
}

.flowWrap .read:after {
  background-color: #c6a82c;
  content: "";
  height: 4px;
  width: 40px;
  margin-left: 5px;
  transform: rotate(-70deg);
}

@media screen and (max-width: 750px) {
  .flowWrap .read:after {
    height: 0.933vw;
    width: 13.333vw;
    margin-right: 0vw;
  }
}

.flowWrap .flow_imgWrap {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 60px;
}

@media screen and (max-width: 750px) {
  .flowWrap .flow_imgWrap {
    flex-wrap: wrap;
  }
}

.flowWrap .flow_imgWrap > div {
  position: relative;
  z-index: 1;
  max-width: 240px;
  width: 20%;
  box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.15);
}

@media screen and (max-width: 750px) {
  .flowWrap .flow_imgWrap > div {
    width: 39.467vw;
    max-width: 100%;
    margin-bottom: 12.8vw;
  }
  .flowWrap .flow_imgWrap > div:nth-child(3) {
    margin-bottom: 0;
  }
  .flowWrap .flow_imgWrap > div:nth-child(4) {
    margin-bottom: 0;
  }
}

.flowWrap .flow_imgWrap:before {
  position: absolute;
  content: '';
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 0;
  width: 100%;
  height: 3px;
  background: #00e1ad;
  background: linear-gradient(90deg, #00e1ad 0%, #052326 100%);
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
}

@media screen and (max-width: 750px) {
  .flowWrap .flow_imgWrap:before {
    background: url("../img/sp/flow_bar.png") center center no-repeat;
    background-size: 100%;
    width: 47.2vw;
    height: 47.2vw;
    max-width: 100%;
  }
}

.flowWrap .flow_imgWrap.show:before {
  opacity: 1;
  transition-delay: 1.25s;
  /* ← 遅延 */
}

/* ---------------------------------------------------- */
/* faq  wrap */
/* ---------------------------------------------------- */
.faqWrap {
  position: relative;
  padding: 0px 0 120px;
  background-color: #f8f6f1;
}

@media screen and (max-width: 750px) {
  .faqWrap {
    padding: 16vw 0;
  }
}

.faqWrap:before {
  position: absolute;
  content: '';
  width: 100%;
  height: 216px;
  background: url("../img/pc/faq_topbg.png") bottom center no-repeat;
  background-size: cover;
  top: -130px;
}

@media screen and (max-width: 750px) {
  .faqWrap:before {
    background: url("../img/sp/faq_topbg.png") bottom center no-repeat;
    background-size: cover;
    height: 18.667vw;
    top: -14.667vw;
  }
}

.faqWrap h2 {
  position: relative;
  z-index: 1;
  font-size: 50px;
  line-height: 1;
  text-align: center;
  font-weight: 600;
  color: #052326;
  margin-bottom: 60px;
  margin-top: -50px;
}

@media screen and (max-width: 750px) {
  .faqWrap h2 {
    font-size: 7.733vw;
    margin-bottom: 8vw;
  }
}

.faqWrap h2:before {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -70px;
  z-index: -1;
  margin: auto;
  content: 'FAQ';
  color: #fff;
  font-size: 190px;
}

@media screen and (max-width: 750px) {
  .faqWrap h2:before {
    font-size: 18.667vw;
    bottom: -5.333vw;
  }
}

.p-qa_content.f-accordion__list {
  width: 100%;
  margin-top: 40px;
}

@media screen and (max-width: 750px) {
  .p-qa_content.f-accordion__list {
    margin-top: 4vw;
  }
}

.p-qa_list {
  width: 100%;
  background-color: #fff;
  padding: 20px 90px 15px;
  margin-bottom: 10px;
}

@media screen and (max-width: 750px) {
  .p-qa_list {
    padding: 2.667vw 2.667vw 1.333vw;
    margin-bottom: 2.667vw;
  }
}

.p-qa_head {
  padding: 10px 10px 20px;
  text-align: left;
  letter-spacing: 0.5px;
  font-weight: 600;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 750px) {
  .p-qa_head {
    padding: 2vw 1.333vw 3.333vw;
  }
}

.p-qa_head p {
  color: #052326;
  font-size: 24px;
  line-height: 1.5;
}

@media screen and (max-width: 750px) {
  .p-qa_head p {
    font-size: 4.267vw;
    width: calc( 100% - 2em);
  }
}

.p-qa_head span {
  font-size: 30px;
  font-weight: 600;
  color: #268a92;
  margin-right: 10px;
  width: 1.5em;
}

@media screen and (max-width: 750px) {
  .p-qa_head span {
    font-size: 4.267vw;
    line-height: 1.5;
    width: 2em;
    margin-right: 0;
    display: inline-block;
  }
}

.p-qa_body_content {
  border-top: 1px solid #cccccc;
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 10px 10px 0;
  padding-top: 20px;
  letter-spacing: 0.5px;
}

@media screen and (max-width: 750px) {
  .p-qa_body_content {
    padding: 3.733vw 1.333vw 2.667vw;
  }
}

.p-qa_body_content p {
  font-size: 16px;
}

@media screen and (max-width: 750px) {
  .p-qa_body_content p {
    font-size: 3.2vw;
    line-height: 1.5;
  }
}

.p-qa_body_content span {
  font-size: 30px;
  font-weight: 600;
  color: #052326;
  margin-right: 10px;
  width: 1.5em;
}

@media screen and (max-width: 750px) {
  .p-qa_body_content span {
    font-size: 4.267vw;
    line-height: 1.5;
    margin-right: 2.667vw;
  }
}

.f-accordion__head {
  position: relative;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: all .5s ease;
  display: flex;
  padding-right: 2em;
}

@media screen and (max-width: 750px) {
  .f-accordion__head {
    padding-right: .25em;
  }
}

.f-accordion__head p {
  position: relative;
}

@media screen and (max-width: 750px) {
  .f-accordion__head p {
    padding-right: 1.75em;
  }
}

@media (max-width: 768px) {
  .f-accordion__icon {
    width: 34px;
    margin-right: 1rem;
  }
}

.f-accordion__head::before {
  content: '';
  display: inline-block;
  width: 15px;
  height: 1px;
  background-color: #268a92;
  position: absolute;
  right: 0px;
  top: 50%;
  transform: translateY(-50%);
  transition: opacity 0.4s;
}

@media screen and (max-width: 750px) {
  .f-accordion__head::before {
    width: 20px;
    height: 2px;
  }
}

.f-accordion__head::after {
  content: '';
  display: inline-block;
  width: 15px;
  height: 2px;
  background-color: #268a92;
  position: absolute;
  right: 0px;
  top: 50%;
  transform: translateY(-50%) rotate(90deg);
  transition: transform 0.4s;
}

@media screen and (max-width: 750px) {
  .f-accordion__head::after {
    width: 20px;
    height: 2px;
  }
}

@media (min-width: 750px) {
  .f-accordion__head::before {
    width: 26px;
    height: 2px;
  }
  .f-accordion__head::after {
    width: 26px;
    height: 2px;
  }
}

.f-accordion__item.active {
  margin-bottom: 30px;
}

.f-accordion__item.active .f-accordion__head::before {
  opacity: 0;
}

.f-accordion__item.active .f-accordion__head::after {
  transform: translateY(-50%) rotate(180deg);
}

@media (max-width: 768px) {
  .f-accordion__head::before {
    width: 13px;
    height: 1px;
    right: 10px;
    width: 20px;
    height: 2px;
  }
  .f-accordion__head::after {
    width: 13px;
    height: 1px;
    right: 10px;
    width: 20px;
    height: 2px;
  }
}

.f-accordion__body {
  overflow: hidden;
  width: 100%;
  height: 0;
  transition: all .2s ease;
  position: relative;
}

.f-accordion__item.active .f-accordion__body {
  height: auto;
}

.p-qa {
  padding: 120px 0;
  background-color: #F2F2F2;
}

@media screen and (max-width: 820px) {
  .p-qa {
    padding: 70px 0;
    margin-top: 0px;
  }
}

/* ---------------------------------------------------- */
/* common
/* ---------------------------------------------------- */
.cta_form .cta_form_ttl {
  width: 100%;
  padding: 10px 10px;
  background: #00e1ad;
  background: linear-gradient(90deg, #00e1ad 0%, #05474d 100%);
  font-size: 18px;
  font-weight: 600;
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 750px) {
  .cta_form .cta_form_ttl {
    text-align: center;
    line-height: 1.3;
    font-size: 5.333vw;
  }
}

.cta_form .cta_form_ttl span {
  font-size: 26px;
}

@media screen and (max-width: 750px) {
  .cta_form .cta_form_ttl span {
    font-size: 8vw;
  }
}

.cta_form .cta_formWrap {
  background-color: #f8f5ee;
  padding: 22px 45px;
}

@media screen and (max-width: 750px) {
  .cta_form .cta_formWrap {
    padding: 8.533vw 5.867vw;
  }
}

.cta_form .cta_formWrap .ctaWrap {
  width: 100%;
}

.cta_form .cta_formWrap .ctaWrap .cta_download {
  width: 100%;
}

.section_inner {
  max-width: 1200px;
  margin: 0 auto;
  width: 94%;
}

.headingh2 .eng {
  display: block;
  font-size: 20px;
  font-weight: 600;
  color: #268a92;
  margin-bottom: 10px;
}

@media screen and (max-width: 750px) {
  .headingh2 .eng {
    font-size: 3.733vw;
    margin-bottom: 2.667vw;
  }
}

.delay1 {
  transition-delay: 0.25s;
}

.delay2 {
  transition-delay: 0.5s;
}

.delay3 {
  transition-delay: 0.75s;
}

.delay4 {
  transition-delay: 1s;
}

.tight {
  /* プロポーショナルメトリクスを有効にする */
  font-feature-settings: "palt" 1;
  /* ベンダープレフィックスも併記するとより確実 */
  -webkit-font-feature-settings: "palt" 1;
  font-feature-settings: "palt";
  /* 新しい記述方法 */
}

.captionType1 {
  text-align: center;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 400;
  margin-bottom: 1em;
  color: #fff;
}

@media screen and (max-width: 750px) {
  .captionType1 {
    font-size: 2.667vw;
    margin-bottom: .35em;
    text-indent: -1em;
    padding-left: 1em;
    text-align: left;
  }
}

.meritWrap_inner .captionType1 {
  text-align: left;
  text-indent: -1em;
  padding-left: 1em;
  margin-top: .5em;
  color: #052326;
  margin-bottom: 0;
}

.mainvisual .fv_leftCnt .captionType1 {
  width: 96%;
  margin: 0 auto;
  text-align: center;
  text-indent: -1em;
  padding-left: 1em;
  margin-top: .5em;
  color: #052326;
  margin-bottom: 0;
}

.introductioneffectimageWrap .imgContentWrap .captionType1 {
  text-align: center;
  margin-top: .5em;
}

.reservePage_form .form_box .captionType1 {
  text-indent: -1em;
  padding-left: 1em;
  color: #555;
  margin-top: 1em;
  margin-bottom: 0;
  text-align: left;
}

/* ---------------------------------------------------- */
/* footer */
/* ---------------------------------------------------- */
footer {
  background: #062527;
  background: linear-gradient(90deg, #062527 0%, #298087 100%);
  padding: 80px 0 0;
  position: relative;
  width: 100%;
}

@media screen and (max-width: 750px) {
  footer {
    padding: 10.667vw 0 24vw;
  }
}

footer .wrap {
  width: 94%;
  max-width: 1600px;
  margin: 0 auto;
}

footer .wrap .footer_logo {
  display: block;
  margin-bottom: 20px;
}

footer .wrap .footer_logo img {
  height: 30px;
}

@media screen and (max-width: 750px) {
  footer .wrap .footer_logo img {
    width: 34.667vw;
    height: auto;
  }
}

footer .wrap .copy {
  padding: 20px 0 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.4);
}

footer .wrap .copy p {
  font-size: 13px;
  font-weight: 300;
  color: #fff;
}

@media screen and (max-width: 750px) {
  footer .wrap .copy p {
    text-align: center;
  }
}

footer .wrap .footerWrap {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 750px) {
  footer .wrap .footerWrap {
    display: block;
  }
}

footer .wrap .footer_menuWrap {
  display: block;
  margin-top: 15px;
}

footer .wrap .footer_menuWrap ul {
  display: block;
  margin-bottom: 20px;
}

footer .wrap .footer_menuWrap li {
  display: block;
  font-size: 13px;
  padding: 15px 0px;
}

@media screen and (max-width: 750px) {
  footer .wrap .footer_menuWrap li {
    font-size: 15px;
  }
}

footer .wrap .footer_menuWrap a {
  display: inline-block;
  font-size: 13px;
  color: #fff;
  text-align: left;
}

footer .wrap .footer_menuWrap a:hover {
  opacity: 0.6;
}

.ctaBtn {
  position: fixed;
  z-index: 2;
  bottom: 0px;
  right: 10px;
  opacity: 1;
  width: 270px;
  height: 280px;
  transform: translateY(0px);
  transition: opacity 0.4s ease, transform 0.4s ease;
  pointer-events: auto;
}

@media screen and (max-width: 750px) {
  .ctaBtn {
    bottom: 0;
    right: 0;
    width: 100%;
    height: auto;
  }
}

.ctaBtn.removeShow {
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
}

.ctaBtn a img {
  filter: drop-shadow(5px 5px 5px #aaa);
}

.cta_formWrap .reservePage_form .form_box {
  width: 100%;
  margin: 0 auto;
}

.cta_formWrap .reservePage_form .form_box .form_box_cnt {
  max-width: 540px;
  width: 96%;
  margin: 0 auto;
}

.cta_formWrap .underline {
  text-decoration: underline;
}

.cta_formWrap .consentBox p {
  text-align: center;
  font-size: 12px;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .consentBox p {
    font-size: 4.267vw;
  }
}

.cta_formWrap .consentBox a {
  text-decoration: underline;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .consentBox a {
    font-size: 4.267vw;
  }
}

.cta_formWrap .formArea {
  width: 100%;
  margin: 0 auto;
  text-align: left;
}

.cta_formWrap .formArea .formWrap {
  padding-bottom: 10px;
}

.cta_formWrap .formArea .formWrap .ttl {
  display: block;
  font-weight: 400;
  font-size: 14px;
  padding-bottom: 6px;
  margin-bottom: 4px;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .formArea .formWrap .ttl {
    font-size: 4.267vw;
    padding-bottom: 1.6vw;
    margin-bottom: 1.067vw;
  }
}

.cta_formWrap .formArea .formWrap .ttlptn2 {
  padding-bottom: 0;
}

.cta_formWrap .formArea .formWrap label span {
  display: block;
  font-weight: 300;
  font-size: 15px;
  padding-bottom: 6px;
  margin-bottom: 8px;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .formArea .formWrap label span {
    font-size: 3.733vw;
  }
}

.cta_formWrap .formArea .formWrap div span.check {
  font-size: 10px;
  background-color: #268a92;
  padding: 2px 6px;
  font-weight: normal;
  color: #fff;
  margin-left: 3px;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .formArea .formWrap div span.check {
    font-size: 3.733vw;
  }
}

.cta_formWrap .formArea .formWrap div input {
  height: 40px;
  margin-right: 10px;
  width: 210px;
  display: inline-block;
  padding: 5px 10px;
  margin-bottom: 5px;
  background-color: #fff;
  border: none;
  outline: 0;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .formArea .formWrap div input {
    font-size: 4vw;
    padding: 5.333vw 2.667vw;
  }
}

.cta_formWrap .formArea .formWrap div textarea {
  padding: 5px 10px;
  background-color: #fff;
  border: none;
  outline: 0;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .formArea .formWrap div textarea {
    padding: 5.333vw 2.667vw;
  }
}

.cta_formWrap .formArea .formWrap div input[type="checkbox"] {
  width: 20px;
  height: 20px;
  display: inline-block;
  vertical-align: baseline;
  margin-bottom: 0;
  margin-right: 5px;
}

.cta_formWrap .dib {
  display: inline-block;
}

.cta_formWrap .formArea .formWrap div label {
  display: inline-block;
  vertical-align: middle;
  line-height: 10px;
  cursor: pointer;
  margin-right: 15px;
  padding: 5px 0;
}

.cta_formWrap .formArea .formWrap div input[type="radio"] {
  width: 20px;
  height: 20px;
  display: inline-block;
  vertical-align: middle;
  margin-top: 10px;
  margin-right: 2px;
}

.cta_formWrap .formArea .formWrap div input[type="radio"]:checked {
  background-color: #268a92;
}

.cta_formWrap select {
  width: 100%;
  height: 50px;
  padding: 5px 10px;
  border: none;
  background: #fff;
}

@media screen and (max-width: 750px) {
  .cta_formWrap select {
    padding: 5.333vw 2.667vw;
  }
}

.cta_formWrap .formArea .formWrap div select {
  width: 150px;
}

.cta_formWrap .formArea .formWrap div input#people {
  width: 100%;
  max-width: 80px;
}

.cta_formWrap .formArea .formWrap div input#doc5,
.cta_formWrap .formArea .formWrap div input#name,
.cta_formWrap .formArea .formWrap div input#kana,
.cta_formWrap .formArea .formWrap div input#age,
.cta_formWrap .formArea .formWrap div input#first_reserve,
.cta_formWrap .formArea .formWrap div input#second_reserve,
.cta_formWrap .formArea .formWrap div input#third_reserve,
.cta_formWrap .formArea .formWrap div input#cardnumber,
.cta_formWrap .formArea .formWrap div input#companyname,
.cta_formWrap .formArea .formWrap div input#jobtitle,
.cta_formWrap .formArea .formWrap div input#departmentname,
.cta_formWrap .formArea .formWrap div input#mail,
.cta_formWrap .formArea .formWrap div input#mail2,
.cta_formWrap .formArea .formWrap div input#tel,
.cta_formWrap .formArea .formWrap div input#doc3 {
  width: 100%;
}

.cta_formWrap .formArea .formWrap div textarea#doc4 {
  width: 100% !important;
  min-height: 180px;
}

.cta_formWrap .formArea .formWrap .dateArea {
  display: inline-block;
}

.cta_formWrap .formArea .formWrap .dateArea input {
  width: 100%;
  max-width: 180px !important;
  margin-right: 10px !important;
}

.cta_formWrap .formArea .formWrap .dateArea input:nth-child(3) {
  margin-left: 10px !important;
}

.cta_formWrap .formArea .formWrap .err {
  display: none;
  color: #268a92;
  font-weight: 500;
  padding-bottom: 5px;
  font-size: 15px;
}

.cta_formWrap #errconsent {
  display: none;
  color: #268a92;
  font-weight: 500;
  padding-bottom: 5px;
  font-size: 15px;
}

.cta_formWrap .formArea .formWrap p.cap {
  font-size: 13px;
  margin-top: -7px;
  display: block;
  font-weight: bold;
  color: #152447;
}

.cta_formWrap input[type="radio"] {
  opacity: 0;
}

.cta_formWrap input[type="checkbox"] {
  opacity: 0;
}

.cta_formWrap label[for="with-consent"] {
  cursor: pointer;
  padding-left: 30px;
  position: relative;
}

.cta_formWrap label[for="with-consent"]::before,
.cta_formWrap label[for="with-consent"]::after {
  content: "";
  display: block;
  position: absolute;
  transform: translateY(-50%);
}

.cta_formWrap label[for="with-consent"]::before {
  background-color: #fff;
  border: none;
  height: 22px;
  width: 22px;
  left: 0px;
  bottom: -15px;
}

.cta_formWrap label[for="with-consent"]::after {
  opacity: 0;
  height: 12px;
  width: 12px;
  left: 0px;
  bottom: -15px;
}

.cta_formWrap input:checked + label[for="with-consent"]::before {
  opacity: 1;
  background-color: #fff;
  border: none;
  height: 22px;
  width: 22px;
  left: 0px;
  bottom: -15px;
}

.cta_formWrap input:checked + label[for="with-consent"]::after {
  opacity: 1;
  content: '';
  display: block;
  position: absolute;
  top: 1px;
  left: 4px;
  width: 14px;
  height: 9px;
  border-left: 4px solid #000;
  border-bottom: 4px solid #000;
  transform: rotate(-45deg);
}

.cta_formWrap label[for="rd_1"],
.cta_formWrap label[for="rd_2"],
.cta_formWrap label[for="rd_3"],
.cta_formWrap label[for="rd_4"] {
  cursor: pointer;
  padding-left: 30px;
  position: relative;
}

.cta_formWrap label[for="rd_1"]::before,
.cta_formWrap label[for="rd_1"]::after,
.cta_formWrap label[for="rd_2"]::before,
.cta_formWrap label[for="rd_2"]::after,
.cta_formWrap label[for="rd_3"]::before,
.cta_formWrap label[for="rd_3"]::after,
.cta_formWrap label[for="rd_4"]::before,
.cta_formWrap label[for="rd_4"]::after {
  content: "";
  display: block;
  border-radius: 50%;
  position: absolute;
  transform: translateY(-50%);
}

.cta_formWrap label[for="rd_1"]::before,
.cta_formWrap label[for="rd_2"]::before,
.cta_formWrap label[for="rd_3"]::before,
.cta_formWrap label[for="rd_4"]::before {
  background-color: #fff;
  border: none;
  height: 22px;
  width: 22px;
  left: -27px;
  bottom: 2px;
}

.cta_formWrap label[for="rd_1"]::after,
.cta_formWrap label[for="rd_2"]::after,
.cta_formWrap label[for="rd_3"]::after,
.cta_formWrap label[for="rd_4"]::after {
  opacity: 0;
  height: 12px;
  width: 12px;
  left: -22px;
  bottom: 12px;
}

.cta_formWrap input:checked + label[for="rd_1"]::before,
.cta_formWrap input:checked + label[for="rd_2"]::before,
.cta_formWrap input:checked + label[for="rd_3"]::before,
.cta_formWrap input:checked + label[for="rd_4"]::before {
  opacity: 1;
  background-color: #fff;
  border: 2px solid #268a92;
  height: 22px;
  width: 22px;
  left: -27px;
  bottom: 2px;
}

.cta_formWrap input:checked + label[for="rd_1"]::after,
.cta_formWrap input:checked + label[for="rd_2"]::after,
.cta_formWrap input:checked + label[for="rd_3"]::after,
.cta_formWrap input:checked + label[for="rd_4"]::after {
  opacity: 1;
  background-color: #268a92;
  height: 12px;
  width: 12px;
  left: -22px;
  bottom: 12px;
}

@media screen and (max-width: 750px) {
  .cta_formWrap .formArea .formWrap div input[type="checkbox"]:first-child {
    margin-bottom: 5px;
  }
}

.cta_formWrap input.sub {
  position: relative;
  background-color: #FF4A61;
  background: linear-gradient(90deg, #ff4a61 0%, #b8081d 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 15px 4px;
  margin-top: 10px;
  border-radius: 6px;
  box-shadow: 0px 5px #b52220;
  cursor: pointer;
  border: none;
  color: #fff;
  font-size: 20px;
  font-weight: 600;
  line-height: 1;
}

.cta_formWrap input.sub:disabled {
  background: #CCC !important;
  box-shadow: 0px 5px #AAA !important;
  transform: translateY(0) !important;
}

@media screen and (max-width: 1150px) {
  .cta_formWrap input.sub {
    font-size: 15px;
  }
}

@media screen and (max-width: 750px) {
  .cta_formWrap input.sub {
    text-align: center;
    font-size: 4.267vw;
    line-height: 1.4;
  }
}

.cta_formWrap input.sub:hover {
  transform: translateY(5px);
  box-shadow: none;
  transition: 0.2s;
}

.cta_formWrap input.sub:before {
  width: 20%;
  max-width: 40px;
  margin-right: 5px;
  background: url("../img/common/cta_download_ico.png") center center no-repeat;
  background-size: 100%;
}

@media screen and (max-width: 1150px) {
  .cta_formWrap input.sub:before {
    width: 40px;
    margin: initial;
  }
}

@media screen and (max-width: 750px) {
  .cta_formWrap input.sub:before {
    width: 9.333vw;
    max-width: 100%;
    margin-right: 1.333vw;
  }
}

.cta_formWrap input.sub:hover {
  background-color: #c44a45;
}

.cta_formWrap input.sub:hover:disabled {
  background: #CCC !important;
  box-shadow: 0px 5px #AAA !important;
  transform: translateY(0) !important;
}

.cta_formWrap input::placeholder {
  color: #a5a5a5;
}

.cta_formWrap input:-ms-input-placeholder {
  color: #a5a5a5;
}

.cta_formWrap input::-ms-input-placeholder {
  color: #a5a5a5;
}

.cta_formWrap #output {
  display: block;
  font-size: 22px;
  line-height: 1.3;
  font-weight: normal;
  color: #222;
  background-color: #fff4f2;
}

.cta_formWrap #output.mailConf {
  padding: 10px 8px;
}

.cta_formWrap p.mailErr {
  display: none;
  font-size: 15px;
  font-weight: 400;
  margin-bottom: 20px;
  color: #268a92;
}

.cta_formWrap .pb20 {
  padding-bottom: 20px;
}

.cta_formWrap .formWrap .Hide {
  display: none;
}

.cta_formWrap a.policyBtn {
  background-color: #152447;
  display: block;
  color: #fff;
  text-align: center;
  font-weight: 300;
  padding: 8px 15px;
  font-size: 15px;
  border-radius: 4px;
  margin: 0 auto;
  width: 50%;
  margin-top: 10px;
  max-width: 260px;
  min-width: 200px;
  cursor: pointer;
  border: none;
}

.cta_formWrap .formArea p.lead {
  margin-bottom: 40px;
  font-weight: bold;
}

.cta_formWrap input#rtn, .cta_formWrap input#fin {
  display: inline-block;
  color: #fff;
  text-align: center;
  font-weight: 300;
  padding: 30px 15px;
  font-size: 18px;
  border-radius: 4px;
  margin: 0 auto;
  width: 40%;
  max-width: 400px;
  margin-top: 30px;
  margin-bottom: 30px;
  min-width: 220px;
  cursor: pointer;
  border: none;
  widows: 100%;
}

.cta_formWrap input#rtn {
  background-color: #959595;
}

.cta_formWrap input#rtn:hover {
  background-color: #7f7f7f;
}

.cta_formWrap input#fin {
  background-color: #E09687;
}

.cta_formWrap input#fin:hover {
  background-color: #c44a45;
}

.cta_formWrap .formArea .btnWrap {
  display: flex;
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  justify-content: center;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  margin-bottom: 40px;
}

@media screen and (max-width: 750px) {
  .cta_formWrap input#rtn, .cta_formWrap input#fin {
    display: block;
    width: 60%;
    max-width: 360px;
    min-width: 240px;
    margin-top: 30px;
    margin-bottom: 0;
  }
}

.cta_formWrap .finWrap {
  width: 100%;
  margin: 0 auto;
  text-align: left;
}

.cta_formWrap .fin_subTtl {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  margin-top: 30px;
  text-align: left;
}

.cta_formWrap .finWrap p.txt01 {
  padding-bottom: 5px;
}

.cta_formWrap .finWrap p.txt02 {
  padding-bottom: 5px;
  padding-top: 5px;
  font-weight: 400;
  margin-bottom: .5em;
}

.cta_formWrap .finWrap p.txt_indent {
  text-indent: -9px;
  padding-left: 16px;
  display: block;
  margin-bottom: 0;
}

.cta_formWrap .homeBtn a {
  background-color: #268a92;
  display: block;
  color: #fff;
  text-align: center;
  font-weight: 300;
  padding: 30px 24px;
  font-size: 18px;
  border-radius: 4px;
  margin: 0 auto;
  width: 80%;
  max-width: 360px;
  margin-top: 40px;
  margin-bottom: 40px;
  /* min-width: 280px; */
  cursor: pointer;
  border: none;
}

.cta_formWrap .homeBtn a:hover {
  background-color: #c44a45;
}

.cta_formWrap.confirmPage .mainvisual_subpage {
  height: auto;
}

.cta_formWrap.finishPage .mainvisual_subpage {
  height: auto;
}

@media screen and (max-width: 750px) {
  .reservePage .reservePage_form .form_box {
    width: 100%;
    margin: 0 auto;
    padding: 0 15px 0;
  }
  .reservePage .reservePage_form .form_box .form_box_cnt {
    max-width: 700px;
    width: 96%;
    margin: 0 auto;
  }
  .reservePage .underline {
    text-decoration: underline;
  }
  .reservePage .consentBox p {
    text-align: left;
  }
  .reservePage .radio_wrap .dib {
    height: auto;
  }
  .reservePage .formArea {
    width: 100%;
    margin: 0 auto;
    text-align: left;
  }
  .reservePage .formArea .formWrap {
    padding-bottom: 10px;
  }
  .reservePage .formArea .formWrap .ttl {
    display: block;
    font-weight: 400;
    font-size: 2vw;
    padding-bottom: 6px;
    margin-bottom: 8px;
  }
  .reservePage .formArea .formWrap .ttlptn2 {
    padding-bottom: 10px;
  }
  .reservePage .formArea .formWrap label span {
    display: block;
    font-weight: 300;
    font-size: 1.867vw;
    padding-bottom: 6px;
    padding-bottom: 1vw;
  }
  .reservePage .formArea .formWrap div span.check {
    font-size: 10px;
    font-size: 3.733vw;
    background-color: #268a92;
    padding: 2px 6px;
    font-weight: normal;
    color: #fff;
    margin-left: 3px;
  }
  .reservePage .formArea .formWrap div input {
    height: 40px;
    height: 5.333vw;
    font-size: 2vw;
    margin-right: 10px;
    width: 210px;
    display: inline-block;
    padding: 5px 10px;
    margin-bottom: 5px;
    background-color: #fff;
    border: none;
    outline: 0;
  }
}

@media screen and (max-width: 750px) and (max-width: 750px) {
  .reservePage .formArea .formWrap div input {
    padding: 5.333vw 2.667vw;
  }
}

@media screen and (max-width: 750px) {
  .reservePage .formArea .formWrap div textarea {
    padding: 5px 10px;
    background-color: #fff;
    border: none;
    font-size: 2vw;
    outline: 0;
  }
}

@media screen and (max-width: 750px) and (max-width: 750px) {
  .reservePage .formArea .formWrap div textarea {
    padding: 5.333vw 2.667vw;
  }
}

@media screen and (max-width: 750px) {
  .reservePage .formArea .formWrap div input[type="checkbox"] {
    width: 20px;
    height: 20px;
    display: inline-block;
    vertical-align: baseline;
    margin-bottom: 0;
    margin-right: 5px;
  }
  .reservePage .dib {
    display: inline-block;
  }
  .reservePage .formArea .formWrap div label {
    display: inline-block;
    vertical-align: middle;
    line-height: 10px;
    line-height: 2.933vw;
    cursor: pointer;
    margin-right: 1.333vw;
    padding: 5px 0;
    padding-left: 3.2vw;
  }
  .reservePage .formArea .formWrap div input[type="radio"] {
    width: 20px;
    height: 20px;
    display: inline-block;
    vertical-align: middle;
    height: 2.667vw;
    width: 2.667vw;
    margin-top: -2px;
    margin-right: 2px;
    display: none;
  }
  .reservePage .formArea .formWrap div input[type="radio"]:checked {
    background-color: #268a92;
  }
  .reservePage select {
    width: 100%;
    height: 5.333vw;
    font-size: 2vw;
    padding: 5px 10px;
    border: none;
    background: #fff;
  }
}

@media screen and (max-width: 750px) and (max-width: 750px) {
  .reservePage select {
    padding: 5.333vw 2.667vw;
  }
}

@media screen and (max-width: 750px) {
  .reservePage .formArea .formWrap div select {
    width: 150px;
    width: calc(100% - 5em);
  }
  .reservePage .formArea .formWrap div input#people {
    width: 100%;
    max-width: 80px;
  }
  .reservePage .formArea .formWrap div input#doc5,
  .reservePage .formArea .formWrap div input#name,
  .reservePage .formArea .formWrap div input#kana,
  .reservePage .formArea .formWrap div input#age,
  .reservePage .formArea .formWrap div input#first_reserve,
  .reservePage .formArea .formWrap div input#second_reserve,
  .reservePage .formArea .formWrap div input#third_reserve,
  .reservePage .formArea .formWrap div input#cardnumber,
  .reservePage .formArea .formWrap div input#companyname,
  .reservePage .formArea .formWrap div input#jobtitle,
  .reservePage .formArea .formWrap div input#departmentname,
  .reservePage .formArea .formWrap div input#mail,
  .reservePage .formArea .formWrap div input#mail2,
  .reservePage .formArea .formWrap div input#tel,
  .reservePage .formArea .formWrap div input#doc3 {
    width: 100%;
  }
  .reservePage .formArea .formWrap div textarea#doc4 {
    width: 100% !important;
    min-height: 180px;
  }
  .reservePage .formArea .formWrap .dateArea {
    display: inline-block;
  }
  .reservePage .formArea .formWrap .dateArea input {
    width: 100%;
    max-width: 180px !important;
    margin-right: 10px !important;
  }
  .reservePage .formArea .formWrap .dateArea input:nth-child(3) {
    margin-left: 10px !important;
  }
  .reservePage .formArea .formWrap .err {
    display: none;
    color: #268a92;
    font-weight: 500;
    padding-bottom: 5px;
    font-size: 15px;
    font-size: 1.733vw;
  }
  .reservePage #errconsent {
    display: none;
    color: #268a92;
    font-weight: 500;
    padding-bottom: 5px;
    font-size: 15px;
    font-size: 1.733vw;
  }
  .reservePage input[type="radio"] {
    opacity: 0;
    display: none;
  }
  .reservePage input[type="checkbox"] {
    opacity: 0;
    display: none;
  }
  .reservePage label[for="with-consent"] {
    cursor: pointer;
    padding-left: 30px;
    padding-left: 2.667vw;
    position: relative;
  }
  .reservePage label[for="with-consent"]::before,
  .reservePage label[for="with-consent"]::after {
    content: "";
    display: block;
    position: absolute;
    transform: translateY(-50%);
  }
  .reservePage label[for="with-consent"]::before {
    background-color: #fff;
    border: none;
    border: none;
    height: 2.133vw;
    width: 2.133vw;
    left: 0vw;
    bottom: -1.067vw;
  }
  .reservePage label[for="with-consent"]::after {
    opacity: 0;
  }
  .reservePage input:checked + label[for="with-consent"]::before {
    opacity: 1;
    background-color: #fff;
    border: none;
    height: 2.133vw;
    width: 2.133vw;
    left: 0vw;
    bottom: -1.067vw;
  }
  .reservePage input:checked + label[for="with-consent"]::after {
    opacity: 1;
    content: '';
    display: block;
    position: absolute;
    top: 0.667vw;
    left: 0.267vw;
    width: 1.6vw;
    height: 0.933vw;
    border-left: 0.4vw solid #000;
    border-bottom: 0.4vw solid #000;
    transform: rotate(-45deg);
  }
  .reservePage label[for="rd_1"],
  .reservePage label[for="rd_2"],
  .reservePage label[for="rd_3"],
  .reservePage label[for="rd_4"] {
    cursor: pointer;
    padding-left: 30px;
    position: relative;
  }
  .reservePage label[for="rd_1"]::before,
  .reservePage label[for="rd_1"]::after,
  .reservePage label[for="rd_2"]::before,
  .reservePage label[for="rd_2"]::after,
  .reservePage label[for="rd_3"]::before,
  .reservePage label[for="rd_3"]::after,
  .reservePage label[for="rd_4"]::before,
  .reservePage label[for="rd_4"]::after {
    content: "";
    display: block;
    border-radius: 50%;
    position: absolute;
    transform: translateY(-50%);
  }
  .reservePage label[for="rd_1"]::before,
  .reservePage label[for="rd_2"]::before,
  .reservePage label[for="rd_3"]::before,
  .reservePage label[for="rd_4"]::before {
    background-color: #fff;
    width: 2.667vw;
    height: 2.667vw;
    left: 0;
    bottom: 0.533vw;
    top: 0;
    margin: auto;
    transform: initial;
  }
  .reservePage label[for="rd_1"]::after,
  .reservePage label[for="rd_2"]::after,
  .reservePage label[for="rd_3"]::after,
  .reservePage label[for="rd_4"]::after {
    opacity: 0;
    height: 12px;
    width: 12px;
    left: -22px;
    bottom: 12px;
  }
  .reservePage input:checked + label[for="rd_1"]::before,
  .reservePage input:checked + label[for="rd_2"]::before,
  .reservePage input:checked + label[for="rd_3"]::before,
  .reservePage input:checked + label[for="rd_4"]::before {
    opacity: 1;
    background-color: #fff;
    border: 0.267vw solid #268a92;
    width: 2.667vw;
    height: 2.667vw;
    left: 0;
    bottom: 0.533vw;
    top: 0;
    margin: auto;
    transform: initial;
  }
  .reservePage input:checked + label[for="rd_1"]::after,
  .reservePage input:checked + label[for="rd_2"]::after,
  .reservePage input:checked + label[for="rd_3"]::after,
  .reservePage input:checked + label[for="rd_4"]::after {
    opacity: 1;
    background-color: #268a92;
    width: 1.333vw;
    height: 1.333vw;
    left: -2.951vw;
    left: 0.667vw;
    bottom: 0.533vw;
    top: 0;
    margin: auto;
    transform: initial;
  }
  .reservePage .cardnumbertxt {
    font-size: 14px;
    font-size: 1.6vw;
    line-height: 1.3;
    margin-top: -8px;
    padding-bottom: 5px;
  }
  .reservePage input.sub {
    background-color: #FF4A61;
    background: linear-gradient(90deg, #ff4a61 0%, #b8081d 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 15px 4px;
    margin-top: 10px;
    border-radius: 6px;
    box-shadow: 0px 5px #b52220;
    cursor: pointer;
    border: none;
    color: #fff;
    font-size: 20px;
    line-height: 1;
    font-size: 1.25vw;
  }
  .reservePage input.sub:disabled {
    background: #CCC !important;
    box-shadow: 0px 5px #AAA !important;
    transform: translateY(0) !important;
  }
}

@media screen and (max-width: 750px) and (max-width: 1150px) {
  .reservePage input.sub {
    font-size: 15px;
  }
}

@media screen and (max-width: 750px) and (max-width: 750px) {
  .reservePage input.sub {
    text-align: center;
    font-size: 4.267vw;
    line-height: 1.4;
  }
}

@media screen and (max-width: 750px) {
  .reservePage input.sub:hover {
    transform: translateY(5px);
    box-shadow: none;
    transition: 0.2s;
  }
  .reservePage input.sub:hover {
    background-color: #c44a45;
  }
  .reservePage input.sub:hover:disabled {
    background: #CCC !important;
    box-shadow: 0px 5px #AAA !important;
    transform: translateY(0) !important;
  }
  .reservePage input::placeholder {
    color: #a5a5a5;
  }
  .reservePage input:-ms-input-placeholder {
    color: #a5a5a5;
  }
  .reservePage input::-ms-input-placeholder {
    color: #a5a5a5;
  }
  .reservePage #output {
    display: block;
    font-size: 22px;
    font-size: 2vw;
    line-height: 1.3;
    font-weight: normal;
    color: #222;
    background-color: #fff4f2;
  }
  .reservePage #output.mailConf {
    padding: 10px 8px;
  }
  .reservePage p.mailErr {
    display: none;
    font-size: 15px;
    font-size: 1.867vw;
    font-weight: 400;
    margin-bottom: 20px;
    color: #268a92;
  }
  .reservePage .pb20 {
    padding-bottom: 20px;
  }
  .reservePage .formWrap .Hide {
    display: none;
  }
  .reservePage .cnf_Answer {
    font-size: 1.867vw;
    display: block;
    margin-bottom: 8px;
  }
  .reservePage a.policyBtn {
    background-color: #152447;
    display: block;
    color: #fff;
    text-align: center;
    font-weight: 300;
    padding: 8px 15px;
    font-size: 15px;
    font-size: 1.867vw;
    border-radius: 4px;
    margin: 0 auto;
    width: 50%;
    margin-top: 10px;
    max-width: 260px;
    min-width: 200px;
    cursor: pointer;
    border: none;
  }
  .reservePage .formArea p.lead {
    margin-bottom: 40px;
    font-weight: bold;
  }
  .reservePage input#rtn, .reservePage input#fin {
    display: inline-block;
    color: #fff;
    text-align: center;
    font-weight: 300;
    padding: 30px 15px;
    font-size: 18px;
    font-size: 2vw;
    border-radius: 4px;
    margin: 0 auto;
    width: 40%;
    max-width: 400px;
    margin-top: 30px;
    margin-bottom: 30px;
    min-width: 220px;
    cursor: pointer;
    border: none;
    widows: 100%;
  }
  .reservePage input#rtn {
    background-color: #959595;
  }
  .reservePage input#rtn:hover {
    background-color: #7f7f7f;
  }
  .reservePage input#fin {
    background-color: #E09687;
  }
  .reservePage input#fin:hover {
    background-color: #c44a45;
  }
  .reservePage .formArea .btnWrap {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    justify-content: center;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    margin-bottom: 40px;
  }
}

@media screen and (max-width: 750px) and (max-width: 750px) {
  .reservePage input#rtn, .reservePage input#fin {
    display: block;
    width: 60%;
    max-width: 360px;
    min-width: 240px;
    margin-top: 30px;
    margin-bottom: 0;
  }
}

@media screen and (max-width: 750px) {
  .reservePage .finWrap {
    width: 100%;
    margin: 0 auto;
    text-align: left;
  }
  .reservePage .finWrap h3 {
    text-align: left;
    font-size: 30px;
    font-size: 2vw;
  }
  .reservePage .fin_subTtl {
    font-size: 2vw;
    font-weight: 400;
    line-height: 1.5;
    margin-top: 30px;
  }
  .reservePage .finWrap p {
    font-size: 1.867vw;
  }
  .reservePage .finWrap p.txt01 {
    padding-bottom: 5px;
  }
  .reservePage .finWrap p.txt02 {
    padding-bottom: 5px;
    padding-top: 5px;
    font-weight: 400;
    margin-bottom: .5em;
    font-size: 2vw;
  }
  .reservePage .finWrap p.txt_indent {
    text-indent: -9px;
    padding-left: 16px;
    display: block;
    margin-bottom: 0;
  }
  .reservePage .homeBtn a {
    background-color: #E09687;
    display: block;
    color: #fff;
    text-align: center;
    font-weight: 300;
    padding: 30px 24px;
    font-size: 18px;
    font-size: 2vw;
    border-radius: 4px;
    margin: 0 auto;
    width: 80%;
    max-width: 360px;
    margin-top: 40px;
    margin-bottom: 40px;
    /* min-width: 280px; */
    cursor: pointer;
    border: none;
  }
  .reservePage .homeBtn a:hover {
    background-color: #c44a45;
  }
  .reservePage.confirmPage .mainvisual_subpage {
    height: auto;
  }
  .reservePage.finishPage .mainvisual_subpage {
    height: auto;
  }
}

main.apply {
  background: linear-gradient(180deg, #1c7f8d, #112a37);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  position: relative;
}

.apply-logo {
  max-width: 200px;
  padding: 30px 0 0 30px;
}

.apply-main {
  align-items: flex-start;
  align-self: center;
  border-radius: 12px;
  display: flex;
  justify-content: center;
  margin: 80px 20px 42px;
  max-width: 792px;
  overflow-x: hidden;
  position: relative;
  width: calc(100% - 40px);
  z-index: 2;
}

.apply-main .apply-container {
  background: #fff;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  min-height: 100%;
  position: relative;
  width: 100%;
  z-index: 2;
  padding: 0 0 30px;
}

.apply-main .apply-container .videoWrap {
  padding: 34% 0 0 0;
  position: relative;
}

.apply-main .apply-container .videoWrap .bannervideo {
  width: 100%;
  height: 260px;
  overflow: hidden;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
}

.apply-main .apply-container .submit-result {
  text-align: center;
}

.apply-main .apply-container .submit-content {
  padding-top: 3%;
}

.apply-main .apply-container .submit-content .success-title {
  color: #000;
  font-size: 24px;
  font-weight: var(---font-weight-title, 600);
  line-height: normal;
  margin-bottom: 20px;
  text-align: center;
}

.apply-main .apply-container .submit-content .success-desc {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 20px;
}

.apply-main .submit-result .success-confirm-btn {
  background: #268a92;
  border-radius: 12px;
  font-size: 18px;
  font-weight: 600;
  height: 56px;
  max-width: 384px;
  width: 100%;
  color: #fff;
  border: none;
  cursor: pointer;
}

.videoArea {
  width: 100%;
  position: relative;
  padding: 40px 0 40px;
  background: url("../img/common/mechanism_bg.png") center center repeat;
  background-size: 72px 72px;
}

@media screen and (max-width: 750px) {
  .videoArea {
    width: 94%;
    margin: 0 auto;
    padding: 26.667vw 0;
  }
}

.videoArea .videoArea_bgTitle {
  display: flex;
  align-items: center;
  justify-content: center;
}

.videoArea .videoArea_bgTitle p {
  color: rgba(38, 138, 146, 0.1);
  font-weight: 600;
  text-align: center;
  line-height: 1.15;
  font-size: 220px;
  font-size: 11.667vw;
  margin: 0;
}

@media screen and (max-width: 1150px) {
  .videoArea .videoArea_bgTitle p {
    font-size: 15vw;
    line-height: 17vw;
  }
}

@media screen and (max-width: 750px) {
  .videoArea .videoArea_bgTitle p {
    font-size: 16.267vw;
  }
}

.videoArea .youtubeWrap {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 740px;
  width: 50%;
  margin: 0 auto;
}

@media screen and (max-width: 750px) {
  .videoArea .youtubeWrap {
    width: 100%;
  }
}

.videoArea .youtubeWrap img {
  cursor: pointer;
}

.yt-modal {
  display: none;
  position: fixed;
  z-index: 9999;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
}

.yt-modal__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  max-width: 800px;
}

.yt-modal__movie iframe {
  width: 100%;
  height: 450px;
}

.yt-modal__movie .caption {
  color: #fff;
  padding-left: 1em;
  text-indent: -1em;
  font-size: 15px;
  font-weight: 400;
  margin-top: .5em;
}

@media screen and (max-width: 750px) {
  .yt-modal__movie .caption {
    font-size: 3.467vw;
  }
}

.yt-modal__close {
  color: #fff;
  font-size: 40px;
  position: absolute;
  right: -30px;
  top: -30px;
  cursor: pointer;
}

@media screen and (max-width: 750px) {
  .yt-modal__close {
    right: 0;
    top: -45px;
  }
}

.foot_companyList {
  padding-top: 20px;
  padding-bottom: 30px;
}

.foot_companyList table {
  width: 100%;
}

.foot_companyList table tr th {
  font-size: 14px;
  color: #fff;
  padding-bottom: .75em;
  line-height: 1.5;
  text-align: left;
  width: 5.5em;
  display: inline-block;
  vertical-align: top;
}

.foot_companyList table tr td {
  font-size: 14px;
  line-height: 1.5;
  color: #fff;
  padding-bottom: .75em;
  padding-left: 1.5em;
  width: calc(100% - 6em);
  display: inline-block;
  vertical-align: top;
}
