@charset "utf-8";

/* CSS Document */
/*----------------------------------------


fv


----------------------------------------*/
.fv {
  position: relative;
  background: url("../images/fv_bg.webp") no-repeat center 50% / 1920px;
  height: 100vh;
  min-height: max(75vh, 900px);
  width: 100%;
  padding-top: 150px;
  opacity: 1;
}

.confirm .fv {
  opacity: 1;
}

.fv .inner {
  max-width: 1650px;
  width: 92%;
  margin: 0 auto;
  height: 100%;
}

.fv .txt_area {
  position: absolute;
  transform: translateY(-50%);
  left: 5%;
  top: min(50%, 350px);
  opacity: 1;
  width: 53%;
  z-index: 5;
  max-width: 830px;
  transition: 0.2s;
}

@media screen and (max-width:1600px) {
  .fv .txt_area {
    left: 0;
    width: 58%;
  }
}

@media screen and (max-height:950px) {
  .fv .txt_area {
    transform: translateY(0);
    top: 5%;
  }
}

.fv.on .txt_area {
  opacity: 1;
  transition: all 0.8s cubic-bezier(0.33, 1, 0.68, 1);
  transition-delay: 0.3s;
}

.fv .txt_area h2 {
  font-size: clamp(5.5rem, 5.5vw, 8.5rem);
  padding-bottom: min(2vw, 20px);
  font-weight: 900;
}

/* .fv #svg-animation {
  position: relative;
  top: -50px;
  left: 5px;
  max-width: 100%;
  height: auto;
} */
.fv .confirm_fight {
  position: absolute;
  top: -50px;
  left: 5px;
  /* display: none; */
  display: block;
  height: auto;
}

/* .confirm .fv #svg-animation{
  display: none;
}
.confirm .fv .confirm_fight{
  display: block;
}
.fv #svg-animation .st0 {
  fill: none;
  stroke: #FFFFFF;
  stroke-width: 20;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
  stroke-dasharray: 1500;
  stroke-dashoffset: 1500;
} */
.fv .txt_area .fight_area {
  position: relative;
  margin-top: 40px;
  margin-top: min(2.0vw, 40px);
}

.fv .txt_area .fight_area .fight {
  position: relative;
  max-width: 280px;
  width: 37%;
  height: 75px;
  height: min(5.8vw, 75px);
  border: 4px solid #514F58;
}

.fv .txt_area p.cach {
  margin-left: 20px;
  font-size: 2.0rem;
  font-size: clamp(1.5rem, 1.5vw, 2.2rem);
  letter-spacing: 0;
}

.fv .fv_list {
  display: flex;
  justify-content: space-between;
  max-width: 840px;
  margin-top: 100px;
  margin-top: min(5.0vw, 100px);
}

.fv .fv_list li {
  position: relative;
  border-radius: 50%;
  width: 30.9%;
  padding-bottom: 30.9%;
  height: 0;
  background: #f7f7f7;
}

.fv .fv_list li figure {
  width: 40%;
  margin: 20% auto 10px;
}

.fv .fv_list li p {
  line-height: 1.3;
  font-size: 2.0rem;
  font-size: clamp(1.4rem, 1.4vw, 2.0rem);
}

/*----------------------------------------


partners_area


----------------------------------------*/
.partners_area {
  margin: min(3.0vw, 30px) auto min(5.0vw, 100px);
}

.partners_area .ph {
  position: relative;
  left: 0;
  width: 100%;
  height: 72px;
  background: url("../images/partner_ph.png") repeat-x center top / 3010px auto;
  animation: partnersmove 50s linear infinite;
  z-index: 2;
}

@keyframes partnersmove {
  0% {
    background-position: 3010px 0;
  }

  100% {
    background-position: 0 0;
  }
}

/*----------------------------------------


various_area


----------------------------------------*/
.various_area {
  position: relative;
  margin-bottom: 200px;
  margin-bottom: min(10vw, 200px);
}

.various_area::after {
  position: absolute;
  content: "";
  width: 640px;
  height: 100%;
  top: -140px;
  right: 0;
  z-index: -1;
  background: url("../images/various_bg.svg") no-repeat left top / 100%;
}

.get_area::before,
.various_area::before,
.voice_area::before {
  position: absolute;
  content: "";
  background: #fff;
  width: 80%;
  height: 65%;
  max-height: 1440px;
  right: 0;
  top: 0;
  border-radius: 30px 0 0 30px;
  z-index: -1;
}

.various_area .title {
  max-width: 945px;
  width: 57%;
  padding-top: 170px;
  padding-top: min(10vw, 170px);
}

/*.voice_area .inner,
.various_area .inner{
  max-width: 1800px;
  width: 94%;
}*/
.voice_area .voice_list,
.various_area .various_list {
  margin-top: 5px;
  margin-top: min(2.0vw, 50vw);
  box-sizing: border-box;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  width: 100%;
  padding: 50px 0;
}

.slick-slider .slick-track {
  width: 100%;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 0 2.3333333%;
}

.voice_area .voice_list li,
.various_area .various_list li {
  float: none;
  width: 31%;
  max-width: 490px;
  height: 100%;

}

.various_area .various_list li {
  padding: 30px 50px;
  padding: min(2.0vw, 30px) min(1.5vw, 50px);
  box-sizing: border-box;
}

.various_area .various_list picture {
  display: block;
  width: 87%;
  max-width: 385px;
  margin: -120px auto 0;
  position: relative;
}

.various_area .various_list p {
  line-height: 2.0;
}

/*----------------------------------------


why_area


----------------------------------------*/
.why_area {
  position: relative;
  background: url("../images/why_bg.webp") no-repeat center top / 1400px, url("../images/why_bg02.webp") no-repeat center bottom / 1400px;
  padding: 170px 0 420px;
  padding: min(12vw, 170px) 0 min(22vw, 420px);
}

.why_area::before {
  position: absolute;
  content: "";
  background: url("../images/why_bg01.webp") no-repeat center top / 100%;
  max-width: 1050px;
  width: 55%;
  height: 100%;
  right: -8%;
  top: 350px;
  top: min(20vw, 350px);
  z-index: 0;
}

.why_area::after {
  position: absolute;
  content: "";
  background: url("../images/why_ph01.webp") no-repeat center top / 100%;
  max-width: 905px;
  width: 47%;
  height: 1080px;
  right: -3%;
  top: 200px;
  top: min(10vw, 200px);
  z-index: 0;
  transform-origin: center right;
  animation: yurayura 4s linear infinite;
}

.why_area .title {
  max-width: 595px;
  width: 36%;
  padding-top: 170px;
  padding-top: min(8vw, 170px);
}

.why_area h2+p {
  margin: 70px 0 100px;
  margin: min(5vw, 70px) 0 min(6vw, 100px);
  max-width: 800px;
  width: 50%;
}

@keyframes yurayura {

  0%,
  100% {
    transform: rotate(1deg);
  }

  50% {
    transform: rotate(-4deg);
  }
}

/*----------------------------------------


voice_area


----------------------------------------*/
.voice_area {
  position: relative;
  top: -80px;
  margin-bottom: 120px;
  margin-bottom: min(6vw, 120px);
}

.voice_area::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: url("../images/get_bg.webp") no-repeat center 250px / 700px, url("../images/voice_bg.svg") no-repeat right 3% / 394px;
  z-index: -1;
}

.voice_area::before {
  top: 80px;
}

.voice_area .title {
  max-width: 926px;
  width: 56%;
  padding-top: 250px;
}

.voice_area .voice_list li {
  position: relative;
  overflow: hidden;
  padding-bottom: 100px;
  padding-bottom: min(7vw, 100px);
}

.voice_area .voice_list .txt_area {
  padding: 30px 50px;
  padding: min(2.0vw, 30px) min(1.5vw, 50px);
  box-sizing: border-box;
}

.voice_area .voice_list picture {
  display: block;
  width: 100%;
}

.voice_area .line_title {
  position: relative;
  padding-left: 40px;
  font-size: 2.2rem;
  font-size: clamp(1.6rem, 1.6vw, 2.2rem);
  margin-bottom: 24px;
  margin-bottom: min(1.8vw, 24px)
}

.voice_area .line_title::before {
  position: absolute;
  content: "";
  border-top: 1px solid #707070;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  width: 30px;
}

.voice_area .txt_area dl {
  width: 48.5%;
  margin-bottom: 20px;
}

.voice_area .txt_area dl h4 {
  background: #707070;
  color: #fff;
  text-align: center;
  padding: 8px 0;
  border-radius: 30px;
  font-size: 1.8rem;
  font-size: clamp(1.3rem, 1.3vw, 1.8rem);
}

.voice_area .txt_area dl.years dd {
  font-size: 1.8rem;
  font-size: clamp(1.4rem, 1.4vw, 1.8rem);
}

.voice_area .txt_area dl.years dd span {
  font-size: 3.6rem;
  font-size: clamp(2.6rem, 2.6vw, 3.6rem);
  line-height: 1.3;
}

.voice_area .txt_area dl.address dd {
  font-size: 2.8rem;
  font-size: clamp(2.0rem, 2.0vw, 2.8rem);
}

.voice_area li .btn {
  position: absolute;
  bottom: 30px;
  margin: 0 auto;
  left: 0;
  right: 0;
}

.voice_area li .btn a {}

/*----------------------------------------


qa_area


----------------------------------------*/
.qa_area {
  padding: min(20vw, 260px) 0 min(12vw, 180px);
  background: url("../images/faq_bg.png") no-repeat center 0 / 1815px;
}

.qa_area::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: url("../images/faq_bg02.svg") no-repeat left -5% top 45% / 338px, url("../images/dot_bg.webp") no-repeat 2% 55% / 128px 128px;
  z-index: -1;
}

.qa_area .title_area {
  width: 19%;
  max-width: 320px;
}

.qa_area .txt_area {
  width: calc(100% - 19%);
  padding-left: 3%;
}

.qa_area .title_area .faq_title {
  width: 120px;
}

.qa_area .title_area h2 {
  font-size: 2.0rem;
  font-size: clamp(1.5rem, 1.5vw, 2.0rem);
}

.qa_area dl {
  margin-bottom: 40px;
  margin-bottom: min(2.5vw, 40px);
  background: #f7f7f7;
}

.qa_area dt {
  position: relative;
  padding: 40px;
  padding: min(3.0vw, 40px);
  cursor: pointer;
  font-size: 2.6rem;
  font-size: clamp(2.0rem, 2.0vw, 2.6rem);
}

.qa_area dt span {
  position: absolute;
  right: 30px;
  right: min(2.0vw, 30px);
  top: 38px;
  top: min(2.0vw, 38px);
  max-width: 66px;
  width: 5vw;
  height: 5vw;
  max-height: 66px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  font-size: 2.0rem;
  transition: 0.3s;
}

.qa_area dl.active dt span {
  transform: rotate(180deg);
}

.qa_area dd {
  display: none;
  padding: 0 40px 40px;
  padding: 0 min(3.0vw, 40px) min(3.0vw, 40px);
}

/*----------------------------------------


get_area


----------------------------------------*/
.get_area {
  position: relative;
}

.get_area::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: -10%;
  left: 0;
  background: url("../images/get_bg.webp") no-repeat right 5% top 0 / 700px;
}

.get_area .title {
  max-width: 845px;
  width: 51%;
  padding-top: 170px;
  padding-top: min(10vw, 170px);
}

.get_area .flow_slide {
  margin-top: 0;
  z-index: 1;
}

.get_area .get_list li {
  width: 33.33333%;
}

.get_area .get_list picture {
  display: block;
  width: 100%;
  margin: 0 auto;
}

/*----------------------------------------


contents_foot_area


----------------------------------------*/
.contents_foot_area {
  padding: 240px 0;
  padding: min(12vw, 250px) 0;
  background: url("../images/foot_bg.webp") no-repeat center bottom /1920px;
}

.contents_foot_area .inner {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: rgba(255, 255, 255, .5);
  max-width: 1200px;
  padding: 100px 200px 60px;
  box-sizing: border-box;
}

.contents_foot_area .inner::before {
  position: absolute;
  content: "";
  width: 128px;
  height: 128px;
  top: 0;
  left: -2%;
  background: url("../images/dot_bg.webp") no-repeat right 5% top 0 / 100%;
  z-index: 5;
}

@supports not (backdrop-filter: blur(10px)) {
  .contents_foot_area .inner {
    background: rgba(255, 255, 255, .8);
  }
}

.contents_foot_area .inner h2 {
  font-size: 4.0rem;
  font-size: clamp(3.0rem, 3.0vw, 4.0rem);
  margin-bottom: 70px;
  margin-bottom: min(4vw, 70px);
}

.contents_foot_area .inner h2 img {
  position: relative;
  display: inline-block;
  max-width: 175px;
  width: 25%;
  margin-right: 10px;
  top: -8px;
}

.contents_foot_area .inner h3 {
  font-size: 2.6rem;
  font-size: clamp(1.8rem, 1.8vw, 2.6rem);
}

.contents_foot_area .inner p {
  margin: 25px auto 40px;
  line-height: 2.1;
  letter-spacing: 0.28rem;
}

.contents_foot_area .inner .btn {
  box-shadow: 7px 7px 14px #c9c9c9, -7px -7px 14px #fff;
  border-radius: 50px;
}

/*----------------------------------------


contact_area


----------------------------------------*/
.contact_area {
  position: absolute;
  width: 36%;
  max-width: 490px;
  padding: 35px 2%;
  box-sizing: border-box;
  font-size: 1.8rem;
  font-size: clamp(1.5rem, 1.5vw, 1.8rem);
  text-align: center;
  z-index: 6;
  opacity: 1;
  /* margin-top: 150px; */
  margin-top: 0;
  top: min(12vw, 150px);
  right: 3%;
}

.contact_area.confirm_active {
  opacity: 1;
  margin-top: 0;
}

.contact_area.active {
  opacity: 1;
  margin-top: 0;
}

.contact_area.active::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 30px;
  border: 4px solid transparent;
  left: 0;
  top: 0;
  animation: blink 1.2s linear 1 1.0s;
}

@keyframes blink {

  0%,
  100% {
    border: 6px solid transparent;
    box-shadow: 7px 7px 14px #dcdcdc, -7px -7px 14px #ffffff;
  }

  30% {
    border: 6px solid #28DE83;
    box-shadow: 15px 15px 30px #fff, 15px 15px 30px #fff, -15px -15px 30px #ffffff, -15px -15px 30px #ffffff;
  }

  50% {
    border: 6px solid #28DE83;
    box-shadow: 15px 15px 30px #fff, 15px 15px 30px #fff, -15px -15px 30px #ffffff, -15px -15px 30px #ffffff;
  }
}

.contact_area h2 {
  font-size: clamp(2.0rem, 1.95vw, 2.3rem);
  margin-bottom: 30px;
  margin-bottom: min(2.0vw, 30px);
  white-space: nowrap;
}

.contact_contents {
  position: relative;
  padding: 0 20px;
  z-index: 4;
}

.contact_area .loader {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  opacity: 1;
  z-index: 5;
}

.contact_area .loader div {
  width: 100%;
  text-align: center;
}

.contact_area .loader div p {
  font-size: clamp(1.1rem, 1.1vw, 1.3rem);
}

.contact_area .loader img {
  width: 20%;
}

.contact_area .loader.hide {
  opacity: 0;
  transition: 0.2s;
  z-index: -1;
}

.contact_area .contact_contents {
  opacity: 1;
}

.contact_area.active .contact_contents {
  opacity: 1;
}

.contact_contents dl,
.contact_area dl {
  position: relative;
  margin-bottom: 15px;
}

.contact_contents dl dt,
.contact_area dl dt {
  margin-bottom: 10px;
  text-align: center;
}

.contact_contents p,
.contact_area p {
  font-size: 1.6rem;
  margin: 20px 0;
}

.contact_contents p.aside,
.contact_area p.aside {
  font-size: 1.25rem;
  margin: 20px 0;
}

.contact_area p.aside01 {
  font-size: 1.25rem;
  margin: 10px 0 0;
  letter-spacing: 0;
}

.contact_contents p i,
.contact_contents p svg,
.contact_area p i,
.contact_area p svg {
  display: inline-block;
  font-size: 1.0rem;
  margin-top: 6px;
  margin: 0 1px;
}

.contactiframe {
  position: relative;
  max-height: 570px;
  min-height: 530px;
  height: 65vh;
}

.contact_contents .btn {
  margin: 0 auto;
}

@media only screen and (min-width:2000px) {
  .contact_area {
    top: min(10vw, 170px);
    right: 15vw;
  }

  /*  */
}

@media only screen and (min-width:751px) {
  .fv {
    max-height: 950px;
  }

  .slick-slide {
    height: auto !important;
  }
}

@media only screen and (max-width:750px) {

  /*----------------------------------------


  fv


  ----------------------------------------*/
  .fv {
    background: url("../images/fv_bg_sp.webp") no-repeat center top / 100%;
    min-height: auto;
    height: auto;
    width: 100%;
    padding-top: 30.333333vw;
  }

  .fv .inner {
    width: 90%;
  }

  .fv .txt_area {
    position: relative;
    transform: translateY(0);
    left: 0;
    top: 0;
    opacity: 1;
    width: 100%;
    max-width: 100%;
  }

  .fv.on .txt_area {
    opacity: 1;
    transition: all 0.8s cubic-bezier(0.33, 1, 0.68, 1);
    transition-delay: 0.3s;
  }

  .fv .txt_area h2 {
    font-size: 9.5vw;
    padding-bottom: min(2vw, 20px);
    letter-spacing: 0;
  }

  .fv #svg-animation {
    position: relative;
    top: -5vw;
    left: 0;
    display: none;
  }

  .fv .confirm_fight {
    top: -5vw;
    left: 0;
  }

  .fv #svg-animation .st0 {
    fill: none;
    stroke: #FFFFFF;
    stroke-width: 20;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-miterlimit: 10;
    stroke-dasharray: 1500;
    stroke-dashoffset: 1500;
  }

  .fv .txt_area .fight_area {
    margin-top: 5.333333333vw;
  }

  .fv .txt_area .fight_area .fight {
    max-width: 36.26666667vw;
    width: 36.26666667vw;
    height: 9.6vw;
    border: 3px solid #514F58;
  }

  .fv .txt_area p.cach {
    margin: 8vw 0;
    font-size: 4.5vw;
  }

  .fv .btn {
    width: 74.66666667vw;
    margin: 0 auto;
  }

  .fv .fv_list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    max-width: 100%;
    margin-top: 9.6vw;
  }

  .fv .fv_list li {
    width: 38vw;
    padding-bottom: 38vw;
    margin: 0 2.133333333vw;
  }

  .fv .fv_list li:nth-child(1) {
    order: 2;
  }

  .fv .fv_list li:nth-child(2) {
    order: 3;
  }

  .fv .fv_list li:nth-child(3) {
    margin: 0 8.133333333vw;
    order: 1;
  }

  .fv .fv_list li figure {
    width: 17.66666667vw;
    margin: 5.333333333vw auto 0;
  }

  .fv .fv_list li p {
    font-size: 3.2vw;
  }

  .fv.on .ph_area {
    transform: scale(1);
    opacity: 1;
  }

  .fv .ph_area .ico {
    position: absolute;
    max-width: 120px;
    min-width: 90px;
    width: 8%;
    z-index: 9;
  }


  /*----------------------------------------


  partners_area


  ----------------------------------------*/
  .partners_area {
    margin: 10.33333333vw auto;
  }

  .partners_area .ph {
    height: 101px;
    background: url("../images/partner_ph_sp.png") repeat-x center top / 1060px auto;
  }

  /*----------------------------------------


  various_area


  ----------------------------------------*/
  .various_area {
    margin: 12.66666667vw 0;
    background: transparent;
  }

  .get_area::before,
  .various_area::before,
  .voice_area::before {
    width: 70.93333333vw;
    height: 65%;
    max-height: 122.6666667vw;
    border-radius: 4vw 0 0 4vw;
  }

  .various_area::before {
    top: 10.66666667vw;
  }

  .various_area::after {
    position: absolute;
    content: "";
    width: 54.93333333vw;
    height: 100%;
    top: 0;
    right: 2vw;
    background: url("../images/various_bg_sp.svg") no-repeat right top / 100%;
  }

  .get_area .inner,
  .voice_area .inner,
  .various_area .inner {
    max-width: 100%;
    width: 100%;
    position: relative;
    z-index: 10;
  }

  .various_area .title {
    left: 5%;
    max-width: 90%;
    width: 90%;
    padding-top: 30.33333333vw;
  }

  .various_area h2 {
    left: 5%;
  }

  .voice_area .voice_list,
  .various_area .various_list {
    margin-top: 5vw;
  }

  .slick-slider .slick-track {
    display: block;
    gap: 0%;
  }

  .slick-slider .slick-track,
  .slick-slider .slick-list {
    padding: 5vw 0;
  }

  .various_area .slick-slider .slick-track,
  .various_area .slick-slider .slick-list {
    padding: 12vw 0 5vw;
  }

  .voice_area .voice_list li,
  .various_area .various_list li {
    float: left;
    width: 98%;
    max-width: 100%;
    margin: 0 2%;
  }

  .various_area .various_list li {
    padding: 6.666666667vw;
  }

  .various_area .various_list picture {
    width: 48.26666667vw;
    max-width: 48.26666667vw;
    margin-top: -17vw;
  }

  .various_area .various_list h3 {
    font-size: 5.866666667vw;
  }

  /*----------------------------------------


  why_area


  ----------------------------------------*/
  .why_area {
    position: relative;
    background: url("../images/why_bg_sp.webp") no-repeat left 0 top -4vw / 100%, url("../images/why_bg02_sp.webp") no-repeat center bottom / 100%;
    padding: 5vw 0 25vw;
    z-index: 5;
  }

  .why_area::after {
    position: absolute;
    content: "";
    background: url("../images/why_ph01.webp") no-repeat center top / 100%;
    max-width: 48.53333333vw;
    width: 48.53333333vw;
    height: 62.4vw;
    right: -5.333333vw;
    top: 9vw;
    z-index: -1;
  }

  .why_area::before {
    display: none;
  }

  .why_area .title {
    max-width: 53.86666667vw;
    width: 53.86666667vw;
    padding-top: 26.66666667vw;
  }

  .why_area h2+p {
    margin: 9.333333333vw 0 15.33333333vw;
    max-width: 100%;
    width: 100%;
  }

  .why_area h2 br.sp {
    display: inline-block !important;
  }

  .why_area .btn {
    margin-left: auto;
    margin-right: auto;
  }

  /*----------------------------------------


  voice_area


  ----------------------------------------*/
  .voice_area {
    background: transparent;
    top: -12vw;
    margin-bottom: 14.66666667vw;
    z-index: 6;
  }

  .voice_area::before {
    top: 9.333333333vw;
  }

  .voice_area::after {
    position: absolute;
    content: "";
    width: 61.33333333vw;
    height: 100%;
    top: 25vw;
    left: auto;
    right: -8vw;
    background: url("../images/get_bg.webp") no-repeat left top / 100%;
  }

  .voice_area .title {
    left: 5%;
    max-width: 82.66666667vw;
    width: 82.66666667vw;
    padding-top: 30.33333333vw;
  }

  .voice_area h2 {
    left: 5%;
  }

  .voice_area .voice_list li {
    padding-bottom: 4vw;
    height: 178.6666667vw;
    overflow: hidden;
    transition: 0.4s;
  }

  .voice_area .voice_list .txt_area {
    padding: 10.666667vw 6.666666667vw;
    -webkit-mask-image: -webkit-linear-gradient(-90deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 50%, transparent 80%);
  }

  .voice_area .voice_list picture {
    display: block;
    width: 100%;
  }

  .voice_area .line_title {
    position: relative;
    padding-left: 6.2vw;
    font-size: 5.333333333vw;
    margin-bottom: 4vw;
  }

  .voice_area .line_title::before {
    width: 5.866666667vw;
  }

  .voice_area .txt_area dl {
    margin-bottom: 3vw;
  }

  .voice_area .txt_area dl h4 {
    padding: 0.8vw 0;
    border-radius: 50px;
    font-size: 3.633333333vw;
    letter-spacing: 0;
  }

  .voice_area .txt_area dl.years dd {
    font-size: 3.733333333vw;
  }

  .voice_area .txt_area dl.years dd span {
    font-size: 10.13333333vw
  }

  .voice_area .txt_area dl.address dd {
    font-size: 7.466666667vw;
  }

  .voice_area .txt_area p {
    line-height: 2.2;
  }

  .voice_area li .btn.gray_btn {
    bottom: 4vw;
  }

  .voice_area li .btn.red_btn {
    position: relative;
    margin-top: 11vw;
  }

  .voice_area li .btn.gray_btn a {
    background: #514F58;
    color: #fff !important;
  }

  .voice_area .voice_list li.open {
    height: 100%;
    overflow: inherit;
  }

  .voice_area .voice_list li.open .txt_area {
    -webkit-mask-image: -webkit-linear-gradient(-90deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 1) 100%);
  }

  .voice_area .voice_list li.open .gray_btn {
    display: none !important;
  }

  /*----------------------------------------


  qa_area


  ----------------------------------------*/
  .qa_area {
    padding: 29.33333333vw 0 5vw;
    background: url("../images/faq_bg_sp.webp") no-repeat left top / 100%;
  }

  .qa_area::after {
    display: none;
  }

  .qa_area .title_area {
    width: 100%;
    max-width: 100%;
    text-align: center;
    margin-bottom: 8vw;
  }

  .qa_area .title_area .faq_title {
    width: 16vw;
    margin: 0 auto 2vw;
  }

  .qa_area .title_area h2 {
    font-size: 4.8vw;
  }

  .qa_area .txt_area {
    position: relative;
    width: 100%;
    padding-left: 0;
    z-index: 5;
  }

  .qa_area dl {
    margin-bottom: 5.333333333vw;
  }

  .qa_area dt {
    padding: 5.333333333vw 14vw 5.33333vw 5vw;
    font-size: 4.266666667vw;
  }

  .qa_area dt span {
    right: 4vw;
    top: 4vw;
    max-width: 66px;
    width: 9.066666667vw;
    height: 9.066666667vw;
    max-height: 9.066666667vw;
    font-size: 4.266666667vw;
  }

  .qa_area dd {
    display: none;
    padding: 0 13.33333333vw 6vw;
  }

  /*----------------------------------------


  get_area


  ----------------------------------------*/
  .get_area {
    position: relative;
    background: url("../images/get_bg.webp") no-repeat right top / 696px;
  }

  .get_area::after {
    position: absolute;
    content: "";
    width: 61.33333333vw;
    height: 100%;
    top: 10vw;
    left: auto;
    right: -3vw;
    background: url("../images/get_bg.webp") no-repeat right 5% top 0 / 100%
  }

  .get_area .title {
    left: 5%;
    max-width: 76.26666667vw;
    width: 76.26666667vw;
    padding-top: 22.66666667vw;
  }

  .get_area h2 {
    left: 5%;
  }

  .get_area .flow_slide {
    margin-top: 0;
  }

  .get_area .get_list li {
    width: 100%;
  }

  .get_area .get_list picture {
    display: block;
    width: 100%;
    margin: 0 auto;
  }

  /*----------------------------------------


  contents_foot_area


  ----------------------------------------*/
  .contents_foot_area {
    padding: 24vw 0;
    background: url("../images/foot_bg_sp.webp") no-repeat center bottom /100%;
  }

  .contents_foot_area .inner {
    padding: 14.66666667vw 6.33333333vw 10vw;
  }

  .contents_foot_area .inner::before {
    width: 10.13333333vw;
    height: 10.13333333vw;
    top: -4vw;
    left: -2vw;
  }

  .contents_foot_area .inner h2 {
    font-size: 5.333333333vw;
    margin-bottom: 8vw;
  }

  .contents_foot_area .inner h2 img {
    display: block;
    max-width: 40vw;
    width: 40vw;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 1.5vw;
  }

  .contents_foot_area .inner h3 {
    font-size: 4.8vw;
    line-height: 1.4;
  }

  .contents_foot_area .inner p {
    margin: 8vw auto;
    letter-spacing: 0;
  }

  /*----------------------------------------


  contact_area


  ----------------------------------------*/
  .contact_area {
    position: relative;
    width: 90%;
    max-width: 90%;
    padding: 9.333333333vw 1vw 9vw;
    font-size: 4vw;
    top: 0 !important;
    margin: 0 auto 8vw !important;
    opacity: 1 !important;
    right: 0;
  }

  .contact_area h2 {
    font-size: 5.3vw;
    margin-bottom: 6vw;
    white-space: wrap;
  }

  .contact_area .loader div p {
    font-size: 3.47777vw;
  }

  .contact_area .loader img {
    width: 30%;
  }

  .contact_contents {
    padding: 0 4vw;
  }

  .contact_contents p.aside,
  .contact_area p.aside {
    font-size: 3.2vw;
    margin: 4vw 0;
    letter-spacing: 0;
  }

  .contactiframe {
    min-height: 550px;
    height: auto;
  }

  .contact_contents .btn,
  .contact_area .btn {}

  .contact_area p.aside01 {
    font-size: 2.6vw;
    margin: 2vw 0 0;
    letter-spacing: 0;
  }
}

@media only screen and (max-width:360px) {

  /*----------------------------------------


  contact_area


  ----------------------------------------*/
  /* .contact_area {
   position: relative;
   width: 90%;
   max-width: 90%;
   padding: 9.333333333vw 5.33333vw;
   font-size: 4vw;
   top:0 !important;
   margin: 0 auto 8vw !important;
   opacity: 1!important;
   right: 0;
 }
 .contact_area h2{
   font-size: 5.33333vw;
   margin-bottom: 10vw;
 } */
  .contact_contents dl,
  .contact_area dl {}

  .contact_contents dl dt,
  .contact_area dl dt {
    margin-bottom: 10px;
  }

  .contact_contents p,
  .contact_area p {
    font-size: 15px;
    margin: 30px 0;
  }

  .contact_contents p i,
  .contact_contents p svg .contact_area p i,
  .contact_area p svg {
    font-size: 15px;
    margin-top: 1vw;
    margin-left: 2vw;
  }

  /*  .contact_contents dl,
 .contact_area dl{
   margin-bottom:6.666666667vw;
 }
 .contact_contents dl dt,
 .contact_area dl dt{
   margin-bottom: 1.5vw;
 }
 .contact_contents p,
 .contact_area p{
   font-size: 3.466666667vw;
   margin: 6.666666667vw 0;
 }
 .contact_contents p i,
 .contact_contents p svg
 .contact_area p i,
 .contact_area p svg{
   font-size: 3.466666667vw;
   margin-top: 1vw;
   margin-left: 2vw;
 } 
 .contact_contents .btn,
 .contact_area .btn{
   width: 100%;
 }*/
  .mw_wp_form {
    position: relative;
  }

}

.modal-open {}

.modal-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 50%);
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
  z-index: 999;
}

.modal-container:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}

/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active {
  opacity: 1;
  visibility: visible;
}

.modal-body {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 900px;
  width: 90%;

}

.modal-close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: -40px;
  right: -40px;
  width: 40px;
  height: 40px;
  font-size: 40px;
  color: #fff;
  cursor: pointer;
}

.modal-content {
  background: #fff;
  text-align: left;
  padding: 30px;
  overflow-y: auto;
  height: 90vh;
  border-radius: 15px;
}

.modal-content iframe {
  width: 100%;
  height: 3600px;
  overflow: scroll;
}
.terms .modal-content iframe{
  height:7000px;
}
@media only screen and (max-width:750px) {
  .modal-container{
  }
  .modal-content{
    padding: 0;
  }
  .modal-content iframe{
    height: 800vw;
  }
  .terms .modal-content iframe{
    height: 1550vw;
  }
}