@charset "UTF-8";
/*　*/
/* ===== base ===== */
.l-contents {
  padding-top: 0;
}
@media only screen and (max-width: 767px) {
  .l-contents {
    padding-top: 7.5rem;
  }
}

.l-contents_container {
  padding-top: 0;
  padding-bottom: 0;
}

/* ===== gnav(TOP限定の動き用) ===== */
.l-gnav {
  transition: opacity 0.6s ease, visibility 0.6s ease;
}
.l-gnav.is-absolute {
  position: absolute;
  z-index: 1000;
  opacity: 1;
  visibility: visible;
}
.l-gnav.is-absolute .l-gnav_container {
  opacity: 1;
  visibility: visible;
  order: 2;
  height: 8.8rem;
}
@media print, screen and (min-width: 768px) {
  .l-gnav.is-absolute .l-gnav_container .l-gnav_outer {
    padding: 0 4rem;
  }
}
.l-gnav.is-absolute .l-gnav_container .l-gnav_outer:before {
  width: 100%;
}
.l-gnav.is-absolute.is-hidden {
  opacity: 0;
  visibility: hidden;
}
@media print, screen and (min-width: 768px) {
  .l-gnav_btnOpen {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.6s ease, visibility 0.6s ease;
  }
}
@media only screen and (max-width: 767px) {
  .l-gnav_btnOpen {
    position: fixed;
  }
}

/* ===== MV ===== */
.mv_sec {
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 767px) {
  .mv_sec {
    padding-bottom: 136.537%;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec {
    margin-bottom: 3rem;
    max-height: calc(100vh - 2rem);
    padding-bottom: 50.1%;
  }
}
.mv_container {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  .mv_container {
    width: 88.3854166667%;
  }
}
.mv_img {
  width: 100%;
  height: 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background: #fff;
  z-index: 10;
  -webkit-mask-image: url(../img/top/mv_mask_sp.svg);
  mask-image: url(../img/top/mv_mask_sp.svg);
  -webkit-mask-size: cover;
  mask-size: cover;
}
@media print, screen and (min-width: 768px) {
  .mv_img {
    -webkit-mask-image: url(../img/top/mv_mask.svg);
    mask-image: url(../img/top/mv_mask.svg);
    -webkit-mask-size: contain;
    mask-size: contain;
  }
}
.mv_ttl {
  position: absolute;
  margin: 0;
  padding: 0;
  border: 0;
  width: 1px;
  height: 1px;
  white-space: nowrap;
  clip: rect(0, 0, 0, 0);
  overflow: hidden;
}
.mv_inner {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 30;
}
.mv_img .m-img01 {
  padding-bottom: 136.537%;
}
@media print, screen and (min-width: 768px) {
  .mv_img .m-img01 {
    padding-bottom: 56.689%;
  }
}
.mv_img .m-img01 img {
  pointer-events: none;
}
.mv_img_wrap {
  position: relative;
  z-index: 10;
}
.mv_sec .swiper-container-fade .swiper-slide {
  opacity: 0 !important;
}
.mv_sec .swiper-container-fade .swiper-slide.swiper-slide-active {
  opacity: 1 !important;
}
.mv_sec .mv_anime_box .mv-anime {
  position: absolute;
  z-index: -1;
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime01 {
    background: url(../img/top/mark-mv01.png) no-repeat;
    background-size: contain;
    width: 3.6458333333vw;
    height: 8.0729166667vw;
    bottom: 15.1041666667vw;
    left: 2.6041666667vw;
    animation: floating-y4 8s ease-in-out infinite alternate-reverse;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime01 {
    background: url(../img/top/mark-mv01_sp.png) no-repeat;
    background-size: contain;
    width: 4.5rem;
    height: 4.5rem;
    top: 0;
    left: 1rem;
    animation: floating-y3 5s ease-in-out infinite alternate-reverse;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime02 {
    background: url(../img/top/mark-mv02.png) no-repeat;
    background-size: contain;
    width: 2.34375vw;
    height: 2.34375vw;
    bottom: 6.25vw;
    left: 1.0416666667vw;
    animation: scale 5s linear infinite;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime02 {
    background: url(../img/top/mark-mv02_sp.png) no-repeat;
    background-size: contain;
    width: 1.6rem;
    height: 1.6rem;
    top: 0;
    right: 1rem;
    animation: floating-y2 2s ease-in-out infinite alternate-reverse;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime03 {
    background: url(../img/top/mark-mv03.png) no-repeat;
    background-size: contain;
    width: 5.7291666667vw;
    height: 10vw;
    top: 11.9791666667vw;
    left: 10.4166666667vw;
    animation: floating-y4 7s ease-in-out infinite alternate-reverse;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime03 {
    background: url(../img/top/mark-mv03_sp.png) no-repeat;
    background-size: contain;
    width: 1.2rem;
    height: 1.4rem;
    top: -4rem;
    left: 9rem;
    animation: rotate2 10s linear infinite;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime04 {
    background: url(../img/top/mark-mv04.png) no-repeat;
    background-size: contain;
    width: 2.5vw;
    height: 2.5520833333vw;
    top: 11.9791666667vw;
    left: 2.6041666667vw;
    animation: floating-y4 3s ease-in-out infinite alternate-reverse;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime04 {
    background: url(../img/top/mark-mv04_sp.png) no-repeat;
    background-size: contain;
    width: 1.4rem;
    height: 1.4rem;
    top: -6rem;
    left: 3rem;
    animation: floating-y3 1.8s ease-in-out infinite alternate-reverse;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime05 {
    background: url(../img/top/mark-mv05.png) no-repeat;
    background-size: contain;
    width: 1.5625vw;
    height: 1.5625vw;
    top: 6.25vw;
    left: 19.7916666667vw;
    animation: scale 5s linear infinite;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime05 {
    background: url(../img/top/mark-mv05_sp.png) no-repeat;
    background-size: contain;
    width: 1.5rem;
    height: 1.5rem;
    top: -6rem;
    right: 8rem;
    animation: floating-y1 2s ease-in-out infinite alternate-reverse;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime06 {
    background: url(../img/top/mark-mv06.png) no-repeat;
    background-size: contain;
    width: 1.4583333333vw;
    height: 1.6666666667vw;
    top: 1.5625vw;
    left: 23.4375vw;
    animation: floating-y1 4s ease-in-out infinite alternate-reverse;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime06 {
    display: none;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime07 {
    background: url(../img/top/mark-mv07.png) no-repeat;
    background-size: contain;
    width: 2.8125vw;
    height: 3.125vw;
    bottom: 2.0833333333vw;
    z-index: 1;
    left: 10.4166666667vw;
    animation: rotate2 8s linear infinite;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime07 {
    display: none;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime08 {
    background: url(../img/top/mark-mv07.png) no-repeat;
    background-size: contain;
    width: 1.6666666667vw;
    height: 1.6666666667vw;
    top: 6.25vw;
    left: 10.4166666667vw;
    animation: rotate2 10s linear infinite;
  }
}
@media only screen and (max-width: 767px) {
  .mv_sec .mv_anime_box .mv-anime.mv-anime08 {
    display: none;
  }
}
.mv_copy {
  position: absolute;
  height: auto;
}
@media print, screen and (min-width: 768px) {
  .mv_copy {
    writing-mode: vertical-rl;
    text-orientation: upright;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 4.1666666667vw;
  }
}
@media only screen and (max-width: 767px) {
  .mv_copy {
    bottom: -2.5rem;
    max-width: calc(100% - 4rem);
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media print, screen and (min-width: 768px) {
  .mv_copy .mv_copy_inner {
    display: flex;
  }
}
.mv_copy .mv-copy_txt {
  background: #fff;
  display: inline-block;
  white-space: nowrap;
  font-weight: 500;
  line-height: 1.7;
}
@media only screen and (max-width: 767px) {
  .mv_copy .mv-copy_txt {
    border-radius: 0.4rem;
    padding: 0.8rem 0 0.8rem 1.2rem;
    font-size: 2.2rem;
    letter-spacing: 0.3rem;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_copy .mv-copy_txt {
    font-size: 2.0833333333vw;
    border-radius: 1.2rem;
    padding: 2rem 1.4rem 0;
    letter-spacing: 0.5rem;
  }
}
@media print, screen and (min-width: 768px) {
  .mv_copy .mv-copy_txt02 {
    margin-right: 0.625vw;
    margin-top: 8.75vw;
  }
}

/* ===== about ===== */
.about_sec {
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .about_sec {
    padding-top: 9.6rem;
  }
}
@media only screen and (max-width: 767px) {
  .about_sec {
    padding-top: 8.5rem;
  }
}
.about_sec .m-sec01_container {
  display: flex;
  width: 100%;
  max-width: none;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .about_sec .m-sec01_container {
    flex-wrap: wrap;
    width: calc(100% - 4rem);
    margin: 0 auto;
    padding: 0;
  }
}
@media print, screen and (min-width: 768px) {
  .about_sec .m-sec01_container {
    padding: 0 4rem 0 0;
  }
}
.about_sec .m-sec01_container .about_img {
  width: 100%;
  height: 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background: #fff;
  z-index: 10;
  -webkit-mask-image: url(../img/top/about_mask_sp.png);
  mask-image: url(../img/top/about_mask_sp.png);
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}
@media print, screen and (min-width: 768px) {
  .about_sec .m-sec01_container .about_img {
    -webkit-mask-image: url(../img/top/about_mask.png);
    mask-image: url(../img/top/about_mask.png);
  }
}
.about_sec .m-sec01_container .about_img_inner {
  display: block;
  position: relative;
  padding-bottom: 82.5%;
  width: 100%;
  height: 0;
  background: transparent;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .about_sec .m-sec01_container .about_img_inner {
    padding-bottom: 64%;
  }
}
.about_sec .m-sec01_container .about_img_inner img {
  width: 100%;
}
.about_sec .m-sec01_container .about_box {
  position: relative;
  flex: 1;
}
@media only screen and (max-width: 767px) {
  .about_sec .m-sec01_container .about_box {
    order: 2;
    margin-top: 3rem;
  }
}
.about_sec .m-sec01_container .about_box .mark_nanairo {
  position: absolute;
  bottom: -2.8rem;
  right: 0;
  width: 60.2rem;
  height: 8.1rem;
  z-index: 1;
  background: transparent url(../img/common/mark-nanairo.svg) 50% 50% no-repeat;
  background-size: contain;
  content: "";
}
@media only screen and (max-width: 767px) {
  .about_sec .m-sec01_container .about_box .mark_nanairo {
    width: 20.4rem;
    height: 2.75rem;
    bottom: -1.5rem;
  }
}
@media print, screen and (min-width: 768px) {
  .about_sec .m-sec01_container .about_txt {
    margin-left: 7.5rem;
    flex: 1;
  }
}
.about_sec .m-sec01_container .about_txt p {
  letter-spacing: 0.1rem;
  line-height: 2.4;
  font-size: 1.25vw;
}
@media only screen and (min-width: 2200px) {
  .about_sec .m-sec01_container .about_txt p {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 767px) {
  .about_sec .m-sec01_container .about_txt p {
    text-align: center;
    font-size: 1.4rem;
  }
}
@media only screen and (min-width: 2200px) {
  .about_sec .m-sec01_container .about_txt p br.only-pc {
    display: none;
  }
}

.about_anime_box .about-anime {
  position: absolute;
  z-index: -1;
}
.about_anime_box .about-anime.about-anime01 {
  background: url(../img/top/mark-about01.png) no-repeat;
  background-size: contain;
  animation: floating-y1 3s ease-in-out infinite alternate-reverse;
}
@media print, screen and (min-width: 768px) {
  .about_anime_box .about-anime.about-anime01 {
    width: 2.5vw;
    height: 2.5520833333vw;
    top: 1.0416666667vw;
    right: 9.375vw;
  }
}
@media only screen and (max-width: 767px) {
  .about_anime_box .about-anime.about-anime01 {
    width: 1.3rem;
    height: 1.4rem;
    top: 4rem;
    right: 6.8rem;
  }
}
.about_anime_box .about-anime.about-anime02 {
  background: url(../img/top/mark-about02.png) no-repeat;
  background-size: contain;
}
@media print, screen and (min-width: 768px) {
  .about_anime_box .about-anime.about-anime02 {
    width: 1.4583333333vw;
    height: 1.6666666667vw;
    top: 0;
    right: 3.6458333333vw;
    animation: rotate1 8s linear infinite;
  }
}
@media only screen and (max-width: 767px) {
  .about_anime_box .about-anime.about-anime02 {
    width: 1rem;
    height: 2rem;
    top: 2rem;
    right: 2rem;
    animation: floating-y2 3s ease-in-out infinite alternate-reverse;
  }
}
.about_anime_box .about-anime.about-anime03 {
  background: url(../img/top/mark-about03.png) no-repeat;
  background-size: contain;
  animation: floating-y3 1.5s ease-in-out infinite alternate-reverse;
}
@media print, screen and (min-width: 768px) {
  .about_anime_box .about-anime.about-anime03 {
    width: 1.5625vw;
    height: 1.5625vw;
    top: 5.7291666667vw;
    right: 3.6458333333vw;
  }
}
@media only screen and (max-width: 767px) {
  .about_anime_box .about-anime.about-anime03 {
    width: 1.5rem;
    height: 1.5rem;
    top: 7rem;
    right: 2rem;
  }
}

/* ===== features ===== */
@media print, screen and (min-width: 768px) {
  #features.features_sec {
    margin-top: 23rem;
  }
}
@media only screen and (max-width: 767px) {
  #features.features_sec {
    margin-top: 11.5rem;
  }
}
#features .m-sec01_container {
  max-width: 184rem;
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container {
    padding: 0;
  }
}
#features .m-sec01_container .features_box01_list {
  position: relative;
  z-index: 30;
  border-radius: 2rem;
  overflow: hidden;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list {
    -webkit-writing-mode: vertical-lr;
    -ms-writing-mode: rl-tb;
    writing-mode: vertical-lr;
    text-orientation: upright;
    border-radius: 4rem;
  }
}
#features .m-sec01_container .features_box01_list > li {
  position: relative;
}
#features .m-sec01_container .features_box01_list > li .features_box01_ttl {
  position: relative;
  padding: 1rem 0;
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  cursor: pointer;
  transition: color 0.3s;
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl {
    text-align: center;
    display: flex;
    align-items: center;
    width: 100%;
    padding: 0.5rem 2rem;
    font-size: 2rem;
  }
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl {
    padding: 4.5rem 0 0 0;
    font-size: 3.9rem;
  }
}
#features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_number {
  margin-right: 0.8rem;
  padding-right: 0.8rem;
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_number {
    margin-bottom: 2.8rem;
    padding-bottom: 2.8rem;
  }
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_number {
    display: flex;
  }
}
#features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_number:before {
  content: "";
  display: inline-block;
  width: 2rem;
  height: 2.4rem;
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_number:before {
    width: 2.7rem;
    height: 4.4rem;
  }
}
#features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon {
  position: absolute;
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 2rem;
  }
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon {
    bottom: 5rem;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }
}
#features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon:before {
  content: "";
  border: 2px solid;
  border-radius: 50%;
  display: inline-block;
  width: 2.8rem;
  height: 2.8rem;
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon:before {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
  }
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon:before {
    width: 6.8rem;
    height: 6.8rem;
  }
}
#features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon:after {
  width: 1.7rem;
  height: 1.7rem;
  content: "";
  display: inline-block;
  position: absolute;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.5rem;
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_ttl .features_box01_icon:after {
    width: 3.2rem;
    height: 3.2rem;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
#features .m-sec01_container .features_box01_list > li:nth-of-type(odd) .features_box01_ttl {
  background: #FFA826;
  color: #fff;
}
#features .m-sec01_container .features_box01_list > li:nth-of-type(odd) .features_box01_ttl .features_box01_icon:after {
  background: transparent url(../img/common/icon_plus_w.svg) 50% 50% no-repeat;
  background-size: contain;
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container .features_box01_list > li:nth-of-type(odd) .features_box01_number {
    border-right: 2px dotted #fff;
  }
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li:nth-of-type(odd) .features_box01_number {
    border-bottom: 3px dotted #fff;
  }
}
#features .m-sec01_container .features_box01_list > li:nth-of-type(even) .features_box01_ttl {
  color: #FFA826;
  background: #fff;
}
#features .m-sec01_container .features_box01_list > li:nth-of-type(even) .features_box01_ttl .features_box01_icon:after {
  background: transparent url(../img/common/icon_plus_o.svg) 50% 50% no-repeat;
  background-size: contain;
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container .features_box01_list > li:nth-of-type(even) .features_box01_number {
    border-right: 2px dotted #FFA826;
  }
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li:nth-of-type(even) .features_box01_number {
    border-bottom: 3px dotted #FFA826;
  }
}
#features .m-sec01_container .features_box01_list > li:first-of-type .features_box01_number:before {
  background: url(../img/top/icon_number1.svg) 50% 50% no-repeat;
  background-size: contain;
}
#features .m-sec01_container .features_box01_list > li:nth-of-type(2) .features_box01_number:before {
  background: url(../img/top/icon_number2.svg) 50% 50% no-repeat;
  background-size: contain;
}
#features .m-sec01_container .features_box01_list > li:nth-of-type(3) .features_box01_number:before {
  background: url(../img/top/icon_number3.svg) 50% 50% no-repeat;
  background-size: contain;
}
#features .m-sec01_container .features_box01_list > li:nth-of-type(4) .features_box01_number:before {
  background: url(../img/top/icon_number4.svg) 50% 50% no-repeat;
  background-size: contain;
}
#features .m-sec01_container .features_box01_list > li .features_box01_inner {
  position: relative;
  overflow: hidden;
}
#features .m-sec01_container .features_box01_list > li .features_box01_inner .features_box01_txt {
  -webkit-writing-mode: horizontal-tb;
  -ms-writing-mode: lr-tb;
  writing-mode: horizontal-tb;
  text-orientation: mixed;
  position: absolute;
  background: #fff;
  border-radius: 0.8rem;
  bottom: 1rem;
  left: 1rem;
  padding: 1rem;
  font-size: 1.2rem;
}
@media only screen and (max-width: 767px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_inner .features_box01_txt {
    width: calc(100% - 2rem);
  }
}
@media print, screen and (min-width: 768px) {
  #features .m-sec01_container .features_box01_list > li .features_box01_inner .features_box01_txt {
    border-radius: 1.2rem;
    bottom: 2rem;
    left: 2rem;
    padding: 4rem;
    line-height: 2.2;
    font-size: 1.6rem;
    max-width: 62.4rem;
  }
}

.features_img_inner {
  width: 100%;
}
.features_img_inner img {
  width: 100%;
}

.features_box01_outer {
  display: grid;
  opacity: 0;
  visibility: hidden;
  grid-template-rows: 0fr;
  transition: padding 0.5s cubic-bezier(0.215, 0.61, 0.355, 1), opacity 0.7s, visibility 0.7s;
  transition: padding 0.5s cubic-bezier(0.215, 0.61, 0.355, 1), opacity 0.7s, visibility 0.7s, -ms-grid-rows 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
}
@media print, screen and (min-width: 768px) {
  .features_box01_outer {
    width: calc(100% - 7.6rem);
  }
}

@media print, screen and (min-width: 768px) {
  .is-features1 .features_box01 li.features1 {
    width: calc(100% - 25.8rem);
  }
}
.is-features1 .features_box01 li.features1 .features_box01_outer {
  opacity: 1;
  visibility: visible;
  grid-template-rows: 1fr;
}
.is-features1 .features_box01 li.features1 .features_box01_ttl .features_box01_icon:after {
  background: transparent url(../img/common/icon_minus_w.svg) 50% 50% no-repeat !important;
  background-size: contain;
  transition: 0.3s;
}

@media print, screen and (min-width: 768px) {
  .is-features2 .features_box01 li.features2 {
    width: calc(100% - 25.8rem);
  }
}
.is-features2 .features_box01 li.features2 .features_box01_outer {
  opacity: 1;
  visibility: visible;
  grid-template-rows: 1fr;
}
.is-features2 .features_box01 li.features2 .features_box01_ttl .features_box01_icon:after {
  background: transparent url(../img/common/icon_minus_o.svg) 50% 50% no-repeat !important;
  background-size: contain;
  transition: 0.3s;
}

@media print, screen and (min-width: 768px) {
  .is-features3 .features_box01 li.features3 {
    width: calc(100% - 25.8rem);
  }
}
.is-features3 .features_box01 li.features3 .features_box01_outer {
  opacity: 1;
  visibility: visible;
  grid-template-rows: 1fr;
}
.is-features3 .features_box01 li.features3 .features_box01_ttl .features_box01_icon:after {
  background: transparent url(../img/common/icon_minus_w.svg) 50% 50% no-repeat !important;
  background-size: contain;
  transition: 0.3s;
}

@media print, screen and (min-width: 768px) {
  .is-features4 .features_box01 li.features4 {
    width: calc(100% - 25.8rem);
  }
}
.is-features4 .features_box01 li.features4 .features_box01_outer {
  opacity: 1;
  visibility: visible;
  grid-template-rows: 1fr;
}
.is-features4 .features_box01 li.features4 .features_box01_ttl .features_box01_icon:after {
  background: transparent url(../img/common/icon_minus_o.svg) 50% 50% no-repeat !important;
  background-size: contain;
  transition: 0.3s;
}

/* ===== daily ===== */
@media print, screen and (min-width: 768px) {
  .daily_sec {
    margin-top: 18rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec {
    margin-top: 8rem;
  }
}
.daily_sec #daily_tab .m-listTab01 {
  display: flex;
  justify-content: center;
}
.daily_sec #daily_tab .m-listTab01 li {
  width: calc(50% - 0.8rem);
}
@media print, screen and (min-width: 768px) {
  .daily_sec #daily_tab .m-listTab01 li {
    width: calc(50% - 20rem);
    max-width: 38rem;
  }
}
.daily_sec #daily_tab .m-listTab01 li:first-of-type {
  margin-right: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec #daily_tab .m-listTab01 li:first-of-type {
    margin-right: 4rem;
  }
}
.daily_sec #daily_tab .m-listTab01 li.is-active a {
  background: #2FC4BB;
  color: #fff;
}
.daily_sec #daily_tab .m-listTab01 li a {
  border: none;
  color: #262116;
  font-size: 1.8rem;
  font-weight: bold;
  width: 100%;
  padding: 1rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec #daily_tab .m-listTab01 li a {
    font-size: 3.6rem;
    padding: 3rem 1rem;
    border-radius: 8rem;
  }
}
@media (hover: hover) {
  .daily_sec #daily_tab .m-listTab01 li a:hover {
    background: #2FC4BB;
    color: #fff;
  }
}
.daily_sec .schedule-timetable_container {
  margin-top: 4rem;
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container {
    margin-top: 12rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule {
  display: flex;
  align-items: flex-start;
  margin-top: 3rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule {
    margin-top: 7rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule:before {
  content: "";
  background: #FFA826;
  width: 0.4rem;
  display: inline-block;
  position: absolute;
  left: 8rem;
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule:before {
    width: 0.2rem;
    left: 3.4rem;
    top: 1rem;
    height: calc(100% - 2rem);
  }
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule:before {
    height: 39rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule:last-of-type:before {
  display: none;
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .time {
  position: relative;
  margin-right: 1.7rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .time {
    margin-right: 5rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .time span {
  background: #FFA826;
  color: #fff;
  font-weight: bold;
  border-radius: 0.8rem;
  text-align: center;
  font-size: 1.4rem;
  letter-spacing: -0.5rem;
  display: inline-block;
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .time span {
    width: 6.7rem;
    padding: 0.6rem;
    line-height: 1.5;
  }
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .time span {
    padding: 1rem;
    border-radius: 1.2rem;
    font-size: 2.8rem;
    min-width: 14rem;
    line-height: 1.7;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .time:after {
  content: "";
  border-top: 0.5rem dotted #DFDBD0;
  width: 5rem;
  display: inline-block;
  position: absolute;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .time:after {
    width: 1.7rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule:first-of-type, .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule:last-of-type {
  margin-top: 0;
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .schedule-box {
  padding: 0 1rem;
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .schedule-box h6 {
  font-size: 1.6rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .schedule-box h6 {
    font-size: 2.8rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .schedule-box .schedule-list {
  font-size: 1.3rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .schedule .schedule-box .schedule-list {
    font-size: 1.8rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .extend {
  position: relative;
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .extend .schedule-box:after {
  background: #F2F0E8;
  content: "";
  position: absolute;
  height: 100%;
  z-index: -1;
  top: 3.5rem;
  left: 8rem;
  border-radius: 0 1.2rem 1.2rem 0;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend .schedule-box:after {
    width: 62.7rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend .schedule-box:after {
    top: 2rem;
    left: 3.3rem;
    width: 100%;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl {
  margin: 7.6rem 0;
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dt {
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dt {
    font-size: 2.4rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list {
  display: flex;
  margin-bottom: 0.8rem;
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list {
    flex-direction: column;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list .extend-info {
  background: #fff;
  border-radius: 0.4rem;
  padding: 0.4rem 1rem;
  line-height: 1.5;
  letter-spacing: 0;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list .extend-info {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list .extend-info {
    padding: 0.4rem 0.8rem;
    font-size: 1.3rem;
  }
}
.daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list .extend-info .extend-ttl {
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
  width: 8em;
  display: inline-block;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list li:first-of-type {
    margin-right: 0.8rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule-timetable_inner .extend dl dd .extend-info_list li:first-of-type {
    margin-bottom: 0.4rem;
  }
}
.daily_sec .schedule-timetable_container .schedule_img_box {
  position: absolute;
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box {
    width: 11.4rem;
    height: 7.6rem;
  }
}
.daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box01 {
  top: 0.8rem;
  right: -2rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box01 {
    width: 30rem;
    height: 20rem;
    top: -5rem;
    right: 35.3rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box01 img {
    border-radius: 0.8rem 0 0 0.8rem;
  }
}
.daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box02 {
  top: 31rem;
  right: -2rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box02 {
    width: 41.2rem;
    height: 27.4rem;
    top: 17.5rem;
    right: -10.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box02 img {
    border-radius: 0.8rem 0 0 0.8rem;
  }
}
.daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box03 {
  top: 39.5rem;
  right: 6rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box03 {
    width: 34.4rem;
    height: 22.9rem;
    top: 45.8rem;
    right: 46.3rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box03 img {
    border-radius: 0.8rem;
  }
}
.daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box04 {
  top: 48.5rem;
  right: -2rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box04 {
    width: 38.1rem;
    height: 25.4rem;
    top: 69.7rem;
    right: -5rem;
  }
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box04 img {
    border-radius: 0.8rem 0 0 0.8rem;
  }
}
.daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box05 {
  bottom: -3.5rem;
  right: -2rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .schedule-timetable_container .schedule_img_box.schedule_img_box05 {
    width: 38.2rem;
    height: 25.5rem;
    bottom: 2.5rem;
    right: 18rem;
  }
}
.daily_sec .schedule-timetable_container .schedule_img_box img {
  border-radius: 2rem;
}
@media only screen and (max-width: 767px) {
  .daily_sec .schedule-timetable_container .schedule_img_box img {
    border-radius: 0.8rem 0 0 0.8rem;
  }
}
.daily_sec .events-list_container .events-list_inner {
  display: flex;
  margin-top: 6rem;
}
@media only screen and (max-width: 767px) {
  .daily_sec .events-list_container .events-list_inner {
    flex-wrap: wrap;
    margin-top: 5rem;
  }
}
@media print, screen and (min-width: 768px) {
  .daily_sec .events-list_container .events-list_inner .events-list {
    width: calc(50% - 2rem);
  }
}
@media print, screen and (min-width: 768px) {
  .daily_sec .events-list_container .events-list_inner .events-list:first-of-type {
    margin-right: 4rem;
  }
}
.daily_sec .events-list_container .events-list_inner .events-list .events {
  display: flex;
  align-items: flex-start;
  margin-bottom: 2.4rem;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .events-list_container .events-list_inner .events-list .events {
    align-items: center;
  }
}
.daily_sec .events-list_container .events-list_inner .events-list .events .events_ttl {
  color: #FFA826;
  font-weight: bold;
  min-width: 4.3em;
  text-align: right;
  margin-right: 2rem;
  line-height: 1.8;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .events-list_container .events-list_inner .events-list .events .events_ttl {
    font-size: 2.8rem;
    margin-right: 3rem;
  }
}
.daily_sec .events-list_container .events-list_inner .events-list .events .events_txt {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .daily_sec .events-list_container .events-list_inner .events-list .events .events_txt {
    font-size: 1.4rem;
  }
}
.daily_sec .events-list_container .monthly-events {
  display: flex;
  align-items: center;
}
.daily_sec .events-list_container .monthly-events .events_ttl {
  color: #FFA826;
  font-weight: bold;
  margin-right: 3rem;
  background: #fff;
  margin-right: 2rem;
  border-radius: 0.4rem;
  font-size: 1.4rem;
  padding: 1rem;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .daily_sec .events-list_container .monthly-events .events_ttl {
    font-size: 1.8rem;
    border-radius: 0.8rem;
    min-width: 7em;
  }
}
.daily_sec .events-list_container .monthly-events .events_txt {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .daily_sec .events-list_container .monthly-events .events_txt {
    font-size: 1.4rem;
  }
}

/* ===== info ===== */
@media print, screen and (min-width: 768px) {
  .info_sec {
    margin-top: 18rem;
  }
}
@media only screen and (max-width: 767px) {
  .info_sec {
    margin-top: 8rem;
  }
}
.info_sec .info_box01 {
  text-align: center;
}
.info_sec .info_box01 .m-ttl02 {
  font-size: 3.6rem;
  text-align: center;
  display: inline-block;
  margin: 0 auto;
  background: #DFDBD0;
  padding: 2.8rem 2rem;
  border-radius: 20rem 20rem 0 0;
  width: 33.4rem;
  letter-spacing: 0.5rem;
  color: #262116;
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .m-ttl02 {
    font-size: 2rem;
    width: 17.2rem;
    padding: 1rem 2rem;
  }
}
.info_sec .info_box01 .guide_info li dl dd .extend-guide-info {
  display: flex;
  flex-direction: column;
}
.info_sec .info_box01 .guide_info li dl dd .extend-guide-info .extend-ttl {
  text-align: justify;
  text-align-last: justify;
  width: 8em;
  display: inline-block;
  padding-right: 1rem;
}
.info_sec .info_box01 .guide_info li dl dd .flow-admission-list {
  display: flex;
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list {
    flex-direction: column;
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li {
    -webkit-writing-mode: vertical-lr;
    -ms-writing-mode: rl-tb;
    writing-mode: vertical-lr;
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li {
    padding-right: 10.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li {
    padding-bottom: 2rem;
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:last-of-type {
    padding-right: 0;
  }
}
.info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:last-of-type:after {
  display: none;
}
.info_sec .info_box01 .guide_info li dl dd .flow-admission-list li .flow-admission {
  border-radius: 2rem;
  padding: 2rem;
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.5rem;
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li .flow-admission {
    width: 100%;
    font-size: 1.6rem;
    letter-spacing: 0.1rem;
    text-align: center;
    padding: 0.5rem 1rem;
    border-radius: 0.8rem;
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li .flow-admission2 {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    line-height: 1.5;
  }
}
.info_sec .info_box01 .guide_info li dl dd .flow-admission-list li .flow-admission2 .supplement {
  line-height: 1;
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li .flow-admission2 .supplement {
    margin-top: 4rem;
    font-size: 1.6rem;
    display: block;
  }
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li .flow-admission2 .supplement {
    font-size: 1.4rem;
    margin-left: 0.4rem;
  }
}
.info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:nth-of-type(-n+3) .flow-admission {
  background: #fff;
  color: #FFA826;
  border: 2px solid #DFDBD0;
}
.info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:nth-of-type(n+4) .flow-admission {
  color: #fff;
  background: #FFA826;
  border: 2px solid #FFA826;
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:last-of-type {
    padding-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:last-of-type {
    padding-bottom: 0;
  }
}
.info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:after {
  content: "";
  width: 0;
  height: 0;
  border-radius: 0.2rem;
  display: inline-block;
  position: absolute;
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:after {
    right: 4rem;
    border-top: 1.4rem solid transparent;
    border-bottom: 1.4rem solid transparent;
    border-left: 2.4rem solid #DFDBD0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li dl dd .flow-admission-list li:after {
    bottom: 0.4rem;
    border-left: 0.8rem solid transparent;
    border-right: 0.8rem solid transparent;
    border-top: 1.1rem solid #DFDBD0;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }
}
.info_sec .info_box01 .guide_info li dl dd .detail_notes {
  margin-top: 1rem;
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li.is-col2_pc dt {
    width: 6em;
  }
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li .goods_btn01 {
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box01 .guide_info li .goods_btn01 .m-btn01 {
    width: 100%;
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box01 .guide_info li .goods_btn01 .m-btn01 {
    min-width: 30rem;
  }
}
.info_sec .info_box02 {
  background: #fff;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box02 {
    border-radius: 4rem;
    padding: 4rem;
    margin-top: 18rem;
  }
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box02 {
    border-radius: 2rem;
    padding: 1rem;
    margin-top: 4rem;
  }
}
.info_sec .info_box02 .tour_ttl01 {
  font-size: 2.6rem;
  font-weight: 600;
  color: #2FC4BB;
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box02 .tour_ttl01 {
    border-radius: 2rem;
    margin-bottom: 2rem;
    padding-bottom: 0;
    padding: 3rem 0 0;
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box02 .tour_ttl01 {
    font-size: 5.2rem;
    margin-bottom: 2.4rem;
  }
}
.info_sec .info_box02 .tour_txt01 {
  font-size: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box02 .tour_txt01 {
    margin-bottom: 3rem;
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box02 .tour_txt01 {
    font-size: 2rem;
  }
}
.info_sec .info_box02 .notes_box {
  background: #F2F0E8;
  padding: 1rem;
  border-radius: 1.2rem;
}
@media only screen and (max-width: 767px) {
  .info_sec .info_box02 .notes_box {
    width: calc(100% - 1rem);
  }
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box02 .notes_box {
    padding: 3rem;
  }
}
.info_sec .info_box02 .notes_box .detail_notes {
  text-align: left;
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  .info_sec .info_box02 .notes_box .detail_notes {
    display: inline-block;
  }
}

/* ====goods_list===== */
@media print, screen and (min-width: 768px) {
  .goods_sec {
    padding: 4rem;
  }
}
@media print, screen and (min-width: 768px) {
  .goods_sec .modal_inner {
    padding-right: 2rem;
  }
}
@media only screen and (max-width: 767px) {
  .goods_sec .modal_inner .goods_txt {
    font-size: 1.4rem;
    text-align: left;
  }
}
.goods_sec .goods_ttl {
  color: #2FC4BB;
  font-size: 2.4rem;
  font-weight: bold;
  margin: 2rem 0 1rem;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_ttl {
    font-size: 2rem;
    line-height: 1.7;
  }
}
.goods_sec .goods_box .goods_list_box {
  display: flex;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box01 .goods_list_box {
    flex-direction: column;
  }
}
@media print, screen and (min-width: 768px) {
  .goods_sec .goods_box01 .goods_list_box > li {
    width: 33.3333333333%;
    border-right: 1px solid #DFDBD0;
    padding-right: 2rem;
    margin-right: 2rem;
    flex: 1;
  }
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box01 .goods_list_box > li {
    width: 100%;
    margin-top: 2rem;
  }
}
.goods_sec .goods_box01 .goods_list_box > li:last-of-type {
  border-right: none;
  padding-right: 0;
  margin-right: 0;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box01 .goods_list_box > li:first-of-type {
    margin-top: 0;
  }
}
.goods_sec .goods_box01 .goods_list_box > li .goods_list .goods_list_ttl {
  border: 1px solid #2FC4BB;
  color: #2FC4BB;
  border-radius: 5rem;
  font-weight: 500;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box01 .goods_list_box > li .goods_list .goods_list_ttl {
    position: relative;
    font-size: 1.6rem;
    padding: 0.6rem 1rem;
  }
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box01 .goods_list_box > li .goods_list .goods_list_ttl:after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 1.5rem;
    width: 1.6rem;
    height: 1.6rem;
    background: transparent url(../img/common/icon_plus.svg) 50% 50% no-repeat;
    background-size: contain;
    content: "";
  }
}
.goods_sec .goods_box01 .goods_list_box > li .goods_list .goods_list_ttl.is-active:after {
  background-image: url(../img/common/icon_minus.svg);
}
.goods_sec .goods_box01 .goods_list_box > li .goods_list .goods_list_txt .goods {
  text-align: left;
  margin-top: 1rem;
  font-size: 1.6rem;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box01 .goods_list_box > li .goods_list .goods_list_txt .goods {
    font-size: 1.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box01 .goods_img {
    max-width: 21.7rem;
    margin: 4rem auto 0;
  }
}
.goods_sec .goods_box02 .goods_ttl {
  margin-top: 5rem;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box02 .goods_ttl {
    margin-top: 4rem;
  }
}
.goods_sec .goods_box02 .goods_list_txt .goods {
  text-align: left;
  margin-top: 1rem;
  font-size: 1.6rem;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box02 .goods_list_box {
    flex-wrap: wrap;
  }
}
@media print, screen and (min-width: 768px) {
  .goods_sec .goods_box02 .goods_list_box > li {
    width: 33.3333333333%;
    flex: 1;
  }
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box02 .goods_list_box > li {
    width: 100%;
  }
}
@media print, screen and (min-width: 768px) {
  .goods_sec .goods_box02 .goods_list_box > li:first-of-type {
    margin-right: 8rem;
  }
}
.goods_sec .goods_box02 .goods_list_box > li dt {
  text-align: left;
  font-size: 1.6rem;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box02 .goods_list_box > li dt {
    text-indent: -1em;
    padding-left: 1em;
  }
}
.goods_sec .goods_box02 .goods_list_box > li .goods_list_txt {
  text-align: left;
}
.goods_sec .goods_box02 .goods_list_box > li .goods_list_txt .m-listNotes {
  margin-top: 1rem;
}
.goods_sec .goods_box03 .goods_ttl {
  margin-top: 5rem;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box03 .goods_ttl {
    margin-top: 4rem;
  }
}
.goods_sec .goods_box03 .goods {
  text-align: left;
}
@media only screen and (max-width: 767px) {
  .goods_sec .goods_box03 .goods {
    display: inline-block;
  }
}

/* ===== overview ===== */
@media print, screen and (min-width: 768px) {
  .overview_sec {
    margin-top: 18rem;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec {
    margin-top: 8rem;
  }
}
.overview_sec .overview_inner {
  display: flex;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner {
    flex-direction: column;
  }
}
@media print, screen and (min-width: 768px) {
  .overview_sec .overview_inner .overview_box {
    width: calc(50% - 4rem);
  }
}
.overview_sec .overview_inner .overview_box01 {
  display: flex;
  flex-direction: column;
}
@media print, screen and (min-width: 768px) {
  .overview_sec .overview_inner .overview_box01 {
    margin-right: 8rem;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box01 .overview_info {
    order: 2;
    margin-top: 4.6rem;
  }
}
@media print, screen and (min-width: 768px) {
  .overview_sec .overview_inner .overview_box01 .overview_info {
    margin-bottom: 3rem;
  }
}
.overview_sec .overview_inner .overview_box01 .overview_info li dt {
  width: 6em;
  letter-spacing: 0.6rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box01 .overview_info li dt {
    width: 5em;
    letter-spacing: 0.3rem;
  }
}
.overview_sec .overview_inner .overview_box01 .map_box {
  position: relative;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box01 .map_box {
    order: 1;
  }
}
.overview_sec .overview_inner .overview_box01 .map_box .map_area {
  position: relative;
  border-radius: 1.5rem;
  overflow: hidden;
  z-index: 5;
  min-height: 40.5rem;
  border: 2px solid #DFDBD0;
}
.overview_sec .overview_inner .overview_box01 .map_box .map_area iframe {
  display: block;
  width: 100%;
  height: 200%;
  position: absolute;
  top: -50%;
  left: 0;
}
@media print, screen and (min-width: 768px) {
  .overview_sec .overview_inner .overview_box01 .map_box .map_area {
    border-radius: 2rem;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box01 .map_box .map_area {
    position: relative;
    width: 100%;
    min-height: 1px;
    aspect-ratio: 760/470;
    border-radius: 1.2rem;
  }
}
.overview_sec .overview_inner .overview_box01 .map_box .map_txt_box {
  border-radius: 20rem;
  background: #FFA826;
  color: #fff;
  font-weight: 500;
  line-height: 1.7;
  position: absolute;
  text-align: center;
  bottom: -2rem;
  left: -2rem;
  z-index: 5;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box01 .map_box .map_txt_box {
    width: 10.7rem;
    height: 10.7rem;
    bottom: -3rem;
    left: -1rem;
  }
}
@media print, screen and (min-width: 768px) {
  .overview_sec .overview_inner .overview_box01 .map_box .map_txt_box {
    width: 17rem;
    height: 17rem;
  }
}
.overview_sec .overview_inner .overview_box01 .map_box .map_txt_box .map_txt {
  position: absolute;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 2rem;
}
@media print, screen and (min-width: 768px) {
  .overview_sec .overview_inner .overview_box01 .map_box .map_txt_box .map_txt {
    width: calc(100% - 4rem);
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box01 .map_box .map_txt_box .map_txt {
    font-size: 1.4rem;
    width: calc(100% - 2rem);
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 {
    margin-top: 3rem;
  }
}
.overview_sec .overview_inner .overview_box02 .access_ttl {
  margin-bottom: 2rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .access_ttl {
    margin-bottom: 1rem;
    font-size: 2rem;
  }
}
.overview_sec .overview_inner .overview_box02 .access_ttl .access_car_icon {
  position: relative;
  padding-left: 6.8rem;
  font-size: 2.6rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .access_ttl .access_car_icon {
    padding-left: 4.8rem;
  }
}
.overview_sec .overview_inner .overview_box02 .access_ttl .access_car_icon:before {
  content: "";
  background: #FFA826;
  border-radius: 50%;
  position: absolute;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  display: inline-block;
  width: 6rem;
  height: 6rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .access_ttl .access_car_icon:before {
    width: 4rem;
    height: 4rem;
  }
}
.overview_sec .overview_inner .overview_box02 .access_ttl .access_car_icon:after {
  position: absolute;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 1.25rem;
  width: 3.6rem;
  height: 2.8rem;
  background: transparent url(../img/top/icon_car.svg) 50% 50% no-repeat;
  background-size: contain;
  content: "";
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .access_ttl .access_car_icon:after {
    left: 0.6rem;
    width: 2.8rem;
    height: 2.8rem;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .access_txt {
    font-size: 1.4rem;
  }
}
.overview_sec .overview_inner .overview_box02 .access_img {
  margin: 2rem 0 4rem;
  border-radius: 2rem;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .access_img {
    border-radius: 1.2rem;
    margin-bottom: 2rem;
  }
}
.overview_sec .overview_inner .overview_box02 .parking_btn01 {
  margin-bottom: 1rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .parking_btn01 {
    text-align: center;
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .overview_inner .overview_box02 .parking_btn01 a {
    width: 100%;
  }
}
.overview_sec .overview_inner .overview_box02 .parking_btn01 span:after {
  width: 2rem;
  height: 2rem;
}
.overview_sec .support_inner {
  position: relative;
}
@media print, screen and (min-width: 768px) {
  .overview_sec .support_inner {
    margin-top: 10rem;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner {
    margin-top: 4rem;
  }
}
.overview_sec .support_inner .m-btn03 {
  display: flex;
  background: #fff;
  border-radius: 4rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner .m-btn03 {
    border-radius: 2rem;
  }
}
.overview_sec .support_inner .m-btn03 .support_img {
  width: 39.7rem;
  overflow: hidden;
  border-radius: 4rem 0 0 4rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner .m-btn03 .support_img {
    width: 35.333%;
    border-radius: 2rem 0 0 2rem;
    aspect-ratio: 312/312;
  }
}
.overview_sec .support_inner .m-btn03 .support_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.overview_sec .support_inner .m-btn03 .support_info {
  flex: 1;
  padding: 2rem 4rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner .m-btn03 .support_info {
    padding: 1rem 0.8rem;
  }
}
.overview_sec .support_inner .m-btn03 .support_info_ttl {
  display: inline-block;
  position: relative;
  padding-top: 6rem;
  font-size: 5.2rem;
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  .overview_sec .support_inner .m-btn03 .support_info_ttl {
    padding-right: 3.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner .m-btn03 .support_info_ttl {
    padding-top: 3rem;
    font-size: 1.8rem;
    line-height: 1.5;
    padding-right: 1.4rem;
  }
}
.overview_sec .support_inner .m-btn03 .support_info_ttl .status {
  position: absolute;
  top: 0;
  font-weight: 500;
  font-size: 2.8rem;
  background: #FFA826;
  color: #fff;
  padding: 0.8rem 1.6rem;
  line-height: 1.5;
  left: -4rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner .m-btn03 .support_info_ttl .status {
    font-size: 1.2rem;
    padding: 0.4rem 0.8rem;
    left: -0.8rem;
    line-height: 1.2;
  }
}
.overview_sec .support_inner .m-btn03 .support_info_ttl:after {
  background: transparent url(../img/common/icon_window_b.svg) 50% 50% no-repeat;
  background-size: contain;
  width: 3rem;
  height: 3rem;
  bottom: 3.5rem;
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner .m-btn03 .support_info_ttl:after {
    width: 1rem;
    height: 1rem;
    bottom: 0.5rem;
  }
}
@media print, screen and (min-width: 768px) {
  .overview_sec .support_inner .m-btn03 .support_info_txt {
    font-size: 2rem;
  }
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner .m-btn03 .support_info_txt {
    font-size: 1.3rem;
    line-height: 1.5;
  }
}
.overview_sec .support_inner:after {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background: #FFA826;
  border-radius: 4rem;
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  width: calc(100% - 9rem);
  left: 50%;
  transform: translateX(-50%) rotate(-2deg);
}
@media only screen and (max-width: 767px) {
  .overview_sec .support_inner:after {
    width: calc(100% - 2rem);
    border-radius: 2rem;
  }
}
@media (hover: hover) {
  .overview_sec .support_inner:hover {
    transform: scale(1.05);
    transition: 0.2s;
  }
  .overview_sec .support_inner:hover:after {
    transition: 0.3s;
    transform: translateX(-50%) rotate(2deg);
  }
}

/* ====faq ===== */
@media print, screen and (min-width: 768px) {
  .faq_sec {
    margin-top: 18rem;
  }
}
@media only screen and (max-width: 767px) {
  .faq_sec {
    margin-top: 8rem;
  }
}
.faq_sec .faq_inner dl {
  padding-bottom: 4rem;
  cursor: pointer;
}
@media only screen and (max-width: 767px) {
  .faq_sec .faq_inner dl {
    padding-bottom: 2rem;
  }
}
.faq_sec .faq_inner dl dt {
  position: relative;
  font-weight: 500;
  margin-top: 0.1rem;
  text-indent: -2em;
  background: #fff;
  border-radius: 5rem;
  padding: 1rem 1rem 1rem 8rem;
  transition: 0.4s;
}
@media (hover: hover) {
  .faq_sec .faq_inner dl dt:hover {
    transform: scale(1.05);
  }
}
@media print, screen and (min-width: 768px) {
  .faq_sec .faq_inner dl dt {
    font-size: 2.4rem;
  }
}
@media only screen and (max-width: 767px) {
  .faq_sec .faq_inner dl dt {
    text-indent: -2em;
    padding: 1rem 5rem 1rem 5rem;
    border-radius: 1.2rem;
    line-height: 1.7;
    font-size: 1.6rem;
  }
}
.faq_sec .faq_inner dl dt:after {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 1.5rem;
  width: 2rem;
  height: 2rem;
  background: transparent url(../img/common/icon_plus.svg) 50% 50% no-repeat;
  background-size: contain;
  content: "";
}
@media print, screen and (min-width: 768px) {
  .faq_sec .faq_inner dl dt:after {
    right: 3rem;
    width: 3.2rem;
    height: 3.2rem;
  }
}
.faq_sec .faq_inner dl dt.is-active:after {
  background-image: url(../img/common/icon_minus.svg);
}
.faq_sec .faq_inner dl dt:before {
  content: "Q.";
  font-size: 4rem;
  color: #2FC4BB;
  margin-right: 1rem;
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .faq_sec .faq_inner dl dt:before {
    font-size: 2.4rem;
  }
}
.faq_sec .faq_inner dl dd {
  text-indent: -3em;
  padding-left: 3em;
}
@media print, screen and (min-width: 768px) {
  .faq_sec .faq_inner dl dd {
    margin: 2rem 0 2rem 2.4rem;
  }
}
@media only screen and (max-width: 767px) {
  .faq_sec .faq_inner dl dd {
    text-indent: -3em;
    padding: 2rem 0 2rem 4em;
    font-size: 1.4rem;
  }
}
.faq_sec .faq_inner dl dd:before {
  content: "A.";
  font-size: 4rem;
  color: #FFA826;
  margin-right: 1.5rem;
  line-height: 1;
  font-weight: bold;
}
@media only screen and (max-width: 767px) {
  .faq_sec .faq_inner dl dd:before {
    font-size: 2.4rem;
  }
}