@charset "UTF-8";
.l-container {
  margin: 0 auto;
  width: 100%;
}

:root {
  --base-value: 2100;
}

html {
  font-size: calc(1 * (100vw / var(--base-value)));
}

@-moz-document url-prefix() {}.l-container {
  width: 100%;
  overflow: hidden;
}

.l-footer {
  padding-top: 0;
  position: relative;
  z-index: 2;
}

.pc-footer {
  margin-top: 0;
}

.feature {
  box-sizing: border-box;
  color: #000;
  font-feature-settings: "palt";
  font-family: "Yu Gothic", "游ゴシック", "YuGothic", "游ゴシック体", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", sans-serif;
  font-weight: 400;
  font-style: normal;
  display: block;
  margin: 0 auto;
  padding: 40px 0 0;
  overflow: hidden;
  width: 100%;
}

.feature a.is-disabled {
  pointer-events: none !important;
}

.feature > .inner {
  margin: auto;
}

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

.feature * {
  box-sizing: border-box;
}

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

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

.feature a {
  display: block;
  text-decoration: none;
  position: relative;
}

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

.feature .default-img {
  display: block;
  position: relative;
  height: auto;
  width: 100%;
}

.feature .link{
  transition: all 0.8s;
}
.feature .link:hover {
  opacity: .7;
  transition: all 0.8s;
}

.feature * {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

.feature a {
  display: block;
  position: relative;
  height: auto;
  width: 100%;
}
.feature a:hover{
  cursor: pointer;
  text-decoration: none;
  transition: 0.3s;
}

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

.feature #sp-only{
  display: none;
}


/* メインビジュアル（.hero)
----------------------------*/

.feature .hero{
  background: #e0cec7;
  padding: 0 0 16.66vw;
  position: relative;
}
.feature .hero .hero__img{
  margin: 0 auto;
  width: 100%;
}

.feature .hero .hero__nav{
  display: flex;
  justify-content: space-between;
  margin: 90px auto 0;
  width: 880px;
}

.feature .hero .hero__nav-btn{
  background: #3a150f;
  position: relative;
  height: 90px;
  width: 420px;
}
.feature .hero .hero__nav-btn::before{
  background: url(../img/arrow01.svg) center top / contain no-repeat;
  content: "";
  display: block;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 56.5px;
  position: absolute;
  height: 10px;
  width: 16px;
}
.feature .hero .hero__nav-btn:nth-of-type(1)::before{
  top: 10px;
  right: 44.5px;
}

.feature .hero .hero__nav-btn a{
  align-items: center;
  color: #e0cec7;
  display: flex;
  font-family: "baskerville-poster-pt", serif;
  font-weight: 400;
  font-size: 30px;
  justify-content: center;
  line-height: 1;
  padding: 6px 18px 0 0;
  height: 100%;
  width: 100%;
}
.feature .hero .hero__nav-btn a span{
  font-style: italic;
  margin: 0 6px 0 0;
}

.feature .hero .hero__text{
  color: #3a150f;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.875;
  margin: 55px auto 0;
  text-align: center;
}

.feature .hero .hero__ttl{
  color: #3a150f;
  font-family: "baskerville-poster-pt", serif;
  font-weight: 400;
  font-size: 60px;
  letter-spacing: 0;
  line-height: 1;
  margin: 147px auto 0;
  width: fit-content;
}

.feature .hero .hero__panel{
  margin: 27px auto 0;
}

.feature .hero .hero__btn{
  background: #3a150f;
  left: -2px;
  margin: 58px auto 0;
  position: relative;
  height: 70px;
  width: 450px;
}
.feature .hero .hero__btn::before{
  background: url(../img/arrow02.svg) center top / contain no-repeat;
  content: "";
  display: block;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 19px;
  position: absolute;
  height: 14px;
  width: 8px;
}

.feature .hero .hero__btn a{
  align-items: center;
  color: #e0cec7;
  display: flex;
  font-family: "baskerville-urw", serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1;
  justify-content: center;
  padding: 0 0 0 5px;
  height: 100%;
  width: 100%;
}

/* 共通
----------------------------*/

.feature .sec{
  position: relative;
  width: 100%;
}

.feature .sec .inner{
  position: relative;
  width: 100%;
  z-index: 2;
}

.feature .sec .sec__flex{
  display: flex;
  position: relative;
}

.feature .sec .sec__img{

}

.feature .sec .sec__for{
  color: #3a150f;
  font-family: "baskerville-poster-pt", serif;
  font-weight: 400;
  font-size: 60px;
  left: 3px;
  line-height: 1;
  margin: 0 auto;
  position: relative;
  width: fit-content;
}
.feature .sec .sec__for span{
  font-style: italic;
  font-size: 36px;
  letter-spacing: -0.05em;
  margin: 0 6px 0 0;
}

.feature .sec .sec__ttl{
  position: relative;
}

.feature .sec .sec__panel{
  margin: 36px auto 0;
}

.feature .sec .sec__btn{
  background: #3a150f;
  margin: 58px auto 0;
  position: relative;
  height: 70px;
  width: 450px;
}
.feature .sec .sec__btn::before{
  background: url(../img/arrow02.svg) center top / contain no-repeat;
  content: "";
  display: block;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 19px;
  position: absolute;
  height: 14px;
  width: 8px;
}

.feature .sec .sec__btn a{
  align-items: center;
  color: #e0cec7;
  display: flex;
  font-family: "baskerville-urw", serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1;
  justify-content: center;
  padding: 0 0 0 11px;
  height: 100%;
  width: 100%;
}

.feature .sec.him .sec__btn{
  background: #d3c1a5;
}
.feature .sec.him .sec__btn::before{
  background: url(../img/arrow03.svg) center top / contain no-repeat;
}
.feature .sec.him .sec__btn a{
  color: #351a12;
  letter-spacing: -0.02em;
  padding: 0 0 0 3px;
}

/* sec01
----------------------------*/

.feature .sec01{
  margin: -16.66vw auto 0;
}
.feature .sec01::before{
  background: url(../img/bg01.svg) center top / cover no-repeat;
  content: "";
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  position: absolute;
  height: 16.66vw;
  width: 100%;
  z-index: 1;
}
.feature .sec01::after{
  background: #c99b9b;
  content: "";
  display: block;
  margin: auto;
  top: 16.6vw;
  left: 0;
  right: 0;
  position: absolute;
  height: calc(100% - 16.6vw);
  width: 100%;
  z-index: 1;
}

.feature .sec01 .sec__for{
  padding: 14.05vw 0 0;
}

.feature .sec01 .sec__ttl{
  left: 4px;
  margin: 80px auto 0;
  width: 463.47px;
}

/* sec02
----------------------------*/

.feature .sec02{
  background: #c99b9b;
  margin: 0 auto;
  padding: 160px 0 0;
}

.feature .sec02 .sec__ttl{
  left: 11px;
  margin: 0 auto;
  width: 416.25px;
}

/* sec03
----------------------------*/

.feature .sec03{
  background: #c99b9b;
  margin: 0 auto;
  padding: 160px 0 304px;
  z-index: 1;
}

.feature .sec03 .sec__ttl{
  left: 4px;
  margin: 0 auto;
  width: 335.42px;
}

/* sec04
----------------------------*/

.feature .sec04{
  margin: -232px auto 0;
  z-index: 2;
}
.feature .sec04::before{
  background: url(../img/bg02.svg) center top / cover no-repeat;
  content: "";
  display: block;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  position: absolute;
  height: 17.06vw;
  width: 100%;
  z-index: 1;
}
.feature .sec04::after{
  background: #351a12;
  content: "";
  display: block;
  margin: auto;
  top: 17vw;
  left: 0;
  right: 0;
  position: absolute;
  height: calc(100% - 16vw);
  width: 100%;
  z-index: 1;
}

.feature .sec04 .sec__for{
  color: #aa9b88;
  padding: 225px 0 0;
}

.feature .sec04 .sec__ttl{
  left: 4px;
  margin: 92px auto 0;
  width: 463.47px;
}

/* sec05
----------------------------*/

.feature .sec05{
  background: #351a12;
  margin: 0 auto;
  padding: 160px 0 0;
}

.feature .sec05 .sec__ttl{
  left: 4px;
  margin: 0 auto;
  width: 327.39px;
}

/* sec06
----------------------------*/

.feature .sec06{
  background: #351a12;
  margin: 0 auto 10.32vw;
  padding: 160px 0;
}
.feature .sec06::after{
  background: url(../img/bg03.svg) center top / cover no-repeat;
  content: "";
  display: block;
  margin: auto;
  bottom: -10.32vw;
  left: 0;
  right: 0;
  position: absolute;
  height: 10.32vw;
  width: 100%;
}

.feature .sec06 .sec__ttl{
  left: 4px;
  margin: 0 auto;
  width: 341px;
}

/* panel共通
----------------------------*/

.feature .panel__list{
  width: 580px;
}

.feature .panel__list .new-list ul{
  display: flex;
  flex-wrap: wrap;
  gap: 28px 0;
  justify-content: space-between;
  width: 100%;
}

.feature .panel__list .new-list ul .m-item{
  width: 180px;
}

.feature .panel__list .new-list ul .m-item-image{
  position: relative;
}
.feature .panel__list .new-list ul .m-item-image img{
  display: block;
  position: relative;
  height: auto;
  width: 100%;
}

.feature .panel__list .new-list ul .m-item-description{
  margin: 10px 0 0 -3px;
}

.feature .panel__list .new-list ul .m-item-brand,
.feature .panel__list .new-list ul .m-item-name,
.feature .panel__list .new-list ul .m-item-price{
  color: #3a150f;
  font-family: "Yu Gothic", "游ゴシック", "YuGothic", "游ゴシック体", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.14285;
}
.feature .him .panel__list .new-list ul .m-item-brand,
.feature .him .panel__list .new-list ul .m-item-name,
.feature .him .panel__list .new-list ul .m-item-price{
  color: #aa9b88;
}

.feature .panel__list .new-list ul .m-item-name{
  margin: -1px 0 0;
}

.feature .panel__list .new-list ul .m-item-icon,
.feature .panel__list .new-list ul .m-item-magazine,
.feature .panel__list .new-list ul .m-item-soldout,
.feature .panel__list .new-list ul .m-item-category{
  display: none;
}

.feature .panel__list .new-list ul .m-item a::after{
  content: none;
}
.feature .panel__list .new-list ul .m-item .m-item-image::after{
  background: rgba(255, 255, 255, 0.6);
  content: "";
  opacity: 0;
  top: 0;
  left: 0;
  position: absolute;
  height: 100%;
  width: 100%;
}
.feature .panel__list .new-list ul .m-item .m-item-image:hover::after{
  opacity: 1;
  transition: 0.4s;
}

.pc-footer{
  margin: 0;
}
.l-footer{
  padding: 0;
}