.pc {
  display: block !important;
}

.sp {
  display: none !important;
}


/* トップ */


/* サイドバー */

#wrapper {
  width: 100%;
  margin: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}


/* 左カラム */

.left-column {
  width: 17%;
  margin-right: 1em;
}


/* 右カラム */

.right-column {
  width: 58%;
}


/* カテゴリーリスト */

* {
  margin: 0;
  padding: 0;
}

.header-style {
  background-color: #225439;
  padding: 10px;
  color: #FFF;
}

.sidebar-list {
  margin: 10px;
}

.sidebar-list ul {
  list-style-type: none;
  width: auto;
}

.sidebar-list h3 {
  font-weight: bold;
  margin: 6px;
  color: #225439;
}

.sidebar-list li img {
  float: left;
  margin: 8px;
  width: 100px;
  height: 100px;
  object-fit: cover;
}

.sidebar-list li p {
  font-size: 13px;
}

.sidebar-list li {
  overflow: auto;
}

.sidebar-list li:hover {
  background: #eee;
  cursor: pointer;
}


/* 検索ボックス */

.search_container {
  margin: 1em;
  box-sizing: border-box;
  position: relative;
  border: 2px solid #225439;
  padding: 0px 10px;
  height: 2.3em;
  width: 90%;
  overflow: hidden;
}

.search_container input[type="text"] {
  border: none;
  height: 2em;
}

.search_container input[type="text"]:focus {
  outline: 0;
}

.search_container input[type="submit"] {
  cursor: pointer;
  font-family: FontAwesome;
  font-size: 1.3em;
  border: none;
  background: none;
  color: #333;
  position: absolute;
  width: 2.5em;
  height: 2em;
  right: 0;
  top: -5px;
  outline: none;
}

.container {
  max-width: 1300px;
  margin: 0 auto;
}

.ie8 .container {
  width: 1300px;
}

.txt--not-applicable {
  font-size: 1.5em;
  margin: 3em 0 4em;
  text-align: center;
  color: #999;
}

.p-top-logo {
  font-size: 20px;
  line-height: 1.4;
  max-width: 90%;
  margin: 30px auto;
  text-align: center;
}

.p-top-logo a {
  display: block;
  transition: opacity .2s;
  text-decoration: none;
  color: #333;
}

.p-top-logo a:hover {
  opacity: .66;
}

.p-top-logo a:active {
  opacity: 1;
}

#slider-wrapper .bx-controls-direction a {
  z-index: 100;
}

#slider-wrapper .bx-viewport {
  top: 0;
  left: 0;
  border: 0;
  background: #f8f8f8;
  box-shadow: none;
}

#slider-wrapper .bx-wrapper img {
  margin: 0 auto;
}

#slider-wrapper .bx-caption {
  top: 0;
  bottom: auto;
  background: rgba(0, 0, 0, .3);
}

#slider-wrapper .bx-caption span {
  padding: 1.5em;
}

#slider-wrapper .bx-pager {
  bottom: 10px;
  padding-top: 0;
}

#slider-wrapper .bx-pager a {
  background: #fff;
}

#slider-wrapper .bx-pager a:hover,
#slider-wrapper .bx-pager a.active {
  background: < {
      $setting-slide-currentColor
  }
  >;
}

.p-news {
  line-height: 1.5;
  display: flex;
  text-align: start;
  align-items: baseline;
  justify-content: flex-start;
  width: 80%;
  min-width: 600px;
  margin: 0 auto;
}

.p-news::after {
  display: block;
  clear: both;
  content: '';
}

.p-news__label {
  font-size: 19px;
  font-weight: normal;
  line-height: 1.6;
  width: 150px;
  margin: 0;
  letter-spacing: 1px;
}

.p-news__content {
  line-height: 1.6;
  margin: 5px 0 20px 10px;
}

.p-news__content p:nth-child(1) {
  margin-top: 0;
}

.p-news__label {
  color: #A18A70;
}


/* .p-news__label::before {
  content: '-';
} */

.p-info {
  line-height: 1.5;
}

.p-contents {
  line-height: 1.5;
  margin-bottom: 40px;
}

.p-contents__list {
  margin: 0 0 20px;
  padding: 0;
  list-style-type: none;
}

.p-contents__list::after {
  display: block;
  clear: both;
  content: '';
}

.p-contents__list li {
  position: relative;
  box-sizing: border-box;
  padding: 0 2em 0 1em;
}

.p-contents__list li::before {
  position: absolute;
  top: .5em;
  left: 0;
  content: '-';
}

.p-contents__list a {
  display: block;
  max-width: 100%;
  padding: .5em 0;
  transition: opacity .2s;
  text-decoration: none;
  color: #333;
}

.p-contents__list a:hover {
  opacity: .66;
}

.p-contents__list a:active {
  opacity: 1;
}

.p-custom-banner {
  margin-top: 50px;
  text-align: center;
}

.p-custom-banner__unit {
  background: < {
      $setting-custom-textColor
  }
  >;
}

.p-custom-banner__unit--text {
  font-family: 'Montserrat', sans-serif;
  padding: 30px 10px;
  color: < {
      $setting-custom-textColor
  }
  >;
  background: < {
      $setting-custom-bgColor
  }
  >;
}

.p-custom-banner__unit--text a {
  color: < {
      $setting-custom-textColor
  }
  >;
}

.p-custom-banner__image {
  width: 100%;
}

.p-custom-banner__heading {
  font-size: 24px;
  padding: 10px 0;
}

.p-custom-banner__body {
  line-height: 1.5;
  padding: 10px 0;
}


/* news-list */

.news-list {
  list-style: none outside;
  margin: 0;
  padding: 0;
}

.news-list .item a {
  display: flex;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  text-decoration: none;
  color: #333;
  border-bottom: 1px solid #CCC;
  padding: 20px 20px;
}

.news-list .item:first-child a {
  border-top: 1px solid #CCC;
}

.news-list .item .date {
  margin: 0;
  min-width: 140px;
  font-size: 16px;
  color: #999;
  padding: 0 20px 0 0;
}

.news-list .item .category {
  margin: 0;
  min-width: 140px;
  padding: 0 20px 0 0;
}

.news-list .item .category span {
  background: #999;
  color: #FFF;
  text-align: center;
  display: inline-block;
  padding: 5px 20px;
  font-size: 12px;
  line-height: 1;
}

.news-list .item .title {
  margin: 0;
  width: 100%;
}

.news-list .item a:hover .title {
  color: #00F;
}


/* product list */

.select--sub-layer {
  max-width: 500px;
  display: block;
  margin: 2em auto;
}

.products-list {
  display: flex;
  justify-content: left;
  list-style: none;
  margin: 0;
  flex-wrap: wrap;
}

.products-list_inner {
  width: 25%;
  padding: 19px;
  box-sizing: border-box;
}

.product-list__unit {
  padding: 0;
}

.product-list__unit a:hover {
  text-decoration: none;
}

.product-list__unit__inner {
  padding: 0 20px;
}

.product-list__unit__inner p {
  margin: 0;
}

.product-list__photo {
  display: block;
  margin: 0 auto;
}

.products-list_bgphoto {
  display: block;
  background-size: cover;
  background-repeat: no-repeat;
  margin: 0 auto;
  width: 100%;
  height: auto;
  background-position: center;
  transition-duration: .3s;
  overflow: hidden;
  padding-top: 100%;
}

.products-list_bgphoto:hover {
  transition-duration: .3s;
  transform: scale(1.03);
}

.product-list__text {
  display: block;
  margin: .6em 0;
  line-height: 1.5;
  text-align: center;
}

.product-list__name {
  font-weight: bold;
  color: #666;
}

.product-list__expl {
  font-size: .8em;
}

.product-list__price,
.option__price {
  color: #aaa;
  font-weight: bold;
}

.product-list__regular-price,
.option__regular-price {
  color: #aaa;
  text-decoration: line-through;
}

.product-list__soldout,
.option__stock {
  color: #FF0000;
  font-weight: bold;
}

.product-list__sort {
  text-align: right;
  margin: 2em 0;
}

.product-list__freespace {
  margin: 3em 0;
}

@media screen and (max-width: 768px) {
  /* ~768px */
  /* 左カラム */
  .left-column {
      display: none;
  }
  /* 右カラム */
  .right-column {
      width: 95%;
  }
  /* news-list */
  .news-list {
      list-style: none;
      margin: 0;
      padding: 0;
  }
  .news-list .item a {
      display: block;
      flex-wrap: wrap;
      flex-wrap: nowrap;
      text-decoration: none;
      color: #333;
      border-bottom: 1px solid #CCC;
      padding: -2px 90px;
  }
  .news-list .item:first-child a {
      border-top: 1px solid #CCC;
  }
  .news-list .item .date {
      margin: 0;
      min-width: 140px;
      font-size: 16px;
      color: #999;
      padding: 0 20px 0 0;
  }
  .news-list .item .category {
      margin: 0;
      min-width: 140px;
      padding: 0 20px 0 0;
  }
  .news-list .item .category span {
      background: #999;
      color: #FFF;
      text-align: center;
      display: inline-block;
      padding: 5px 20px;
      font-size: 12px;
      line-height: 1;
  }
  .news-list .item .title {
      margin: 0;
      width: 100%;
  }
  .news-list .item a:hover .title {
      color: #00F;
  }
  .p-news {
      width: 100%;
  }
  .products-list {
      display: flex;
      justify-content: left;
      list-style: none;
      margin: 0;
      flex-wrap: wrap;
  }
  .products-list_inner {
      width: 50%;
      padding: 19px;
      box-sizing: border-box;
  }
  .pickup-feature-cont {
      justify-content: center;
      padding: 0 2vw;
      position: relative;
      z-index: 0;
  }
  .feature-h3 {
      letter-spacing: 0;
  }
  .top-info-cont-inner {
      flex-wrap: wrap;
  }
  .pickup-feature-inner {
      width: 100%;
  }
  .info-imgcont {
      width: 100%;
      height: 300px;
      background-size: contain;
  }
  .info-imgcont img {
      max-width: 300px;
      height: auto;
  }
  .info-txtcont {
      width: 100%;
  }
  #wrapper {
      margin-bottom: 50px;
  }
  .p-news {
      line-height: 1.5;
      display: flex;
      flex-flow: column;
      text-align: start;
      width: 100%;
      margin: 0 auto;
  }
  .p-news__label {
      display: block;
  }
  .p-news__content {
      display: block;
      margin: unset !important;
  }
}

@media screen and (min-width: 600px) {
  .p-top-logo {
      display: none;
  }
  #slider-wrapper .bx-pager {
      bottom: 30px;
  }
  .p-contents__list li::before {
      top: 0;
  }
  .p-contents__list li {
      float: left;
      width: 50%;
      margin-bottom: 20px;
  }
  .p-contents__list li:nth-child(2n + 1) {
      clear: left;
  }
  .p-contents__list a {
      display: inline-block;
      padding: 0;
  }
  .p-custom-banner {
      display: table;
      width: 100%;
      margin-top: 100px;
      table-layout: fixed;
  }
  .p-custom-banner__unit {
      display: table-cell;
      box-sizing: border-box;
      width: 50%;
      max-width: 50%;
      vertical-align: middle;
      word-break: break-all;
  }
  .p-custom-banner__unit--text {
      padding: 10px 20px;
  }
}

@media screen and (min-width: 960px) {
  .p-news__label {}
  .p-news__content {
      overflow: hidden;
      margin: 0 0 20px;
  }
  .p-custom-banner__heading {
      font-size: 30px;
  }
}

/*202501カスタマイズここから-----------------------*/
.p-page-content {
  max-width: 100%;
}
#ranking {
  margin: 50px 0 40px;
}

/*--イチオシエリア------------------------------*/
/* 背景を画面全体に広げる */
.top-pick-section {
  background-color: #cf1126;
  width: 100%;
  position: relative;
  padding: 20px 0 50px;
  box-sizing: border-box;
  margin: 50px 0;
}

/* 中央寄せされたコンテンツ */
.top-pick-container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 15px;
  box-sizing: border-box;
}
/* 見出し */
.section-heading {
  font-size: 45px;
  color: #ffffff;
  text-align: center;
  margin: 40px 0 0px;
}
.section-subheading-w {
  text-align: center;
  margin: 10px 0 50px;
  color: #fff;
}

/* 上段 */
.top-pick-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  margin-bottom: 30px;
}

.left-area {
  flex: 1;
  max-width: 40%;
}

.product-image {
  width: 100%;
  height: auto;
  border-radius: 0; /* 角丸無し */
}

.right-area {
  flex: 1;
  max-width: 50%;
  text-align: left;
  padding: 0 60px;
}

/* 商品名 */
.productmidashi{
  color: #ffffff;
  font-weight: bold;
  margin-bottom: 10px;
  text-align: center;
}
.product-name {
  font-size: 40pt;
  color: #ffffff;
  font-weight: bold;
  margin-bottom: 10px;
  text-align: center;
}

/* 商品説明 */
.product-description {
  font-size: 14pt;
  line-height: 1.6;
  color: #ffffff;
  margin-bottom: 20px;
}

/* ボタン */
.button-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.detail-button, .line-button {
  width: 100%;
  padding: 10px;
  font-size: 14pt;
  border-radius: 0;
  border: none;
  cursor: pointer;
  text-align: center;
}

.detail-button {
  background-color: #fdf77f;
  color: #333333;
  margin-bottom: 15px;
  border-radius: 30px;
  padding: 20px 0;
}

.line-button {
  background-color: #02c755;
  color: #ffffff;
  border-radius: 30px;
  padding: 20px 0;
}

/* 下段 */
.bottom-gallery {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  gap: 10px;
}

.gallery-item {
  text-align: center;
  max-width: 22%;
}

.gallery-item a {
  display: block;
  text-decoration: none;
  color: inherit; /* テキストカラーを継承 */
}

.gallery-item img {
  width: 100%;
  border-radius: 0; /* 角丸無し */
}

.product-label {
  background-color: #555555;
  color: #ffffff;
  padding: 5px 10px;
  margin: 0; /* 間隔無し */
  display: block;
  width: 100%; /* 画像幅と揃える */
  box-sizing: border-box;
  text-align: center;
  border-radius: 0; /* 角丸無し */
}

@media screen and (min-width: 600px) {
   .newitems.c-product-list__item:nth-child(4n) {
    clear: both;
    display: none;
  }
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .top-pick-content {
    flex-direction: column;
    align-items: center;
  }
.left-area {
  flex: 1;
  max-width: 80%;
}
  .right-area {
    text-align: left;
    max-width: 100%;
    padding: 0px 20px;
  }
  .section-heading {
  font-size: 24px;
  }
  .product-name {
    font-size: 30pt;
  }

  .product-description {
    font-size: 12pt;
  }

  .bottom-gallery {
    flex-direction: column;
    align-items: center;
  }

  .gallery-item {
    max-width: 90%;
  }
  .bottom-gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2列表示 */
    gap: 10px; /* 要素間の余白 */
  }

  .bottom-gallery .gallery-item {
    width: 100%; /* 各要素がグリッドセル内に収まるように調整 */
  }
}


/*--TOPカテゴリエリア------------------------------*/
/* 背景を画面全体に広げる */
.top-cat-section {
  /*background-color: #fdf77f ;*/
  width: 100%;
  position: relative;
  padding: 20px 0 50px;
  box-sizing: border-box;
  margin: 50px 0;
}

/* 中央寄せされたコンテンツ */
.top-cat-container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 15px;
  box-sizing: border-box;
}
/* 見出し */
.cat-section-heading {
  font-size: 45px;
  color: #333;
  text-align: center;
  margin: 40px 0 0px;
}
.section-subheading {
  text-align: center;
  margin: 10px 0 50px;
  color: #333;
}

/* 下段 */
.bottom-gallery {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  gap: 10px;
}

.gallery-item {
  text-align: center;
  max-width: 22%;
  margin-bottom: 20px;
}

.gallery-item a {
  display: block;
  text-decoration: none;
  color: inherit; /* テキストカラーを継承 */
}

.gallery-item img {
  width: 100%;
  border-radius: 0; /* 角丸無し */
}

.product-label {
  background-color: #555555;
  color: #ffffff;
  padding: 5px 10px;
  margin: 0; /* 間隔無し */
  display: block;
  width: 100%; /* 画像幅と揃える */
  box-sizing: border-box;
  text-align: center;
  border-radius: 0; /* 角丸無し */
}


/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .top-cat-content {
    flex-direction: column;
    align-items: center;
  }
  .section-heading,.cat-section-heading,.pop-section-heading{
  font-size: 28px !important;
  }

  .bottom-gallery {
    flex-direction: column;
    align-items: center;
  }

  .gallery-item {
    max-width: 90%;
  }
  .bottom-gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2列表示 */
    gap: 10px; /* 要素間の余白 */
  }

  .bottom-gallery .gallery-item {
    width: 100%; /* 各要素がグリッドセル内に収まるように調整 */
  }
}


/*--TOP人気シリーズエリア------------------------------*/
/* 背景を画面全体に広げる */
.top-pop-section {
  /*background-color: #d6ecf2;*/
  width: 100%;
  position: relative;
  padding: 20px 0 50px;
  box-sizing: border-box;
  margin: 50px 0;
}

/* 中央寄せされたコンテンツ */
.top-pop-container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 15px;
  box-sizing: border-box;
}

/* 見出し */
.pop-section-heading {
  font-size: 45px;
  color: #333;
  text-align: center;
  margin: 40px 0 0px;
}

.section-subheading {
  text-align: center;
  margin: 10px 0 50px;
  color: #333;
}

/* 下段 */
.bottom-gallery-pop {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px;
}

.gallery-item-pop {
  text-align: center;
  flex-basis: 48%; /* PCで2列表示にするための確定幅 */
  margin-bottom: 20px;
}

.gallery-item-pop a {
  display: block;
  text-decoration: none;
  color: inherit; /* テキストカラーを継承 */
}

.gallery-item-pop img {
  width: 100%;
  border-radius: 0; /* 角丸無し */
}

.product-label {
  background-color: #555555;
  color: #ffffff;
  padding: 5px 10px;
  margin: 0; /* 間隔無し */
  display: block;
  width: 100%; /* 画像幅と揃える */
  box-sizing: border-box;
  text-align: center;
  border-radius: 0; /* 角丸無し */
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .top-pop-container {
    padding: 0 15px;
  }

  .bottom-gallery-pop {
    display: grid;
    grid-template-columns: repeat(1, 1fr); /* スマホでは1列表示 */
    gap: 10px; /* 要素間の余白 */
  }

  .gallery-item-pop {
    max-width: 100%; /* スマホ表示では幅を100%に */
    margin-bottom: 20px;
  }
}


/*新スライドショー*/
     .slider-container {
      position: relative;
      overflow: hidden;
      width: 100vw;
      height: 464px; /* スライドの高さ */
      display: contents;
    }

    .slides {
      display: flex;
      transition: transform 0.5s ease;
      width: 150%; /* 3つの画像が並ぶ幅 */
    }

    .slide {
      flex: 0 0 33.33%; /* 各スライドの幅は 33.33% */
      height: 100%;
      position: relative;
    }

    .slide img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

    .navigation-dots {
      display: flex;
      justify-content: center;
      align-items: center;
      margin-top: 20px;
    }

    .dot {
      width: 10px;
      height: 10px;
      margin: 0 5px;
      background-color: #ccc;
      border-radius: 50%;
      cursor: pointer;
    }

    .dot.active {
      background-color: #333;
    }

    @media (max-width: 768px) {
      .slider-container {
        height: 300px;
      }

      .slide {
        flex: 0 0 100%;
        width: 100%;
        transform: translateX(0) !important;
      }
      .slides {

  width: 100% !important;;
  transform: none !important;
}
    } 
/*新スライドショーここまで*/


/*レビュー一覧*/
        .review-container {
            display: block;
            margin: auto;
            max-width: 800px;
          margin-bottom: 30px;
        }
        .review-item {
            display: flex;
            border-bottom: 1px solid #ccc;
            padding: 40px 0;

        }
        .review-left {
            flex: 1;
            padding-right: 25px;
        }
        .review-left img {
            max-width: 100%;
            height: auto;
        }
        .review-right {
            flex: 2;
        }
	.review-rating {
          color: #bb0;
          padding: 15px 0;
	}

        .review-product {
            font-size: 18pt;
        }
        .review-title {
            font-size: 14pt;
            font-weight: bold;
            padding: 0 0 15px 0;
        }
        .review-details {
            font-size: 12pt;
            padding: 0 0 15px 0;
        }
        .review-button {
            display: inline-block;
            padding: 10px 20px;
            border: 1px solid #aaa;
            background: transparent;
            text-decoration: none;
            color: #333;
            text-align: center;
            margin: 25px 0;
        }
        .review-text {
            font-size: 12pt;
            padding: 0 0 10px 0;
         }
        @media (max-width: 768px) {
            .review-container {
                grid-template-columns: 1fr;
              padding: 0 10px;
            }
            .review-product {
                font-size: 14pt;
            }
            .review-title {
                font-size: 12pt;
            }
          .review-button {
               margin: 10px 0 0 0;
          }
        }
/*レビュー一覧ここまで*/


.sp-topbanner {
  text-align: center;
  margin:20px 0 0 0;
}

.sp-topbanner img {
  margin:5px 0;
}

@media (min-width: 768px) {
  .sp-topbanner {
    display:none;
  }
}