@charset "UTF-8";
@-moz-document url-prefix() {}html {
  font-size: 10px;
}

body {
  overflow-x: hidden;
}

.l-container {
  width: 100%;
}

.l-container #feature {
  font-family: 游ゴシック体, 游ゴシック Medium, Yu Gothic Medium, Yu Gothic, YuGothic, Hiragino Kaku Gothic ProN, Meiryo, sans-serif;
  font-weight: 400;
  font-style: normal;
  margin: 32px auto 0;
  overflow: hidden;
  width: 100%;
}

.l-container #feature .default-img {
  display: block;
  height: auto;
  width: 100%;
}

.l-container:after{
  content: none;
}

.l-container #feature * {
  box-sizing: border-box;
}

.l-container #feature *::after {
  box-sizing: border-box;
}

.l-container #feature *::before {
  box-sizing: border-box;
}

.l-container #feature a{
  display: block;
  text-decoration: none;
  position: relative;
  transition: all 0.3s;
}

.l-container #feature a::after{
  background: rgba(255, 255, 255, 0.3);
  content: "";
  opacity: 0;
  top: 0;
  left: 0;
  position: absolute;
  pointer-events: none;
  transition: 0.3s;
  height: 100%;
  width: 100%;
}
.l-container #feature a:hover::after{
  cursor: pointer;
  opacity: 1;
}

.l-container #feature #sp-only{
  display: none !important;
}

.l-container #feature .target[data-fade="fadeIn"]{
  opacity: 0;
  transform: translateY(8rem);
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.l-container #feature .target[data-fade="fadeIn"][data-is-active="true"]{
  opacity: 1;
  transform: translateY(0);
}

/* credit */

.l-container #feature .creditList{
  width: fit-content;
}

.l-container #feature .credit{
  display: flex;
  flex-wrap: wrap;
  gap: 7px 2px;
}

.l-container #feature .credit li,
.l-container #feature .credit li a{
  color: #666;
  display: flex;
  font-family: "meno-banner-condensed", serif;
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 0.02em;
  line-height: 1;
  position: relative;
}

.l-container #feature .credit li .price{
  margin: 0 0 0 2.5px;
}

.l-container #feature .credit li::after{
  content: "/";
  margin: 0 0 0 2px;
}

.l-container #feature .credit li:last-of-type::after,
.l-container #feature .credit01 li:nth-of-type(3)::after,
.l-container #feature .credit03 li:nth-of-type(3)::after,
.l-container #feature .credit08 li:nth-of-type(3)::after{
  content: none;
}

.l-container #feature .credit01{
  margin: 14.5px 0 0;
  width: 300px;
}
.l-container #feature .credit02{
  margin: 14.5px 0 0;
}
.l-container #feature .credit03{
  margin: 14.5px auto 0;
  width: 280px;
}

.l-container #feature .credit04{
  margin: 14.5px auto 0;
}
.l-container #feature .credit05{
  margin: 14.5px auto 0;
}

.l-container #feature .credit06{
  margin: 14.5px auto 0;
}
.l-container #feature .credit07{
  margin: 110px auto 0;
}
.l-container #feature .credit07 .credit li,
.l-container #feature .credit07 .credit li a{
  color: #fff;
}
.l-container #feature .credit08{
  margin: 8.5px auto 0;
  width: 70%;
}

.l-container #feature .credit03 .credit,
.l-container #feature .credit05 .credit,
.l-container #feature .credit08 .credit{
  justify-content: center;
}

/* hero */

.l-container #feature .hero {
  margin: 0 auto;
  position: relative;
  width: 1000px;
}

.l-container #feature .hero__mv{
  left: 3px;
  margin: 0 auto;
  position: relative;
  width: 100%;
}

.l-container #feature .hero__text{
  color: #040000;
  font-family: "seiwa-do-l", sans-serif;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0.15em;
  line-height: 2.14285;
  margin: 95px auto 0;
  text-align: center;
  width: fit-content;
}

/* main */

.l-container #feature .sec{
  margin: 0 auto;
  position: relative;
  width: 100%;
}

.l-container #feature .sec .inner{
  margin: 0 auto;
  position: relative;
}

.l-container #feature .sec .sec__flex{
  display: flex;
}

.l-container #feature .sec .sec__img{
  position: relative;
}

/* sec01 */

.l-container #feature .sec01{
  margin: 97px auto 0;
}

.l-container #feature .sec01 .inner{
  left: -17px;
  width: 762px;
}

.l-container #feature .sec01 .img01{
  margin: 0;
  width: 500px;
}

.l-container #feature .sec01 .item02{
  margin: -177px 0 0 auto;
  width: 343.5px;
}

.l-container #feature .sec01 .img03{
  margin: -122px 0 0 100px;
  width: 241.6px;
}

/* sec02 */

.l-container #feature .sec02{
  margin: 179px auto 0;
}

.l-container #feature .sec02 .flex01{
  align-items: flex-start;
  margin: 0 auto;
  width: 1400px;
}
.l-container #feature .sec02 .flex02{
  flex-wrap: wrap;
  margin: 0 0 0 auto;
  justify-content: space-between;
  width: 564px;
}

.l-container #feature .sec02 .img04{
  margin: 233px 0 0 182px;
  width: 450px;
}
.l-container #feature .sec02 .img05{
  width: 280px;
}

/* sec03 */

.l-container #feature .sec03{
  margin: 180px auto 0;
}

.l-container #feature .sec03 .inner{
  width: 835px;
}

.l-container #feature .sec03 .img06,
.l-container #feature .sec03 .img07{
  margin: 0 auto;
  width: 400px;
}

.l-container #feature .sec03 .sec__loop{
  position: absolute;
  top: 26px;
  left: 0;
  width: 371.8px;
  z-index: 10;
}

.l-container #feature .sec03 .sec__loop-inner{
  display: flex;
  overflow-x: clip;
  position: relative;
  width: 100%;
}

.l-container #feature .sec03 .sec__loop .sec__loop-text{
  flex-shrink: 0;
  white-space: nowrap;
  width: 371.8px;
  &:nth-of-type(odd){
    animation: MoveLeft01 20s -10s infinite linear;
  }
  &:nth-of-type(even){
    animation: MoveLeft02 20s infinite linear;
  }
}

@keyframes MoveLeft01 {
  from {transform: translateX(100%);}
  to {transform: translateX(-100%);}
}

@keyframes MoveLeft02 {
  from {transform: translateX(0);}
  to {transform: translateX(-200%);}
}

/* sec04 */

.l-container #feature .sec04{
  margin: 180px auto 0;
}

.l-container #feature .sec04 .inner{
  width: 650px;
}

.l-container #feature .sec04 .flex01{
  flex-wrap: wrap;
  margin: 0 auto;
  width: 100%;
}

.l-container #feature .sec04 .img08{
  width: 325px;
}

/* sec05 */

.l-container #feature .sec05{
  margin: 102px auto 0;
}

.l-container #feature .sec05 .sec__ttl{
  margin: 0 auto;
  width: 415.2px;
}

.l-container #feature .sec05 .sec__swiper{
  margin: 98px auto 0;
  width: 540px;
}

/* sec06 */

.l-container #feature .sec06{
  margin: 180px auto 0;
}

.l-container #feature .sec06 .inner{
  left: -2px;
  width: 908px;
}

.l-container #feature .sec06 .flex01{
  flex-wrap: wrap;
  margin: 0 auto;
  position: relative;
  width: 100%;
}

.l-container #feature .sec06 .img10{
  margin: 0 0 0 516px;
  position: relative;
  width: 179px;
  z-index: 1;
}
.l-container #feature .sec06 .img11{
  margin: -78px 0 0 684px;
  position: relative;
  width: 224.98px;
  z-index: 2;
}
.l-container #feature .sec06 .img12{
  margin: -217px 0 0 440px;
  position: relative;
  width: 283px;
  z-index: 3;
}
.l-container #feature .sec06 .item13{
  margin: -449px 0 0 0;
  position: relative;
  width: 464.5px;
  z-index: 1;
}

.l-container #feature .sec06 .sec__loop{
  position: absolute;
  top: 80px;
  left: 30px;
  height: 282px;
  width: 10.58px;
  z-index: 10;
}

.l-container #feature .sec06 .sec__loop-inner{
  overflow: hidden;
  position: relative;
  height: 100%;
  width: 100%;
}

.l-container #feature .sec06 .sec__loop .sec__loop-text{
  flex-shrink: 0;
  white-space: nowrap;
  height: 282px;
  width: 10.58px;
  &:nth-of-type(odd){
    animation: MoveLeft03 20s -10s infinite linear;
  }
  &:nth-of-type(even){
    animation: MoveLeft04 20s infinite linear;
  }
}

@keyframes MoveLeft03 {
  from {transform: translateY(100%);}
  to {transform: translateY(-100%);}
}

@keyframes MoveLeft04 {
  from {transform: translateY(0);}
  to {transform: translateY(-200%);}
}

/* sec07 */

.l-container #feature .sec07{
  margin: 220px auto 0;
}

.l-container #feature .sec07 .img14{
  width: 340px;
}
.l-container #feature .sec07 .item15{
  background: url("../img/img15-bg.jpg") center top / contain no-repeat;
  margin: 150px auto 0;
  height: 681px;
  width: 1340px;
}
.l-container #feature .sec07 .img15{
  margin: 0 auto;
  padding: 120px 0 0;
  position: relative;
  width: 660px;
}
.l-container #feature .sec07 .img15::before,
.l-container #feature .sec07 .img15::after{
  color: #fff;
  content: "SPRING";
  font-family: "acumin-pro-semi-condensed", sans-serif;
  font-weight: 200;
  font-size: 15.97px;
  position: absolute;
  bottom: -30px;
  left: 0;
}
.l-container #feature .sec07 .img15::after{
  content: "2025";
  bottom: -28px;
  left: initial;
  right: 0;
}

.l-container #feature .sec07 .sec__loop{
  margin: 0 auto;
  overflow: hidden;
  width: 100%;
}

.l-container #feature .sec07 .sec__loop-inner{
  display: flex;
  gap: 0 4px;
  width: 100%;
}

.l-container #feature .sec07 .sec__loop-slide{
  display: flex;
  flex-shrink: 0;
  gap: 0 4px;
  &:nth-of-type(even){
    padding: 0 4px 0 0;
  }
}
.l-container #feature .sec07 .sec__loop-slide.on{
  &:nth-of-type(odd){
    animation: MoveLeft01 50s -25s infinite linear;
  }
  &:nth-of-type(even){
    animation: MoveLeft02 50s infinite linear;
  }
}

.l-container #feature .sec07 .js-fade{
  opacity: 0;
  transform: translateY(10%);
  transition: ease-in, opacity 1s, transform 1s;
}
.l-container #feature .sec07 .js-fade.show{
  opacity: 1;
  transform: translateY(0);
}

.l-container #feature .sec07 .js-fade.delay01{
  transition-delay: 0.3s;
}
.l-container #feature .sec07 .js-fade.delay02{
  transition-delay: 0.6s;
}
.l-container #feature .sec07 .js-fade.delay03{
  transition-delay: 0.9s;
}
.l-container #feature .sec07 .js-fade.delay04{
  transition-delay: 1.2s;
}
.l-container #feature .sec07 .js-fade.delay05{
  transition-delay: 1.5s;
}
.l-container #feature .sec07 .js-fade.delay06{
  transition-delay: 1.8s;
}
.l-container #feature .sec07 .js-fade.delay07{
  transition-delay: 2.1s;
}

/* sec08 */

.l-container #feature .sec08{
  margin: 180px auto 0;
}

.l-container #feature .sec08 .inner{
  width: 836px;
}

.l-container #feature .sec08 .sec__ttl{
  margin: 176px auto 0;
  width: 630.87px;
}

.l-container #feature .sec08 .sec__staff{
  color: #212121;
  font-family: "meno-banner-condensed", serif;
  font-weight: 300;
  font-size: 14px;
  letter-spacing: 0.0em;
  line-height: 1.5;
  margin: 98px auto 0;
  text-align: center;
}

.l-container #feature .sec08 .sec__btn{
  margin: 180px auto 0;
  width: 280px;
}

.l-container #feature .sec08 .img16{
  margin: 0 0 0 7px;
  width: 500px;
}
.l-container #feature .sec08 .item17{
  margin: -221px 0 0 auto;
  width: 360px;
}

/* swiper */

.l-container #feature .swiper-pagination{
  display: flex;
  gap: 0 4px;
  justify-content: space-between;
  margin: auto;
  bottom: 14px;
  left: 0;
  right: 0;
  width: fit-content;
}
.l-container #feature .swiper-pagination-bullet{
  border-radius: 0;
  background: #fff;
  margin: 0 !important;
  opacity: 1;
  position: relative;
  height: 1px;
  width: 20px;
}
.l-container #feature .swiper-pagination-bullet::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  background: #515151;
}
.l-container #feature .swiper-pagination-bullet-active::before {
  animation: pagination 2s linear forwards;
}

@keyframes pagination{
  100% {width: 100%; opacity: 1;}
}