@charset "UTF-8";
/* CSS Document */
/* CSS Document */
/* 基本設定-------------------------------------------*/
/* 共通パーツ-------------------------------------------*/
.main-wrapper {
  background: #fff;
}

.scroll-wrapper .swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}

/*------------------------------------------
mv__container
------------------------------------------*/
.mv__container {
  position: relative;
  width: 100%;
  height: 696px;
}
.mv__container .mv__video {
  pointer-events: none;
  width: 100%;
  height: 100%;
}
.mv__container .mv__video > video {
  width: 100%;
}
.mv__container .mv__ttl {
  width: 94.4vw;
  position: absolute;
  left: 0;
  bottom: 106px;
  z-index: 2;
}
@media (min-width: 1025px) {
  .mv__container .mv__ttl {
    width: 354px;
  }
}

/*------------------------------------------
lead__container
------------------------------------------*/
.lead__container {
  position: relative;
  z-index: 3;
  margin: -34px auto 0;
}
.lead__container::after {
  content: "";
  background: url(../images/lead_bg.png) no-repeat center/100%;
  width: 165px;
  height: 377px;
  position: absolute;
  right: 0;
  bottom: 55px;
  z-index: -1;
}
.lead__container .inner {
  width: 100%;
  padding: 0 20px 0 126px;
}
.lead__container .ttl {
  width: 58.4vw;
  margin-bottom: 48px;
}
@media (min-width: 1025px) {
  .lead__container .ttl {
    width: 219px;
  }
}
.lead__container .txt {
  letter-spacing: 0.1em;
  line-height: 2.5;
  font-size: 14px;
  position: relative;
}

/*------------------------------------------
special__container
------------------------------------------*/
.special__container {
  overflow: hidden;
  padding: 50px 0 0;
  position: relative;
  z-index: 3;
}
.special__container .ttl {
  width: 69.6vw;
  margin: 0 0 24px 30.4vw;
}
@media (min-width: 1025px) {
  .special__container .ttl {
    width: 261px;
    margin: 0 0 24px 114px;
  }
}
.special__container .scroll__container {
  padding-left: 20px;
}
.special__container .scroll__wrapper {
  position: relative;
  width: 100%;
  height: 600px;
}
.special__container .scroll__list {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 16px;
}
.special__container .item {
  width: 306px;
  height: 460px;
  border-radius: 20px;
  background: linear-gradient(135deg, #fff 0%, #fff 60%, #e8fffe 100%);
  -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  padding: 20px 18px;
}
.special__container .item .list--img {
  width: 100%;
  max-width: 250px;
  margin: 0 0 5px auto;
  position: relative;
}
.special__container .item .list--img::before {
  content: "";
  width: 33px;
  position: absolute;
  top: 0;
  left: -18px;
}
.special__container .item .list--img img {
  overflow: hidden;
  border-radius: 50%;
  -webkit-box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.16);
          box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.16);
}
.special__container .item .list--ttl {
  font-family: "Noto Serif JP", system-ui;
  font-weight: 700;
  font-size: 21px;
  line-height: 1.1;
  margin-bottom: 6px;
  position: relative;
}
.special__container .item .list--ttl::before {
  content: "";
  background: #0beb92;
  width: 100%;
  height: 7px;
  position: absolute;
  left: 0;
  bottom: 0;
}
.special__container .item .list--ttl > span {
  position: relative;
  z-index: 2;
}
.special__container .item .list--txt {
  color: #414141;
  letter-spacing: 0.05em;
  font-size: 13px;
}
.special__container .item:first-child .list--img::before {
  background: url(../images/scroll_ttl_1.png) no-repeat center/100%;
  height: 225px;
}
.special__container .item:nth-child(2) .list--img::before {
  background: url(../images/scroll_ttl_2.png) no-repeat center/100%;
  height: 172px;
}
.special__container .item:nth-child(3) .list--img::before {
  background: url(../images/scroll_ttl_3.png) no-repeat center/100%;
  height: 211px;
}
.special__container .item:nth-child(3) .list--img::after {
  content: "";
  background: url(../images/scroll_icon.png) no-repeat center/100%;
  width: 45px;
  height: 45px;
  position: absolute;
  right: 0;
  bottom: 0;
}

/*------------------------------------------
pickup__container
------------------------------------------*/
.pickup__container {
  margin-top: -292px;
  position: relative;
}
.pickup__container .pickup__ttl {
  width: 86.6666666667vw;
}
@media (min-width: 1025px) {
  .pickup__container .pickup__ttl {
    width: 325px;
  }
}
.pickup__container .pickup__list {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 40px 0;
}
.pickup__container .pickup__list > li {
  width: 50%;
}
.pickup__container .pickup__list .list--img {
  width: 100%;
  margin-bottom: 8px;
}
.pickup__container .pickup__list .list--in {
  padding: 0 10px;
  letter-spacing: 0.05em;
}
.pickup__container .pickup__list .list--ttl {
  letter-spacing: 0.15em;
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 8px;
}
.pickup__container .pickup__list .list--info,
.pickup__container .pickup__list .list--price,
.pickup__container .pickup__list .list--op {
  font-weight: 400;
  font-size: 12px;
}
.pickup__container .pickup__list .list--info,
.pickup__container .pickup__list .list--price {
  margin-bottom: 2px;
}

/*------------------------------------------
bnr__container
------------------------------------------*/
.bnr__container {
  padding: 0 0 72px;
}
.bnr__container .inner {
  background: url(../images/bnr_bg.png) no-repeat center/100%;
  height: 160px;
}
.bnr__container .bnr__cnt {
  width: 333px;
  margin: 0 auto;
}
.bnr__container .bnr__cnt img {
  margin-top: -16px;
}

/*------------------------------------------
brands__container
------------------------------------------*/
.brands__container {
  position: relative;
  padding: 13.3333333333vw 0 20.2666666667vw;
}
@media (min-width: 1025px) {
  .brands__container {
    padding: 50px 0 76px;
  }
}
.brands__container .brands__ttl {
  width: 97.3333333333vw;
  margin: 0 0 6.4vw 0;
}
@media (min-width: 1025px) {
  .brands__container .brands__ttl {
    width: 365px;
    margin: 0 0 24px 0;
  }
}
.brands__container .brands__list {
  width: 334px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 40px;
}
.brands__container .brands__list > li {
  width: 100%;
}
.brands__container .brands__list > li > a {
  display: block;
}
.brands__container .brands__list > li .img {
  width: 100%;
}
.brands__container .brands__list > li .ttl {
  text-align: center;
  margin-top: 8px;
  font-weight: 400;
  font-size: 14px;
}