@charset "utf-8";
/* CSS Document */
:root{
	--category-color: #a69a2f;
	--category-color-dark: #726712;
}
mark{ color: inherit; background-image: linear-gradient(to bottom, transparent 40%, #fffd6c 40%);}

/*-----------------------------------------------
 子カテ/index
-----------------------------------------------*/
/*---メインイメージ---*/
.main-box{
	margin: 0 auto 30px;
}
.main-box h2{
	margin: 0 auto 10px;
	padding-left: 40px;
	font-size: 25px;
	font-weight: 700;
	line-height: 1.5em;
	position: relative;
}
.main-box h2:before{
	content: "";
	display: block;
	width: 10px;
	height: 10px;
	border-top: 3px solid var(--category-color);
	border-right: 3px solid var(--category-color);
	transform: rotate(45deg);
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
.main-box h2 + img{
	margin-bottom: 20px;
	border-bottom: 3px solid var(--category-color);
}
.main-box > .read-box h3{
	display: block;
	width: fit-content;
	color: var(--category-color-dark);
	margin: 0 auto 20px;
	padding: 5px 30px;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.5em;
	text-align: center;
	position: relative;
}
.main-box > .read-box h3:before,
.main-box > .read-box h3:after{
	content: "";
	display: block;
	width: 15px;
	height: 15px;
	position: absolute;
}
.main-box > .read-box h3:before{
	border-top: 1px solid #111;
	border-left: 1px solid #111;
	left: 0;
	top: 0;
}
.main-box > .read-box h3:after{
	border-bottom: 1px solid #111;
	border-right: 1px solid #111;
	right: 0;
	bottom: 0;
}


@media screen and ( max-width: 736px ){
	.main-box h2{
		padding-left: 40px;
		font-size: 25px;
	}
	.main-box h2:before{
		left: 10px;
	}

	.main-box > .read-box{
		width: 95%;
		margin: auto;
	}
	.main-box > .read-box h3{
		padding: 10px;
		font-size: 20px;
	}
}

@media screen and ( max-width: 480px ){
	.main-box h2{
		font-size: 22px;
	}

	.main-box > .read-box h3{
		padding: 5px;
		font-size: 18px;
	}
}


/*---各ランキング---*/
.mainContents section.accessRanking{
	margin: 50px auto;
}

.accessRanking > .ranking-title{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 5px;
    background-color: var(--category-color);
    color: #fff;
	margin: 0 auto 20px;
	padding: 5px;
	font-size: 20px;
    font-weight: 700;
	line-height: 1.6em;
    text-align: center;
    letter-spacing: 0.08em;
    border: none;
    border-radius: 10px;
	position: relative;
}
.accessRanking > .ranking-title:before{
	content: "";
	flex-shrink: 0;
	display: block;
	width: 100px;
	height: 30px;
    background: url(../../../../_images/category/_common/ranking-icon-crown.webp) no-repeat center;
}

.accessRanking > .ranking-title + p{
	line-height: 1.8em;
}

@media screen and ( max-width: 768px ){
	.accessRanking > .ranking-title{
		font-size: 20px;
	}
	.accessRanking > .ranking-title + p{
		width: 95%;
		margin: auto;
	}
}
@media screen and ( max-width: 480px ){
	.accessRanking > .ranking-title{
		flex-direction: column;
		font-size: 18px;
		line-height: 1.5em;
	}
}

/*-----リンクボタンリスト----*/
.select-link{
	background-color: #f2f2f2;
	margin: 0 auto 30px;
	padding: 30px;
	border-radius: 15px;
}
.select-link .select-title{
	display: flex;
	align-items: center;
	gap: 15px;
	width: fit-content;
	margin: 0 auto 20px;
	font-size: 22px;
	font-weight: 700;
	text-align: center;
	position: relative;
}
.select-link .select-title:before,
.select-link .select-title:after{
	content: "";
	display: block;
	width: 30px;
	height: 1px;
	background-color: #111;
}

.select-link ul{
	display: flex;
	flex-wrap: wrap;
	gap: 10px 15px;
}
.select-link ul > li{
	width: calc((100% - 30px) / 3);
	color: var(--category-color);
	font-size: 16px;
	font-weight: 700;
	text-align: center;
	border: 1px solid #111;
	border-radius: 15px;
	overflow: hidden;
}
.select-link ul > li a{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	background-color: #fff;
	padding: 25px 5px 35px;
	position: relative;
}
.select-link ul > li a:before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	border: 6px solid transparent;
	border-left: 8px solid var(--category-color);
	transform: translateX(-50%);
	position: absolute;
	bottom: 10px;
	left: 50%;
}

.select-link ul > li a:hover{
	background-color: #fffd6c;
	color: inherit;
}

/*--ブランドリンク--*/
.brand-link{
	margin: 0 auto 30px;
}
.brand-link .brand-title{
	width: fit-content;
	margin: 0 auto 20px;
	padding-bottom: 8px;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.3em;
	text-align: center;
	position: relative;
}
.brand-link .brand-title:after{
	content: "";
	display: block;
	width: 250px;
	height: 2px;
	background-color: var(--category-color);
	transform: translateX(-50%);
	position: absolute;
	left: 50%;
	bottom: 0;
}

.brand-link ul{
	display: flex;
	flex-wrap: wrap;
	gap: 15px 15px;
}
.brand-link ul > li{
	width: calc((100% - 30px) / 3);
}
.brand-link ul > li a{
	display: flex;
	align-items: center;
	height: 100%;
	padding: 10px 20px;
	font-size: 14px;
	font-weight: 700;
	border: 2px solid #d2c874;
	border-radius: 20px;
	position: relative;
}
.brand-link ul > li a:after{
	content: "";
	display: block;
	border: 6px solid transparent;
	border-left: 8px solid #d2c874;
	transform: translateY(-50%);
	position: absolute;
	right: 5px;
	top: 50%;
}
.brand-link ul > li a:hover{
	background-color: #fffd6c;
	color: var(--category-color-dark);
}

@media screen and ( max-width: 768px ){
	.select-link{
		width: 95%;
		padding: 3%;
	}
	.select-link .select-title{
		font-size: 20px;
	}
	.select-link ul{
		gap: 10px 15px;
	}
	.select-link ul > li{
		font-size: 16px;
	}
	.select-link ul > li a{
		padding: 5px 5px 25px;
	}
	.select-link ul > li a:before{
		bottom: 5px;
	}

	.select-link ul > li a:hover{
		background-color: #fffd6c;
		color: inherit;
	}

	/*--ブランドリンク--*/
	.brand-link{
		width: 95%;
	}
	.brand-link .brand-title{
		font-size: 20px;
	}
	.brand-link .brand-title:after{
		width: 220px;
	}

	.brand-link ul{
		gap: 15px 10px;
	}
	.brand-link ul > li{
		width: calc((100% - 20px) / 3);
	}
	.brand-link ul > li a{
		padding: 10px 20px 10px 10px;
	}
	.brand-link ul > li a:after{
		right: 5px;
	}
}

@media screen and ( max-width: 480px ){
	.select-link{
		width: 95%;
		padding: 3%;
	}
	.select-link .select-title{
		font-size: 18px;
	}
	.select-link ul{
		gap: 10px 15px;
	}
	.select-link ul > li{
		width: 100%;
		font-size: 16px;
		text-align: left;
	}
	.select-link ul > li a{
		padding: 5px 25px 5px 5px;
	}
	.select-link ul > li a:before{
		transform: translate(-50%, 0);
		bottom: auto;
		right: 0;
		left: auto;
	}

	/*--ブランドリンク--*/
	.brand-link .brand-title{
		font-size: 18px;
	}

	.brand-link ul{
		gap: 10px 10px;
	}
	.brand-link ul > li{
		width: calc((100% - 15px) / 2);
	}
	.brand-link ul > li a{
		padding: 8px 15px 8px 5px;
		font-size: 13px;
		line-height: 1.3em;
		border-radius: 10px;
	}
	.brand-link ul > li a:before{
		right: 0;
	}
}

/*---- アイテムリスト ----*/

.mainContents section.itemListBox{
	margin: 50px auto;
}


/*---- おすすめ一覧 ----*/
.mainContents section.osusumeListBox{
	margin: 40px auto;
}

.osusumeListBox > .title{
	color: #222;
	margin: 0 auto 30px;
	padding: 15px 15px;
	font-size: 25px;
	text-align: center;
	position: relative;
}
.osusumeListBox > .title:before,
.osusumeListBox > .title:after{
	content: "";
	display: block;
	background-color: var(--category-color-dark);
	width: 350px;
	height: 1px;
	transform: translateX(-50%);
	position: absolute;
	left: 50%;
}
.osusumeListBox > .title:before{
	top: 0;
}
.osusumeListBox > .title:after{
	bottom: 0;
}

/**/
.osusumeListBox .itemHead{
	position: relative;
}
/**/
.osusumeListBox .itemHead .hBox{
	margin: 0 0 20px;
	position: relative;
}
.osusumeListBox .itemHead .hBox .title{
	background: url(../../../../_images/category/pen/title_bg_border.gif) repeat;
	color: var(--category-color-dark);
	padding: 20px 0 15px;
	font-size: 23px;
	text-align: center;
	border-bottom: 1px solid var(--category-color-dark);
}
.osusumeListBox .itemHead .hBox .caption{
	display: block;
	width: fit-content;
	min-width: 400px;
	background-color: var(--category-color-dark);
	color: #fff;
	margin: auto;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.5em;
	text-align: center;
}
.osusumeListBox .itemHead .hBox .caption em{
	color: #ffe747;
	font-weight: bold;
}

.osusumeListBox .itemHead .textBox{
	margin-right: 250px;
	min-height: 150px;
}
.osusumeListBox .itemHead .textBox:after{
	content: "";
	display: block;
	width: 240px;
	height: 260px;
	background-repeat: no-repeat;
	position: absolute;
	top: -20px;
	right: 0;
	z-index: 10;
}

.osusumeListBox .itemHead .textBox p{
	font-size: 13px;
	font-weight: 500;
}

/**/
.osusumeListBox .sub-title{
	width: 100%;
	color: var(--category-color-dark);
	width: 95%;
	margin: 15px auto;
	font-size: 18px;
	font-weight: 500;
	padding-left: 35px;
	clear: both;
	position: relative;
}
.osusumeListBox .sub-title:before{
	content: "";
	display: block;
	width: 16px;
	height: 16px;
	background-image: linear-gradient(45deg, var(--category-color) 50%, var(--category-color-dark) 50%);
	letter-spacing: -1.0em;
	transform: translateY(-50%) rotate(45deg);
	position: absolute;
	left: 5px;
	top: 50%;
}

/**/
.osusumeListBox .itemList{
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	width: 95%;
	margin: 0 auto 50px;
}
.osusumeListBox .itemList > li{
	width: calc((100% - 60px) / 3);
}
.osusumeListBox .itemList > li .itemImg{
	margin: 0 auto 5px;
}
.osusumeListBox .itemList > li .itemImg img{
	width: 100%;
	height: auto;
	border: 2px solid #ccc;
}

/*商品情報*/
.osusumeListBox .itemList > li .itemInfo .name{
	font-size: 16px;
	font-weight: 700;
}
.osusumeListBox .itemList > li .itemInfo ul li{
	font-weight: 700;
}
.osusumeListBox .itemList > li .itemInfo ul li.itemNo{
	font-size: 12px;
}
.osusumeListBox .itemList > li .itemInfo ul li.itemPrice{
	margin-bottom: 5px;
	font-size: 15px;
	line-height: 1.3em;
}
.osusumeListBox .itemList > li .itemInfo ul li.itemPrice em{
	color: #ff002a;
	font-size: 21px;
}
.osusumeListBox .itemList > li .itemInfo ul li.itemPrice span{
	display: inline-block;
	font-size: 11px;
}
.osusumeListBox .itemList > li .itemInfo p.itemRead{
	margin-bottom: 5px;
	font-size: 13px;
}

/*商品リンク*/
.osusumeListBox .itemList > li .itemLinkBtn{
	margin-top: 20px;
}
.osusumeListBox .itemList > li .itemLinkBtn a{
	display: flex;
	align-items: center;
	background-color: #ff5d7c;
	color: #fff;
	padding: 10px;
	font-size: 15px;
	font-weight: 700;
	text-align: center;
	position: relative
}
.osusumeListBox .itemList > li .itemLinkBtn a:hover{
	background-color: #ffadbd;
}
.osusumeListBox .itemList > li .itemLinkBtn a:after{
	content: "";
	display: block;
	border: 6px solid transparent;
	border-left: 10px solid #fff;
	transform: translateY(-50%);
	position: absolute;
	top: 50%;
	right: 5px;
}


@media screen and ( max-width: 736px ){
	.osusumeListBox > .title{
		font-size: 22px;
	}
	.osusumeListBox > .title:before,
	.osusumeListBox > .title:after{
		width: 350px;
	}

	/**/
	.osusumeListBox .itemHead{
		margin-bottom: 30px;
	}
	.osusumeListBox .itemHead .hBox{
		margin: 0 0 20px;
		position: relative;
	}
	.osusumeListBox .itemHead .hBox .title{
		font-size: 23px;
	}
	.osusumeListBox .itemHead .hBox .caption{
		width: 70%;
		font-size: 18px;
	}

	.osusumeListBox .itemHead .textBox{
		display: flex;
		flex-direction: column-reverse;
		justify-content: center;
		gap: 15px;
		margin-right: 0;
		min-height: auto;
	}
	.osusumeListBox .itemHead .textBox:after{
		margin: auto;
		position: static;
	}

	/**/
	.osusumeListBox .sub-title{
		font-size: 18px;
	}

	/**/
	.osusumeListBox .itemList{
		gap: 30px;
	}
	.osusumeListBox .itemList > li{
		width: calc((100% - 30px) / 2);
	}
	.osusumeListBox .itemList > li .itemImg{
		max-width: 250px;
		margin: 0 auto 10px;
	}

	/*商品情報*/
	.osusumeListBox .itemList > li .itemInfo .name{
		font-size: 16px;
	}
	.osusumeListBox .itemList > li .itemInfo ul li.itemNo{
		font-size: 12px;
	}
	.osusumeListBox .itemList > li .itemInfo ul li.itemPrice{
		font-size: 15px;
	}
	.osusumeListBox .itemList > li .itemInfo ul li.itemPrice em{
		font-size: 21px;
	}
}
@media screen and ( max-width: 480px ){
	.osusumeListBox > .title{
		font-size: 20px;
	}
	.osusumeListBox > .title:before,
	.osusumeListBox > .title:after{
		width: 300px;
	}

	/**/
	.osusumeListBox .itemHead{
		margin-bottom: 30px;
	}
	.osusumeListBox .itemHead .hBox{
		margin: 0 0 20px;
		position: relative;
	}
	.osusumeListBox .itemHead .hBox .title{
		font-size: 23px;
	}
	.osusumeListBox .itemHead .hBox .caption{
		width: 70%;
		min-width: 280px;
	}

	.osusumeListBox .itemHead .textBox{
		gap: 15px;
	}

	/**/
	.osusumeListBox .sub-title{
		font-size: 18px;
	}

	/**/
	.osusumeListBox .itemList{
		gap: 15px;
	}
	.osusumeListBox .itemList > li{
		width: calc((100% - 15px) / 2);
	}

	/*商品情報*/
	.osusumeListBox .itemList > li .itemInfo .name{
		font-size: 15px;
	}
	.osusumeListBox .itemList > li .itemInfo ul li.itemPrice{
		font-size: 14px;
	}
	.osusumeListBox .itemList > li .itemInfo ul li.itemPrice em{
		font-size: 19px;
	}
}


/*------------------------------------------------
    孫カテ
-------------------------------------------------*/
.hierarchy3Cont .contentHead{
	width: 100%;
	min-height: 425px;
	margin-bottom: 40px;
	position: relative;
}

.hierarchy3Cont .contentHead .h2Box{
	width: 100%;
	height: 90px;
	background: linear-gradient(to right, rgba(252,243,171,1) 0%,rgba(253,248,205,1) 50%, transparent 70%);
	overflow: hidden;
	position: relative;
	z-index: 50;
}
.hierarchy3Cont .contentHead .h2Box h2{
	display: flex;
	align-items: center;
	height: 85px;
	background: linear-gradient(to right, rgba(119,113,62,1) 0%,rgba(163,155,88,1) 50%, transparent 70%);
	color: #fff;
	padding: 5px 0 5px 100px;
	font-size: 28px;
	font-weight: 700;
	line-height: 1.3em;
	position: relative;
}
.hierarchy3Cont .contentHead .h2Box h2:before{
	content: "";
	display: block;
	width: 120px;
	height: 120px;
	background: #fff;
	background-repeat: no-repeat;
	background-position: 80% 50%;
	border-radius: 50%;
	transform: translateY(-50%);
	position: absolute;
	top: 50%;
	left: -40px;
}

.hierarchy3Cont .contentHead .headText{
	width: 100%;
	min-height: 430px;
	background-repeat: no-repeat;
	background-position: right top;
	padding: 110px 20px 20px;
	position: absolute;
	top: 0;
	left: 0;
}

.hierarchy3Cont .contentHead .headText > dl{
	width: 440px;
}
.hierarchy3Cont .contentHead .headText > dl > dt{
	margin-bottom: 10px;
	font-size: 22px;
	font-weight: bold;
	line-height: 1.5em;
}
.hierarchy3Cont .contentHead .headText > dl > dt mark{
	color: #ff5e8f;
}
.hierarchy3Cont .contentHead .headText > dl > dd p{
	font-size: 13px;
}

@media screen and ( max-width: 736px ){
	.hierarchy3Cont .contentHead{
		min-height: auto;
		margin-bottom: 40px;
	}

	.hierarchy3Cont .contentHead .h2Box{
		height: auto;
		background: linear-gradient(to right, rgba(252,243,171,1) 0%,rgba(253,248,205,1) 100%);
		padding-bottom: 5px;
	}
	.hierarchy3Cont .contentHead .h2Box h2{
		height: auto;
		min-height: 70px;
		background: linear-gradient(to right, rgba(119,113,62,1) 0%,rgba(163,155,88,1) 100%);
		padding: 20px 10px 20px 70px;
		font-size: 24px;
	}
	.hierarchy3Cont .contentHead .h2Box h2:before{
		width: 90px;
		height: 90px;
		background-size: 50%;
		left: -30px;
	}
	
	.hierarchy3Cont .contentHead .headText{
		min-height: auto;
		background-size: 50% auto;
		padding-top: 5%;
		position: static;
	}
	.hierarchy3Cont .contentHead .headText > dl{
		width: 70%;
		margin: 0;
		text-shadow: 0 0 2px #fff;
	}
	.hierarchy3Cont .contentHead .headText > dl > dt{
		font-size: 21px;
	}
	.hierarchy3Cont .contentHead .headText > dl > dt br{
		display: none;
	}
	.hierarchy3Cont .contentHead .headText > dl > dd{
		background: rgba(255,255,255,0.6);
		padding: 5px;
	}
}
@media screen and ( max-width: 480px ){
	.hierarchy3Cont .contentHead .h2Box h2{
		padding: 10px 10px 10px 70px;
		font-size: 22px;
	}

	.hierarchy3Cont .contentHead .headText{
		background-size: 45% auto;
	}
	.hierarchy3Cont .contentHead .headText > dl{
		width: 100%;
	}
	.hierarchy3Cont .contentHead .headText > dl dt{
		width: 70%;
		font-size: 20px;
	}
}




/*------------------------------------------------
    共通
-------------------------------------------------*/
.relationLink,
.groupLink{
	margin: 50px auto;
}
.relationLink > .title,
.groupLink > .title{
	color: #333;
	margin-bottom: 15px;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.5em;
	text-align: center;
	border-bottom: 1px solid #ff7417;
}

/*---- 関連リンク ----*/
.relationLink ul{
	display: flex;
	flex-wrap: wrap;
	gap: 15px 10px;
	padding: 0;
}
.relationLink ul li{
	width: calc((100% - 20px) / 3);
}
.relationLink ul li img{
	width: 100%;
	height: auto;
}
.relationLink ul li a{
	display: block;
}


/*---- グループリンク ----*/
.groupLink ul{
	display: flex;
	flex-wrap: wrap;
	gap: 15px 15px;
	padding: 0 25px;
}
.groupLink ul li{
	width: 200px;
}
.groupLink ul li a{
	display: block;
}

@media screen and ( max-width: 736px ){
	.relationLink,
	.groupLink{
		width: auto;
		margin: 50px 0;
	}
	.relationLink > .title,
	.groupLink > .title{
		font-size: 18px;
	}

	/*---- 関連リンク ----*/
	.relationLink ul{
		margin: 0 2.5%;
	}
	.relationLink ul li{
		width: calc((100% - 20px) / 3);
	}

	/*---- グループリンク ----*/
	.groupLink ul{
		margin: 0 2.5%;
		padding: 0;
	}
	.groupLink ul li{
		width: calc((100% - 30px) / 3);
		text-align: center;
	}
	.groupLink ul li img{
		max-width: 200px;
	}
}
@media screen and ( max-width: 450px ){
	.groupLink ul{
		gap: 10px;
	}
	.relationLink ul li,
	.groupLink ul li{
		width: calc((100% - 10px) / 2);
	}
}




