@charset "UTF-8";
/*! --------------------------------------------------------------------
------------------------------------------------------------------------
index
------------------------------------------------------------------------
--------------------------------------------------------------------- */
/* ========================================================
.top-bar
======================================================== */
.top-bar {
  position: relative;
  margin-top: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.top-bar__txt {
  padding: 16px 32px;
  background-color: #a32929;
  color: #fff;
  font-weight: 700;
  text-align: center;
  font-size: 3.2rem;
  line-height: 1.3;
}
@media screen and (max-width: 1020px) {
  .top-bar__txt {
    width: 100%;
    padding: 12px 24px;
    font-size: 2.4rem;
  }
}

.top-bar__txt .txt-in {
  display: block;
}

/* ========================================================
.sec-mv
======================================================== */
.sec-mv {
  margin-top: -4px;
  position: relative;
}

.sec-mv__in {
  position: relative;
  height: calc(100vh - 80px - 71px);
}
@media screen and (max-width: 1020px) {
  .sec-mv__in {
    height: 100vh;
    height: 100svh;
  }
}

/* .mv-box
=========================================== */
.sec-mv .all-time_label {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .sec-mv .all-time_label {
    top: auto;
    bottom: 0;
    width: 48vw;
    max-width: 240px;
  }
}

/* .mv-box
=========================================== */
.sec-mv .mv-box {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
}

.sec-mv .site-ttl-wrap {
  position: relative;
  margin: 0 auto;
  width: 680px;
}
@media screen and (max-width: 1399px) {
  .sec-mv .site-ttl-wrap {
    width: 480px;
  }
}
@media screen and (max-width: 767px) {
  .sec-mv .site-ttl-wrap {
    width: calc(100% - 32px);
  }
}

.sec-mv .accent-txt {
  position: absolute;
  top: -80px;
  right: -160px;
  display: block;
  width: 280px;
}
@media screen and (max-width: 1399px) {
  .sec-mv .accent-txt {
    top: -76px;
    right: -104px;
    width: 278px;
  }
}
@media screen and (max-width: 767px) {
  .sec-mv .accent-txt {
    top: -15.5vw;
    right: unset;
    left: calc(50% - 19.5vw);
    width: 38vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-mv .accent-txt img {
    width: 100%;
  }
}

.sec-mv .site-ttl {
  text-align: center;
}

.sec-mv .mv-catch {
  margin-top: 80px;
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-catch {
    margin-top: 48px;
  }
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-catch {
    margin-top: 32px;
  }
}

.sec-mv .mv-catch-txt__in {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto;
  height: 70px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-catch-txt__in {
    height: 50px;
  }
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-catch-txt__in {
    height: auto;
  }
}

@media screen and (max-width: 767px) {
  .sec-mv .mv-catch-txt01,
  .sec-mv .mv-catch-txt02 {
    display: none;
  }
}

.sec-mv .mv-catch-txt01 .mv-catch-txt__in {
  width: 461px;
  background-image: url("../img/index/mv_catch_bg01.png");
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-catch-txt01 .mv-catch-txt__in {
    width: 325px;
  }
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-catch-txt01 .mv-catch-txt__in img {
    width: 272px;
    width: 224px;
  }
}

.sec-mv .mv-catch-txt02 .mv-catch-txt__in {
  width: 898px;
  background-image: url("../img/index/mv_catch_bg02.png");
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-catch-txt02 .mv-catch-txt__in {
    width: 770px;
    width: 644px;
  }
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-catch-txt02 .mv-catch-txt__in img {
    width: 622px;
    width: 512px;
  }
}

.sec-mv .mv-catch-txt + .mv-catch-txt {
  margin-top: 10px;
}

.sec-mv .mv-catch-txt-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-catch-txt-sp {
    display: block;
    max-width: 280px;
    margin: 0 auto;
  }
}

.sec-mv .mv-open {
  margin-top: 80px;
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-open {
    margin-top: 48px;
  }
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-open {
    margin-top: 32px;
  }
}

.sec-mv .mv-open-txt {
  position: relative;
  margin: 0 auto;
  width: 258px;
}
@media screen and (max-width: 1399px) {
  .sec-mv .mv-open-txt {
    width: 182px;
  }
}

.sec-mv .mv-open-txt:before,
.sec-mv .mv-open-txt:after {
  content: "";
  position: absolute;
  top: 50%;
  display: block;
  width: 44px;
  height: 1px;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-open-txt:before,
  .sec-mv .mv-open-txt:after {
    width: 32px;
  }
}

.sec-mv .mv-open-txt:before {
  left: -80px;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-open-txt:before {
    left: -40px;
  }
}

.sec-mv .mv-open-txt:after {
  right: -80px;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-open-txt:after {
    right: -40px;
  }
}

/* .mv-swiper-box-wrap
=========================================== */
.sec-mv .mv-swiper-box-wrap {
  position: absolute;
  overflow: hidden;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.sec-mv .mv-swiper-box {
  height: 100%;
}

.sec-mv .mv-swiper {
  height: 100%;
}

.sec-mv .mv-swiper-slide {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.sec-mv .mv-swiper-slide__in {
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

.sec-mv .mv-swiper-slide01 .mv-swiper-slide__in {
  background-image: url("../img/index/mv_slide_01.webp");
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-swiper-slide01 .mv-swiper-slide__in {
    background-image: url("../img/index/mv_slide_01_sp.webp");
  }
}

.sec-mv .mv-swiper-slide02 .mv-swiper-slide__in {
  background-image: url("../img/index/mv_slide_02.webp");
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-swiper-slide02 .mv-swiper-slide__in {
    background-image: url("../img/index/mv_slide_02_sp.webp");
  }
}

.sec-mv .mv-swiper-slide03 .mv-swiper-slide__in {
  background-image: url("../img/index/mv_slide_03.webp");
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-swiper-slide03 .mv-swiper-slide__in {
    background-image: url("../img/index/mv_slide_03_sp.webp");
  }
}

.sec-mv .mv-swiper-slide04 .mv-swiper-slide__in {
  background-image: url("../img/index/mv_slide_04.webp");
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-swiper-slide04 .mv-swiper-slide__in {
    background-image: url("../img/index/mv_slide_04_sp.webp");
  }
}

.swiper-mv-button-next,
.swiper-mv-button-prev {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 50px;
  height: 50px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border-radius: 50%;
  cursor: pointer;
  z-index: 3;
  background-color: #5e5953;
  -webkit-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out;
}
@media screen and (max-width: 1020px) {
  .swiper-mv-button-next,
  .swiper-mv-button-prev {
    width: 40px;
    height: 40px;
  }
}
@media screen and (max-width: 767px) {
  .swiper-mv-button-next,
  .swiper-mv-button-prev {
    top: unset;
    bottom: 22vw;
    -webkit-transform: unset;
            transform: unset;
  }
}
.swiper-mv-button-next svg,
.swiper-mv-button-prev svg {
  width: 14px;
  height: 22px;
}
@media screen and (max-width: 767px) {
  .swiper-mv-button-next svg,
  .swiper-mv-button-prev svg {
    width: 8px;
  }
}

.swiper-mv-button-next {
  right: 40px;
}
@media screen and (max-width: 767px) {
  .swiper-mv-button-next {
    right: unset;
    left: 80px;
  }
}
.swiper-mv-button-next svg {
  margin-right: -2px;
  -webkit-transition: margin-right 0.2s ease-in-out;
  transition: margin-right 0.2s ease-in-out;
}

.swiper-mv-button-next:hover {
  opacity: 0.8;
}
@media screen and (max-width: 1020px) {
  .swiper-mv-button-next:hover {
    opacity: 1;
  }
}
.swiper-mv-button-next:hover svg {
  margin-right: -6px;
}
@media screen and (max-width: 1020px) {
  .swiper-mv-button-next:hover svg {
    margin-right: -2px;
  }
}

.swiper-mv-button-prev {
  left: 40px;
}
@media screen and (max-width: 767px) {
  .swiper-mv-button-prev {
    left: 24px;
  }
}
.swiper-mv-button-prev svg {
  margin-left: -2px;
  -webkit-transition: margin-left 0.2s ease-in-out;
  transition: margin-left 0.2s ease-in-out;
}

.swiper-mv-button-prev:hover {
  opacity: 0.8;
}
@media screen and (max-width: 1020px) {
  .swiper-mv-button-prev:hover {
    opacity: 1;
  }
}
.swiper-mv-button-prev:hover svg {
  margin-left: -6px;
}
@media screen and (max-width: 1020px) {
  .swiper-mv-button-prev:hover svg {
    margin-left: -2px;
  }
}

/* .mv-plan-link
=========================================== */
.sec-mv .mv-plan-link {
  position: absolute;
  bottom: -24px;
  right: 32px;
  z-index: 15;
  width: 124px;
  height: 124px;
  color: #191919;
}
@media screen and (max-width: 1199px) {
  .sec-mv .mv-plan-link {
    bottom: 20px;
    right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-plan-link {
    z-index: 5;
    width: 96px;
    height: 96px;
  }
}
.sec-mv .mv-plan-link a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  background-color: #ffcc1a;
  border-radius: 50%;
  -webkit-box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.5);
          box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.5);
  -webkit-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out;
}
.sec-mv .mv-plan-link a:hover {
  opacity: 0.8;
}

.sec-mv .mv-plan-link__in {
  margin-top: -16px;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-plan-link__in {
    margin-top: -8px;
  }
}
.sec-mv .mv-plan-link__in .en {
  display: block;
  text-align: center;
  font-size: 4.4rem;
  font-family: "Bebas Neue", sans-serif;
  text-shadow: 3px 2px 0 #cd9f00;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-plan-link__in .en {
    font-size: 3.4rem;
  }
}
.sec-mv .mv-plan-link__in .jp {
  display: block;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-plan-link__in .jp {
    font-size: 1.1rem;
  }
}

.sec-mv .mv-plan-link-arrow {
  position: absolute;
  bottom: 10px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: block;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background-color: #191919;
  background-image: url("../img/common/base/arrow_bottom01_yellow.svg");
  background-repeat: no-repeat;
  background-size: 12px 6px;
  background-position: top 56% center;
  -webkit-transition: bottom 0.2s ease-in-out;
  transition: bottom 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-plan-link-arrow {
    bottom: 6px;
    width: 14px;
    height: 14px;
    background-size: 8px 4px;
  }
}

.sec-mv .mv-plan-link a:hover .mv-plan-link-arrow {
  bottom: 6px;
}
@media screen and (max-width: 767px) {
  .sec-mv .mv-plan-link a:hover .mv-plan-link-arrow {
    bottom: 3px;
  }
}

/* ========================================================
.sec-about
======================================================== */
.sec-about {
  padding: 160px 0 168px;
}
@media screen and (max-width: 1020px) {
  .sec-about {
    padding: 100px 0 100px;
  }
}
@media screen and (max-width: 767px) {
  .sec-about {
    padding: 60px 0 180px;
  }
}

.sec-about .cmn-sec-ttl01__in {
  margin-bottom: -40px;
}

.sec-about__in {
  padding-top: 114px;
  min-height: 100px;
  background-image: linear-gradient(to left, transparent 100px, #0d0d0d 100px);
}
@media screen and (max-width: 1020px) {
  .sec-about__in {
    background-image: linear-gradient(to left, transparent 40px, #0d0d0d 40px);
  }
}
@media screen and (max-width: 767px) {
  .sec-about__in {
    padding-top: 84px;
    margin: 0 16px;
    background-image: unset;
    background-color: #0d0d0d;
  }
}

.sec-about .about-catch {
  text-align: center;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 1399px) {
  .sec-about .about-catch {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 1020px) {
  .sec-about .about-catch {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-about .about-catch {
    font-size: clamp(14px, 4.5vw, 18px);
  }
}

.sec-about .about-site-ttl {
  padding-top: 16px;
  text-align: center;
}
@media screen and (max-width: 1020px) {
  .sec-about .about-site-ttl {
    width: 390px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .sec-about .about-site-ttl {
    padding-top: 32px;
    width: auto;
  }
}

.sec-about .about-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-top: 60px;
}
@media screen and (max-width: 1399px) {
  .sec-about .about-box {
    margin-top: 48px;
  }
}
@media screen and (max-width: 1020px) {
  .sec-about .about-box {
    margin-top: 32px;
  }
}
@media screen and (max-width: 767px) {
  .sec-about .about-box {
    display: block;
    margin-top: 0;
  }
}

.sec-about .about-img {
  position: relative;
  width: 642px;
}
@media screen and (max-width: 1399px) {
  .sec-about .about-img {
    width: 46.2858%;
  }
}
@media screen and (max-width: 767px) {
  .sec-about .about-img {
    width: 100%;
    max-width: 324px;
  }
}
.sec-about .about-img img {
  position: absolute;
  top: 40px;
  left: 0;
  display: block;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .sec-about .about-img img {
    top: -80px;
    left: -32px;
  }
}

.sec-about .about-content {
  padding-top: 40px;
  padding-right: 140px;
  padding-bottom: 72px;
  width: calc(100% - 648px - 72px);
}
@media screen and (max-width: 1399px) {
  .sec-about .about-content {
    width: calc(53.7142% - 40px);
  }
}
@media screen and (max-width: 1020px) {
  .sec-about .about-content {
    padding-right: 60px;
    padding-bottom: 40px;
    width: calc(53.7142% - 40px);
  }
}
@media screen and (max-width: 767px) {
  .sec-about .about-content {
    padding-right: 0;
    padding-bottom: 120px;
    width: 100%;
  }
}
.sec-about .about-content__in {
  font-size: 2rem;
  line-height: 1.8;
}
@media screen and (max-width: 1399px) {
  .sec-about .about-content__in {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 1199px) {
  .sec-about .about-content__in {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-about .about-content__in {
    font-size: 1.4rem;
  }
}

/* ========================================================
.sec-features
======================================================== */
.sec-features {
  position: relative;
  padding: 80px 0;
  background-color: #5e5953;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .sec-features {
    padding: 40px 0 80px;
  }
}
.sec-features .cmn-sec-ttl01 .ttl-en {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.sec-features .cmn-sec-ttl01 .ttl-en__num {
  color: #7a0a0f;
}
.sec-features .cmn-sec-ttl01 .ttl-jp {
  padding-left: 76px;
  color: #a4a09a;
  text-align: left;
}
.sec-features:after {
  content: "";
  position: absolute;
  bottom: 80px;
  right: 0;
  z-index: 1;
  width: 249px;
  height: 1109px;
  background-image: url("../img/index/features_bg_txt01.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media screen and (max-width: 1399px) {
  .sec-features:after {
    width: 17.7857vw;
    height: 79.2143vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features:after {
    display: none;
  }
}

.sec-features .features-list {
  margin-top: 16px;
}

.sec-features .features-list__item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item {
    display: block;
  }
}

.sec-features .features-list__item:nth-child(1) {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  z-index: 6;
  width: calc(100% + 300px);
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(1) {
    width: 121.4286%;
  }
}
.sec-features .features-list__item:nth-child(1) .features-box {
  padding-top: 60px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(1) .features-box {
    padding-top: 4.2857vw;
  }
}
.sec-features .features-list__item:nth-child(1) .features-box__in {
  margin-left: 140px;
  margin-right: -200px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(1) .features-box__in {
    margin-left: 10vw;
    margin-right: -14.2857vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(1) .features-box__in {
    margin-left: 0;
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(1) .features-txt {
    padding-right: 0;
  }
}

.sec-features .features-list__item:nth-child(2) {
  z-index: 5;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-left: -48px;
  margin-top: -20px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(2) {
    margin-left: -3.4288vw;
    margin-top: 2vw;
    width: 64.8571%;
  }
}
@media screen and (max-width: 1199px) {
  .sec-features .features-list__item:nth-child(2) {
    width: 70%;
  }
}
@media screen and (max-width: 1020px) {
  .sec-features .features-list__item:nth-child(2) {
    width: 88%;
    margin-left: -15vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(2) {
    width: 100%;
    margin-top: 40px;
    margin-left: 0;
  }
}
.sec-features .features-list__item:nth-child(2) .features-box {
  padding-bottom: 40px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(2) .features-box {
    padding-bottom: 2.8571vw;
    margin-left: 3vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(2) .features-box {
    width: 278px;
    margin-top: -60px;
    margin-left: auto;
    margin-right: -16px;
  }
}
.sec-features .features-list__item:nth-child(2) .features-box__in {
  margin-left: -28px;
  margin-right: 28px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(2) .features-box__in {
    margin-left: -2vw;
    margin-right: 2vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(2) .features-img__in {
    margin-left: -100px;
  }
}

.sec-features .features-list__item:nth-child(3) {
  z-index: 4;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-top: -300px;
  width: calc(100% + 72px);
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(3) {
    margin-top: -21.4288vw;
    margin-left: auto;
    margin-right: -5.1428vw;
    width: 82%;
  }
}
@media screen and (max-width: 1199px) {
  .sec-features .features-list__item:nth-child(3) {
    margin-right: -12vw;
  }
}
@media screen and (max-width: 1020px) {
  .sec-features .features-list__item:nth-child(3) {
    width: 94%;
    margin-top: -88px;
    margin-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(3) {
    margin-top: 80px;
    margin-left: 0;
  }
}
.sec-features .features-list__item:nth-child(3) .features-box {
  padding-bottom: 124px;
  width: 348px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(3) .features-box {
    padding-bottom: 8.8571vw;
    width: 28vw;
  }
}
@media screen and (max-width: 1199px) {
  .sec-features .features-list__item:nth-child(3) .features-box {
    padding-bottom: 6vw;
  }
}
@media screen and (max-width: 1020px) {
  .sec-features .features-list__item:nth-child(3) .features-box {
    width: 32vw;
    margin-right: 4vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(3) .features-box {
    width: 100%;
    margin-right: 0;
  }
}
.sec-features .features-list__item:nth-child(3) .features-ttl {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(3) .features-img {
    margin-top: -300px;
    margin-left: 80px;
    width: calc(100% + 80px);
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(3) .features-img__in {
    margin-right: -62px;
  }
}

.sec-features .features-list__item:nth-child(4) {
  z-index: 3;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-top: -60px;
  margin-left: 40px;
  width: 100%;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(4) {
    margin-top: -4.2857vw;
    margin-left: 2.8571vw;
    width: 78.5714%;
  }
}
@media screen and (max-width: 1020px) {
  .sec-features .features-list__item:nth-child(4) {
    margin-left: -9vw;
    width: 84%;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(4) {
    margin-top: 40px;
    margin-left: 0;
    width: 100%;
  }
}
.sec-features .features-list__item:nth-child(4) .features-box {
  width: 348px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(4) .features-box {
    width: 28vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(4) .features-box {
    margin-top: -16px;
    margin-left: auto;
    margin-right: -20px;
    width: 280px;
  }
}
.sec-features .features-list__item:nth-child(4) .features-box__in {
  margin-left: -60px;
  margin-right: 28px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(4) .features-box__in {
    margin-left: -2vw;
    margin-right: 2vw;
  }
}
.sec-features .features-list__item:nth-child(4) .features-ttl {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.sec-features .features-list__item:nth-child(4) .features-txt {
  width: 356px;
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(4) .features-txt {
    width: auto;
  }
}
.sec-features .features-list__item:nth-child(4) .features-img {
  margin-right: 42px;
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(4) .features-img__in {
    margin-left: -172px;
  }
}

.sec-features .features-list__item:nth-child(5) {
  z-index: 2;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-top: 60px;
  margin-left: -136px;
  width: calc(100% + 172px);
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(5) {
    margin-top: 4.2857vw;
    margin-left: -9.7143vw;
    width: calc(100% + 12.2857vw);
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(5) {
    margin-top: 100px;
    margin-left: 0;
  }
}
.sec-features .features-list__item:nth-child(5) .features-box {
  width: 348px;
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(5) .features-box {
    margin-left: 8px;
    width: auto;
    max-width: 304px;
  }
}
.sec-features .features-list__item:nth-child(5) .features-box__in {
  margin-left: -620px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-list__item:nth-child(5) .features-box__in {
    margin-left: -44.2857vw;
  }
}
@media screen and (max-width: 1020px) {
  .sec-features .features-list__item:nth-child(5) .features-box__in {
    margin-left: -64vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(5) .features-box__in {
    margin-left: 0;
  }
}
.sec-features .features-list__item:nth-child(5) .features-ttl {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
.sec-features .features-list__item:nth-child(5) .features-txt {
  width: 356px;
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(5) .features-txt {
    width: auto;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(5) .features-img {
    margin-top: -280px;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-list__item:nth-child(5) .features-img__in {
    margin-left: -100px;
    margin-right: -500px;
  }
}

.sec-features .features-box {
  position: relative;
  z-index: 2;
  width: 316px;
}

.sec-features .features-ttl {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-bottom: 16px;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-ttl {
    padding-bottom: 1.1428vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-ttl {
    padding-bottom: 12px;
    text-shadow: 4px 4px 8px rgba(25, 25, 25, 0.44);
  }
}
.sec-features .features-ttl:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 170px;
  height: 1px;
  background-color: #c9c9c9;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-ttl:after {
    width: 12.1428vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-ttl:after {
    width: 170px;
  }
}
@media screen and (max-width: 1399px) {
  .sec-features .features-ttl__num img {
    height: 5.1428vw;
    width: 4.4vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-ttl__num img {
    height: 56px;
    width: 48px;
  }
}
.sec-features .features-ttl__txt {
  padding-left: 10px;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.2;
  -webkit-transform: skewX(-12deg);
          transform: skewX(-12deg);
}
@media screen and (max-width: 1399px) {
  .sec-features .features-ttl__txt {
    font-size: clamp(16px, 2vw, 28px);
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-ttl__txt {
    font-size: 2.6rem;
  }
}

.sec-features .features-txt {
  padding-top: 40px;
  width: 380px;
  font-size: 1.7rem;
  line-height: 1.8;
}
@media screen and (max-width: 1399px) {
  .sec-features .features-txt {
    padding-top: 2.8571vw;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1199px) {
  .sec-features .features-txt {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-features .features-txt {
    width: auto;
    text-shadow: 2px 2px 4px rgba(25, 25, 25, 0.44);
  }
}

/* ========================================================
.sec-plan
======================================================== */
.sec-plan {
  position: relative;
  padding: 80px 0;
  background-color: #fff;
  color: #191919;
}
@media screen and (max-width: 767px) {
  .sec-plan {
    padding: 56px 0;
  }
}
.sec-plan .cmn-sec-ttl01 {
  margin-bottom: 40px;
}
.sec-plan .cmn-sec-ttl01 .ttl-en {
  color: #191919;
}
.sec-plan .cmn-sec-ttl01 .ttl-en__txt:before {
  background-color: #191919;
}

.sec-plan .plan-img {
  max-width: 680px;
  margin: 60px auto 0;
}
@media screen and (max-width: 767px) {
  .sec-plan .plan-img {
    margin: 40px auto 0;
  }
}

/* .cost-table
=========================================== */
.sec-plan .cost-table {
  margin: 64px auto 0;
  max-width: 1000px;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table {
    width: calc(100% + 16px);
    margin: 20px 0 0 -8px;
  }
}
@media screen and (max-width: 374px) {
  .sec-plan .cost-table {
    width: calc(100% + 32px);
    margin: 20px 0 0 -16px;
  }
}

.sec-plan .cost-table table {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table {
    table-layout: fixed;
  }
}

.sec-plan .cost-table table + table {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table + table {
    margin-top: 40px;
  }
}

.sec-plan .cost-table table,
.sec-plan .cost-table th,
.sec-plan .cost-table td {
  border: 2px solid #d4d4d4;
  border-collapse: collapse;
}

.sec-plan .cost-table th,
.sec-plan .cost-table td {
  padding: 8px;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table th,
  .sec-plan .cost-table td {
    padding: 8px;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table th,
  .sec-plan .cost-table td {
    padding: 8px 6px;
  }
}

.sec-plan .cost-table th {
  background-color: #0d0d0d;
  color: #fff;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table th {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table th {
    padding: 8px 4px;
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 374px) {
  .sec-plan .cost-table th {
    padding: 8px 4px;
    font-size: 1.2rem;
  }
}
.sec-plan .cost-table th .small-txt {
  font-size: 1.4rem;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table th .small-txt {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table th .small-txt {
    display: block;
    padding-top: 4px;
    line-height: 1.4;
    font-size: 0.8rem;
  }
}

.sec-plan .cost-table tr .size {
  position: relative;
}
.sec-plan .cost-table tr .size:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 4px;
  height: 100%;
  background-color: #f0f;
}

.sec-plan .cost-table tr:nth-child(2) .size:after {
  background-color: #ff4239;
}

.sec-plan .cost-table tr:nth-child(3) .size:after {
  background-color: #ff9500;
}

.sec-plan .cost-table tr:nth-child(4) .size:after {
  background-color: #e2b117;
}

.sec-plan .cost-table tr:nth-child(5) .size:after {
  background-color: #34c759;
}

.sec-plan .cost-table tr:nth-child(6) .size:after {
  background-color: #00c7be;
}

.sec-plan .cost-table tr:nth-child(7) .size:after {
  background-color: #007aff;
}

.sec-plan .cost-table tr:nth-child(8) .size:after {
  background-color: #5856d6;
}

.sec-plan .cost-table tr:nth-child(9) .size:after {
  background-color: #827573;
}

.sec-plan .cost-table th span.bg-red {
  display: inline-block;
  padding: 6px 0 8px 6px;
  margin-right: 16px;
  background-color: #a32929;
  vertical-align: 2px;
  font-size: 1.8rem;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table th span.bg-red {
    margin-right: 8px;
    font-size: 1.6rem;
    vertical-align: 0;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table th span.bg-red {
    display: block;
    padding: 4px 4px 4px;
    margin: 4px auto;
    width: 100%;
    max-width: 10em;
    font-size: 1rem;
  }
}

@media screen and (max-width: 767px) {
  _::-webkit-full-page-media, _:future, :root .sec-plan .cost-table th span.bg-red {
    padding: 4px 4px 2px;
  }
}

.sec-plan .cost-table td {
  background-color: #fff;
}

.sec-plan .cost-table table col.col1 {
  width: 224px;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table col.col1 {
    width: 140px;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table col.col1 {
    width: 80px;
  }
}
@media screen and (max-width: 399px) {
  .sec-plan .cost-table table col.col1 {
    width: 68px;
  }
}

.sec-plan .cost-table table col.col2 {
  width: 392px;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table col.col2 {
    width: 132px;
  }
}

.sec-plan .cost-table table col.col3 {
  width: 364px;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table col.col3 {
    width: 168px;
  }
}
@media screen and (max-width: 399px) {
  .sec-plan .cost-table table col.col3 {
    width: calc(100% - 68px - 132px);
  }
}

.sec-plan .cost-table table tr:nth-child(2n) td {
  background-color: #e9e9e9;
}

.sec-plan .cost-table table tr td.bg-white {
  background-color: #000;
}

.sec-plan .cost-table table tr td.bg-gray {
  background-color: #e9e9e9;
}

.sec-plan .cost-table table tr td.type {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.type {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.type {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 374px) {
  .sec-plan .cost-table table tr td.type {
    font-size: 1.2rem;
  }
}

.sec-plan .cost-table table tr td.size {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.size {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.size {
    padding: 6px 4px;
    font-size: 1.6rem;
    line-height: 1.2;
  }
}
@media screen and (max-width: 374px) {
  .sec-plan .cost-table table tr td.size {
    font-size: 1.2rem;
  }
}
.sec-plan .cost-table table tr td.size .color-txt {
  margin-top: 2px;
  color: #53504c;
  font-size: 1.3rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.size .color-txt {
    font-size: 1.1rem;
  }
}
@media screen and (max-width: 399px) {
  .sec-plan .cost-table table tr td.size .color-txt {
    font-size: 0.9rem;
  }
}
.sec-plan .cost-table table tr td.size .size-detail {
  padding-top: 3px;
  display: block;
}
.sec-plan .cost-table table tr td.size .note {
  font-size: 1.6rem;
  padding-top: 4px;
  line-height: 1.3;
  display: block;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.size .note {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.size .note {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 399px) {
  .sec-plan .cost-table table tr td.size .note {
    padding-top: 0;
    font-size: 1rem;
  }
}

.sec-plan .cost-table table tr td.price {
  padding-top: 6px;
  padding-bottom: 18px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price {
    padding-bottom: 11px;
  }
}

.sec-plan .cost-table table tr td.price .before {
  position: relative;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .before {
    display: block;
  }
}
.sec-plan .cost-table table tr td.price .before .num {
  font-size: 2.2rem;
  font-weight: 500;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .before .num {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .before .num {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 374px) {
  .sec-plan .cost-table table tr td.price .before .num {
    font-size: 1.4rem;
  }
}
.sec-plan .cost-table table tr td.price .before .unit {
  font-size: 1.6rem;
  font-weight: 700;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .before .unit {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .before .unit {
    font-size: 1.1rem;
  }
}

.sec-plan .cost-table table tr td.price .after {
  position: relative;
  padding-left: 8px;
  color: #a32929;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after {
    display: block;
    padding-top: 2px;
    padding-left: 0;
  }
}
.sec-plan .cost-table table tr td.price .after:before {
  content: "→";
  padding-right: 8px;
  color: #0d0d0d;
  font-size: 2.8rem;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .after:before {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after:before {
    padding-right: 4px;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 374px) {
  .sec-plan .cost-table table tr td.price .after:before {
    font-size: 1.4rem;
  }
}
.sec-plan .cost-table table tr td.price .after .num {
  font-size: 3.6rem;
  font-weight: 700;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .after .num {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after .num {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 432px) {
  .sec-plan .cost-table table tr td.price .after .num {
    font-size: 2rem;
  }
}
.sec-plan .cost-table table tr td.price .after .unit {
  font-size: 2.4rem;
  font-weight: 700;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .after .unit {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after .unit {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 374px) {
  .sec-plan .cost-table table tr td.price .after .unit {
    font-size: 1rem;
  }
}

.sec-plan .cost-table table tr td.price .after-accent {
  position: relative;
  z-index: 1;
  margin-left: 48px;
  padding-left: 12px;
  padding-right: 16px;
  color: #a32929;
  font-style: italic;
  text-shadow: #fff 3px 0px 0px, #fff 2.83487px 0.981584px 0px, #fff 2.35766px 1.85511px 0px, #fff 1.62091px 2.52441px 0px, #fff 0.705713px 2.91581px 0px, #fff -0.287171px 2.98622px 0px, #fff -1.24844px 2.72789px 0px, #fff -2.07227px 2.16926px 0px, #fff -2.66798px 1.37182px 0px, #fff -2.96998px 0.42336px 0px, #fff -2.94502px -0.571704px 0px, #fff -2.59586px -1.50383px 0px, #fff -1.96093px -2.27041px 0px, #fff -1.11013px -2.78704px 0px, #fff -0.137119px -2.99686px 0px, #fff 0.850987px -2.87677px 0px, #fff 1.74541px -2.43999px 0px, #fff 2.44769px -1.73459px 0px, #fff 2.88051px -0.838247px 0px;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after-accent {
    display: inline-block;
    margin-left: 14px;
    padding-top: 2px;
    padding-left: 7px;
    padding-right: 11px;
  }
}
.sec-plan .cost-table table tr td.price .after-accent:before {
  content: "→";
  position: absolute;
  top: 50%;
  left: -40px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  color: #0d0d0d;
  font-size: 2.4rem;
  font-weight: 400;
  font-style: normal;
  text-shadow: none;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .after-accent:before {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after-accent:before {
    top: 64%;
    left: -18px;
    font-size: 1.4rem;
  }
}
.sec-plan .cost-table table tr td.price .after-accent:after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 2px;
  left: 0;
  display: block;
  width: 100%;
  height: calc(100% + 6px);
  background-color: #666666;
  clip-path: polygon(0 52%, 100% 0, 100% 100%, 0% 100%);
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after-accent:after {
    top: 14px;
    height: calc(100% - 10px);
  }
}
.sec-plan .cost-table table tr td.price .after-accent .month-num {
  margin-right: -4px;
  font-size: 3.2rem;
  font-weight: 600;
  letter-spacing: 0;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after-accent .month-num {
    margin-right: -5px;
    font-size: 2rem;
  }
}
.sec-plan .cost-table table tr td.price .after-accent .month-txt {
  margin-right: -2px;
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after-accent .month-txt {
    margin-right: -4px;
    font-size: 1.8rem;
    letter-spacing: -0.06em;
  }
}
.sec-plan .cost-table table tr td.price .after-accent .num {
  font-size: 4.2rem;
  font-weight: 600;
  letter-spacing: -0.04em;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .after-accent .num {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after-accent .num {
    margin-right: -2px;
    font-size: 2.8rem;
  }
}
.sec-plan .cost-table table tr td.price .after-accent .unit {
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.price .after-accent .unit {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.price .after-accent .unit {
    font-size: 1.6rem;
  }
}

.sec-plan .cost-table table tr td.contact .contact-btn {
  width: 100%;
  height: 48px;
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.contact .contact-btn {
    height: 54px;
  }
}
.sec-plan .cost-table table tr td.contact .contact-btn a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  border: 2px solid #0d0d0d;
  border-radius: 8px;
  background-color: #ffcc1a;
  color: #000;
  font-size: 2rem;
  font-weight: 700;
  -webkit-box-shadow: 2px 2px 0 #53504c;
          box-shadow: 2px 2px 0 #53504c;
  -webkit-transition: opacity 0.2s ease-in-out;
  transition: opacity 0.2s ease-in-out;
}
.sec-plan .cost-table table tr td.contact .contact-btn a:hover {
  opacity: 0.8;
}
@media screen and (max-width: 1020px) {
  .sec-plan .cost-table table tr td.contact .contact-btn a {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.contact .contact-btn a {
    text-align: center;
    font-size: 1.6rem;
    line-height: 1.2;
  }
}
@media screen and (max-width: 767px) {
  .sec-plan .cost-table table tr td.contact .contact-btn__in span {
    display: none;
  }
}

/* .attention-block
=========================================== */
.sec-plan .attention-block {
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .sec-plan .attention-block {
    margin: 16px auto 0;
  }
}

.sec-plan .attention-txt {
  line-height: 1.8;
  text-indent: -1em;
  margin-left: 1em;
}

/* ========================================================
.sec-comparison
======================================================== */
.sec-comparison {
  background-color: #f7f7f7;
  padding: 64px 0 80px;
}
@media screen and (max-width: 767px) {
  .sec-comparison {
    padding: 40px 0 56px;
  }
}

.sec-comparison .comparison-ttl {
  color: #191919;
  text-align: center;
  font-size: 3.2rem;
  font-weight: 700;
  font-style: italic;
}
@media screen and (max-width: 767px) {
  .sec-comparison .comparison-ttl {
    line-height: 1.3;
    font-size: 2.4rem;
  }
}

.sec-comparison .comparison-list__item {
  background-color: #e9e9e9;
  margin-top: 2px;
}

.sec-comparison .comparison-list__item:last-child {
  overflow: hidden;
  border-radius: 0 0 16px 16px;
}

.sec-comparison .haeding-block {
  position: relative;
  margin-top: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  border-radius: 16px 16px 0 0;
}
@media screen and (max-width: 767px) {
  .sec-comparison .haeding-block {
    margin-top: 24px;
  }
}

.sec-comparison .haeding-block__ttl {
  background-color: #191919;
  width: 192px;
  height: 40px;
  border-top-left-radius: 16px;
}
@media screen and (max-width: 767px) {
  .sec-comparison .haeding-block__ttl {
    width: calc(100% - 88px - 88px);
  }
}

.sec-comparison .haeding-block__garage {
  width: 184px;
  padding: 12px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #cd9f00;
  border-left: 2px solid #f7f7f7;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .sec-comparison .haeding-block__garage {
    font-size: 1.4rem;
    width: 88px;
  }
}

.sec-comparison .haeding-block__container {
  background-color: #191919;
  width: 120px;
  padding: 12px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-left: 2px solid #f7f7f7;
}
@media screen and (max-width: 767px) {
  .sec-comparison .haeding-block__container {
    border-top-right-radius: 16px;
    width: 88px;
  }
}

.sec-comparison .haeding-block__txt {
  background-color: #191919;
  border-left: 2px solid #f7f7f7;
  border-top-right-radius: 16px;
  padding: 12px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: calc(100% - 192px - 184px - 120px);
}
@media screen and (max-width: 767px) {
  .sec-comparison .haeding-block__txt {
    padding: 12px;
    display: none;
  }
}

.sec-comparison .comparison-block {
  color: #191919;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .sec-comparison .comparison-block {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.sec-comparison .comparison-block__ttl,
.sec-comparison .comparison-block__garage,
.sec-comparison .comparison-block__container,
.sec-comparison .comparison-block__txt {
  padding: 12px 16px;
  line-height: 1.3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.sec-comparison .comparison-block__ttl {
  width: 192px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .sec-comparison .comparison-block__ttl {
    width: calc(100% - 88px - 88px);
    background-color: #e9e9e9;
    padding: 8px 12px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media screen and (max-width: 767px) {
  .sec-comparison .comparison-block__ttl .ttl-txt {
    font-size: 1.6rem;
  }
}

.sec-comparison .comparison-block__ttl .ttl-description {
  display: none;
}
@media screen and (max-width: 767px) {
  .sec-comparison .comparison-block__ttl .ttl-description {
    display: block;
    margin-top: 4px;
    font-weight: 400;
  }
}

.sec-comparison .comparison-block__garage {
  border-left: 2px solid #f7f7f7;
  color: #962926;
  font-size: 3.2rem;
  width: 184px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #ffcc1a;
}
@media screen and (max-width: 767px) {
  .sec-comparison .comparison-block__garage {
    width: 88px;
    background-color: #ffcc1a;
    padding: 4px 12px;
  }
}
.sec-comparison .comparison-block__garage.mark-bold {
  font-size: 3.6rem;
  font-weight: 700;
}

.sec-comparison .comparison-block__container {
  border-left: 2px solid #f7f7f7;
  width: 120px;
  color: #a32929;
  font-size: 2rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .sec-comparison .comparison-block__container {
    width: 88px;
    background-color: #e9e9e9;
    padding: 4px 12px;
  }
}

.sec-comparison .comparison-block__txt {
  border-left: 2px solid #f7f7f7;
  width: calc(100% - 192px - 184px - 120px);
}
@media screen and (max-width: 767px) {
  .sec-comparison .comparison-block__txt {
    display: none;
    width: 100%;
  }
}

/* ========================================================
.sec-access
======================================================== */
.sec-access {
  position: relative;
  padding: 80px 0;
}
@media screen and (max-width: 767px) {
  .sec-access {
    padding: 56px 0;
  }
}
.sec-access:after {
  content: "";
  position: absolute;
  bottom: 20px;
  left: 0;
  z-index: 1;
  width: 225px;
  height: 770px;
  background-image: url("../img/index/access_bg_txt01.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media screen and (max-width: 1399px) {
  .sec-access:after {
    width: 16.0714vw;
    height: 55vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-access:after {
    display: none;
  }
}

.sec-access .access-bnr {
  position: relative;
  z-index: 2;
  margin-top: 80px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .sec-access .access-bnr {
    margin-top: 40px;
    margin-left: -16px;
    width: calc(100% + 32px);
  }
}
@media screen and (max-width: 767px) {
  .sec-access .access-bnr img {
    width: 100%;
  }
}

.sec-access .access-box {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .sec-access .access-box {
    display: block;
    margin-top: 40px;
  }
}

.sec-access .access-box .access-info-ttl {
  color: #b7b7b7;
  font-size: 5.8rem;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 767px) {
  .sec-access .access-box .access-info-ttl {
    font-size: 4rem;
  }
}
.sec-access .access-box .access-info-ttl:before {
  content: "";
  display: inline-block;
  margin-right: 20px;
  vertical-align: -2px;
  width: 1px;
  height: 26px;
  background-color: #b7b7b7;
  -webkit-transform: rotate(28deg);
          transform: rotate(28deg);
}

.sec-access .access-box .access-info-detail {
  margin-right: 40px;
  color: #e9e9e9;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .sec-access .access-box .access-info-detail {
    margin-top: 16px;
  }
}
.sec-access .access-box .access-info-detail__ttl {
  font-size: 1.8rem;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .sec-access .access-box .access-info-detail__ttl {
    font-size: 1.6rem;
  }
}
.sec-access .access-box .access-info-detail__txt {
  margin-top: 20px;
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  .sec-access .access-box .access-info-detail__txt {
    margin-top: 12px;
    font-size: 1.6rem;
  }
}

.sec-access .access-map {
  position: relative;
  width: 536px;
  height: 0;
  padding-top: 400px;
}
@media screen and (max-width: 767px) {
  .sec-access .access-map {
    margin-top: 28px;
    width: 100%;
    padding-top: clamp(20px, 63vw, 280px);
  }
}
.sec-access .access-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* ========================================================
.sec-flow
======================================================== */
.sec-flow {
  position: relative;
  padding: 80px 0;
  background-image: url("../img/index/flow_bg01.webp");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media screen and (max-width: 767px) {
  .sec-flow {
    padding: 56px 0;
    background-image: url("../img/index/flow_bg01_sp.webp");
  }
}

.sec-flow .flow-list {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list {
    margin-top: 40px;
  }
}

.sec-flow .flow-list__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 1020px) {
  .sec-flow .flow-list__item {
    display: block;
  }
}
.sec-flow .flow-list__item + .flow-list__item {
  margin-top: 36px;
}

.sec-flow .flow-list__item:nth-child(2) {
  margin-top: 30px;
  margin-left: clamp(1px, 6.4286vw, 90px);
}
@media screen and (max-width: 1199px) {
  .sec-flow .flow-list__item:nth-child(2) {
    margin-left: 3.125vw;
  }
}
@media screen and (max-width: 1020px) {
  .sec-flow .flow-list__item:nth-child(2) {
    margin-top: 36px;
    margin-left: 9.375vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item:nth-child(2) {
    margin-left: 0;
  }
}

.sec-flow .flow-list__item:nth-child(3) {
  margin-left: calc(clamp(1px, 6.4286vw, 90px) * 2);
}
@media screen and (max-width: 1199px) {
  .sec-flow .flow-list__item:nth-child(3) {
    margin-left: 6.25vw;
  }
}
@media screen and (max-width: 1020px) {
  .sec-flow .flow-list__item:nth-child(3) {
    margin-left: 18.75vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item:nth-child(3) {
    margin-left: 0;
  }
}

.sec-flow .flow-list__item:nth-child(4) {
  margin-left: calc(clamp(1px, 6.4286vw, 90px) * 3);
}
@media screen and (max-width: 1199px) {
  .sec-flow .flow-list__item:nth-child(4) {
    margin-left: 9.375vw;
  }
}
@media screen and (max-width: 1020px) {
  .sec-flow .flow-list__item:nth-child(4) {
    margin-left: 28.125vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item:nth-child(4) {
    margin-left: 0;
  }
}

.sec-flow .flow-list__item:nth-child(5) {
  margin-left: calc(clamp(1px, 6.4286vw, 90px) * 4);
}
@media screen and (max-width: 1199px) {
  .sec-flow .flow-list__item:nth-child(5) {
    margin-left: 12.5vw;
  }
}
@media screen and (max-width: 1020px) {
  .sec-flow .flow-list__item:nth-child(5) {
    margin-left: 37.5vw;
  }
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item:nth-child(5) {
    margin-left: 0;
  }
}

.sec-flow .flow-list__item .item-step {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 8px;
  width: 340px;
  background-color: #fff;
  -webkit-transform: skewX(-22deg);
          transform: skewX(-22deg);
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item .item-step {
    margin: 0 auto;
    width: calc(100% - 36px);
    max-width: 308px;
  }
}
.sec-flow .flow-list__item .item-step .step-num {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 70px;
  height: 44px;
  background-color: #191919;
}
.sec-flow .flow-list__item .item-step .step-num__in {
  margin-bottom: -4px;
  font-size: 2.2rem;
  font-family: "Bebas Neue", sans-serif;
  -webkit-transform: skewX(22deg);
          transform: skewX(22deg);
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item .item-step .step-num__in {
    font-size: 2rem;
  }
}
.sec-flow .flow-list__item .item-step .step-num__in .num {
  font-size: 3.2rem;
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item .item-step .step-num__in .num {
    font-size: 2.8rem;
  }
}
.sec-flow .flow-list__item .item-step .step-ttl {
  margin-bottom: -6px;
  width: calc(100% - 70px);
  text-align: center;
  color: #191919;
  font-size: 2.2rem;
  font-weight: 700;
  -webkit-transform: skewX(22deg);
          transform: skewX(22deg);
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item .item-step .step-ttl {
    margin-bottom: -14px;
    font-size: 2rem;
  }
}

.sec-flow .flow-list__item .item-step__in {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
}

.sec-flow .flow-list__item .item-step__in:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: calc(100% - 30px);
  height: 8px;
  background-color: #191919;
}

.sec-flow .flow-list__item .item-step__in:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: #191919 transparent transparent transparent;
  border-width: 16px 30px 0px 0px;
  -webkit-transform: skewX(22deg);
          transform: skewX(22deg);
}

.sec-flow .flow-list__item .step-content {
  margin-left: 32px;
}
@media screen and (max-width: 1020px) {
  .sec-flow .flow-list__item .step-content {
    margin-top: 8px;
    margin-left: 0;
  }
}

.sec-flow .flow-list__item .step-content-txt {
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item .step-content-txt {
    margin: auto;
    display: table;
    text-align: left;
    max-width: 296px;
  }
}

.sec-flow .flow-list__item .step-content-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item .step-content-block {
    display: block;
  }
}
.sec-flow .flow-list__item .step-content-block .contact-tel {
  font-size: 4.6rem;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 767px) {
  .sec-flow .flow-list__item .step-content-block .contact-tel {
    text-align: center;
  }
}

.sec-flow .contact-btn {
  margin-left: 20px;
  width: 280px;
  height: 50px;
}
@media screen and (max-width: 767px) {
  .sec-flow .contact-btn {
    margin: 4px auto 0;
  }
}
.sec-flow .contact-btn a {
  position: relative;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  border-radius: 6px;
  border: 2px solid #191919;
  background-color: #ffcc1a;
  background-image: url("../img/common/base/btn_bg_arrow01.png");
  background-repeat: no-repeat;
  background-size: 212px 8px;
  background-position: top 48% left 50%;
  -webkit-box-shadow: 5px 5px 0 #575757;
          box-shadow: 5px 5px 0 #575757;
  -webkit-transition: top 0.2s ease-in-out, left 0.2s ease-in-out, 0.2s ease-in-out;
  transition: top 0.2s ease-in-out, left 0.2s ease-in-out, 0.2s ease-in-out;
}
.sec-flow .contact-btn a:hover {
  top: 5px;
  left: 5px;
  -webkit-box-shadow: 0 0 0 #575757;
          box-shadow: 0 0 0 #575757;
}
.sec-flow .contact-btn a:hover:before {
  content: "";
  position: absolute;
  top: -7px;
  left: 0;
  display: block;
  width: 100%;
  height: 5px;
}
.sec-flow .contact-btn a:hover:after {
  content: "";
  position: absolute;
  top: -7px;
  left: -7px;
  display: block;
  width: 5px;
  height: calc(100% + 7px);
}
.sec-flow .contact-btn .btn-ttl {
  padding: 0 8px;
  background-color: #ffcc1a;
  color: #191919;
}
.sec-flow .contact-btn .btn-ttl__jp {
  display: block;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
}

/* ========================================================
.sec-question
======================================================== */
.sec-question {
  position: relative;
  padding: 80px 0;
  background-color: #fff;
  color: #191919;
}
@media screen and (max-width: 767px) {
  .sec-question {
    padding: 56px 0;
  }
}
.sec-question .cmn-sec-ttl01 {
  margin-bottom: 40px;
}
.sec-question .cmn-sec-ttl01 .ttl-en {
  color: #191919;
}
.sec-question .cmn-sec-ttl01 .ttl-en__txt:before {
  background-color: #191919;
}

.sec-question .question-list {
  margin: 80px auto 0;
  width: 100%;
  max-width: 1000px;
  border-top: 1px solid #191919;
}
@media screen and (max-width: 767px) {
  .sec-question .question-list {
    margin: 40px auto 0;
  }
}

.sec-question .question-list__item {
  padding: 20px 0 32px;
  border-bottom: 1px solid #191919;
}
@media screen and (max-width: 1020px) {
  .sec-question .question-list__item {
    padding: 8px 0 20px;
  }
}

.sec-question .question-list__item .question-box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-top: 12px;
  padding-left: 20px;
  padding-right: 71px;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .question-box {
    padding-left: 16px;
    padding-right: 40px;
  }
}
.sec-question .question-list__item .question-box .icon {
  width: 50px;
  color: #5e5953;
  font-size: 4rem;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 1020px) {
  .sec-question .question-list__item .question-box .icon {
    width: 40px;
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .question-box .icon {
    width: 28px;
    font-size: 2.6rem;
  }
}
.sec-question .question-list__item .question-box .question-txt {
  padding-top: 4px;
  width: calc(100% - 50px);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4;
  -webkit-transition: color 0.2s ease-in-out;
  transition: color 0.2s ease-in-out;
}
@media screen and (max-width: 1020px) {
  .sec-question .question-list__item .question-box .question-txt {
    padding-top: 2px;
    width: calc(100% - 40px);
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .question-box .question-txt {
    font-size: 1.8rem;
  }
}
.sec-question .question-list__item .question-box:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 4px;
  height: calc(100% - 11px);
  background-color: #a32929;
}
@media screen and (max-width: 1020px) {
  .sec-question .question-list__item .question-box:before {
    height: calc(100% - 12px);
  }
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .question-box:before {
    width: 3px;
  }
}
.sec-question .question-list__item .question-box:after {
  content: "";
  position: absolute;
  top: 26px;
  right: 24px;
  display: block;
  width: 27px;
  height: 16px;
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
  background-image: url("../img/common/base/arrow_bottom01.svg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media screen and (max-width: 1020px) {
  .sec-question .question-list__item .question-box:after {
    top: 20px;
    width: 24px;
    height: 14px;
  }
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .question-box:after {
    top: calc(50% + 1px);
    right: 16px;
    width: 15px;
    height: 9px;
  }
}

.sec-question .question-list__item .question-box:hover .question-txt {
  color: #a32929;
}

.sec-question .question-list__item .question-box.is-open:after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.sec-question .question-list__item .answer-box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-top: 52px;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .answer-box {
    padding-top: 32px;
    padding-left: 12px;
  }
}
.sec-question .question-list__item .answer-box .icon {
  width: 50px;
  color: #a32929;
  font-size: 4rem;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 1020px) {
  .sec-question .question-list__item .answer-box .icon {
    width: 40px;
    font-size: 3.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .answer-box .icon {
    width: 28px;
    font-size: 2.6rem;
  }
}
.sec-question .question-list__item .answer-box .answer-txt {
  width: calc(100% - 50px);
  font-size: 1.8rem;
  line-height: 1.8;
}
@media screen and (max-width: 1020px) {
  .sec-question .question-list__item .answer-box .answer-txt {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .answer-box .answer-txt {
    font-size: 1.4rem;
  }
}
.sec-question .question-list__item .answer-box .answer-txt__in {
  display: block;
}
.sec-question .question-list__item .answer-box .answer-txt__in + .answer-txt__in {
  padding-top: 1.4em;
}
.sec-question .question-list__item .answer-box:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 4px;
  height: 92px;
  background-color: #a32929;
}
@media screen and (max-width: 767px) {
  .sec-question .question-list__item .answer-box:before {
    width: 3px;
    height: 64px;
  }
}

/* ========================================================
.sec-contact
======================================================== */
.sec-contact {
  position: relative;
  padding: 80px 0;
}
@media screen and (max-width: 767px) {
  .sec-contact {
    padding: 40px 0;
  }
}
.sec-contact .cmn-sec-ttl01 {
  margin-bottom: -40px;
}
@media screen and (max-width: 767px) {
  .sec-contact .cmn-sec-ttl01 {
    margin-bottom: -68px;
  }
}

.sec-contact .contact-box {
  padding: 0 20px 80px;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  background-color: #0d0d0d;
}
@media screen and (max-width: 767px) {
  .sec-contact .contact-box {
    padding: 0 16px 40px;
  }
}

.sec-contact .contact-tel-box {
  margin: 0 auto;
  padding: 120px 20px 40px;
  max-width: 680px;
}
@media screen and (max-width: 767px) {
  .sec-contact .contact-tel-box {
    margin: 28px auto 0;
    padding: 60px 0 0;
  }
}

.sec-contact .contact-sub-ttl {
  padding-bottom: 8px;
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .sec-contact .contact-sub-ttl {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 399px) {
  .sec-contact .contact-sub-ttl .sp-m-none {
    display: none;
  }
}
.sec-contact .contact-sub-ttl br {
  display: none;
}
@media screen and (max-width: 399px) {
  .sec-contact .contact-sub-ttl br {
    display: block;
  }
}

.sec-contact .tel-hours {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .sec-contact .tel-hours {
    font-size: 1.2rem;
  }
}
.sec-contact .tel-hours__ttl {
  padding: 8px 8px 10px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .sec-contact .tel-hours__ttl {
    padding: 8px 6px 8px;
  }
}
.sec-contact .tel-hours__txt {
  margin-left: 8px;
  font-weight: 700;
}
.sec-contact .tel-hours__txt .num-box {
  vertical-align: -1px;
}
.sec-contact .tel-hours__txt .num {
  font-size: 1.8rem;
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .sec-contact .tel-hours__txt .num {
    font-size: 1.6rem;
  }
}

.sec-contact .tel-num {
  text-align: center;
}
.sec-contact .tel-num a {
  position: relative;
  display: inline-block;
  font-size: 6rem;
  font-weight: 500;
  font-family: "Bebas Neue", sans-serif;
}
@media screen and (max-width: 767px) {
  .sec-contact .tel-num a {
    font-size: clamp(36px, 15.5vw, 62px);
  }
}

/* ========================================================
.contact-form
======================================================== */
.contact-form .contact-form-list {
  margin: 60px auto 0;
  max-width: 900px;
}
@media screen and (max-width: 767px) {
  .contact-form .contact-form-list {
    margin: 32px auto 0;
  }
}

.contact-form .contact-form-list__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .contact-form .contact-form-list__item {
    display: block;
  }
}

.contact-form .contact-form-list__item + .contact-form-list__item {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .contact-form .contact-form-list__item + .contact-form-list__item {
    margin-top: 8px;
  }
}

.contact-form .contact-form-list__item + .contact-form-list__item.sec-padding {
  margin-top: 48px;
}

.contact-form .contact-ttl {
  padding-top: 12px;
  width: 260px;
}
@media screen and (max-width: 1020px) {
  .contact-form .contact-ttl {
    padding-top: 14px;
  }
}
@media screen and (max-width: 767px) {
  .contact-form .contact-ttl {
    padding-top: 10px;
    width: 100%;
  }
}
.contact-form .contact-ttl__in {
  position: relative;
  font-size: 2rem;
  font-weight: 700;
}
@media screen and (max-width: 1020px) {
  .contact-form .contact-ttl__in {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .contact-form .contact-ttl__in {
    margin-bottom: 10px;
    font-size: 1.6rem;
  }
}

.contact-form .contact-ttl__in.req:after {
  content: "必須";
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: inline-block;
  padding: 5px 12px 7px;
  background-color: #a32929;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 700;
}
@media screen and (max-width: 1020px) {
  .contact-form .contact-ttl__in.req:after {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .contact-form .contact-ttl__in.req:after {
    margin-left: 6px;
    padding: 4px 6px;
    font-size: 1.3rem;
    position: relative;
    -webkit-transform: unset;
            transform: unset;
    vertical-align: 2px;
  }
}
.contact-form .contact-ttl__in.req.adjust:after {
  margin-left: -12px;
}

.contact-form .contact-input {
  width: calc(100% - 260px - 40px);
}
@media screen and (max-width: 767px) {
  .contact-form .contact-input {
    width: 100%;
  }
}

.contact-form .contact-input.check-list {
  padding-top: 4px;
}

.contact-form .contact-sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .contact-form .contact-sub {
    display: block;
  }
}
.contact-form .contact-sub + .contact-sub {
  margin-top: 12px;
}

.contact-form .contact-sub-ttl {
  margin-right: 8px;
  width: 102px;
  font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
  .contact-form .contact-sub-ttl {
    display: block;
    margin-bottom: 4px;
    width: 100%;
    font-size: 1.6rem;
  }
}

.contact-form .contact-sub-input {
  width: calc(100% - 102px);
}
@media screen and (max-width: 767px) {
  .contact-form .contact-sub-input {
    width: 100%;
  }
}

/* .contact-input
=========================================== */
.wpcf7 input[type=text],
.wpcf7 input[type=tel],
.wpcf7 input[type=number],
.wpcf7 input[type=email],
.wpcf7 textarea,
.wpcf7 select {
  padding: 8px 12px 10px;
  border: 2px solid #5e5953;
  border-radius: 6px;
  color: #191919;
}

.wpcf7 input[type=text],
.wpcf7 input[type=tel],
.wpcf7 input[type=number],
.wpcf7 input[type=email],
.wpcf7 select {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .wpcf7 input[type=text],
  .wpcf7 input[type=tel],
  .wpcf7 input[type=number],
  .wpcf7 input[type=email],
  .wpcf7 select {
    width: 100%;
  }
}
.wpcf7 input[type=text].extra-short,
.wpcf7 input[type=tel].extra-short,
.wpcf7 input[type=number].extra-short,
.wpcf7 input[type=email].extra-short,
.wpcf7 select.extra-short {
  width: 124px;
}
@media screen and (max-width: 767px) {
  .wpcf7 input[type=text].extra-short,
  .wpcf7 input[type=tel].extra-short,
  .wpcf7 input[type=number].extra-short,
  .wpcf7 input[type=email].extra-short,
  .wpcf7 select.extra-short {
    width: 100%;
    max-width: 124px;
  }
}
.wpcf7 input[type=text].short,
.wpcf7 input[type=tel].short,
.wpcf7 input[type=number].short,
.wpcf7 input[type=email].short,
.wpcf7 select.short {
  width: 424px;
}
@media screen and (max-width: 767px) {
  .wpcf7 input[type=text].short,
  .wpcf7 input[type=tel].short,
  .wpcf7 input[type=number].short,
  .wpcf7 input[type=email].short,
  .wpcf7 select.short {
    width: 100%;
  }
}
.wpcf7 input[type=text].long,
.wpcf7 input[type=tel].long,
.wpcf7 input[type=number].long,
.wpcf7 input[type=email].long,
.wpcf7 select.long {
  width: 100%;
}
.wpcf7 input[type=text].ta-right,
.wpcf7 input[type=tel].ta-right,
.wpcf7 input[type=number].ta-right,
.wpcf7 input[type=email].ta-right,
.wpcf7 select.ta-right {
  text-align: right;
}

.wpcf7 textarea {
  width: 100%;
  line-height: 1.6;
}

.wpcf7 select {
  position: relative;
  background-color: #fff;
  color: #191919;
  cursor: pointer;
}

.wpcf7 .wpcf7-form-control-wrap:has(select):after {
  content: "";
  position: absolute;
  top: calc(50% + 1px);
  right: 14px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: inline-block;
  width: 14px;
  height: 10px;
  background-image: url("../img/common/base/arrow_bottom01.svg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  pointer-events: none;
}

.wpcf7 .wpcf7-list-item {
  position: relative;
  margin: 0;
}

.wpcf7 .wpcf7-list-item label {
  cursor: pointer;
}

.wpcf7 .wpcf7-list-item-label {
  font-size: 1.8rem;
}

.wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]) {
  position: relative;
  width: 32px;
  height: 32px;
  margin: 0.4rem;
  border: 2px solid #191919;
  border-radius: 6px;
  background-color: #fff;
  outline: none;
  vertical-align: -14px;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]) {
    position: absolute;
    top: 0;
    left: 0;
  }
}
.wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]):before, .wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]):after {
  position: absolute;
  content: "";
  background: #17773e;
}
.wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]):before {
  left: 2px;
  top: 17px;
  width: 0;
  height: 4px;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]):after {
  right: 8px;
  bottom: 3px;
  width: 4px;
  height: 0;
  -webkit-transform: rotate(40deg);
          transform: rotate(40deg);
  -webkit-transition-delay: 0.05s;
          transition-delay: 0.05s;
}
.wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]):checked:before {
  left: 2px;
  top: 17px;
  width: 12px;
  height: 4px;
}
.wpcf7 .wpcf7-list-item input[type=checkbox]:not(.land-unit input[type=checkbox]):checked:after {
  right: 8px;
  bottom: 3px;
  width: 4px;
  height: 22px;
}

.wpcf7 .wpcf7-list-item input[type=radio],
.wpcf7 .land-unit .wpcf7-list-item input[type=checkbox] {
  position: relative;
  border-radius: 50%;
  border: 2px solid #191919;
  background: #fff;
  height: 32px;
  width: 32px;
  vertical-align: -10px;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
}
.wpcf7 .wpcf7-list-item input[type=radio]:before,
.wpcf7 .land-unit .wpcf7-list-item input[type=checkbox]:before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #17773e;
  margin: 5px;
  -webkit-transform: scale(0);
          transform: scale(0);
  -webkit-transition: all ease-out 250ms;
  transition: all ease-out 250ms;
}

.wpcf7 .wpcf7-list-item input[type=radio]:checked,
.wpcf7 .land-unit input[type=checkbox]:checked {
  border: 2px solid #17773e;
}
.wpcf7 .wpcf7-list-item input[type=radio]:checked:before,
.wpcf7 .land-unit input[type=checkbox]:checked:before {
  -webkit-transform: scale(1);
          transform: scale(1);
}

.wpcf7 .wpcf7-list-item input[type=radio] {
  background-color: #fff;
}

.wpcf7 .wpcf7-form-control.vertical .wpcf7-list-item {
  display: block;
}
@media screen and (max-width: 767px) {
  .wpcf7 .wpcf7-form-control.vertical .wpcf7-list-item .wpcf7-list-item-label {
    display: block;
    padding-top: 9px;
    padding-left: 42px;
    min-height: 42px;
    font-size: 1.6rem;
    line-height: 1.4;
  }
}

.wpcf7 .wpcf7-form-control.beside {
  display: block;
  margin-left: -4px;
}
.wpcf7 .wpcf7-form-control.beside .wpcf7-list-item {
  margin: 8px;
}

.wpcf7 .wpcf7-form-control.land-unit {
  margin-left: 16px;
}
@media screen and (max-width: 767px) {
  .wpcf7 .wpcf7-form-control.land-unit {
    margin-left: 8px;
  }
}

.cmn-btn01-wrap {
  margin-top: 40px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .cmn-btn01-wrap {
    margin-top: 24px;
  }
}

.wpcf7 .cmn-btn01 {
  margin: 0 auto;
  width: 280px;
  height: 50px;
}
.wpcf7 .cmn-btn01 input {
  position: relative;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  border-radius: 6px;
  border: 2px solid #191919;
  background-color: #ffcc1a;
  background-image: url("../img/common/base/btn_bg_arrow01_separate.png");
  background-repeat: no-repeat;
  background-size: 189px 7px;
  background-position: top 48% left 50%;
  -webkit-box-shadow: 5px 5px 0 #575757;
          box-shadow: 5px 5px 0 #575757;
  color: #191919;
  font-size: 2rem;
  font-weight: 700;
  font-family: "Noto Sans JP", sans-serif;
  -webkit-transition: top 0.2s ease-in-out, left 0.2s ease-in-out, 0.2s ease-in-out;
  transition: top 0.2s ease-in-out, left 0.2s ease-in-out, 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .wpcf7 .cmn-btn01 input {
    font-family: "Hiragino Kaku Gothic ProN", "Noto Sans JP", "游ゴシック", sans-serif;
  }
}
.wpcf7 .cmn-btn01 input:hover {
  background-color: #ffdb5f;
}
.wpcf7 .cmn-btn01 input:hover:before {
  content: "";
  position: absolute;
  top: -7px;
  left: 0;
  display: block;
  width: 100%;
  height: 5px;
}
.wpcf7 .cmn-btn01 input:hover:after {
  content: "";
  position: absolute;
  top: -7px;
  left: -7px;
  display: block;
  width: 5px;
  height: calc(100% + 7px);
}
.wpcf7 .cmn-btn01 .btn-ttl {
  padding: 0 8px;
  background-color: #ffcc1a;
  color: #191919;
}
.wpcf7 .cmn-btn01 .btn-ttl__jp {
  display: block;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
}

.wpcf7 .wpcf7-spinner {
  position: absolute;
  bottom: -32px;
  left: 50%;
  margin: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.wpcf7 .wpcf7-form-control-wrap[data-name=your-date]:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: inline-block;
  width: 18px;
  height: 20px;
  background-image: url("../img/index/icon_calender01.svg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  pointer-events: none;
}

/* エラー・完了
=========================================== */
.contact-form .wpcf7 span.wpcf7-not-valid-tip {
  margin-top: 4px;
  padding: 4px 4px 6px;
  background-color: #a32929;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 700;
}
.contact-form .wpcf7 span.wpcf7-not-valid-tip:before {
  content: "※";
}

.contact-form .wpcf7 form .wpcf7-response-output {
  margin: 40px 0 0;
  padding: 12px 16px;
  text-align: center;
  border: 2px solid #17773e;
  background-color: #fff;
  color: #17773e;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .contact-form .wpcf7 form .wpcf7-response-output {
    margin: 28px 0 0;
    font-size: 1.6rem;
  }
}

.contact-form .wpcf7 form.sent .wpcf7-response-output {
  border: 2px solid #17773e;
}

.contact-form .wpcf7 form.invalid .wpcf7-response-output,
.contact-form .wpcf7 form.unaccepted .wpcf7-response-output,
.contact-form .wpcf7 form.payment-required .wpcf7-response-output {
  border: 2px solid #a32929;
  color: #a32929;
}
@media screen and (max-width: 767px) {
  .contact-form .wpcf7 form.invalid .wpcf7-response-output,
  .contact-form .wpcf7 form.unaccepted .wpcf7-response-output,
  .contact-form .wpcf7 form.payment-required .wpcf7-response-output {
    text-align: left;
  }
}

.contact-form .wpcf7 form.failed .wpcf7-response-output,
.contact-form .wpcf7 form.aborted .wpcf7-response-output {
  border: 2px solid #a32929;
  color: #a32929;
}
@media screen and (max-width: 767px) {
  .contact-form .wpcf7 form.failed .wpcf7-response-output,
  .contact-form .wpcf7 form.aborted .wpcf7-response-output {
    text-align: left;
  }
}/*# sourceMappingURL=index.min.css.map */