@charset "UTF-8";
/* ------------------------------
    main
------------------------------ */
/* sec_mv */
#sec_mv {
  position: relative;
}
#sec_mv .wrap {
  height: 57.4rem;
}
#sec_mv .inner {
  position: absolute;
  z-index: 2;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
#sec_mv .ttl {
  width: 35.3rem;
  margin: 0 auto;
}
#sec_mv .lang {
  font-size: 1.5rem;
  color: #fff;
  text-align: center;
  margin-top: 3rem;
}
#sec_mv .lang a, #sec_mv .lang span {
  display: inline-block;
  color: #fff;
  font-weight: 400;
}
#sec_mv .lang .current {
  font-weight: 700;
}
#sec_mv .lang .line {
  padding: 0 0.5em;
}
#sec_mv .bg {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
}
#sec_mv .bg img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
  height: 100%;
  min-height: 57.4rem;
}

@media screen and (max-width: 767px) {
  #sec_mv .ttl {
    width: 49.3rem;
  }
  #sec_mv .lang {
    font-size: 2.3rem;
    margin-top: 5rem;
  }
  #sec_mv .bg img {
    min-height: 57.4rem;
  }
}
/* sec_01 */
#sec01 {
  background: url("../img/bg_sec01_pc.jpg") no-repeat center top/cover;
  padding: 9.5rem 0;
}
#sec01 .img {
  width: 59.2rem;
  margin: 0 auto;
}
#sec01 .txt {
  font-size: 1.8rem;
  color: #fff;
  text-align: center;
  line-height: 2.2222222222;
  margin-top: 3rem;
}

@media screen and (max-width: 767px) {
  #sec01 {
    background-image: url("../img/bg_sec01_sp.jpg");
  }
  #sec01 .txt {
    font-size: 2.6rem;
    line-height: 1.9230769231;
  }
}
/* sec_02 */
#sec02 {
  background: #232122 url("../img/bg_sec02.jpg") no-repeat center top/cover;
  padding: 9.5rem 0;
}
#sec02 .sec_ttl {
  margin-bottom: 5.5rem;
}
#sec02 .profile_box {
  gap: 0 6rem;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 5em;
}
#sec02 .profile_box * {
  color: #c6c6c6;
}
#sec02 .inner {
  padding: 0 0.5rem;
}
#sec02 .inner > p {
  color: #fff;
}
#sec02 .img {
  width: 33.6rem;
}
#sec02 .txt_box {
  width: 46rem;
  margin-top: -0.7em;
}
#sec02 .name {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.3333333333;
  margin-bottom: 2.4rem;
  color: #fff;
}
#sec02 .pos {
  position: relative;
  display: inline-block;
  font-size: 1.7rem;
  background: #fff;
  padding: 0.05em 0.6em;
  color: #232121;
  margin-left: 0.6em;
  bottom: 0.2em;
}
#sec02 .subttl {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.3636363636;
  color: #c6c6c6;
  padding-bottom: 0.8rem;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid #c6c6c6;
}
#sec02 .timeline {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}
#sec02 .timeline dt, #sec02 .timeline dd {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
#sec02 .timeline dt {
  width: 7rem;
}
#sec02 .timeline dd {
  width: calc(100% - 8rem);
}
#sec02 .timeline + .subttl {
  margin-top: 2.5rem;
}
#sec02 .btn_youtube {
  margin: 4rem auto 0;
  text-align: center;
}
#sec02 .btn_youtube img {
  width: 60rem;
}
#sec02 .btn_blog {
  margin: 4rem auto 0;
  text-align: center;
}
#sec02 .btn_blog img {
  width: 60rem;
}
#sec02.en .timeline dt, #sec02.en .timeline dd {
  line-height: 1.3333333333;
}
#sec02.en .timeline dt:nth-of-type(n + 2) {
  margin-top: 1.1em;
}
#sec02.en .timeline dd:nth-of-type(n + 2) {
  margin-top: 1.1em;
}
#sec02.en .list li {
  position: relative;
  padding-left: 1em;
  line-height: 1.3333333333;
}
#sec02.en .list li::before {
  position: absolute;
  content: "●";
  left: 0;
  top: 0;
}
#sec02.en .list li + li {
  margin-top: 0.8em;
}
#sec02.en .btn_youtube {
  margin: 6.5rem auto 0;
}

@media screen and (max-width: 767px) {
  #sec02 {
    background-size: 120%;
  }
  #sec02 .profile_box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 6rem 0;
  }
  #sec02 .inner {
    padding: 0;
  }
  #sec02 .txt_box {
    width: 90%;
    margin-top: 0;
  }
  #sec02 .name {
    font-size: 3.6rem;
    margin-bottom: 3rem;
  }
  #sec02 .subttl {
    font-size: 2.8rem;
  }
  #sec02 .timeline {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  #sec02 .timeline dt, #sec02 .timeline dd {
    font-size: 2.4rem;
  }
  #sec02 .timeline dt {
    width: 10rem;
  }
  #sec02 .timeline dd {
    width: calc(100% - 11rem);
  }
  #sec02 .timeline + .subttl {
    margin-top: 2.5rem;
  }
}
/* sec_03 */
#sec03 {
  background: #3e3a39;
  padding: 9.5rem 0;
}
#sec03 .sec_ttl {
  margin-bottom: 5.5rem;
}
#sec03 .price_box {
  margin-top: 5.5rem;
}
#sec03 .price_box .txt01,
#sec03 .price_box .txt02,
#sec03 .price_box .txt03 {
  text-align: center;
  color: #fff;
}
#sec03 .price_box .txt01 {
  font-size: 2rem;
  line-height: 2;
  font-weight: 700;
}
#sec03 .price_box .txt02 {
  font-size: 1.4rem;
  line-height: 2.8571428571;
  font-weight: 700;
  margin: 0.4rem auto 3.6rem;
}
#sec03 .price_box .txt03 {
  font-size: 1.6rem;
  line-height: 1.875;
}
#sec03 .price_num {
  position: relative;
  font-size: 4.6rem;
  font-weight: 700;
  line-height: 1.7391304348;
  color: #fff;
  margin-bottom: 2.4rem;
  text-align: center;
}
#sec03 .price_num::before {
  position: absolute;
  content: "";
  width: 39.6rem;
  height: 1px;
  background: #fff;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 0;
}
#sec03 .price_num .tag {
  position: relative;
  display: inline-block;
  font-size: 2.4rem;
  background: #fff;
  line-height: 1.35;
  padding: 0 0.6em 0.1em 0.6em;
  color: #3e3a39;
  margin-right: 0.9em;
  bottom: 0.4em;
}
#sec03 .price_num .sm {
  display: inline-block;
  font-size: 0.68em;
  margin-left: 0.4em;
}
#sec03 .btn {
  margin-top: 6rem;
}
#sec03 .slider_box {
  display: none;
}
#sec03 .slider_box .item {
  width: 88rem;
  height: 58rem;
  background: #e2e2e2;
  border-radius: 1rem;
  padding: 3rem 5rem 0;
  display: -webkit-box !important;
  display: -webkit-flex !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
}
#sec03 .slider_box .thumb {
  width: 78rem;
  height: auto;
  aspect-ratio: 1560/786;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
}
#sec03 .slider_box .thumb img {
  width: 100%;
  height: auto;
}
#sec03 .slider_box .txt {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  min-height: 10rem;
}
#sec03 .slider_box .txt p {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 2.2222222222;
  text-align: center;
}
#sec03 .slider_box.slick-initialized {
  display: block;
}
#sec03 .slider_box .slick-track {
  display: -webkit-box !important;
  display: -webkit-flex !important;
  display: -ms-flexbox !important;
  display: flex !important;
  gap: 0 5rem;
}
#sec03 .slider_box .slide-arrow {
  position: absolute;
  background: url("../img/arrow_slider.svg") no-repeat center center/contain;
  width: 2.4rem;
  height: 4.1rem;
  top: calc((100% - 12rem) / 2);
  margin: auto;
  z-index: 2;
}
#sec03 .slider_box .prev-arrow {
  left: -5rem;
  -webkit-transform: rotate(-180deg);
          transform: rotate(-180deg);
}
#sec03 .slider_box .next-arrow {
  right: -5rem;
}
#sec03 .slider_box button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}
#sec03 .slider_box .slide-dots {
  margin: 2.4rem auto 0;
  text-align: center;
}
#sec03 .slider_box .slide-dots li {
  display: inline-block;
  margin: 0 2rem;
}
#sec03 .slider_box .slide-dots li button {
  position: relative;
  text-indent: -9999px;
}
#sec03 .slider_box .slide-dots li button:before {
  content: "";
  background: #9e9e9f;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
}
#sec03 .slider_box .slide-dots li.slick-active button:before {
  content: "";
  background: #fff;
}
#sec03.en .price_num::before {
  width: 47.5rem;
}
#sec03.en .price_num .tag {
  padding: 0 0.4em 0.1em 0.4em;
  margin-right: 0.7em;
}

@media screen and (max-width: 767px) {
  #sec03 .price_box {
    margin-top: 5.5rem;
  }
  #sec03 .price_box .txt01 {
    font-size: 2.8rem;
  }
  #sec03 .price_box .txt02 {
    font-size: 2.2rem;
    line-height: 1.75;
    margin: 0.4rem auto 3.6rem;
  }
  #sec03 .price_box .txt03 {
    font-size: 2.6rem;
    line-height: 1.75;
  }
  #sec03 .price_num {
    font-size: 6rem;
  }
  #sec03 .price_num::before {
    width: 53rem;
  }
  #sec03 .price_num .tag {
    font-size: 2.8rem;
  }
  #sec03 .price_num .sm {
    font-size: 0.8em;
  }
  #sec03 .slider_box .item {
    width: 67rem;
    height: auto;
    padding: 3rem 3rem;
  }
  #sec03 .slider_box .thumb {
    width: 61rem;
  }
  #sec03 .slider_box .txt {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-top: 3rem;
  }
  #sec03 .slider_box .txt p {
    font-size: 2.4rem;
    line-height: 1.75;
  }
  #sec03 .slider_box .slick-track {
    display: -webkit-box !important;
    display: -webkit-flex !important;
    display: -ms-flexbox !important;
    display: flex !important;
    gap: 0 3rem;
  }
  #sec03 .slider_box .slide-arrow {
    width: 2rem;
    height: 3.6rem;
    top: calc((100% - 12rem) / 2);
  }
  #sec03 .slider_box .prev-arrow {
    left: -3rem;
    -webkit-transform: rotate(-180deg);
            transform: rotate(-180deg);
  }
  #sec03 .slider_box .next-arrow {
    right: -3rem;
  }
  #sec03 .slider_box .slide-dots li button:before {
    width: 1.6rem;
    height: 1.6rem;
  }
  #sec03.en .price_num {
    font-size: 5.8rem;
  }
  #sec03.en .price_num::before {
    width: 60rem;
  }
}
/* sec_04 */
#sec04 {
  background: #232121;
  padding: 9.5rem 0 10rem;
  overflow: hidden;
}
#sec04 .sec_ttl {
  margin-bottom: 5.5rem;
}
#sec04 .lead {
  margin-bottom: 6rem;
}
#sec04 .lead p {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 2.2222222222;
  color: #fff;
  text-align: center;
}
#sec04 .box {
  background: #3e3a39;
  border-radius: 1rem;
  padding: 3rem 0 3.5rem;
}
#sec04 .box + .box {
  margin-top: 4.2rem;
}
#sec04 .box > p {
  text-align: center;
  color: #fff;
}
#sec04 .subttl {
  color: #fff;
  font-weight: 700;
  font-size: 3rem;
  line-height: 1.6666666667;
  margin-bottom: 2.8rem;
}
#sec04 .img_wrap {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 2rem;
  margin-top: 4rem;
  padding-bottom: 0.6rem;
}
#sec04 .img_wrap .img {
  width: 25rem;
}
#sec04 .img_wrap .img figcaption {
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  padding-top: 1.5rem;
}
#sec04 .movie_wrap {
  text-align: center;
  margin-top: 4rem;
}
#sec04 .movie_wrap iframe {
  border: 0;
  width: 100%;
  height: 100%;
  max-width: 52rem;
  aspect-ratio: 52/29;
  margin: 0 auto;
}
#sec04 .movie_wrap .caption {
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  padding-top: 1rem;
}
#sec04 .movie_wrap .caption + iframe {
  margin-top: 3.5rem;
}
#sec04 .btn {
  margin-top: 3rem;
  padding-bottom: 0.5rem;
}
#sec04.en .lead {
  width: calc(100% + 14.8rem);
  margin-left: -7.4rem;
  margin-right: -7.4rem;
}

@media screen and (max-width: 767px) {
  #sec04 {
    padding-bottom: 9.5rem;
  }
  #sec04 .lead {
    margin-bottom: 5rem;
  }
  #sec04 .lead p {
    font-size: 2.6rem;
  }
  #sec04 .subttl {
    font-size: 3.2rem;
  }
  #sec04 .img_wrap .img figcaption {
    font-size: 2.2rem;
  }
  #sec04 .movie_wrap iframe {
    max-width: 60rem;
  }
  #sec04 .movie_wrap .caption {
    font-size: 2.2rem;
  }
  #sec04 .btn {
    margin-top: 4rem;
  }
}
/* sec_05 */
#sec05 {
  background: #3e3a39;
  padding: 9.5rem 0 10rem;
}
#sec05 .wrap {
  max-width: 100rem;
}
#sec05 .lead {
  margin-bottom: 6rem;
}
#sec05 .lead .txt01 {
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
}
#sec05 .lead .txt02 {
  color: #fff;
  text-align: center;
  margin-top: 2.4rem;
}
#sec05 .access {
  display: grid;
  grid-template-columns: 56rem 1fr;
  grid-template-rows: auto auto;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 4rem;
  grid-template-areas: "map txt" "map btn";
}
#sec05 .access .map {
  grid-area: map;
  width: 56rem;
}
#sec05 .access .map iframe {
  border: 0;
  width: 100%;
  height: 100%;
  aspect-ratio: 560/347;
}
#sec05 .access .txt {
  grid-area: txt;
}
#sec05 .access .txt * {
  color: #fff;
}
#sec05 .access .txt .name {
  font-size: 3rem;
  margin-bottom: 1.4rem;
  font-weight: 700;
}
#sec05 .access .btn_area {
  grid-area: btn;
}
#sec05 .access .btn_area .btn + .btn {
  margin-top: 1rem;
}

@media screen and (max-width: 767px) {
  #sec05 {
    padding-bottom: 9.5rem;
  }
  #sec05 .wrap {
    max-width: inherit;
  }
  #sec05 .lead {
    margin-bottom: 8rem;
  }
  #sec05 .lead .txt01 {
    font-size: 2.8rem;
  }
  #sec05 .access {
    grid-template-columns: 100%;
    grid-template-rows: auto auto auto;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 4rem 0;
    grid-template-areas: "txt" "map" "btn";
  }
  #sec05 .access .map {
    width: 63.6rem;
    margin: 0 auto;
  }
  #sec05 .access .txt {
    width: 63.6rem;
    margin: 0 auto;
  }
  #sec05 .access .txt .name {
    font-size: 3.2rem;
  }
  #sec05 .access .btn_area .btn + .btn {
    margin-top: 3.3rem;
  }
}
/*# sourceMappingURL=index.css.map */