@import url("https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@500;600&family=Zen+Old+Mincho:wght@500&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
:root {
  --bc-brown01: #41382f;
  --bc-brown02: #d0920b;
  --bc-blue01: rgba(46,156,239,.25);
  --bc-blue02: #bde3ff;
}

body, .f-zen {
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
}

.f-spo-m {
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-style: normal;
}

.f-spo-sb {
  font-family: "Shippori Mincho", serif;
  font-weight: 600;
  font-style: normal;
}

.f-sans {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

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

@media screen and (max-width: 500px) {
  .pc2 {
    display: none;
  }
}

@media screen and (min-width: 769px) {
  .sp {
    display: none;
  }
}

@media screen and (min-width: 501px) {
  .sp2 {
    display: none;
  }
}

.ov {
  transition: 0.3s;
}
.ov:hover {
  opacity: 0.75;
}

body {
  max-width: 1500px;
  width: 100%;
  margin: 0 auto;
  color: var(--bc-brown01);
}

main section img[src*=_sp] {
  width: 100%;
}
main section.mv .catWrap {
  display: grid;
  grid-template-columns: repeat(5, 20%);
  grid-template-rows: 1fr 1fr;
  gap: 10px 0;
  max-width: 550px;
  width: 85%;
  margin: 0 auto;
  padding: 25px 0;
}
main section.mv .catWrap .catBox {
  display: flex;
  flex-direction: column;
}
main section.mv .catWrap .catBox figure {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 55px;
  margin-bottom: 10px;
}
@media screen and (max-width: 500px) {
  main section.mv .catWrap .catBox figure {
    margin-bottom: 4px;
  }
  main section.mv .catWrap .catBox figure img[width="43"] {
    width: 26px;
  }
  main section.mv .catWrap .catBox figure img[width="71"] {
    width: 48px;
  }
  main section.mv .catWrap .catBox figure img[width="63"] {
    width: 42px;
  }
  main section.mv .catWrap .catBox figure img[width="58"] {
    width: 38px;
  }
  main section.mv .catWrap .catBox figure img[width="60"] {
    width: 40px;
  }
  main section.mv .catWrap .catBox figure img[width="61"] {
    width: 40px;
  }
  main section.mv .catWrap .catBox figure img[width="75"] {
    width: 52px;
  }
  main section.mv .catWrap .catBox figure img[width="53"] {
    width: 34px;
  }
  main section.mv .catWrap .catBox figure img[width="49"] {
    width: 31px;
  }
  main section.mv .catWrap .catBox figure img[width="51"] {
    width: 36px;
  }
}
main section.mv .catWrap .catBox p {
  line-height: 1;
  text-align: center;
  font-size: 14px;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (max-width: 500px) {
  main section.mv .catWrap .catBox p {
    font-size: 11px;
  }
}
main section.mv .btnWrap {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 136px;
  padding: 0 5%;
  background: url(../img/mv_btn_bg.jpg) no-repeat center center/cover;
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 9999;
}
@media screen and (max-width: 768px) {
  main section.mv .btnWrap {
    background: url(../img/mv_btn_bg_sp01.jpg) no-repeat left top/auto 100%, url(../img/mv_btn_bg_sp02.jpg) no-repeat right top/auto 100%;
    background-color: #0d2541;
  }
}
main section.lead {
  padding-bottom: 120px;
  background: url(../img/lead_bg01.jpg) no-repeat right top, url(../img/lead_bg02.png) no-repeat right bottom;
  background-color: #fcf1e3;
}
@media screen and (max-width: 768px) {
  main section.lead {
    padding-bottom: 72px;
    background-position: right center, right bottom;
    background-size: 125% auto, 140px auto;
  }
}
main section.lead .inner, main section.lead .cntWrap {
  max-width: 1000px;
  width: 90%;
  margin: 0 auto;
  padding-top: 70px;
}
main section.lead .leadTop {
  position: relative;
}
main section.lead .leadTop picture.pc {
  max-width: 37.5%;
  position: absolute;
  top: 0;
  left: 0;
}
main section.lead .leadTop .txt {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
  margin: 0 0 0 auto;
}
@media screen and (min-width: 769px) {
  main section.lead .leadTop .txt {
    max-width: 630px;
    width: 60%;
  }
}
main section.lead .leadTop .txt hgroup {
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  main section.lead .leadTop .txt hgroup {
    text-align: center;
  }
}
main section.lead .leadTop .txt hgroup h2 {
  margin-bottom: 30px;
  font-size: 36px;
}
@media screen and (max-width: 768px) {
  main section.lead .leadTop .txt hgroup h2 {
    font-size: 30px;
  }
}
@media screen and (max-width: 500px) {
  main section.lead .leadTop .txt hgroup h2 {
    font-size: 26px;
  }
}
main section.lead .leadTop .txt hgroup h2 .fzs {
  font-size: 26px;
}
@media screen and (max-width: 768px) {
  main section.lead .leadTop .txt hgroup h2 .fzs {
    font-size: 22px;
  }
}
@media screen and (max-width: 500px) {
  main section.lead .leadTop .txt hgroup h2 .fzs {
    font-size: 20px;
  }
}
main section.lead .leadTop .txt hgroup h2 .fzm {
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  main section.lead .leadTop .txt hgroup h2 .fzm {
    font-size: 26px;
  }
}
main section.lead .leadTop .txt hgroup p {
  width: 250px;
  margin: 0 auto;
}
main section.lead .leadTop .txt picture.sp {
  width: 100vw;
  margin: -10vw 0 0 -5vw;
}
main section.lead .leadTop .txt > p {
  line-height: 1.8;
}
main section.lead .cntWrap {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 40px 0;
  position: relative;
  z-index: 5;
}
main section.lead .cntWrap figure {
  width: 48%;
}
@media screen and (max-width: 768px) {
  main section.lead .cntWrap figure {
    gap: 24px 0;
    width: 100%;
  }
}
main section.worries {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 50px 0;
  padding: 70px 5% 80px;
  background: url(../img/worries_bg.jpg) no-repeat center center/cover;
}
main section.worries .secTtl {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
main section.worries .secTtl span {
  margin-bottom: 15px;
  font-size: 24px;
}
main section.worries .secTtl p {
  font-size: 30px;
}
@media screen and (max-width: 500px) {
  main section.worries .secTtl p {
    font-size: 26px;
  }
}
main section.worries .secTtl p i {
  font-size: 36px;
  position: relative;
}
@media screen and (max-width: 500px) {
  main section.worries .secTtl p i {
    font-size: 30px;
  }
}
main section.worries .secTtl p i::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: currentColor;
  position: absolute;
  top: 0;
  left: calc(50% - 2px);
}
main section.worries ul {
  display: flex;
  flex-direction: column;
  gap: 40px 0;
  max-width: 1000px;
  width: 100%;
}
main section.worries ul li:nth-of-type(2) {
  margin: 0 0 0 auto;
}
@media screen and (min-width: 769px) {
  main section.worries ul li img {
    width: auto;
  }
}
main section.foryou {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 160px 0 100px;
  background: url(../img/foryou_bg.jpg) no-repeat top center/cover;
  position: relative;
}
@media screen and (max-width: 768px) {
  main section.foryou {
    padding: 140px 0 72px;
    background: url(../img/foryou_bg_sp01.jpg) no-repeat center top/100% auto, url(../img/foryou_bg_sp02.jpg) repeat right bottom;
  }
}
main section.foryou::before {
  content: "";
  width: 600px;
  height: 80px;
  background-color: #fff;
  position: absolute;
  top: -1px;
  left: 50%;
  translate: -50% 0;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
}
@media screen and (max-width: 768px) {
  main section.foryou::before {
    max-width: 350px;
    width: 70%;
    height: 70px;
  }
}
main section.foryou .secTtl {
  margin-bottom: 75px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  main section.foryou .secTtl {
    margin-bottom: 52px;
  }
  main section.foryou .secTtl img {
    width: 320px;
  }
}
@media screen and (max-width: 500px) {
  main section.foryou .secTtl img {
    width: 260px;
  }
}
main section.foryou .secTtl p {
  margin-bottom: 20px;
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  main section.foryou .secTtl p {
    font-size: 26px;
  }
}
main section.foryou .secTtl p em {
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  main section.foryou .secTtl p em {
    font-size: 20px;
  }
}
main section.foryou picture {
  margin-bottom: 80px;
}
@media screen and (max-width: 768px) {
  main section.foryou picture {
    margin-bottom: 42px;
  }
}
main section.reason {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 100px 0;
}
@media screen and (max-width: 768px) {
  main section.reason {
    padding: 74px 0;
  }
}
main section.reason .secTtl {
  display: inline-flex;
  justify-content: center;
  align-items: baseline;
  gap: 0 15px;
  margin-bottom: 50px;
  font-size: 36px;
}
@media screen and (max-width: 768px) {
  main section.reason .secTtl {
    margin-bottom: 24px;
    font-size: 28px;
  }
  main section.reason .secTtl img {
    width: 160px;
  }
}
@media screen and (max-width: 500px) {
  main section.reason .secTtl {
    gap: 0 5px;
    font-size: 24px;
  }
}
main section.reason .secTtl em {
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  main section.reason .secTtl em {
    font-size: 24px;
  }
}
@media screen and (max-width: 500px) {
  main section.reason .secTtl em {
    font-size: 20px;
  }
}
main section.reason p.lead {
  max-width: 90%;
  margin-bottom: 50px;
  text-align: center;
}
main section.reason .cntWrap {
  display: flex;
  flex-direction: column;
  gap: 60px 0;
  max-width: 1000px;
  width: 90%;
}
main section.reason .cntWrap .cntBox {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  padding: 60px 50px;
  border-radius: 10px;
  background-color: #fff;
  box-shadow: 0 0 20px rgba(102, 68, 34, 0.2);
  position: relative;
}
@media screen and (max-width: 768px) {
  main section.reason .cntWrap .cntBox {
    flex-direction: column-reverse;
    gap: 24px 0;
    padding: 50px 5% 28px;
  }
}
main section.reason .cntWrap .cntBox .point {
  position: absolute;
  top: 0;
  left: 30px;
  translate: 0 -50%;
}
@media screen and (max-width: 768px) {
  main section.reason .cntWrap .cntBox .point {
    width: 110px;
    left: 20px;
  }
}
main section.reason .cntWrap .cntBox picture.txt {
  max-width: 500px;
  width: 56%;
}
@media screen and (max-width: 768px) {
  main section.reason .cntWrap .cntBox picture.txt {
    width: 100%;
  }
}
main section.reason .cntWrap .cntBox figure {
  max-width: 340px;
  width: 38%;
}
@media screen and (max-width: 768px) {
  main section.reason .cntWrap .cntBox figure {
    width: 100%;
    margin: 0 auto;
  }
}
main section.lineup {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 100px;
  padding: 100px 5%;
  background: url(../img/lineup_bg01.jpg) no-repeat center top, url(../img/lineup_bg02.jpg) repeat center center;
}
@media screen and (max-width: 768px) {
  main section.lineup {
    margin-bottom: 68px;
    padding: 68px 5% 46px;
    background-size: 100% auto, auto;
  }
}
main section.lineup .secTtl {
  display: inline-flex;
  justify-content: center;
  align-items: baseline;
  gap: 8px 15px;
  margin-bottom: 50px;
  font-size: 36px;
}
@media screen and (max-width: 768px) {
  main section.lineup .secTtl {
    flex-direction: column;
    align-items: center;
    font-size: 28px;
  }
}
main section.lineup .secTtl em {
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  main section.lineup .secTtl em {
    font-size: 24px;
  }
}
main section.lineup ul.anchWrap {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 15px 20px;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  main section.lineup ul.anchWrap li {
    width: 45%;
    text-align: center;
  }
}
main section.lineup .cntWrap {
  max-width: 1000px;
  width: 100%;
  padding-bottom: 80px;
  border-radius: 20px;
  background-color: #fff;
  box-shadow: 0 0 20px rgba(102, 68, 34, 0.2);
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap {
    padding-bottom: 42px;
  }
}
main section.lineup .cntWrap:nth-last-of-type(n+2) {
  margin-bottom: 80px;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap:nth-last-of-type(n+2) {
    margin-bottom: 58px;
  }
}
main section.lineup .cntWrap .sliderWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 70px 0;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap {
    padding: 48px 0;
  }
}
main section.lineup .cntWrap .sliderWrap:nth-of-type(2) {
  background-color: #f7f7f7;
}
main section.lineup .cntWrap .sliderWrap .cntTtl {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 30px;
  margin-bottom: 40px;
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap .cntTtl {
    gap: 0 18px;
    margin-bottom: 28px;
    font-size: 26px;
  }
}
@media screen and (max-width: 500px) {
  main section.lineup .cntWrap .sliderWrap .cntTtl {
    gap: 0 12px;
    font-size: 22px;
  }
}
main section.lineup .cntWrap .sliderWrap .cntTtl::before, main section.lineup .cntWrap .sliderWrap .cntTtl::after {
  content: "";
  width: 100px;
  height: 1px;
  background-color: var(--bc-brown02);
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap .cntTtl::before, main section.lineup .cntWrap .sliderWrap .cntTtl::after {
    width: 80px;
  }
}
@media screen and (max-width: 500px) {
  main section.lineup .cntWrap .sliderWrap .cntTtl::before, main section.lineup .cntWrap .sliderWrap .cntTtl::after {
    width: 50px;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox {
  max-width: 870px;
  width: 90%;
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider {
  padding-bottom: 38px;
  position: relative;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider {
    padding-bottom: 16px;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider .slick-track li {
  padding: 0 15px;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider .slick-track li {
    padding: 0 10px;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider .slick-track li figure img {
  width: 100%;
  border-radius: 15px;
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider .slick-track li figure figcaption {
  padding-top: 6px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider .slick-track li figure figcaption {
    font-size: 16px;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider .slick-track li figure figcaption span {
  font-size: 14px;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider .slick-track li figure figcaption span {
    font-size: 13px;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow {
  display: flex;
  min-width: 50px;
  min-height: 50px;
  border-radius: 50%;
  background-color: #d8d0bf;
  font-size: 0;
  position: absolute;
  top: 25%;
  z-index: 9;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow {
    min-width: 30px;
    min-height: 30px;
    top: 15%;
  }
}
@media screen and (max-width: 500px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow {
    top: 10vw;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow.slick-prev {
  left: 15px;
  translate: -50% 0;
}
@media screen and (max-width: 500px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow.slick-prev {
    left: 0;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow.slick-prev::before {
  border-left: 2px solid #41382f;
  rotate: -45deg;
  translate: -25% -50%;
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow.slick-next {
  right: 15px;
  translate: 50% 0;
}
@media screen and (max-width: 500px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow.slick-next {
    right: 0;
  }
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow.slick-next::before {
  border-right: 2px solid #41382f;
  rotate: 45deg;
  translate: -75% -50%;
}
main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow::before {
  content: "";
  min-width: 15px;
  min-height: 15px;
  border-top: 2px solid #41382f;
  position: absolute;
  top: 50%;
  left: 50%;
}
@media screen and (max-width: 500px) {
  main section.lineup .cntWrap .sliderWrap .sliderBox ul.slider i.slick-arrow::before {
    min-width: 10px;
    min-height: 10px;
  }
}
main section.lineup .cntWrap .btnWrap {
  padding: 0 5%;
  text-align: center;
}
main section.voice {
  margin-bottom: 100px;
}
@media screen and (max-width: 768px) {
  main section.voice {
    padding: 0 5%;
  }
}
main section.voice .secTtl {
  display: flex;
  justify-content: center;
  align-items: baseline;
  margin-bottom: 50px;
  font-size: 36px;
}
@media screen and (max-width: 768px) {
  main section.voice .secTtl {
    margin-bottom: 28px;
    font-size: 28px;
  }
}
main section.voice .secTtl em {
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  main section.voice .secTtl em {
    font-size: 22px;
  }
}
main section.voice .cntWrap {
  gap: 15px 10px;
}
@media screen and (min-width: 769px) {
  main section.voice .cntWrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 768px) {
  main section.voice .cntWrap {
    display: flex;
    flex-direction: column;
  }
}
main section.voice .cntWrap .cntBox {
  height: 100%;
  padding-bottom: 70px;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  main section.voice .cntWrap .cntBox {
    padding-bottom: 34px;
    border-radius: 20px !important;
  }
}
main section.voice .cntWrap .cntBox:nth-of-type(1) {
  border-radius: 0 30px 30px 0;
  background: url(../img/voice01_bg02.jpg) repeat center center;
}
main section.voice .cntWrap .cntBox:nth-of-type(1) p {
  background: url(../img/voice01_bg01.jpg) repeat center center;
}
main section.voice .cntWrap .cntBox:nth-of-type(2) {
  border-radius: 30px 0 0 30px;
  background: url(../img/voice02_bg02.jpg) repeat center center;
}
main section.voice .cntWrap .cntBox:nth-of-type(2) p {
  background: url(../img/voice02_bg01.jpg) repeat center center;
}
main section.voice .cntWrap .cntBox p {
  padding: 40px 0 30px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  main section.voice .cntWrap .cntBox p {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 500px) {
  main section.voice .cntWrap .cntBox p {
    padding: 30px 0 25px;
  }
  main section.voice .cntWrap .cntBox p img {
    width: 200px;
  }
}
main section.voice .cntWrap .cntBox ul {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 25px 0;
  padding: 0 5%;
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  main section.voice .cntWrap .cntBox ul li {
    margin-top: -10px;
  }
}
main section.step {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 110px;
  padding: 100px 5%;
  background: url(../img/step_bg.jpg) no-repeat center center/cover;
}
@media screen and (max-width: 768px) {
  main section.step {
    margin-bottom: 72px;
    padding: 68px 10%;
  }
  main section.step picture {
    max-width: 380px;
  }
}
main section.step .secTtl {
  display: inline-flex;
  justify-content: center;
  align-items: baseline;
  margin-bottom: 50px;
  font-size: 36px;
}
main section.step .secTtl em {
  font-size: 30px;
}
main section.step picture {
  max-width: 950px;
}
main section.qa {
  margin-bottom: 120px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  main section.qa {
    margin-bottom: 78px;
  }
}
main section.qa .secTtl {
  display: flex;
  justify-content: center;
  align-items: baseline;
  margin-bottom: 50px;
  font-size: 36px;
}
main section.qa .secTtl em {
  font-size: 30px;
}
main section.qa .cntWrap {
  display: flex;
  flex-direction: column;
  gap: 30px 0;
  max-width: 1000px;
  width: 90%;
  margin: 0 auto;
}
main section.qa .cntWrap dl {
  padding: 40px;
  border-radius: 10px;
  background-color: #fff;
  box-shadow: 0 0 20px rgba(102, 68, 34, 0.2);
}
@media screen and (max-width: 768px) {
  main section.qa .cntWrap dl {
    padding: 24px 5%;
  }
}
main section.qa .cntWrap dl dt, main section.qa .cntWrap dl dd {
  display: flex;
  align-items: center;
  gap: 0 20px;
}
main section.qa .cntWrap dl dt {
  font-size: 18px;
  position: relative;
  cursor: pointer;
}
main section.qa .cntWrap dl dt.ex i::after {
  content: none;
}
main section.qa .cntWrap dl dt::before {
  content: "Q";
  line-height: 1;
  font-size: 36px;
}
main section.qa .cntWrap dl dt i {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  margin: 0 0 0 auto;
  position: relative;
}
main section.qa .cntWrap dl dt i::before, main section.qa .cntWrap dl dt i::after {
  content: "";
  border: 1px solid #41382f;
}
main section.qa .cntWrap dl dt i::before {
  width: 30px;
}
main section.qa .cntWrap dl dt i::after {
  height: 30px;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
main section.qa .cntWrap dl dd {
  margin-top: 20px;
  padding-top: 30px;
  border-top: 1px solid #c6c3c0;
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  main section.qa .cntWrap dl dd {
    margin-top: 16px;
    padding-top: 22px;
  }
}
main section.qa .cntWrap dl dd::before {
  content: "A";
  line-height: 1;
  font-size: 40px;
}
main section.cta {
  padding-bottom: 150px;
  position: relative;
}
@media screen and (max-width: 768px) {
  main section.cta {
    padding-bottom: 84px;
  }
}
main section.cta::before {
  content: "";
  display: block;
  width: 100%;
  height: 130%;
  background: url(../img/cta_bg.jpg) no-repeat bottom center/cover;
  position: absolute;
  left: 0;
  bottom: 0;
}
main .cta .inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 1000px;
  width: 90%;
  margin: 0 auto;
  position: relative;
}
main .cta .inner > p {
  margin-bottom: 40px;
  text-align: center;
  font-size: 30px;
}
@media screen and (max-width: 768px) {
  main .cta .inner > p {
    font-size: 26px;
  }
}
@media screen and (max-width: 500px) {
  main .cta .inner > p {
    font-size: 20px;
  }
}
main .cta .inner > p em {
  font-size: 36px;
}
@media screen and (max-width: 768px) {
  main .cta .inner > p em {
    font-size: 30px;
  }
}
@media screen and (max-width: 500px) {
  main .cta .inner > p em {
    font-size: 26px;
  }
}
main .cta .inner .cntWrap {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 30px 2.55%;
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  main .cta .inner .cntWrap {
    justify-content: space-evenly;
  }
}
main .cta .inner .cntWrap figure {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px 0;
  max-width: 22.5%;
}
@media screen and (max-width: 768px) {
  main .cta .inner .cntWrap figure {
    max-width: 45%;
  }
  main .cta .inner .cntWrap figure img {
    width: 180px;
  }
}
@media screen and (max-width: 768px) {
  main .cta .inner .cntWrap figure img {
    width: 120px;
  }
}
main .cta .inner .cntWrap figure figcaption {
  margin: auto 0;
  text-align: center;
  font-size: 20px;
}
@media screen and (max-width: 768px) {
  main .cta .inner .cntWrap figure figcaption {
    font-size: 18px;
  }
}
@media screen and (max-width: 500px) {
  main .cta .inner .cntWrap figure figcaption {
    font-size: 16px;
  }
}
main .cta .inner > img {
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  main .cta .inner > img {
    font-size: 38px;
  }
}

footer {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 50px;
  background-color: #0d2541;
}
footer small {
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
}/*# sourceMappingURL=style.css.map */

.app_lp_custom_pt{
	padding-top:40px;
}
.app_lp_custom_h{
    position: fixed;
    left: 0;
    top: 0;
    z-index: 9999;
    height: 40px;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    padding: 0px 5%;
    border-bottom: 1px solid #cdcdcd;
    width: 100%;
    background: #fff;
}

.app_lp_custom_h .check.icon{
	color: #000;
    position: absolute;
    width: 14px;
    height: 14px;
    border-bottom: solid 2px rgb(107 107 107);
    border-left: solid 2px rgb(107 107 107);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}