@charset "utf-8";


/* 検索結果
----------------------------------------------- */
.conditionarea {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 8px;
	text-align: right;
}

/* ページ送り
----------------------------------------------- */
.pagenumberarea {
	width: 100%;
	height: auto;
	padding: 4px;
	background-color: #f3f3f3;
	display: flex;
	justify-content: space-between;
}

@media screen and (max-width: 767px) {
	.pagenumberarea {
		flex-flow: column nowrap;
		align-items: center;
	}

	.pagenumberarea li {
		text-align: center;
	}
}

.pagenumberarea li {
	display: flex;
	gap: 8px;
	flex-wrap: nowrap;
	white-space: nowrap;
}

.pagenumberarea li a[href=""]{
	text-decoration: none;
	font-weight: bold;
	color: #fff;
	background-color: var(--gray);
	padding: 4px;
	border-radius: 4px;
	line-height: 1em;
}

.pagenumber {
	color: var(--aka);
	font-weight: bold;
}

.pager {
	width: 100%;
	text-align: center;
	padding: 8px;
	order: 99;
}




/* 商品一覧 */

/* タイトル
----------------------------------------------- */
div#listtitle {
	width: 100%;
	margin: 0 0 10px 0;
	border-top: 2px solid #ff0000;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-bottom: 2px solid #999;
	background: url("../img/products/title_icon.gif") no-repeat left center;
	background-color: #ffebca;
}

div#listtitle h2 {
	padding: 10px 0 10px 30px;
	font-size: 140%;
}

/* カテゴリインフォ
----------------------------------------------- */

.kf h3,
.mf h3,
.about_maker h3{
	text-align: center;
	color: #fff;
	background-color: var(--orange);
	background-image: var(--grade);
	background-blend-mode: hard-light;
	margin: 0;
	font-size: 14px;
	line-height: 1.5em;
	margin-bottom: 8px;
}
.kf{
	width: 100%;
}
.kf .swiper-slide{
	width: auto;
}
.kf h4{
    background-color: #ffbb44;
    text-align: center;
    font-size: 14px;
    line-height: 1.5em;
    margin-bottom: 8px;
    color: #fff
}

/* カテゴリインフォ ページ上部バナー
----------------------------------- */
.bannerfield img{
	width: 100%;
	height: auto;
	object-fit: contain;
}

.bannerfield img + p,
.bannerfield a + p{
	margin-top: 0.5em;
}

.bannerfield ul{
	display: grid;
	grid-template-columns: repeat(auto-fit, var(--4bun));
	gap: 8px;
}

/* カテゴリインフォ リスト類基本
----------------------------------- */
.about_maker ul{
	clear: both;
}

.kf ul li,
.mf ul li,
.about_maker ul li{
	overflow: hidden;
	position: relative;
}

.kf ul li:hover,
.kf ul li:active,
.mf ul li:hover,
.mf ul li:active,
.about_maker ul li:hover,
.about_maker ul li:active {
	background-color: var(--usuora);
}

.kf ul li h6,
.mf ul li h6,
.about_maker ul li h6 {
	display: block;
	width: 100%;
	border-bottom: 1px solid var(--gray);
	border-left: 8px solid var(--gray);
	color: var(--gray);
	padding-left: 4px;
	font-weight: bold;
	font-size: 14px;
	line-height: 24px;
	white-space: nowrap;
}

.kf ul li:hover h6,
.kf ul li:active h6,
.mf ul li:hover h6,
.mf ul li:active h6,
.about_maker ul li:hover h6,
.about_maker ul li:active h6 {
	border-bottom: 1px solid var(--orange);
	border-left: 8px solid var(--orange);
	color: var(--orange);
}

.kf ul li a,
.mf ul li a,
.about_maker ul li a{
	text-decoration: none;
}

/*中間親項目*/
.kf ul li.span1,
.mf ul li.span1,
.about_maker ul li.span1 {
	background-color: #999;
}
.kf ul li.span2,
.mf ul li.span2,
.about_maker ul li.span2 {
	grid-column: span 2;
	background-color: #999;
}
.kf ul li.span3,
.mf ul li.span3,
.about_maker ul li.span3 {
	grid-column: span 3;
	background-color: #999;
}

.kf ul li.span1 h6,
.mf ul li.span1 h6,
.about_maker ul li.span1 h6,
.kf ul li.span2 h6,
.mf ul li.span2 h6,
.about_maker ul li.span2 h6,
.kf ul li.span3 h6,
.mf ul li.span3 h6,
.about_maker ul li.span3 h6 {
	border-bottom: 1px solid var(--gray);
	border-left: 16px solid var(--gray);
	color: #fff;
}

.kf ul li.span1 a h6:hover,
.kf ul li.span1 a h6:active,
.mf ul li.span1 a h6:hover,
.mf ul li.span1 a h6:active,
.about_maker ul li.span1 a h6:hover,
.about_maker ul li.span1 a h6:active,
.kf ul li.span2 a h6:hover,
.kf ul li.span2 a h6:active,
.mf ul li.span2 a h6:hover,
.mf ul li.span2 a h6:active,
.about_maker ul li.span2 a h6:hover,
.about_maker ul li.span2 a h6:active,
.kf ul li.span3 a h6:hover,
.kf ul li.span3 a h6:active,
.mf ul li.span3 a h6:hover,
.mf ul li.span3 a h6:active,
.about_maker ul li.span3 a h6:hover,
.about_maker ul li.span3 a h6:active,
.kf ul li.selected h6,
.mf ul li.selected h6,
.about_maker ul li.selected h6{
	background-color: var(--usuora);
	border-bottom: 1px solid var(--orange);
	border-left: 16px solid var(--orange);
	color: var(--orange);
}

.kf .kflex{
    overflow: hidden;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    align-items: flex-start;
    align-content: stretch;
	gap: 8px;
}
.kf .kflex ul.wid1 {
	flex: 1 1 150px;
}
.kf .kflex ul.wid2 {
	flex: 1 1 300px;
}
.kf .kflex ul.wid3 {
	flex: 1 1 450px;
}
.kf .kflex ul.wid4 {
	flex: 1 1 600px;
}
.kf .kflex ul.wid5 {
	flex: 1 1 750px;
}


/* カテゴリインフォ リスト類：メーカー
----------------------------------- */
.kf ul.makers li img,
.mf ul.makers li img {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: auto;
}

.kf ul.makers li:hover img,
.kf ul.makers li:active img,
.mf ul.makers li:hover img,
.mf ul.makers li:active img {
	opacity: 1.0;
}

.kf ul.makers li h6,
.mf ul.makers li h6 {
	padding-left: 22px;
}


/* カテゴリインフォ メーカー解説
----------------------------------- */

.about_maker{
	display: grid;
	grid-template-columns: clamp(48px, 17vw, 100px) auto;
	gap: 8px;
}

.about_maker div:first-child {
	background-color:#000;
	
}


/* カテゴリインフォ 警告
----------------------------------- */
.caution {
	width: auto;
	margin: 0 auto;
	padding: 8px;
	background-color: var(--usuki);
}

.caution h4 {
	font-size: 18px;
	font-weight: bold;
	color: var(--aka);
	text-align: center;
	padding: 4px;
}

.caution ul {
	width: 100%;
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	gap: 4px;
}

.caution ul li:before {
	content: "○"
}

/* カテゴリインフォ 管理画面から更新できる箇所
----------------------------------- */
div.category_info p {
	text-align: center;
	font-weight: bold;
}



/* 商品
----------------------------------------------- */
div.listarea {
	clear: both;
	padding: 2px 0 2px 0;
	overflow: hidden;
	background: url("../img/common/line_580.gif") no-repeat bottom;
	height: auto;
}

ul.listarea2 li {
	padding: 8px;
}

div.listarea3 {
	height: 300px;
	width: 165px;
	padding: 0 0 10px 0;
	overflow: hidden;
	float: left;
}

.listcomment2 {
	overflow: hidden;
	text-overflow: ellipsis;
}

div.listrightblock li {
	display: inline;
	padding: 0 0 5px 0;
}

div.listrightblock h3 {
	width: 100%;
	margin: 2px 0;
	padding: 2px 10px;
	border-bottom: 2px solid #ebebd6;
	background-color: #f9f9ec;
	font-size: 120%;
}

div.listrightblock h3 a {
	font-size: 100%;
	font-weight: bold;
}

div.listrightblock .listcomment {
	margin: 0 0 5px 0;
}

div.listrightblock .pricebox {
	float: left;
}

div.listrightblock .soldout {
	clear: both;
}

div.listrightblock .in_cart {
	margin: 20px auto 5px 130px;
	padding: 10px;
	width: 285px;
	clear: both;
	background-color: #ecf5ff;
	border: 1px solid #CCCCCC;
}

div.listrightblock .quantity {
	width: 150px;
}

div.listrightblock .btnbox {
	margin: 0 0 10px 0;
	padding: 1px;
	float: right;
}

div.listrightblock dt {
	width: 75px;
	float: left;
	text-align: right;
	padding: 3px;
	font-weight: bold;
}

div.listrightblock dd {
	padding: 3px;
}

div.listrightblock .cartbtn {
	clear: both;
	text-align: center;
}

div.listrightblock .cartbtn img {
	display: block;
	width: 115px;
	margin: 5px auto 0 auto;
}

.jyotai {
	background-color: var(--gray);
	color: #fff;
	font-size: 16px;
	font-weight: normal;
}

.kosuu {
	margin-top: 10px;
}

div.listrightblock .box54 {
	width: 100%;
	border: solid 1px #ccc;
}

#cart {
	vertical-align: bottom;
}


/*--------------------------------------------------------
商品詳細detailページ用
--------------------------------------------------------*/

/*全体の並び*/
#detailarea {
	display: grid;
	grid-template-columns: 1fr 375px;
    grid-template-rows: fit-content(640px);
	grid-auto-rows: auto;
	gap: 16px;
}

#detailarea > section{
    width: 100%;
    height: 100%;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

#detailrightblock,
#detailboxleft,
#detailunderleft,
#detailinform,
#classcategory_list ul,
#detailrightblock div,
#allsubarea {
	display: flex;
	flex-flow: column;
	flex-wrap: nowrap;
	overflow: hidden;
}

#detailrightblock,
#detailboxleft,
#detailunderleft,
#detailinform {
	gap: 16px;
}

#classcategory_list ul {
	gap: 0px;
}

#detailrightblock .item {
	gap: 8px;
}

#detailphotoblock {
	order: 1;
}

#detailrightblock {
	order: 2;
	grid-column: 2 / 3;
	grid-row: 1 / 3;
}

#allsubarea {
	order: 3;
}

@media screen and (max-width: 767px) {
	#detailarea {
        display: flex;
        flex-flow: column;
        flex-wrap: nowrap;
        overflow: hidden;
	}
    #detailarea > section{
        height: auto;
    }
	#detailrightblock {
		grid-column: auto;
		grid-row: auto;
	}
}

/*ページ内汎用
-----------------------------------------*/
#detailarea img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: contain;
}


/*詳細欄
--------------------------------------------------*/

/*タイトル*/

#detailrightblock #detailtitle {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	border-bottom: 4px solid var(--orange);
}

#detailrightblock div#detailtitle.nologin {
	border-left: 16px solid var(--orange);
}

#detailtitle div.favorite_btn {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	align-items: center;
	background-color: var(--orange);
	flex: 0 0 56px;
	justify-content: center;
}

#detailtitle div.favorite_btn div {
	width: 32px;
	height: 32px;
	flex: 0 0 32px;
	border-radius: 16px;
	aspect-ratio: 1 / 1;
	background-color: #fff;
	text-align: center;
}

#detailtitle div.favorite_btn a {
  text-decoration: none;
}

#detailtitle div.favorite_btn span {
	font-size: 24px;
	line-height: 30px;
	color: var(--usu_gr);
	margin: 0 auto;
}

#detailtitle div.favorite_btn span.sumi {
	color: #ea0;
}

#detailtitle div.favorite_btn p {
	text-align: center;
	font-size: 10px;
	line-height: 1.5em;
	font-weight: bold;
	color: #fff;
}

#detailtitle h2 {
	width: 100%;
	color: var(--gray);
	font-weight: bold;
    font-size: 20px;
	line-height: 1.2em;
	padding: 0 0 4px 8px;
	margin: 0;
}

#detailtitle h2 textarea[readonly]{
    display: block;
    width: 100%;
    font-size: 20px;
    height: 6.4em;
    font-weight: normal;
}

/*ページID*/
#detailrightblock div.page_id{
    display: flex;
    flex-direction: row;
    justify-content: center;
    font-weight: bold;
    border: 2px solid var(--orange);
    background-color: #fff;
    line-height:1em;
    padding: 8px 4px 2px 4px;
    align-items: baseline;
}
#detailrightblock div.page_id span:first-child{
    padding-bottom: 2px;
}
#detailrightblock div.page_id span:last-child{
    font-size: 24px;
    color: var(--orange);
}

/*ステータス*/
.status_icon {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-template-rows: auto;
	gap: 5px;
}

ul.item_list li ul.status_icon {
	grid-template-columns: repeat(3, 1fr);
	gap: 1px;
}

ul.item_list li ul.status_icon li,
ul.item_list li ul.status_icon li img {
	width: 100%;
	height: auto;
	border: none;
	padding: 0;
	background-color: rgba(0, 0, 0, 0);
	display: block;
	aspect-ratio: 21 / 6;
}


/*小タイトル*/
#detailrightblock h3 {
	background-color: var(--gray);
	width: 100%;
	font-size: 16px;
	color: #fff;
	font-weight: bold;
	text-align: center;
	line-height: 1em;
	padding: 4px;
}

/*状態選択*/
#classcategory_list li {
	border-bottom: 1px solid var(--gray);
}

#classcategory_list h5{
	border-bottom: 1px solid var(--gray);
    display:block;
    margin:0;
    margin-bottom: 4px;
    font-size: 20px;
    line-height: 1.5em;
}

#classcategory_list textarea[readonly]{
    display: block;
    width: 100%;
    font-size: 20px;
    height: 2em;
    font-weight: normal;
}

#classcategory_list dl {
    display: grid;
    grid-template-columns: auto 3fr;
    font-size: 14px;
    line-height:1.5em;
    align-items: center;
}

#classcategory_list dt span::after {
	content: "："
}

#classcategory_list dd.price {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	color: var(--aka);
	font-weight: bold;
	font-size: 32px;
    line-height: 0.8em;
	transform: translateY(2px);
    padding: 0;
    padding-bottom: 4px;
}

#classcategory_list dd.marume~dd.price{
    padding-top: 4px;
}

#classcategory_list dd.price span{
	font-size: 20px;
	margin-top: 2px;
}

#classcategory_list dd.price span.point{
    font-size: 14px;
    font-weight: normal;
    color: var(--gray);
    padding-top: 3px;
}

#classcategory_list dd.price span.p_sale{
    font-size: 20px;
    margin: 0 4px 0 0;
    translate: 0 -2px;
}

#classcategory_list li label {
	margin: 0;
	padding: 0;
	width: 100%;
	height: auto;
	cursor: pointer;
}

#classcategory_list li label input {
	display: none;
}

#classcategory_list li label input ~ div {
    display: flex;
    gap: 4px;
	background-color: #fff;
	padding: 12px;
	border-left: 8px solid var(--usu_gr);
}

#classcategory_list li label input[type="radio"]:checked ~ div {
	background-color: var(--usu_ki);
	border-left: 8px solid var(--orange);
}

#classcategory_list li label input[type="radio"]:hover ~ div {
	background-color: var(--usu_ki);
}

#classcategory_list .dettyu {
	display: flex;
	flex-flow: row;
	flex-wrap: nowrap;
	justify-content: space-between
}

#classcategory_list .dettyu a {
	display: block;
	width: 100%;
	text-align: center;
}

#classcategory_list .staimgs{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
}

#classcategory_list .staimgs a{
    flex: 1 1 auto;
}


/*カゴボタン周り
-------------------------------------------------*/
#detailrightblock #cartbox,
#detailrightblock #cartbox .quantity {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: flex-end;
}

#detailrightblock #cartbox {
	gap: 8px;
}

#detailrightblock #cartbox .quantity {
	margin-bottom: -2px;
}

#detailrightblock #cartbox .quantity input {
	margin-bottom: 4px;
	max-width: 64px;
}

#detailrightblock #cartbox .btn_box {
	margin: 0
}

#detailrightblock #cartbox .btn_box a.big {
	width: 100%;
    min-height: 64px;
    font-size: 24px;
}


/*メイン画像と画像一覧
----------------------------------------------- */
#mainphoto > img ,
#subphotolist li img {
	aspect-ratio: 4 / 3;
}

#mainphoto {
	position: relative;
	width: 100%;
	height: auto;
	max-width: 569px;
	aspect-ratio: 4 / 3;
	background-color: #fff;
	margin: 0 auto;
	border: 1px solid var(--usu_gr);
}

#mainphoto > #reserve_benefits {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 20%;
	height: auto;
}

#subphotolist {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-template-rows: auto;
	background-color: var(--usu_gr);
	gap: 1px;
	border: 1px solid var(--usu_gr);
	position: relative;
	top: -1px;
}

#subphotolist li{
	background-color: #fff;
	aspect-ratio: 4 / 3;
}

/* サブ画像・文章・タイトル
----------------------------------------------- */
#allsubarea {
	gap: 16px;
}

#allsubarea > div {
	width: 100%;
	height: auto;
	display: flex;
	flex-flow: column nowrap;
	gap: 0;
	overflow: hidden;
	background-color: #fff;
	border: 1px solid var(--usu_gr);
}
	
#allsubarea > div h3 {
	width: 100%;
	font-size: 14px;
	font-weight: bold;
	text-align: center;
	line-height: 1em;
	padding: 4px;
	background-color: var(--usu_gr);
}

#allsubarea p.ps {
	font-size: 15px;
    line-height: 1.2em;
	background-color: var(--usu_gr);
	padding: 4px;
}


/* 予約商品
----------------------------------------------- */
#order_st {
	display: grid;
	border: 4px solid #e4e4e4;
	padding: 8px;
	gap: 8px;
	grid-template-columns: 100px 1fr;
	background-color: #fff;
}

#order_st > h4 {
	font-size: 20px;
	padding: 10px;
	background-image: linear-gradient(#aaa, #777);
	background-blend-mode: hard-light;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-flow: column nowrap;
}

#order_st > h4,
#order_st > h4 span {
	text-align: center;
	color: #fff;
	font-weight: bolder;
}

#order_st > h4 span {
	display: block;
	font-size: 14px;
}

#order_st > div {
	overflow: hidden;
	display: flex;
	flex-flow: column nowrap;
	gap: 8px;
}

#order_st h4.o_red {
	background-color: var(--aka)
}

#order_st h4.o_ora {
	background-color: var(--orange)
}

#order_st h4.o_blu {
	background-color: var(--ao)
}

#order_st h5 {
	width: 100%;
	font-size: 16px;
	padding: 2px;
	background-color: #e4e4e4;
}

#order_st h5:active,
#order_st h5:hover {
	background-color: var(--usuora);
}

#order_st h5 + div {
	margin-top: 4px;
}


/* メインコメントCSS
----------------------------------------------- */
#detailrightblock #main_coment {
    display: flex;
    gap:0.5em;
	border: 2px dotted var(--usu_gr);
	padding: 12px;
	border-radius: 4px;
}

#detailrightblock #main_coment h3 {
	margin-bottom: 8px;
}

#main_coment{
	font-size: 16px;
}

/*#main_coment内の見出し*/
/*#main_coment b b はsmartyでh4に変換するようにしたので廃止*/
#main_coment h4,
#main_coment table caption{
    background-color: var(--usu_gr);
    width: 100%;
    display:block;
    font-size: 14px;
    text-align: center;
    line-height: 1em;
    padding: 4px;
    margin-bottom: 4px;
    margin-top: 1em;
    font-weight: bold;
}
#main_coment div{
    display: flex;
    gap:0.5em;
	color: var(--gray);
}
#main_coment div p {
	font-feature-settings: "palt";
	vertical-align: baseline;
	text-align: justify;
	word-wrap: break-word;
	word-break: break-all;
}
#main_coment div p:last-of-type {
	text-align-last: left;
}

#main_coment table,
#main_coment table tbody,
#main_coment table tbody tr {
	width: 100%;
	display: flex;
	justify-content: stretch;
	align-items: stretch;
	align-content: stretch;
	font-size: 14px;
    line-height: 1.25em;
	border: none;
	background-color: #fff;
}

#main_coment table tbody {
	flex-flow: column nowrap;
}

#main_coment table tbody tr {
	width: 100%;
	flex-flow: row nowrap;
}

#main_coment table tbody tr td {
	width: 100%;
	flex-flow: row nowrap;
}

#main_coment table[width="100%"] > tbody > tr {
	display: grid;
	grid-template-rows: auto;
	gap: 4px;
}

#main_coment table[width="100%"]:not([class]) > tbody > tr,
#main_coment table.tcol4[width="100%"] > tbody > tr {
	grid-template-columns: repeat(auto-fill, var(--4bun));
}

#main_coment table.tcol3[width="100%"] > tbody > tr {
	grid-template-columns: repeat(auto-fill, var(--3bun));
}

#main_coment table.tcol2[width="100%"] > tbody > tr {
	grid-template-columns: repeat(auto-fill, var(--2bun));
}

#main_coment table[width="100%"] > tbody > tr td {
	align-self: flex-end;
	overflow: hidden;
	display: flex;
	flex-flow: column nowrap;
	justify-content: stretch;
	align-items: stretch;
	align-content: stretch;
	align-self: stretch;
}

#main_coment table[width="100%"] > tbody > tr td[valign="top"] {
	display: none;
}

#main_coment table[width="100%"]:not([class]) > tbody > tr td:first-child {
	grid-column: span 2;
}

#main_coment table[width="100%"] > tbody > tr td a {
	display: flex;
	width: 100%;
	height: 100%;
}

#main_coment table[width="100%"] > tbody > tr td:not(first-child) img {
	width: 100%;
	height: auto;
	object-fit: contain;
	margin: 0 auto;
}

#main_coment table[width="100%"]:not([class]) > tbody > tr td:not(first-child) img {
	width: 100%;
	max-width: 432px;
	object-position: bottom right;
}

#main_coment table:not([width$="%"]) > tbody {
	gap: 1px;
	background-color: var(--usu_gr);
	border: 1px solid var(--usu_gr);
	max-width: 512px;
		flex-direction: column;
}
#main_coment table:not([width$="%"]) > tbody > tr td,
#main_coment table:not([width$="%"]) > tbody > tr th{
    padding: 4px;
    padding-left: 6px;
}
#main_coment table:not([width$="%"]) > tbody > tr td:first-child ,
#main_coment table:not([width$="%"]) > tbody > tr th {
    width: 100%;
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
	flex: 0 1 clamp(64px, 33%, 160px);
	background-color: #ebebf0;
}

#main_coment table:not([width$="%"]) > tbody > tr td:last-child {
	flex: 2 1 clamp(96px, 66%, 512px);
	text-align: left;
	background-color: #fff;
}

/*汎用説明画像
----------------------------------------------- */
.guid-banners ul{
	width: 100%;
	display: flex;
	flex-flow: row wrap;
	gap: 1px;
}
.guid-banners ul li{
	flex: 0 1 calc(calc(100% - 1px) / 2);
	aspect-ratio: 1 / 1;
}
.guid-banners ul li img{
	display: block;
	object-fit: contain;
	width: 100%;
	height: auto;
	aspect-ratio: 1 / 1;
}
.guid-banners ul li#guid_maker_close{order: 98}
.guid-banners ul li#guid_maker_japan{order: 98}
.guid-banners ul li#guid_maker_foreign{order: 98}
.guid-banners ul li#guid_syu_gusgun{order: 1}
.guid-banners ul li#guid_syu_dendougun{order: 1}
.guid-banners ul li#guid_syu_modelgun{order: 1}
.guid-banners ul li#guid_res_gusgun{order: 2}
.guid-banners ul li#guid_res_modelgun{order: 2}
.guid-banners ul li#guid_res_dendougun{order: 2}
.guid-banners ul li#guid_charge{order: 3}
.guid-banners ul li#guid_cbug{order: 4}
.guid-banners ul li#guid_bb{order: 5}
.guid-banners ul li#guid_load{order: 6}
.guid-banners ul li#guid_silicon{order: 7}
.guid-banners ul li#guid_target{order: 8}
.guid-banners ul li#guid_goggles{order: 9}
.guid-banners ul li#guid_age{order: 97}
.guid-banners ul li#guid_vintage{order: 99}


/*レビュー
----------------------------------------------- */
#customervoicearea {
	width: 100%;
	display: flex;
	flex-flow: column nowrap;
	gap: 16px;
}

img#review {
	text-align: center;
	height: 32px;
	width: auto;
	max-width: 100%;
}

#customervoicearea .voicedate {
	font-weight: bold;
	margin: 0;
	background-color: #e4e4e4;
	padding: 4px 8px;
}

#customervoicearea .voicetitle {
	padding: 5px 0;
	font-size: 18px;
	font-weight: bold;
}

#customervoicearea ul {
	border: 4px solid #e4e4e4;
	padding: 20px;
	display: flex;
	flex-flow: column nowrap;
	gap: 16px;
}

#customervoicearea li {
	padding-bottom: 8px;
	border-bottom: 2px dotted #e4e4e4;
}


/* この商品を買った人はこんな商品も買っています
----------------------------------------------- */
div#whoboughtarea {
	width: 100%;
	padding: 0;
}


/* ノベルティ詳細
----------------------------------------------- */
section#presentarea > div {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: center;
	gap: 16px;
	margin: 16px 0;
}

section#presentarea > div > div {
	display: grid;
	grid-template-columns: repeat(auto-fill, var(--2bun));
	grid-template-rows: auto;
}

section#presentarea > div > div div {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: center;
	gap: 1px;
}

section#presentarea > div > div#tokuten div {
	background-color: var(--orange);
	border: 4px solid var(--orange);
}
section#presentarea > div > div#tokuten h3 {
	color: var(--orange);
}

section#presentarea > div > div#zenpre div {
	background-color: var(--pink);
	border: 4px solid var(--pink);
}
section#presentarea > div > div#zenpre h3 {
	color: var(--pink);
}

section#presentarea > div > div#reviewpre div {
	background-color: var(--ao);
	border: 4px solid var(--ao);
}
section#presentarea > div > div#reviewpre h3 {
	color: var(--ao);
}

section#presentarea > div > div .tesxs {
	color: #fff;
	text-align: center;
	padding: 16px;
}

section#presentarea > div > div .imgs {}

section#presentarea > div > div img {
	width: 100%;
	height: auto;
	object-fit: contain;
}

section#presentarea > div > div h3 {
	font-size: 20px;
	line-height: 1.1em;
	background-color: #fff;
	padding: 8px;
	margin-bottom: 16px;
}

section#presentarea > div > div p {
	font-size: 18px;
	line-height: 1.5em;
}

section#presentarea > div > div p span {
	font-size: 24px;
	font-weight: bold;
	display: block;
	line-height: 1.3em;
}



/* スライダーレイアウト
----------------------------------------------- */
.list_slide_wrap {
	background-color: #fff;
}

.list_slide_wrap .swiper-slide {
	background-color: var(--gray);
}

.list_slide_wrap .swiper-slide,
.list_slide_wrap .swiper-slide a {
	aspect-ratio: 16 / 9;
}

.list_slide_wrap .swiper-slide img.fit {
	object-fit: contain;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
}


/* luminous-lightbox対応
----------------------------------------------- */
.lum-lightbox{
	z-index: 199999;
}


/* オプション欄
----------------------------------------------- */
.classlist {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.classlist li:not(:has(select)) {
	display: none;
}
/*オプション・レビュー共通書式*/
.classlist li:has(select[id^="plg_productoptions_"]),
#reviewget {
	border: 4px solid #000;
}
.classlist li:has(select[id^="plg_productoptions_"])::before,
#reviewget::before {
	content: "";
	background-size: contain;
	background-repeat: no-repeat;
	display: block;
	padding-bottom: 50%;
	width: 100%;
	height: auto;
	border-bottom: 4px solid #000;
}
.classlist li select[id^="plg_productoptions_"],
#reviewget select {
	background-color: #000;
	color: #fff;
}

/*各オプションのカラー・画像*/

/*レビュー特典*/
#reviewget {
	border-color: var(--ao);
}
#reviewget::before {
	border-color: var(--ao);
	background-image: url("../../../../images/option/option_000.png");
}
#reviewget select {
	background-color: var(--ao);
}

/*電動ガンスターター*/
.classlist li:has(select#plg_productoptions_3) {
	border-color: var(--midori);
}
.classlist li:has(select#plg_productoptions_3)::before {
	border-color: var(--midori);
	background-image: url("../../../../images/option/option_003.png");
}
.classlist li select#plg_productoptions_3 {
	background-color: var(--midori);
}

/*ガスガンスターター*/
.classlist li:has(select#plg_productoptions_4) {
	border-color: var(--orange);
}
.classlist li:has(select#plg_productoptions_4)::before {
	border-color: var(--orange);
	background-image: url("../../../../images/option/option_004.png");
}
.classlist li select#plg_productoptions_4 {
	background-color: var(--orange);
}


/* プライスダウン・セール期間表記
----------------------------------------------- */
div.saleband {
	background-color: var(--aka);
	color: #fff;
	font-weight: bold;
	text-align: center;
}
ul.item_list div.saleband {
	font-size: 1em;
	line-height: 1.4em;
	padding-top: 1px;
}
div#detailinform div.saleband {
	font-size: 1.25em;
	line-height: 1em;
	padding: 6px 0 4px 0;
}
.price span.p_sale, .price span.p_down {
	display: inline-block;
	color: #fff;
	width: 4em;
	height: 1.25em;
	text-align: center;
	line-height: 1.3em;
	margin-right: 8px;
	overflow: hidden;
	transform: translateY(2px);
}
.price span.p_sale {
	background-color: var(--aka);
}
.price span.p_down {
	background-color: var(--orange);
}


/* 商品購入時のご注意 in product
----------------------------------------------- */
.pu_wrap{
    display: flex;
    flex-flow: column;
    flex-wrap: nowrap;
    gap: 24px;
}
.pu_wrap > div{
    overflow: hidden;
}
.pu_wrap > div h5{
    font-size: 16px;
    background-color: var(--midori);
    color: #fff;
    padding: 4px 16px 4px 16px;
    margin-bottom: 0.5em;
}
.pu_wrap > div p{
    font-size: 14px;
}
    
.pu_wrap > div .grids{
    display: grid;
    grid-template-columns: repeat(auto-fill, var(--3bun));
    gap: 30px;
}
.pu_wrap > div .grids.g4{
    grid-template-columns: repeat(auto-fill, var(--4bun));
}
.pu_wrap > div .grids div{
    display: flex;
    flex-flow: column;
    flex-wrap: nowrap;
    gap: 8px;
}
.pu_wrap > div .grids img{
    width: 100%;
    height: auto;
    display: block;
    vertical-align: top;
    object-fit: scale-down;
    border: solid 1px var(--usu_gr);
}