/* --- サブカテゴリー 設定 --- */

.select--sub-layer {
  max-width: 100%;
  display: block;
  margin: 0 auto 20px auto;
  padding: 0;
  font-size: 1.1rem;
}

.select--sub-layer:focus {
  outline: none;
}

@media only screen and (max-width: 768px) {
  .select--sub-layer {
   margin: 20px auto 0 auto;
  }
}

/* --- ソート 設定 --- */

.itemsortWrap {
  width: 100%;
  height: 50px;
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;}

.itemsort {
  width: 100%;
  height: 50px;
  margin: 0;
  padding: 0;
  text-align: center;
}

.itemsortLeft {
  float: left;
  width: 50%;
  height: 50px;
  margin: 0;
  padding: 0 25px 0 0;
}

.itemsortRight {
  float: left;
  width: 50%;
  height: 50px;
  margin: 0;
  padding: 0 0 0 25px;
}

.itemsort p {
  width: 100%;
  height: 48x;
  line-height: 48px;
  margin: 0;
  padding: 0;
  font-weight: bold;
  color: #000;
  font-size: 1.1rem;
  border: 1px solid #DDD;
  background-color: #FFF;
}

.itemsort a {
  display: block;
  width: 100%;
  height: 48x;
  font-weight: bold;
  color: #000;
  font-size: 1.1rem;
  background-color: #FFF;
}

.itemsort a:hover {
  color: #FFF;
  background-color: #000;
}

.itemsort a:active {
  color: #FFF;
  background-color: #000;
}

@media only screen and (max-width: 768px) {
  .itemsortWrap {
   height: 45px;
   padding: 20px 0 40px 0;
  }
  .itemsort {
   height: 45px;
  }
  .itemsortLeft {
   height: 45px;
   padding: 0 10px 0 0;
  }
  .itemsortRight {
   height: 45px;
   padding: 0 0 0 10px;
  }
  .itemsort p {
   height: 45px;
   line-height: 45px;
  }
  .itemsort a {
   height: 43px;
  }
}

/* --- 商品数 設定 --- */

.product__count {
  width: 100%;
  height: 20px;
  line-height: 20px;
  margin: 20px 0 20px 0;
  padding: 0;
  font-size: 1.1rem;

  color: #666;
  text-align: right;
}

/* --- プロダクトリスト 設定 --- */

.section__block {
  margin: 0 0 0 -30px;
}

@media only screen and (max-width: 768px) {
 .section__block {
  margin: 0 0 0 0;
 }
}

.product-list__freespace {
  margin: 0;
}

.product-list__unit {
  padding: 0;
}

.product-list__unit__inner {
  margin: 0 0 0 30px;
  padding: 30px 0;
}

@media only screen and (max-width: 768px) {
  .product-list__unit__inner {
   margin: 0;
   padding: 20px 0;
  }
  .product-list__unit:nth-child(2n+1){
   padding-right: 10px;
  }
  .product-list__unit:nth-child(2n){
   padding-left: 10px;
  }
}

.product-list__unit__inner p {
  margin: 0;
}

.product-list__photo {
  display: block;
  width: 100%;
  margin: 0 auto 10px auto;
}

.product-list__text {
  display: block;
  height: 20px;
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
}

@media only screen and (max-width: 768px) {
  .product-list__text {
   margin: 0; padding: 0 10px;
  }
}

.product-list__expl {
  font-size: 1.1rem;
}

.product-list__price,
.option__price {
  font-size: 1.1rem;
  color: #000;
}

.product-list__regular-price,
.option__regular-price {
  font-size: 1.1rem;
  color: #000;
}

.product-list__soldout,
.option__stock {
  font-size: 1.1rem;
  color: #BF0000;
  font-weight: bold;
}

.product-list__regular {
  font-size: 1.1rem;
  color: #BF0000;
}

/* --- 商品名 設定 --- */

.product-list__unit__inner p {
  height: 20px;
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

h5 {
  height: 20px;
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

h6 {
  height: 20px;
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  font-weight: normal;
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* --- ページネーション 設定 --- */

.pagenation {
  margin: 0;
  padding: 60px 0;
  text-align: center;
}

.pagenation__list {
  margin: 0; 
  padding: 0;
}

.pagenation__unit {
  display: inline-block;
  line-height: 1;
  margin: 0;
  padding: 2px 2px;
}

.pagenation__unit a {
  margin: 0;
  padding: 2px 2px;
  color: #000;
}

.pagenation__unit a:hover {
  color: #666;
}

.pagenation__unit a:active {
  color: #666;
}

.pagenation__unit span {
  color: #666;
  padding: 2px 2px;
}

.pagenation__info {
  font-size: 1.4em;
}

/* --- デザイナー 設定 --- */

#wrapper {
  overflow: hidden;
}

.designersinfoWrap {
  position: relative;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  padding: 0;
}

.designersinfoWrap img {
  width: 100%;
  margin: 0;
  padding: 0;
}

.designersinfo {
  width: 70%;
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin: 0;
  padding: 0;
}

.designersinfo h2 {
  height: 30px;
  line-height: 30px;
  margin: 0;
  padding: 0;
  font-size: 2rem;
  color: #FFF;
  font-family: 'EB Garamond', serif;
  font-weight: 400;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.designersinfo h3 {
  height: 20px; 
 line-height: 20px;
  margin: 0 0 10px 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  font-weight: 400;
}

.designersinfo h4 {
  height: 20px;
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  font-weight: normal;
}

.designersinfo h5 {
  height: 20px;
  line-height: 20px;
  margin: 10px 0 0 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  font-weight: normal;
}

.designersinfo p {
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  text-align: justify;
  text-justify: inter-ideograph;
}

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  .pc {
   display: none !important;
  }
  .sp {
   display: block !important;
  }
  .designersinfoWrap {
   aspect-ratio: 1 / 1;
  }
  .designersinfo {
   width: 100%;
   padding: 0 20px 0 20px;
  }
  .designersinfo h2 {
   font-size: 2rem;
  }
   img {
   max-width: 100%;
  }
}

/* --- デザイナー(新設定) 設定 --- */

.designerWrap {
  position: relative;
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  padding: 0;
  aspect-ratio: 7 / 4;
  background-color: #000;
}

.designerWrap img {
  width: 100%;
  margin: 0;
  padding: 0;
  opacity: 0.5;
  aspect-ratio: 7 / 4;
  object-fit: cover;
}

.designer {
  width: 70%;
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin: 0;
  padding: 0;
}

.designer h2 {
  height: 30px;
  line-height: 30px;
  margin: 0;
  padding: 0;
  font-size: 2rem;
  color: #FFF;
  font-family: 'EB Garamond', serif;
  font-weight: 400;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.designer h3 {
  height: 20px; 
 line-height: 20px;
  margin: 0 0 10px 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  font-weight: 400;
}

.designer h4 {
  height: 20px;
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  font-weight: normal;
}

.designer h5 {
  height: 20px;
  line-height: 20px;
  margin: 10px 0 0 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  font-weight: normal;
  text-align: left
}

.designer p {
  line-height: 20px;
  margin: 0;
  padding: 0;
  font-size: 1.1rem;
  color: #FFF;
  text-align: justify;
  text-justify: inter-ideograph;
}

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  .designerWrap {
   aspect-ratio: 4 / 5;
  }
  .designerWrap img {
   aspect-ratio: 4 / 5;
  }
  .designer {
   width: 100%;
   padding: 0 20px 0 20px;
  }
  .designer h2 {
   font-size: 2rem;
  }
  .pc {
   display: none !important;
  }
  .sp {
   display: block !important;
  }
}