/*--------------------------------*/
.slick-slider {
  width: 100%;
  margin: 0 auto;
}

.slide-item {
  position: relative;
}

.slide-item img {
  width: 100%;
  height: auto;
  display: block;
}

.slide-item a {
  display: block;
  text-decoration: none;
  color: white;
  position: relative;
}

.slide-overlay {
  position: absolute;
  bottom: 0;
  width: 100%;
  background: rgba(40, 20, 0, 0.5); /* 半透明オーバーレイ */
  text-align: center;
  padding: 20px 5px;
}

.slide-en {
  font-family: "Libre Caslon Text", serif;
  font-size: 30px;
  font-weight: 400;
  margin: 0;
}

.slide-ja {
  font-size: 14px;
  margin: 4px 0 0;
}
@media (max-width: 480px) {
	.slide-overlay { 
		padding: 10px 5px;
	}
	.slide-en {
	  font-size: 20px;
	}	
}

.decoration-line {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 20px 0;
  width: 100%;
}

/* 左右装飾 */
.decoration-line::before,
.decoration-line::after {
  content: '';
  width: 24px;
  height: 24px;
  background-image: url('https://img21.shop-pro.jp/PA01499/027/etc_base64/bGVmdA.png?cmsp_timestamp=20250713193824');
  background-repeat: no-repeat;
  background-size: contain;
  flex-shrink: 0;
}

.decoration-line::before {
  margin-right: 10px;
}

.decoration-line::after {
  margin-left: 10px;
  transform: scaleX(-1); /* 右用に反転 */
}
.decoration-line .line {
  flex-grow: 1;
  height: 1px;
  background-color: #bfa94b;
}
.decoration-line.reverse {
  transform: scaleY(-1);
}
/* レスポンシブ対応
@media (max-width: 768px) {
  .decoration-line::before,
  .decoration-line::after {
    width: 16px;
    height: 16px;
    margin: 0 6px;
  }
} */

.txt-greeting {
	text-align: center;
}
.txt-greeting span {
	font-size: 20px;
}

.cat-grid {
  display: grid;
  grid-template-columns: 1fr; /* スマホ：1列 */
  gap: 20px;
  margin: 0px auto;
}

.cat-grid img {
  width: 100%;
  height: auto;
  display: block;
	transition: opacity 0.3s ease;
}
.cat-item:hover img {
  opacity: 0.7; 
}
@media (min-width: 768px) {
  .cat-grid {
    grid-template-columns: 1fr 1fr; /* 2列 */
  }
}
.cat-item {
  position: relative;
  display: block; 
  text-decoration: none;
  color: inherit;
  overflow: hidden;
}

.cat-item img {
  width: 100%;
  height: auto;
  display: block;
}

.cat-caption {
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 12px 16px;
  background: none;
  color: #af9946;
  font-size: 20px;
  text-align: right;
  font-weight: 600;
  text-shadow: 
    -1px -1px 2px #ffffff,
     1px -1px 2px #ffffff,
    -1px  1px 2px #ffffff,
     1px  1px 2px #ffffff;
}

@media (max-width: 480px) {
  .cat-caption {
    font-size: 16px;
    padding: 10px 12px;
  }
}

.cat-caption-group {
  padding: 12px;
  color: #fff;
  font-size: 20px;
  text-align: center;
  background: #b9a96d;
}
.cat-caption-group span {
	color: #e6daaa;
	font-size: 16px;
}
a:hover {
  text-decoration: none !important;
}

.category-col {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  width: 100%;
  margin-top: 30px;
  gap: 2% 2%; 
}

.category-col li {
  width: 23%;
  padding: 0; 
  margin-bottom: 15px;
  font-size: 14px;
}

.category-col img {
  max-width: 100%;
  height: auto;
}

.category-col h4 {
  margin-top: 5px;
  margin-bottom: 5px;
  color: #452A0B;
  font-size: 16px;
  text-align: center;
}

/* タブレット：3列 */
@media (max-width: 768px) {
  .category-col li {
    width: 32%;
  }
  .category-col h4 {
    letter-spacing: 1px;
    font-size: 15px;
  }
}

/* スマホ：2列 */
@media (max-width: 480px) {
  .category-col li {
    width: 48%;
  }
}



.news_col{
    clear:both;
 	padding:30px 0 100px !important;;
}
.news_col2{
    clear:both;
	padding: 0px 0px 50px !important;;
}
.news_box {
	clear: both;
	text-align: center;
	/* padding-top: 30px; */
}
.news_box img {
	max-width:50%;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
@media (max-width: 768px){
	.news_box {
		margin-bottom: 50px;
	}
}

#contents .ttl .mid{
    font-size:80%;
    font-weight: 400;
}
#contents .set1-ttl{
    font-size:20px;
	letter-spacing: 1px;
    font-weight: 400;
    line-height:180%;
    position: relative;
    z-index: 3;
}
#contents .txt{
    font-size:15px;
    position: relative;
    z-index: 3;
    line-height: 220%;
}
#contents .copytext {
	font-size:16px;
}
#lead{
    position: relative;
    padding:0px 0 0px;
    clear:both;
}
#lead:before{
    content:'';
    background: url(https://img21.shop-pro.jp/PA01499/027/etc_base64/bGVhZF9iZw.png?cmsp_timestamp=20230511164220);
    background-size:cover;
    width:600px;
    height:500px;
    position:absolute;
    left:-300px;
    top:800px;
}
#lead .img1{
    width:48%;
    height:auto;
    position: relative;
    z-index: 1;
    float:left;
}
#lead .img2{
	width:400px;
    height:auto;
    position: relative;
    z-index: 1;
    float:left;
    padding:100px 40px 0 60px;
}
#lead .ttl{
    float:right;
}
#lead .col{
    float:right;
    width:47%;
    position: relative;
    top:100px;
}
#lead .txt{
    padding:40px 0;
}

#oil{
    position: relative;
    padding:140px 0 40px;
    clear:both;
    border-bottom:1px solid #452a0b; 
}
#oil .img1{
    width:54%;
    height:auto;
    position: relative;
    z-index: 1;
    float:right;
}
#oil .col{
    float:left;
    width:40%;
    position: relative;
    top:0px;
}
#oil .col h3{
    padding:80px 0 30px;
}
.bnr_col {
	clear:both;
	padding:30px 0;
    width: 100%;
	display: flex;
	-webkit-box-pack:justify;
	 -ms-flex-pack:justify;
	justify-content: space-between;
	flex-wrap: wrap;
}
.bnr_col li {
    width:48%;
    text-align: center;
    height:350px;
    position: relative;
    background-size: cover;
    
}
.bnr_col li a {
    height:100%;
    width:100%;
    display: block;
    text-decoration: none;
    color:#fff;
    border:1px solid #452a0b;    
    box-sizing: border-box;
}
.bnr_col li .txt{
    background:rgba(112,65,12,0.95);
    width:180px;
    height:auto;
    position: absolute;
    top: 20%;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    padding:20px 0px;
	line-height: 150% !important;
}
.bnr_col li .txt2{
    /*height:50px;*/
    padding:20px 0px;
}
.bnr_col li .txt .en{
    color:#d0ba92;
    font-size:70%;
}
.bnr_col li:hover:after{
    content:'';
    width:100%;
    height:100%;
    background: rgba(255,255,255,0.3);
    z-index: 8;
    position: absolute;
    left:0;
    top:0;
}
.bnr_col_zakka li{
    width:24%;
    height:350px;    
}

#oilcat01{
    background: url(https://img21.shop-pro.jp/PA01499/027/etc_base64/YXJvbWE.jpg?cmsp_timestamp=20250704213144) no-repeat center center;
	background-size: cover;
}
#oilcat02{
    background: url(https://img21.shop-pro.jp/PA01499/027/etc_base64/cHVycG9zZQ.jpg?cmsp_timestamp=20250704213144) no-repeat center center;
	background-size: cover;
}
#oilcat03{
    background: url(https://img21.shop-pro.jp/PA01499/027/etc_base64/c2VyaWVz.jpg?cmsp_timestamp=20240313133745) no-repeat center center;
	background-size: cover;
}

#goods{
    position: relative;
    padding:100px 0 80px;
    clear:both;

}
#goods h2 .wh{
    color:#fff;
}
#goods .img1{
    width:58%;
    height:auto;
    position: relative;
    z-index: 1;
    float:right;
    margin-top:-80px;
}
#goods .img2{
    width:80%;
    height:auto;
    position: relative;
    z-index: 1;
	left:200px;
    top:40px;

}
#goods .col{
    float:left;
    width:38%;
    position: relative;
    top:70px;
}
#goods .col h3{
    padding:0 0 40px;
}

.top-news {
	border: solid 3px #452A0B; 
	padding: 15px; 
	text-align: center; 
	font-size: 16px;
	margin-bottom: 80px;
}
@media (max-width: 768px){
	.desc-shop {
		text-align:left;
		padding: 20px;
	}

	#kv{
		margin-top:0px;
		margin-bottom: 20px;
	}
    .key_col{
        padding:10% 0;
        text-align: center
          
    }
    .key_col h3{
        font-size:8vw;
        padding-bottom:5%;
    }
    .key_col p{
        font-size:5vw;
        line-height: 180%;
    }
	
    .news_col{
	  padding:30px 0 20px !important;;
	}
	.news_col2{
	padding: 0px 0px 20px !important;;
	}
	
	#contents h2{
        font-size:11vw;
        letter-spacing: -1px;
	}
	#contents .set1-ttl{
		font-size:18px;
	}
	#contents .txt{
		font-size:4vw;
	}
	#lead{
		padding:0px 0 0px;
	}
	#lead:before{
		background: none;
	}
	#lead .img1{
		width:100%;    
		float:none;
		text-align: center;
		margin:20px auto 0;
		}
	#lead .img2{
		width:100%;
		float:none;
		text-align: center;
		padding:20px 0 0;
	}
	#lead .img1 img{
		object-fit: cover;
		height:300px;
		}
	#lead .ttl{
		float:right;
		padding-bottom: 2%;
	}
	#lead .col{
		float:none;
		width:100%;
		position: relative;
		top:20px;
	}
	#lead .txt{
		padding:5% 0;
	}

	#oil{
		padding:80px 0 40px;
		border-bottom:1px solid #452a0b; 
	}
	#oil .img1{
		width:100%;
		float:none;
		margin:10px auto 0;
	}
	#oil .img1 img{
		object-fit: cover;
		height:300px;
		}
	#oil .col{
		float:none;
		width:100%;
		top:0px;
	}
	#oil .col h3{
		padding:20px 0 20px;
	}
	.bnr_col{
		padding:40px 0;
	}
	.bnr_col li{
		width:96%;
		height:500px;
		margin:0 auto 5%;
	}

	.bnr_col li a{
		height:100%;
		width:100%;
	}

	.bnr_col li .txt{
		width:180px;
		height:60px;
	   position: absolute;
		top: 20%;
	  left: 0;
	  right: 0;
	  bottom: 0;
	  margin: auto;
		padding:30px 0;

	}
	.bnr_col li .txt2{
		line-height:140% !important;
		}

	#goods{
		padding:40px 0 0px;

	}
	#goods h2 .wh{
		color:#452a0b;
	}
	#goods .img1{
		width:100%;
		height:auto;
		position: relative;
		z-index: 1;
		float:none;
		margin-top:10px;
	}
	#goods .img1 img{
		object-fit: cover;
		height:260px;
		}
	#goods .img2{
		width:50%;
		height:100%;
		z-index: 1;
	   float:right;
		margin-right:160px;
		top:-20px;
	}
	#goods .img2 img{
		object-fit: cover;
		height:120px;
		}
	#goods .col{
		float:none;
		clear:both;
		width:100%;
		position: relative;
		top:0px;
	}
	#goods .col h3{
		padding:0 0 20px;
	}

	.top-news {
		font-size: 14px;
	}
}

/*li.recommend-unit,li.seller-unit{
	max-width:320px;
}*/

@media (max-width: 480px){
	#contents .set1-ttl{
		font-size:20px;
	}
}

body {
  counter-reset: number 0;           /* number のカウンタを 0 にセット */
}

li.top_ranking{
	position: relative;
}
li.top_ranking a.top_ranking_a:before {
    counter-increment: number 1;
    content: counter(number) " ";
    position: absolute;
    left: 0;
    top: 0;
    z-index: 11;
    background: #fff;
    padding: 5px 20px 10px 10px;
    border-radius: 0 0 10em;
    font-size: 22px;
	box-shadow: 4px 4px 7px rgba(0,0,0,0.2);
}

.box-cattop {
  display: flex;
  flex-wrap: wrap;
  gap: 10px; /* アイテム間の余白 */
}

.item-cattop {
  text-align: center;
  padding: 20px;
  flex: 1 1 calc(25% - 10px); /* デスクトップ: 4列 */
}

/* タブレット（幅768px以上） */
@media (max-width: 1024px) {
  .item-cattop {
    flex: 1 1 calc(33.333% - 10px); /* 3列 */
  }
}

/* スマホ（幅767px以下） */
@media (max-width: 767px) {
  .item-cattop {
    flex: 1 1 calc(50% - 10px); /* 2列 */
  }
}


