/* Sass Document */
#fv {
  padding: 0 4rem 12rem;
  background: url(../img/index/bg_fv.svg) no-repeat center bottom;
  background-size: 100% auto;
  position: relative;
}
@media screen and (max-width: 1200px) {
  #fv {
    padding: 0 3.3333333333vw 10vw;
  }
}
@media screen and (max-width: 840px) {
  #fv {
    padding: 2.6666666667vw 4vw 5.3333333333vw;
    background: url(../img/index/bg_fv_sp.svg) no-repeat center bottom;
    background-size: 100% auto;
  }
}
#fv .wrap {
  position: relative;
  max-width: 184rem;
  width: 100%;
}
@media screen and (max-width: 840px) {
  #fv .wrap {
    width: 92vw;
  }
}
#fv .fv_top {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  max-width: 184rem;
  width: 100%;
  padding: 19.5rem 12.4rem;
  border-radius: 2rem;
}
#fv .fv_top .fv_img{
    position: absolute;
    top: 0;
    left: 0;
   z-index: 1;
  }
#fv .fv_top .fv_img img {
  border-radius: 2vw;
}
@media screen and (max-width: 1200px) {
  #fv .fv_top {
    padding: 16.25vw 10.3333333333vw;
    border-radius: 1.6666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top {
    padding: 48vw 4.2666666667vw 5.3333333333vw;
  }
  #fv .fv_top .fv_img img {
  border-radius: 4vw;
}
}
#fv .fv_top .txta_area {
  margin-bottom: 6rem;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1200px) {
  #fv .fv_top .txta_area {
    margin-bottom: 5vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top .txta_area {
    margin-bottom: 4.5333333333vw;
  }
}
#fv .fv_top .txta_area .box_g {
  display: inline-block;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  height: 5.8rem;
  padding: 0.1em 0.5em 0;
  margin-bottom: 1.5rem;
  font-size: 3.2rem;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  background: #009844;
  border-radius: 0.5rem;
  -webkit-box-shadow: 0 0 0.1rem rgba(25, 25, 25, 0.4);
          box-shadow: 0 0 0.1rem rgba(25, 25, 25, 0.4);
}
@media screen and (max-width: 1200px) {
  #fv .fv_top .txta_area .box_g {
    height: 4.8333333333vw;
    margin-bottom: 1.25vw;
    font-size: 2.6666666667vw;
    border-radius: 0.4166666667vw;
    -webkit-box-shadow: 0 0 0.8333333333vw rgba(25, 25, 25, 0.4);
            box-shadow: 0 0 0.8333333333vw rgba(25, 25, 25, 0.4);
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top .txta_area .box_g {
    height: 8.8vw;
    margin-bottom: 0;
    font-size: 4.2666666667vw;
    border-radius: 0.5333333333vw;
    -webkit-box-shadow: 0 0 1.6vw rgba(25, 25, 25, 0.4);
            box-shadow: 0 0 1.6vw rgba(25, 25, 25, 0.4);
  }
  #fv .fv_top .txta_area .box_g.sp {
    display: inline-block !important;
  }
  #fv .fv_top .txta_area .box_g.sp + .box_g {
    margin: 0.5333333333vw 0 3.2vw;
  }
}
#fv .fv_top .txta_area .box_g .yelow {
  color: #FFD802;
  line-height: 1;
}
#fv .fv_top .txta_area .box_g .yelow .en {
  font-size: 5rem;
  font-weight: 600;
  line-height: 1;
}
@media screen and (max-width: 1200px) {
  #fv .fv_top .txta_area .box_g .yelow .en {
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top .txta_area .box_g .yelow .en {
    font-size: 7.2vw;
  }
}
#fv .fv_top .txta_area .box_g .yelow .small {
  font-size: 3.2rem;
  line-height: 1;
}
@media screen and (max-width: 1200px) {
  #fv .fv_top .txta_area .box_g .yelow .small {
    font-size: 2.6666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top .txta_area .box_g .yelow .small {
    font-size: 4.2666666667vw;
  }
}
#fv .fv_top .txta_area .main_title {
  font-size: 6.2rem;
  color: #fff;
  font-family: "Noto Sans JP";
  line-height: 1.387;
  text-shadow: 0 0 1.5rem rgba(0, 0, 0, 0.6);
}
@media screen and (max-width: 1200px) {
  #fv .fv_top .txta_area .main_title {
    font-size: 5.1666666667vw;
    text-shadow: 0 0 1.25vw rgba(0, 0, 0, 0.6);
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top .txta_area .main_title {
    font-size: 7.4666666667vw;
    text-shadow: 0 0 2.1333333333vw rgba(0, 0, 0, 0.6);
  }
}
#fv .fv_top ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  z-index: 2;
  position: relative;
}
@media screen and (max-width: 1200px) {
  #fv .fv_top ul {
    gap: 0.8333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top ul {
    gap: 1.8666666667vw;
  }
}
#fv .fv_top ul li {
  width: 20rem;
  -webkit-box-shadow: 0 0 1rem rgba(25, 25, 25, 0.2);
          box-shadow: 0 0 1rem rgba(25, 25, 25, 0.2);
  border-radius: 2rem;
}
@media screen and (max-width: 1200px) {
  #fv .fv_top ul li {
    width: 16.6666666667vw;
    -webkit-box-shadow: 0 0 0.8333333333vw rgba(25, 25, 25, 0.2);
            box-shadow: 0 0 0.8333333333vw rgba(25, 25, 25, 0.2);
    border-radius: 1.6666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .fv_top ul li {
    width: 26.6666666667vw;
    -webkit-box-shadow: 0 0 2.1333333333vw rgba(25, 25, 25, 0.2);
            box-shadow: 0 0 2.1333333333vw rgba(25, 25, 25, 0.2);
    border-radius: 2.1333333333vw;
  }
}
#fv .fv_top ul li img {
  width: 100%;
}
#fv .fv_top ul li:nth-of-type(1) {
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}
#fv .fv_top ul li:nth-of-type(2) {
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
}
#fv .fv_top ul li:nth-of-type(3) {
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}
#fv .new_news_area {
  position: absolute;
  bottom: -5rem;
  left: 0;
  right: 0;
  z-index: 1;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area {
    bottom: -3.125vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area {
    position: unset;
    margin-top: 4vw;
  }
}
#fv .new_news_area a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 120rem;
  width: 95%;
  height: 10rem;
  padding: 0 5.5rem;
  margin: auto;
  background: #fff;
  border-radius: 5rem;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area a {
    width: 100%;
    height: 6.25vw;
    padding: 0 1.875vw;
    border-radius: 3.125vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a {
    position: relative;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 92vw;
    height: auto;
    padding: 5.8666666667vw 14.9333333333vw 7.2vw 6.6666666667vw;
    border-radius: 4vw;
  }
}
#fv .new_news_area a .title02 {
  padding-right: 4rem;
  margin-right: 3rem;
  font-size: 2.1rem;
  font-weight: 700;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#191919), color-stop(0.1rem, #191919), color-stop(0.1rem, transparent), color-stop(0.4rem, transparent));
  background-image: linear-gradient(to bottom, #191919, #191919 0.1rem, transparent 0.1rem, transparent 0.4rem);
  background-size: 0.1rem 0.4rem;
  background-position: right;
  background-repeat: repeat-y;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area a .title02 {
    padding-right: 1.25vw;
    margin-right: 1.25vw;
    font-size: 1.3125vw;
    background-image: -webkit-gradient(linear, left top, left bottom, from(#191919), color-stop(0.1rem, #191919), color-stop(0.1rem, transparent), color-stop(0.25vw, transparent));
    background-image: linear-gradient(to bottom, #191919, #191919 0.1rem, transparent 0.1rem, transparent 0.25vw);
    background-size: 0.1rem 0.25vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a .title02 {
    width: 100%;
    padding-right: 0;
    margin-right: 0;
    margin-bottom: 3.7333333333vw;
    font-size: 5.8666666667vw;
    background-image: none;
  }
}
#fv .new_news_area a .date {
  margin-right: 2.8rem;
  font-size: 1.4rem;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area a .date {
    margin-right: 1.25vw;
    font-size: 0.875vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a .date {
    margin-right: 2.6666666667vw;
    font-size: 2.9333333333vw;
  }
}
#fv .new_news_area a .cat {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 3.2rem;
  padding: 0 1em;
  margin-right: 2.8rem;
  font-size: 1.3rem;
  color: #47B022;
  border: 0.1rem solid #47B022;
  border-radius: 1.6rem;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area a .cat {
    height: 2vw;
    margin-right: 1.75vw;
    font-size: 0.8125vw;
    border-radius: 1vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a .cat {
    height: 6.1333333333vw;
    margin-right: auto;
    font-size: 2.9333333333vw;
    border-radius: 4.2666666667vw;
  }
}
#fv .new_news_area a .title {
  max-width: 50rem;
  margin-right: auto;
  font-size: 1.5rem;
  font-weight: 500;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area a .title {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a .title {
    width: 100%;
    margin-top: 1.6vw;
    font-size: 3.7333333333vw;
  }
}
#fv .new_news_area a .btn_more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.5rem;
  font-size: 1.5rem;
  color: #47B022;
  font-weight: 700;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area a .btn_more {
    gap: 0.9375vw;
    font-size: 0.875vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a .btn_more {
    position: absolute;
    bottom: 10.6666666667vw;
    right: 4.8vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a .btn_more span {
    display: none;
  }
}
#fv .new_news_area a .btn_more img {
  width: 2.4rem;
}
@media screen and (max-width: 1600px) {
  #fv .new_news_area a .btn_more img {
    width: 1.5vw;
  }
}
@media screen and (max-width: 840px) {
  #fv .new_news_area a .btn_more img {
    width: 6.4vw;
  }
}

#banner_area {
  padding: 6rem 0;
}
@media screen and (max-width: 1200px) {
  #banner_area {
    padding: 5vw 0;
  }
}
@media screen and (max-width: 840px) {
  #banner_area {
    padding: 10.6666666667vw 0;
  }
}
#banner_area .splide__pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  margin-top: 1.9rem;
}
@media screen and (max-width: 1200px) {
  #banner_area .splide__pagination {
    gap: 0.8333333333vw;
    margin-top: 1.5833333333vw;
  }
}
@media screen and (max-width: 840px) {
  #banner_area .splide__pagination {
    gap: 2.1333333333vw;
    margin-top: 5.3333333333vw;
  }
}
#banner_area .splide__pagination li .splide__pagination__page {
  width: 1rem;
  height: 1rem;
  background: #DCDAD2;
  border-radius: 50%;
  cursor: pointer;
  -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
}
@media screen and (max-width: 1200px) {
  #banner_area .splide__pagination li .splide__pagination__page {
    width: 0.8333333333vw;
    height: 0.8333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #banner_area .splide__pagination li .splide__pagination__page {
    width: 2.1333333333vw;
    height: 2.1333333333vw;
  }
}
#banner_area .splide__pagination li .splide__pagination__page:hover, #banner_area .splide__pagination li .splide__pagination__page.is-active {
  background: #47B022;
}

#arrival_area {
  padding: 12rem 0 8rem;
}
@media screen and (max-width: 1200px) {
  #arrival_area {
    padding: 10vw 0 6.6666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area {
    padding: 18.6666666667vw 0 11.7333333333vw;
  }
}
#arrival_area .title_area {
  margin-bottom: 5rem;
}
@media screen and (max-width: 1200px) {
  #arrival_area .title_area {
    margin-bottom: 4.1666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area .title_area {
    margin-bottom: 8vw;
  }
}
#arrival_area #arrival_slide .splide__list .splide__slide a {
  position: relative;
  display: block;
  padding: 2.7rem 2.7rem 3rem;
  background: #fff;
  border-radius: 1rem;
  overflow: hidden;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a {
    padding: 2.25vw 2.25vw 2.5vw;
    border-radius: 0.8333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a {
    padding: 3.7333333333vw 4.8vw 5.3333333333vw;
    border-radius: 2.6666666667vw;
  }
}
#arrival_area #arrival_slide .splide__list .splide__slide a .shop {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 3.5rem;
  padding: 0 0.8em;
  font-size: 1.4rem;
  color: #fff;
  font-weight: 700;
  background: #224F96;
  border-radius: 1rem 0 1rem 0;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .shop {
    height: 2.9166666667vw;
    font-size: 1.1666666667vw;
    border-radius: 0.8333333333vw 0 0.8333333333vw 0;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .shop {
    height: 8.2666666667vw;
    font-size: 3.4666666667vw;
    border-radius: 2.6666666667vw 0 2.6666666667vw 0;
  }
}
#arrival_area #arrival_slide .splide__list .splide__slide a figure {
  aspect-ratio: 1/0.75;
}
#arrival_area #arrival_slide .splide__list .splide__slide a figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#arrival_area #arrival_slide .splide__list .splide__slide a .in {
  padding: 1.8rem 0.6rem;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in {
    padding: 1.5vw 0.5vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in {
    padding: 4vw 2.1333333333vw 0;
  }
}
#arrival_area #arrival_slide .splide__list .splide__slide a .in .cat_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.3rem;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .cat_list {
    gap: 0.4166666667vw;
    margin-bottom: 1.0833333333vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .cat_list {
    gap: 1.6vw;
    margin-bottom: 2.9333333333vw;
  }
}
#arrival_area #arrival_slide .splide__list .splide__slide a .in .cat_list li {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 3.2rem;
  padding: 0 1.7rem;
  font-size: 1.3rem;
  color: #47B022;
  border: 0.1rem solid #47B022;
  border-radius: 1.6rem;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .cat_list li {
    height: 2.6666666667vw;
    padding: 0 1.4166666667vw;
    font-size: 1.0833333333vw;
    border-radius: 1.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .cat_list li {
    height: 7.4666666667vw;
    padding: 0 4vw;
    font-size: 2.9333333333vw;
    border-radius: 4.2666666667vw;
  }
}
#arrival_area #arrival_slide .splide__list .splide__slide a .in .title03 {
  margin-bottom: 1.7rem;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.625;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .title03 {
    margin-bottom: 1.4166666667vw;
    font-size: 1.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .title03 {
    margin-bottom: 3.4666666667vw;
    font-size: 4vw;
  }
}
#arrival_area #arrival_slide .splide__list .splide__slide a .in .date {
  font-size: 1.3rem;
  color: #B4B4B4;
  font-weight: 600;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .date {
    font-size: 1.0833333333vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .splide__list .splide__slide a .in .date {
    font-size: 3.4666666667vw;
  }
}
#arrival_area #arrival_slide .btn_area {
  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;
  gap: 4rem;
  margin-top: 5rem;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .btn_area {
    gap: 3.3333333333vw;
    margin-top: 4.1666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .btn_area {
    margin-top: 7.2vw;
  }
}
#arrival_area #arrival_slide .btn_area .splide__arrows {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.5rem;
  padding-right: 4rem;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#191919), color-stop(0.1rem, #191919), color-stop(0.1rem, transparent), color-stop(0.4rem, transparent));
  background-image: linear-gradient(to bottom, #191919, #191919 0.1rem, transparent 0.1rem, transparent 0.4rem);
  background-size: 0.1rem 0.4rem;
  background-position: right;
  background-repeat: repeat-y;
}
@media screen and (max-width: 1200px) {
  #arrival_area #arrival_slide .btn_area .splide__arrows {
    gap: 1.25vw;
    padding-right: 3.3333333333vw;
    background-image: -webkit-gradient(linear, left top, left bottom, from(#191919), color-stop(0.1rem, #191919), color-stop(0.1rem, transparent), color-stop(0.3333333333vw, transparent));
    background-image: linear-gradient(to bottom, #191919, #191919 0.1rem, transparent 0.1rem, transparent 0.3333333333vw);
    background-size: 0.1rem 0.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .btn_area .splide__arrows {
    padding-right: 0;
    background-image: none;
  }
}
#arrival_area #arrival_slide .btn_area .splide__arrows img {
  width: 100%;
}
#arrival_area #arrival_slide .btn_area .splide__arrows .splide__arrow {
  cursor: pointer;
  -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .btn_area .splide__arrows .splide__arrow {
    position: absolute;
    bottom: 56vw;
    width: 10.6666666667vw;
  }
}
#arrival_area #arrival_slide .btn_area .splide__arrows .splide__arrow:hover {
  opacity: 0.7;
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .btn_area .splide__arrows .splide__arrow--prev {
    left: 4vw;
  }
}
@media screen and (max-width: 840px) {
  #arrival_area #arrival_slide .btn_area .splide__arrows .splide__arrow--next {
    right: 4vw;
  }
}

#achivement_area {
  padding: 19rem 0 49rem;
  background: url(../img/index/bg01.svg) no-repeat center bottom;
  background-size: auto 100%;
}
@media screen and (max-width: 1200px) {
  #achivement_area {
    padding: 15.8333333333vw 0 40.8333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #achivement_area {
    padding: 21.3333333333vw 0 49.6vw;
    background: url(../img/index/bg01_sp.svg) no-repeat center bottom;
    background-size: cover;
  }
}

#about_area {
  position: relative;
}
#about_area .about_area_wrap {
  max-width: 184rem;
  width: 95.8333333333%;
  padding: 14.3rem 0 14.7rem;
  margin: -36.3rem auto 0;
  background: #F6F6F3;
  border-radius: 5rem 5rem 0 0;
}
@media screen and (max-width: 1600px) {
  #about_area .about_area_wrap {
    padding: 8.9375vw 0 9.1875vw;
    margin: -22.6875vw auto 0;
    border-radius: 3.125vw 3.125vw 0 0;
  }
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap {
    width: 92vw;
    padding: 8vw 0 26.6666666667vw;
    margin: -36.2666666667vw auto 0;
    border-radius: 4vw 4vw 0 0;
  }
}
#about_area .about_area_wrap .wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 140rem;
  z-index: 1;
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap .wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 8.5333333333vw;
    width: 80vw;
  }
}
#about_area .about_area_wrap .wrap figure {
  max-width: 70rem;
  width: 50%;
  margin-left: 4rem;
}
@media screen and (max-width: 1600px) {
  #about_area .about_area_wrap .wrap figure {
    margin-left: 0;
  }
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap .wrap figure {
    max-width: none;
    width: 100%;
  }
}
#about_area .about_area_wrap .wrap .txt_area {
  max-width: 57rem;
  width: 45%;
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap .wrap .txt_area {
    max-width: none;
    width: 100%;
  }
}
#about_area .about_area_wrap .wrap .txt_area .title_area {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-bottom: 2rem;
}
@media screen and (max-width: 1600px) {
  #about_area .about_area_wrap .wrap .txt_area .title_area {
    margin-bottom: 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap .wrap .txt_area .title_area {
    margin-bottom: 5.3333333333vw;
  }
}
@media screen and (max-width: 1600px) {
  #about_area .about_area_wrap .wrap .txt_area .title_area .title02 {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap .wrap .txt_area .title_area .title02 {
    font-size: 8vw;
  }
}
@media screen and (max-width: 1600px) {
  #about_area .about_area_wrap .wrap .txt_area > p {
    font-size: 0.9375vw;
  }
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap .wrap .txt_area > p {
    font-size: 3.7333333333vw;
  }
}
#about_area .about_area_wrap .wrap .txt_area .btn a {
  margin: 3.2rem 0;
}
@media screen and (max-width: 1600px) {
  #about_area .about_area_wrap .wrap .txt_area .btn a {
    margin: 2vw 0;
  }
}
@media screen and (max-width: 840px) {
  #about_area .about_area_wrap .wrap .txt_area .btn a {
    margin: 8vw 0;
  }
}

#service_area {
  padding: 12rem 0;
  background: url(../img/index/bg02.jpg) no-repeat center center;
  background-size: cover;
}
@media screen and (max-width: 1200px) {
  #service_area {
    padding: 10vw 0;
  }
}
@media screen and (max-width: 840px) {
  #service_area {
    padding: 17.3333333333vw 0 13.3333333333vw;
    background: url(../img/index/bg02_sp.jpg) no-repeat center center;
    background-size: cover;
  }
}
#service_area .title_area {
  margin-bottom: 5rem;
}
@media screen and (max-width: 1200px) {
  #service_area .title_area {
    margin-bottom: 4.1666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .title_area {
    margin-bottom: 9.6vw;
  }
}
#service_area .flex {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 3rem;
}
@media screen and (max-width: 1200px) {
  #service_area .flex {
    gap: 2.5vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex {
    gap: 3.2vw;
  }
}
#service_area .flex .service_btn {
/*  width: calc((100% - 3rem) / 2);*/
  width: 100%;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn {
    width: calc((100% - 2.5vw) / 2);
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn {
    width: 100%;
  }
}
#service_area .flex .service_btn a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 3rem;
/*  padding: 4.5rem 2rem 5rem 4rem;*/
  padding: 3.7rem 2rem 3.3rem 4rem;
  background: #fff;
  border-radius: 1rem;
  overflow: hidden;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn a {
    gap: 2.5vw;
    padding: 3.75vw 1.6666666667vw 4.1666666667vw 2.5vw;
    border-radius: 0.8333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn a {
    padding: 5.8666666667vw 9.3333333333vw 6.9333333333vw 6.6666666667vw;
    border-radius: 1.8666666667vw;
  }
}
#service_area .flex .service_btn a * {
  -webkit-transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
}
#service_area .flex .service_btn a .image {
  position: relative;
  width: 12rem;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn a .image {
    width: 10vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn a .image {
    position: absolute;
    top: 5.8666666667vw;
    left: 6.6666666667vw;
    width: 21.3333333333vw;
    margin-right: 4.8vw;
  }
}
#service_area .flex .service_btn a .image img {
  position: absolute;
  top: 0;
  left: 0;
}
#service_area .flex .service_btn a .image img.on {
  opacity: 0;
}
#service_area .flex .service_btn a .in .title02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.5rem;
  margin-bottom: 1.6rem;
  font-size: 3.7rem;
  font-weight: 700;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn a .in .title02 {
    gap: 2.0833333333vw;
    margin-bottom: 1.3333333333vw;
    font-size: 2.9166666667vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn a .in .title02 {
    display: block;
    margin-top: 1.8666666667vw;
    margin-left: 26.1333333333vw;
    margin-bottom: 6.9333333333vw;
    font-size: 6.1333333333vw;
  }
}
#service_area .flex .service_btn a .in .title02 span {
  font-size: 1.5rem;
  color: #BCBCBC;
  letter-spacing: 0;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn a .in .title02 span {
    font-size: 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn a .in .title02 span {
    display: block;
    margin-top: 1.3333333333vw;
    font-size: 3.4666666667vw;
  }
}
#service_area .flex .service_btn a .in p {
  font-size: 1.6rem;
  line-height: 1.875;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn a .in p {
    font-size: 1.1666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn a .in p {
    font-size: 3.7333333333vw;
  }
}
#service_area .flex .service_btn a .arrow {
  position: absolute;
  bottom: 0;
  right: 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: 5rem;
  height: 5rem;
  border-radius: 1rem 0 1rem 0;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn a .arrow {
    width: 4.1666666667vw;
    height: 4.1666666667vw;
    border-radius: 0.8333333333vw 0 0.8333333333vw 0;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn a .arrow {
    width: 9.3333333333vw;
    height: 9.3333333333vw;
    border-radius: 1.8666666667vw 0 1.8666666667vw 0;
  }
}
#service_area .flex .service_btn a:hover .image img.on {
  opacity: 1;
}
#service_area .flex .service_btn a:hover .image img.off {
  opacity: 0;
}
#service_area .flex .service_btn a:hover .in .title02 .en {
  color: #fff;
}
#service_area .flex .service_btn a:hover .in .arrow {
  background: #fff;
}
#service_area .flex .service_btn a:hover p {
  color: #fff;
}
#service_area .flex .service_btn.store a .in .title02 {
  color: #224F96;
}
#service_area .flex .service_btn.store a .arrow {
  background: #224F96;
}
#service_area .flex .service_btn.store a:hover {
  background: #224F96;
  opacity: 1;
}
#service_area .flex .service_btn.store a:hover .in .title02 {
  color: #fff;
}
#service_area .flex .service_btn.store a:hover .arrow {
  background: #fff;
}
#service_area .flex .service_btn.store a:hover .arrow .dli-arrow-right {
  color: #224F96;
}
#service_area .flex .service_btn.line a .in .title02 {
  color: #47B022;
}
#service_area .flex .service_btn.line a .arrow {
  background: #47B022;
}
#service_area .flex .service_btn.line a:hover {
  background: #47B022;
  opacity: 1;
}
#service_area .flex .service_btn.line a:hover .in .title02 {
  color: #fff;
}
#service_area .flex .service_btn.line a:hover .arrow {
  background: #fff;
}
#service_area .flex .service_btn.line a:hover .arrow .dli-arrow-right {
  color: #47B022;
}
#service_area .flex .service_btn.customer {
  width: 100%;
}
#service_area .flex .service_btn.customer a {
  padding: 3.7rem 2rem 3.3rem 4rem;
}
@media screen and (max-width: 1200px) {
  #service_area .flex .service_btn.customer a {
    padding: 3.0833333333vw 1.6666666667vw 2.75vw 3.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #service_area .flex .service_btn.customer a {
    padding: 5.8666666667vw 9.3333333333vw 6.9333333333vw 6.6666666667vw;
    border-radius: 1.8666666667vw;
  }
}
#service_area .flex .service_btn.customer a .in .title02 {
  color: #E6791B;
}
#service_area .flex .service_btn.customer a .arrow {
  background: #E6791B;
}
#service_area .flex .service_btn.customer a:hover {
  background: #E6791B;
  opacity: 1;
}
#service_area .flex .service_btn.customer a:hover .in .title02 {
  color: #fff;
}
#service_area .flex .service_btn.customer a:hover .arrow {
  background: #fff;
}
#service_area .flex .service_btn.customer a:hover .arrow .dli-arrow-right {
  color: #E6791B;
}

#news_area {
  padding: 9rem 0 10rem;
}
@media screen and (max-width: 1200px) {
  #news_area {
    padding: 7.5vw 0 8.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area {
    padding: 10.6666666667vw 0 16vw;
  }
}
#news_area .flex {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 840px) {
  #news_area .flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 8vw;
  }
}
#news_area .flex .left .title_area {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-bottom: 5.8rem;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .left .title_area {
    margin-bottom: 4.8333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .left .title_area {
    margin-bottom: 8vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .left .tabs {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 1.8666666667vw;
    width: 100%;
  }
}
#news_area .flex .left .tabs .tablink {
  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: 20rem;
  height: 6rem;
  font-size: 1.8rem;
  color: #191919;
  background: #EAEAE4;
  border-radius: 0.5rem;
  cursor: pointer;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .left .tabs .tablink {
    width: 16.6666666667vw;
    height: 5vw;
    font-size: 1.5vw;
    border-radius: 0.4166666667vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .left .tabs .tablink {
    width: auto;
    height: 9.3333333333vw;
    padding: 0 3.7333333333vw;
    font-size: 3.7333333333vw;
    border-radius: 1.3333333333vw;
  }
}
#news_area .flex .left .tabs .tablink + .tablink {
  margin-top: 1rem;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .left .tabs .tablink + .tablink {
    margin-top: 0.8333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .left .tabs .tablink + .tablink {
    margin-top: 0;
  }
}
#news_area .flex .left .tabs .tablink:hover, #news_area .flex .left .tabs .tablink.active {
  color: #fff;
  background: #009844;
}
#news_area .flex .news {
  max-width: 86rem;
  width: 76%;
}
@media screen and (max-width: 840px) {
  #news_area .flex .news {
    max-width: none;
    width: 100%;
  }
}
#news_area .flex .news .tabcontent {
  display: none;
}
#news_area .flex .news .tabcontent#cat1 {
  display: block;
}
#news_area .flex .news .item {
  padding-bottom: 3rem;
  margin-bottom: 3rem;
  border-bottom: 0.1rem solid #DDDDD4;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item {
    padding-bottom: 2.5vw;
    margin-bottom: 2.5vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item {
    padding-bottom: 7.2vw;
    margin-bottom: 7.2vw;
  }
}
#news_area .flex .news .item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#news_area .flex .news .item a .left {
  position: relative;
  max-width: 23.8rem;
  width: 28%;
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .left {
    max-width: none;
    width: 37.3333333333vw;
  }
}
#news_area .flex .news .item a .left .shop_name {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 3.5rem;
  padding: 0 1em;
  font-size: 1.4rem;
  color: #fff;
  font-weight: 700;
  background: #224F96;
  border-radius: 0.5rem 0 0.5rem 0;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item a .left .shop_name {
    height: 2.9166666667vw;
    font-size: 1.1666666667vw;
    border-radius: 0.4166666667vw 0 0.4166666667vw 0;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .left .shop_name {
    height: 6.4vw;
    font-size: 2.6666666667vw;
    border-radius: 1.3333333333vw 0 1.3333333333vw 0;
  }
}
#news_area .flex .news .item a .left figure {
  border-radius: 0.5rem;
  overflow: hidden;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item a .left figure {
    border-radius: 0.4166666667vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .left figure {
    border-radius: 1.3333333333vw;
  }
}
#news_area .flex .news .item a .right {
  max-width: 54.2rem;
  width: 68%;
  margin-right: 3.5rem;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item a .right {
    margin-right: 0;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .right {
    max-width: none;
    width: 43.2vw;
    margin-right: 0;
  }
}
#news_area .flex .news .item a .right .flex {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.3rem;
  margin-bottom: 1.6rem;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item a .right .flex {
    gap: 1.9166666667vw;
    margin-bottom: 1.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .right .flex {
    gap: 2.6666666667vw;
    margin-bottom: 2.6666666667vw;
  }
}
#news_area .flex .news .item a .right .flex .date {
  font-size: 1.4rem;
  color: #9A9A9A;
  font-weight: 600;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item a .right .flex .date {
    font-size: 1.1666666667vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .right .flex .date {
    font-size: 2.9333333333vw;
  }
}
#news_area .flex .news .item a .right .flex .cat {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 3.2rem;
  padding: 0 1em;
  font-size: 1.3rem;
  color: #47B022;
  border: 0.1rem solid #47B022;
  border-radius: 1.6rem;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item a .right .flex .cat {
    height: 2.6666666667vw;
    font-size: 1.0833333333vw;
    border-radius: 1.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .right .flex .cat {
    height: 6.1333333333vw;
    font-size: 2.9333333333vw;
    border-radius: 4.2666666667vw;
  }
}
#news_area .flex .news .item a .right .title {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.825;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
@media screen and (max-width: 1200px) {
  #news_area .flex .news .item a .right .title {
    font-size: 1.3333333333vw;
  }
}
@media screen and (max-width: 840px) {
  #news_area .flex .news .item a .right .title {
    font-size: 3.7333333333vw;
    line-height: 1.78571;
  }
}
#news_area .btn a {
  margin: 7.8rem 0 0 auto;
}
@media screen and (max-width: 1200px) {
  #news_area .btn a {
    margin: 6.5vw 0 0 auto;
  }
}
@media screen and (max-width: 840px) {
  #news_area .btn a {
    margin: 6.4vw auto 0;
  }
}