@charset "utf-8";
/*-------------------------------------------------*/
/*(C) A.C.Planet Inc. All rights reserved.*/
/*--------------------------------------------------*/

/*見出し
----------------------------------------*/

h1{
}

h2,
h2.ec-headingTitle,
.ec-productRole .ec-productRole__title h2.ec-headingTitle,
.ec-rectHeading h2,
ec-newspage4Heading h2{
	font-size: 1.57rem !important;
	color:#fff;
	font-weight: normal !important;
	margin: 40px 0 24px;
	padding: 7px;
	position: relative;
	text-align:center;
	background-color: var(--main-color);
	background-image:url(../imgs/common/bg_h2-left.svg),url(../imgs/common/bg_h2-right.svg);
	background-repeat: no-repeat;
    background-size: 52px;
	background-position:left top,right bottom;
}
h3{
	font-size: 1.429rem;
	color: var(--sub-color01);
	margin:0 0 20px;
	padding: 15px 0 ;
	position: relative;
	text-align:center;
	font-weight:500;
}
h3::after{
	content: '';
	display: block;
	width: 100%;
	height: 1px;
	background: var(--sub-color01);
	position: absolute;
	bottom: 0;
	left: 0;
}
h4{
	font-size: 1rem;
	font-weight: normal;
	margin: 20px 0 12px;
	padding: 3px 0;
	background:var(--sub-color02);
	position: relative;
	text-align:center;
}
h5{
    font-size: 1rem;
    border-left: 2px solid var(--main-color);
    padding-left: 1em;
    margin-top: .5rem;
}
.strong{
	font-size: 1.12rem;
	font-weight: bold;
	color: var(--main-color);
	margin: 20px 0 20px;
}
@media print, (min-width: 769px) {
	h2{
		margin-top:80px;
		font-size:1.875rem !important;
		background-size:70px;
		margin-bottom:30px;
		padding:8px;
	}
	h3{
		font-size:1.5625rem;
		padding:18px 0;
		margin-bottom:30px;
	}
	h4{
		padding: 7px 0;
		margin-bottom:20px;
	}
}
/*パンくず*/
.breadcrumb{
	background:var(--sub-color01);
	margin:0;
}
.breadcrumb_list{
	display:flex;
	flex-wrap:wrap;
	color:#fff;
	margin-top:0;
	font-size:0.857rem;
	padding:1px 10px;
	gap:0px 10px;
}
.breadcrumb_item{
    display: flex;
    align-items: center;
    gap: 10px;
	padding:0 !important;
}

.breadcrumb_item::before{
	display:none;
}
.breadcrumb_item a{
	color:#fff;
}
.breadcrum_item:not(:last-child){
	position:relative;
}
.breadcrumb_item:not(:last-child)::after{
	width:4px;
	height:4px;
	border-radius:50%;
	background:var(--main-color);
	content:"";
	display:inline-block;
}
@media screen and (min-width: 992px) {
	.breadcrumb_list{
		font-size:1rem;
    	padding-left:30px;
	}
}
/*メインビジュアル*/
.page_mv{
	position:relative;
	margin-bottom:30px;
}
.page_mv_bg{
	height:150px;
	object-fit:cover;
    margin: 0;
    padding-bottom: 26px;
    box-sizing: content-box;
	overflow:hidden;
}
.page_mv_bg img{
    width: 100%;
    object-fit: cover;
    object-position: center;
    height: 100%;
}
.page_top_bnr{
	margin-bottom:0 !important;
}
.page_top_bnr .page_mv_bg{
	height:unset;
	padding-bottom:0;
}
.page_mv_title_content{
	position:relative;
}
.page_mv_title_wrapper{
	background:#fff;
	position:absolute;
	bottom:0;
	display:inline-block;
	left:0;
    padding: 15px 18px 8px 10px;
}
h1{
    margin: 0;
    font-size: 1.7857rem;
    font-weight: normal;
	color:var(--sub-color01);
	position:relative;
	padding-bottom:20px;
	margin-top:20px;
	margin-bottom:20px;
}
.page_mv_title{
	margin:0
}
h1::after{
	content:"";
	height:1px;
	width:30px;
	display:block;
	position:absolute;
	bottom:0;
	left:0;
	background:var(--main-color);
}
.cmn_campaign{
	margin-top:100px;
	break-inside: avoid;
}

@media print, (min-width: 769px) {
	.page_mv{
		margin-bottom:80px;
	}
	.page_mv_bg{
		height:300px;
		margin-bottom:0;
		padding-bottom:0;
	}
	.cmn_campaign{
		//margin-top:225px;
		margin-top:175px;
		
	}
	.page_mv_title_wrapper{
		padding: 21px 50px 0px;
	}
	h1.page_mv_title::after{
		width:50px;
	}
	h1{
		font-size:2.1875rem;
		margin-bottom:30px;
		padding-bottom:26px;
	}
	h1::after{
		width:35px;
	}
}
/*店舗情報
------------------------------*/
.store_list{
	display:flex;
	flex-wrap:wrap;
	gap:10px;
}
.store_item{
	width:calc( (100% - 10px)/2 );
}
.store_item a{
	display:flex;
	border:1px solid #ccc;
	align-items:center;
	color:var(--sub-color01);
	text-decoration:unset;
	font-size:0.857rem;
}
.store_item .store_item_img{
	width:100%;
}
.store_item .store_item_name{
	width:100%;
	text-align:center;
	position:relative;
	display:flex;
	align-items:center;
	justify-content:center;
	gap:10px;
	transition:.3s;
}
.store_item .store_item_name::after{
    content: "";
    border: 1px solid var(--main-color);
    display: block;
    transform-origin: 50%;
    transform: rotate(135deg);
    width: 6px;
    height: 6px;
    border-left: unset;
    border-bottom: unset;
    transition: .3s;
	position: relative;
    top: 0;
}
.store_table table{
	width:100%;
}
.store_info + .store_info{
	margin-top:88px;
}
.store_info_catch{
	color:var(--main-color);
	font-size:1.143rem;
	line-height:1.75em;
	text-align:center;
}
.store_info .page_photoslides{
	margin:0 35px;
}
.store_table{
	width:100%;
}
.page_photoslides_wrapper{
	position:relative;
    margin-top: 10px;
    margin-bottom: 10px;
}
.part_kazaru.page_photoslides_wrapper{
	margin-top:25px;
}
.page_photoslides{
	margin:0 22px;
}
.page_photoslides ul{
	margin-top:0;
}
.page_photoslides .page_photoslide_item figure{
	border-bottom:1px dotted #ccc;
}
.page_photoslides figcaption{
	margin-bottom:5px;
	font-size:0.857rem;
	line-height:1.5em;
}
.page_photoslide_item{
	position:relative;
}
.page_photoslide_item figure{
	margin:0;
	margin-bottom:8px;
	width:100%;
}
.page_photoslide_item figure img{
	width:100%;
}
.page_photoslide_item_tag{
	display:inline-block;
	background:var(--main-color);
	color:#fff;
	position:absolute;
	top:0;
	left:0;
	font-size:0.857rem;
	margin:0;
	padding:2px 11px;
	line-height:1.5em;
}
.page_photoslides_wrapper .swiper-pagination-bullets{
	position:relative;
    bottom: unset;
    top: unset;
    line-height: 10px;
}
.page_photoslides_wrapper .swiper-pagination-bullet{
	width:10px;
	height:10px;
	border:1px solid var(--main-color);
	background:unset;
	opacity:1;
}
.page_photoslides_wrapper .swiper-pagination-bullet-active{
	background:var(--main-color);
}
.page_photoslides-thumbs{
	margin-top:7px;
}
.page_photoslides-thumbs .swiper-wrapper{
	margin:0;
	flex-wrap:wrap;
	gap:5px;
}
.page_photoslides-thumbs .swiper-slide{
	border:1px solid #ccc;
    aspect-ratio: 16 / 10;
    overflow: hidden;
	position:relative;
	width:calc( ( 100% - (5px * 4) ) / 5);
}
.page_photoslides-thumbs .swiper-slide.swiper-slide-thumb-active::after,
.slideThumb.is-active::after{
	content:"";
	position:absolute;
	top:0;
	width:100%;
	height:100%;
    border: 2px solid var(--main-color);
	display:block;
}
.page_photoslides-thumbs .swiper-slide{
	cursor:pointer;
}
.page_photoslides-thumbs .swiper-slide figure{
	margin:0;
}
.page_photoslides-thumbs .swiper-slide figure img{
	width:100%;
}
.part_kazaru{
    margin-top: 40px;
    margin-bottom: 80px;
}
.part_kazaru_select{
	display:flex;
	flex-wrap:wrap;
    margin-bottom: 20px;
	gap:10px;
}
.part_kazaru_select_item{
	min-width:calc( (100% - (10px * 3)) / 4 ); 
}
.part_kazaru_select_item a{
	display:block;
	border:1px solid #cccccc;
	text-decoration:none;
	text-align:center;
	padding-left:10px;
	padding-right:10px;
}
.part_kazaru_select_item.is-show a{
	background:#f2ece3;
}
.part_kazaru_slide_list_item p:has(+.btn01){
	margin-bottom:30px;
}
.part_kazaru_slide_list_item .btn01{
    padding-right: 27px;
	margin-top:5px;
	margin-bottom:5px;
	font-size: 0.85rem;
}
.part_kazaru_slide_list_item .btn01:has( + .btn01){
	margin-right:10px;
}
.part_kazaru_slide_list_item .text-center .btn01:has( + .btn01){
	margin-right:5px;
	margin-left:5px;
}
.part_kazaru_slide{
	margin-top:40px;
	position:relative;
}
.part_kazaru .page_photoslides{
	background:#f2ece3;
}
.part_kazaru .page_photoslides:not(.swiper-initialized) .page_photoslide_list{
	justify-content: center;
}
.part_kazaru .page_photoslide_item,
.part_kazaru .page_photoslides-thumbs{
	padding:10px;
}
.part_kazaru .page_photoslide_item{
	padding-bottom:0;
}
.part_kazaru .page_photoslides-thumbs{
	padding-top:0;
	margin-top:0;
}
@media screen and (max-width: 768px) {
.page_photoslides{
	margin:0 15px;
}
}
.store_access{
	text-align:center;
	margin-bottom:30px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.store_access_item{
	position:relative;
	display:inline-block;
	padding:3px 20px;
	font-weight:100;
	margin-bottom:10px;
    margin-top: 4px;

}
.store_access_item::after{
	content:"";
	display:block;
	height:1px;
	width:100%;
	background:var(--main-color);
	position:absolute;
	bottom:0;
	left:0;
}
.store_access_start,
.store_access_time{
	font-size:1.79rem;
	font-weight:500;
}
.store_access_time{
	color:var(--main-color);
}
.store_access_from{
	font-size:1.143rem;
}
.store_access_title{
	background:var(--sub-color01);
	color:#fff;
	font-size:1rem;
	font-weight:100;
	display:inline-block;
	padding:0px 5px;
    margin-top: 8px;
}
.store_table .list:first-child{
	margin-top:0;
}
.store_reserve{
	margin-top:20px;
}
.store_reserve_title{
	display:flex;
	justify-content:center;
	font-size:1.143rem;
	text-align:center;
	gap:17px;
}
.store_reserve_title::before, .store_reserve_title::after {
    content: "";
    display: block;
    width: 1px;
    height: 20px;
    background: var(--sub-color01);
}
.store_reserve_title::before {
    transform: rotate(-30deg);
}
.store_reserve_title::after {
    transform: rotate(30deg);
}
.store_reserve_btns{
	margin-top:7px;
    display: flex;
    gap: 10px;
    justify-content: center;
}
.store_reserve .btn01{
	/*width:100%;*/
}

@media print, (min-width: 769px) {
	.store_list{
		gap:20px;
	}
	.store_item{
		width:285px;
	}
	.store_item a{
		font-size:1rem;
	}
	.store_item .store_item_img{
		width:auto;
        height: 90px;
	}
	.store_item .store_item_img img{
		height:100%;
	}
	.store_item .store_item_name{
		width:unset;
        flex: 1;
		gap:22px;
	}
	.store_item a:hover .store_item_name::after{
	    top: 3px;
    	transition: .3s;
	}
	.store_info_catch{
		font-size:1.625rem;
        margin-bottom: 16px;
		margin-top:34px;
	}
	.store_info_top,
	.store_info_btm{
		display:flex;
		align-items:center;
		gap:60px;
		margin-bottom:35px;
	}
	.store_info_top_01,
	.store_info_top_02,
	.store_info_btm_01,
	.store_info_btm_02{
		width:50%;
        min-height: 0;
        min-width: 0;
	}
	.page_photoslides{
		margin:0 30px;
	}
	.page_photoslide_item_tag{
		font-size:1rem;
        padding: 4px 22px;
	}
	.page_photoslide_list:has(+.page_photoslides-thumbs){
	}
	.page_photoslides-thumbs .swiper-wrapper{
		justify-content: center;
	}
	.page_photoslides figure{
		margin-bottom:0;
	}
	.page_photoslides figcaption{
		font-size:0.975rem;
		margin:11px 0;
	}
	.page_photoslides .page_photoslide_list:has(+.page_photoslides-thumbs) figure{
		border-bottom:0;
	}
	.page_photoslides-thumbs{
		border-top: 1px dotted #ccc;
	    padding-top: 30px;
		margin-top:0;
	}
	.page_photoslides_wrapper .swiper-pagination-bullets{
		margin-top:16px;
	}
	.page_photoslides_wrapper .swiper-pagination-bullet{
		width:16px;
		height:16px;
	}
	.page_photoslides:not(.swiper-initialized):has( > .page_photoslides-thumbs) .page_photoslide_item{
		margin-right: 26px;
        width: calc( (100% - (26px * 2)) / 3);
	}
	.page_photoslides:not(.swiper-initialized):has( > .page_photoslides-thumbs) .page_photoslide_item:last-child{
		margin-right:0;
	}
	.part_kazaru .page_photoslides-thumbs{
		padding-top:30px;
	}
	.part_kazaru .page_photoslides{
		padding:10px;
	}
	.part_kazaru .page_photoslide_item{
		padding:0;
	}
	.store_access_item{
		padding:10px 25px;
	}
	.store_access_title{
		margin-top:19px;
		margin-bottom:6px;
		font-size:1.375rem;
        padding: 6px 19px;
	}
	.store_access_start,
	.store_access_time{
		font-size:2.48125rem;
        font-weight: normal;
	}
	.store_access_from{
		font-size:1.5875rem;
	}
	.store_info_btm{
		background:var(--sub-color02);
		padding:50px;
		align-items:unset;
	}
	.store_map iframe{
		height:347px;
	}
	.store_table{
		width:100%;
		line-height:1.4em;
		margin-top:0;
	}
	.store_reserve_title{
		font-size:1.125rem;
        align-items: center;
	}
	.store_reserve_title::before,
	.store_reserve_title::after{
		height:19px;
	}
	.store_reserve {
	    margin-top: 22px;
	}
	.store_reserve_btns{
		margin-top:10px;
	}
}
@media screen and (min-width: 992px) {
	.page_photoslides-thumbs .swiper-slide{
		height:82px;
        width: auto !important;
	}
}
@media print, (max-width: 991px) and (min-width: 769px) {
	.store_info_top,
	.store_info_btm{
		flex-direction:column;
	}
	.store_info_top_01,
	.store_info_top_02,
	.store_info_btm_01,
	.store_info_btm_02{
		width:100%;
	}
	.part_kazaru .page_photoslide_item,
	.part_kazaru .page_photoslides-thumbs{
		padding:10px;
	}
	.page_photoslides figcaption{
		margin-bottom:0;
	}
}
/*ひな人形*/
.page_search{
	padding-top:30px;
	padding-bottom:30px;
	margin-top:40px;
	/*font-size:0.857rem;*/
}
.page_search h2{
	background:none;
	color:inherit;
	font-size:1.43rem !important;
	margin:0;
	padding:0;
	text-align:left;
}
.page_search th{
    white-space: nowrap;
	font-size:1rem;
}
.page_search td label{
	min-width:49%;
}
.page_search .btn_gosearch{
	background:var(--main-color);
	color:#fff;
	border:unset;
    padding: 4px 17px;
	margin:0 auto;
	margin-top:10px;
	min-width:104px;
	position:relative;
}
.page_search .btn_gosearch.is-loading::after{
    content: "";
    display: inline-block;
    width: 0.9em;
    height: 0.9em;
    border-radius: 50%;
    border: 3px solid var(--main-color);
    border-top-color: transparent;
    animation: spinner 1.5s linear infinite;
    margin-left: 10px;
    position: absolute;
    right: -20px;
    top: 6px;
}
@keyframes spinner {
  to {
    transform: rotate(360deg);
  }
}
.btn_gosearch_number{
	font-size:0.857rem;
}
.product_list{
	margin-top:30px;
	margin-bottom:30px;
}
.ec-searchnavRole__infos{
	margin-bottom:20px;
}
.ec-select{
	display:flex;
	align-items:center;
	gap:10px
}
.ec-select select.form-select{
    width: auto;
    border-radius: 0;
    border-color: #ccc;
	position:relative;
	background-image: url(../imgs/common/icon_arrow-down.png);
    background-size: 8px;
    padding-right: 53px;
	appearance: none;
}
.ec-shelfRole__info{
	border-top:1px dotted #ccc;
	color:var(--main-color);
	padding:5px 0;
}
.ec-shelfRole__info p{
	margin-top:0;
}
.ec-shelfGrid{
	margin-top:0;
	display:flex;
	flex-wrap:wrap;
	gap:0 30px;
	border-bottom:1px dotted #ccc;
}
.ec-shelfGrid__item,
.renew_page .ec-shelfGrid .ec-shelfGrid__item{
	width: calc( (100% - 30px) / 2 );
	position:relative;
	padding:20px 0 17px;
	margin:0;
	break-inside: avoid;
}
.ec-shelfGrid:not(.no-search) .ec-shelfGrid__item::before{
	display:none;
}
@media screen and (max-width:768px){
	.no-search .ec-shelfGrid__item:nth-of-type(even)::before,
	.searched .ec-shelfGrid__item[data-count="2"]::before,
	.searched .ec-shelfGrid__item[data-count="4"]::before,
	.searched .ec-shelfGrid__item[data-count="6"]::before,
	.searched .ec-shelfGrid__item[data-count="8"]::before,
	.searched .ec-shelfGrid__item[data-count="10"]::before,
	.searched .ec-shelfGrid__item[data-count="12"]::before{
		content:"";
		height:calc(100% - 40px);
		width:0;
		border-right:1px dotted #ccc;
		display:block;
		position:absolute;
		left:-15px;
		top:20px;
	}
	.no-search .ec-shelfGrid__item:nth-of-type(odd)::before,
	.searched .ec-shelfGrid__item[data-count="1"]::before,
	.searched .ec-shelfGrid__item[data-count="3"]::before,
	.searched .ec-shelfGrid__item[data-count="5"]::before,
	.searched .ec-shelfGrid__item[data-count="7"]::before,
	.searched .ec-shelfGrid__item[data-count="9"]::before,
	.searched .ec-shelfGrid__item[data-count="11"]::before{
		content:"";
		height:0;
		width: calc((100% * 2) + 30px);
		border-top:1px dotted #ccc;
		display:block;
		position:absolute;
		left:0;
		top:0;
	}
}
.ec-shelfGrid .ec-shelfGrid__item-image{
	border:1px solid #ccc;
	width:100%;
	aspect-ratio:1;
	padding:5px;
	margin:0;
    height: unset;
}
.ec-shelfGrid__item-image img{
	width:100%;
	height:100%;
	object-fit:contain;
}
.ec-shelfGrid__item a,
.ec-shelfGrid__item > div{
	text-decoration:unset;
	color:inherit;
    display: flex;
    flex-direction: column;
    gap: 6px;
	position:relative;
}
.ec-shelfGrid__item-image.product-sold-out{
	position:relative;
}
.ec-shelfGrid__item-image.product-sold-out::before{
	content: "";
    background-color: rgba(0, 0, 0, 0.6);
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 0;
    left: 0;
    top: 0;
}
.ec-shelfGrid__item-image.product-sold-out::after{
    content: "完売御礼";
    color: #fff;
    position: absolute;
    z-index: 25;
    font-size: 1.5em;
    letter-spacing: 0.2em;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    text-align: center;
	left:0;
}
.product_category{
	margin-top:4px;
}
.product_category > *{
	display:flex;
	background:var(--sub-color02);
	font-size:0.857rem;
	padding:1px 5px;
	margin-top:0;
    line-height: 1.5em;
}
.product_name{
	line-height:1.32rem;
}
.product_name p{
	margin-top:0;
}
.price02-default{
	color:var(--main-color);
	margin-top:-3px;
	line-height:1.32rem;
}

@media print, (min-width: 769px) {
	#category_top h2:first-of-type{
		margin-top:60px;
	}
	.page_search{
		margin-top:82px;
	    padding-top: 38px;
    	padding-bottom: 40px;
	}
	.page_search h2{
		font-size:1.75rem !important;
        line-height: 1.4em;
	}
	.page_search_title{
		font-size:0.875rem;
		display:flex;
		gap:33px;
		margin-bottom:14px;
	}
	.page_search table{
		width:100%;
	}
	.page_search td label{
		min-width:unset;
		margin-right:32px;
		margin-top:5px;
		margin-bottom:5px;
	}
	.page_search table th{
		padding-right:40px;
		width:8em;
	}
	.page_search table td{
		padding-left:40px;
	}
	.page_search table th,
	.page_search table td {
    	padding: 16px 10px;
	}
	.page_search table th:has( + td){
		padding-right:20px;
	}
	.page_search table th + td{
		padding-left:30px;
	}
	.page_search table th + td:before {
	    height: calc(100% - 40px);
	}
	.page_search .btn_gosearch{
		margin-top:20px;
	}
	.btn_gosearch_number{
		font-size:0.875rem;
	}
	.product_list{
		margin-top:57px;
	}
	.product_category{
		margin-top:10px;
	}
}
@media screen and (min-width: 992px) {
	.ec-shelfGrid{
		gap: 0 60px;
	}
	.renew_page .ec-shelfGrid .ec-shelfGrid__item{
		padding: 30px 0px;
	    width: calc((100% - (60px*3)) / 4);
	    position: relative;
	    padding: 30px 0 26px;
	}
	.ec-shelfGrid__item a,
	.ec-shelfGrid__item > div{
		gap:10px;
	}
	.no-search .ec-shelfGrid__item:nth-of-type(4n+1)::before,
	.searched .ec-shelfGrid__item[data-count="1"]::before,
	.searched .ec-shelfGrid__item[data-count="5"]::before,
	.searched .ec-shelfGrid__item[data-count="9"]::before{
		content:"";
		height:0;
		width: calc((100% * 4) + (60px * 3));
		border-top:1px dotted #ccc;
		display:block;
		position:absolute;
		left:0;
		top:0;
	}
	.no-search .ec-shelfGrid__item:nth-of-type(4n+2)::before,
	.no-search .ec-shelfGrid__item:nth-of-type(4n+3)::before,
	.no-search .ec-shelfGrid__item:nth-of-type(4n)::before,
	.searched .ec-shelfGrid__item[data-count="2"]::before,
	.searched .ec-shelfGrid__item[data-count="3"]::before,
	.searched .ec-shelfGrid__item[data-count="4"]::before,
	.searched .ec-shelfGrid__item[data-count="6"]::before,
	.searched .ec-shelfGrid__item[data-count="7"]::before,
	.searched .ec-shelfGrid__item[data-count="8"]::before,
	.searched .ec-shelfGrid__item[data-count="10"]::before,
	.searched .ec-shelfGrid__item[data-count="11"]::before,
	.searched .ec-shelfGrid__item[data-count="12"]::before{
		content:"";
		height: calc(100% - 60px);
		width:0;
		border-right:1px dotted #ccc;
		display:block;
		position:absolute;
	    left: -30px;
	    top: 30px;
	}
}
@media print, (max-width: 991px) and (min-width: 769px) {
	.ec-shelfGrid{
		gap: 0 60px;
	}
	.renew_page .ec-shelfGrid .ec-shelfGrid__item{
		padding: 30px 0px;
	    width: calc((100% - (60px*2)) / 3);
	    position: relative;
	    padding: 30px 0 26px;
	}
	.ec-shelfGrid__item a{
		gap:10px;
	}
	.no-search .ec-shelfGrid__item:nth-of-type(3n+1)::before,
	.searched .ec-shelfGrid__item[data-count="1"]::before,
	.searched .ec-shelfGrid__item[data-count="4"]::before,
	.searched .ec-shelfGrid__item[data-count="7"]::before,
	.searched .ec-shelfGrid__item[data-count="10"]::before{
		content:"";
		height:0;
		width: calc((100% * 3) + (60px * 2));
		border-top:1px dotted #ccc;
		display:block;
		position:absolute;
		left:0;
		top:0;
	}
	.no-search .ec-shelfGrid__item:nth-of-type(3n+2)::before,
	.no-search .ec-shelfGrid__item:nth-of-type(3n)::before,
	.searched .ec-shelfGrid__item[data-count="2"]::before,
	.searched .ec-shelfGrid__item[data-count="3"]::before,
	.searched .ec-shelfGrid__item[data-count="5"]::before,
	.searched .ec-shelfGrid__item[data-count="6"]::before,
	.searched .ec-shelfGrid__item[data-count="8"]::before,
	.searched .ec-shelfGrid__item[data-count="9"]::before,
	.searched .ec-shelfGrid__item[data-count="11"]::before,
	.searched .ec-shelfGrid__item[data-count="12"]::before{
		content:"";
		height: calc(100% - 60px);
		width:0;
		border-right:1px dotted #ccc;
		display:block;
		position:absolute;
	    left: -30px;
	    top: 30px;
	}
}
/*商品詳細*/
.ec-productRole{
	padding-bottom:40px;
}
.ec-sliderItemRole{
	padding-top:20px;
	padding-bottom:20px;
	position:relative;
	margin-bottom:0;
}
.ec-sliderItemRole::before{
	content:"";
	display:block;
	width:100vw;
	height:100%;
	position:absolute;
	z-index:0;
	top:0;
	left:50%;
	transform:translateX(-50%);
	background:var(--sub-color02);
}
.ec-sliderItemRole .item_visual{
	margin-bottom:10px;
}
.item_visual .slide-item{
	background:#fff;
	aspect-ratio:1;
	display:flex;
	align-items:center;
	justify-content:center;
}
.ec-sliderItemRole .item_nav{
	display:flex;
	gap:10px;
	flex-wrap:wrap;
}
.item_nav .slideThumb{
	width:calc( (100% - (10px * 3)) / 4 );
	background:#fff;
	display:flex;
	align-items:center;
	justify-content:center;
	aspect-ratio:1;
	position:relative;
	margin-bottom:0;
}
.ec-price{
	display:flex;
	gap:10px;
	align-items:center;
	margin-bottom:20px;
	font-weight:bold;
}
.ec-price .ec-price__tax{
	color:var(--main-color);
	border:1px solid var(--main-color);
	font-size:0.714rem;
	line-height:1.5em;
	padding:1px 9px;
}
.ec-price .ec-price__price{
	color:var(--main-color);
	font-size:1.286rem;
    font-weight: normal;
    padding: unset;
}
.ec-productRole__table{
	width:100%;
	font-size:0.857rem;
}
.ec-productRole__table th{
	width:6em;
}
.ec-catlist{
	margin-top:0;
	display:flex;
	flex-wrap:wrap;
	gap:8px;
}
.ec-catlist a{
	color:inherit;
}
.ec-catlist li{
	display:flex;
	align-items:center;
	gap:8px;
}
.ec-catlist li:not(:last-child)::after {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--sub-color03);
    content: "";
    display: inline-block;
}
.ec-productRole__profile h2{
	background:unset;
	border-left:1px solid var(--main-color);
	font-size:1.143rem;
	color:inherit;
	text-align:left;
	padding: 0px 0px 0px 10px;
    margin-top: 20px;
    margin-bottom: 12px;
}
.item_detail{
	padding-top:40px;
	padding-bottom:40px;
}
.item_detail .item_detail_img img{
	width:100%;
	//aspect-ratio:1;
	background:#fff;
	padding:5px;
	object-fit:contain;
}
.item_detail_img + .item_detail_img{
	margin-top:20px;
}
.ec-product-else h2{
	color:#fff;
	position:relative;
	display:flex;
	background:unset;
	font-size:1.286rem !important;
	align-items:center;
	padding:0;
    margin-top: 45px;
}
.ec-product-else h2 span{
	display:inline-block;
	color:#fff;
	position:relative;
	padding:5px 20px 5px 0;
    max-width: calc(100% - 50px);
    text-align: left;
	z-index:1;
}
.ec-product-else h2 span::after{
	content:"";
	background:var(--sub-color01);
	display:block;
	height:100%;
	width:calc(100% + 20px + var(--bs-gutter-x));
	position:absolute;
	top:0;
	left:calc(var(--bs-gutter-x) * -.5);
	z-index:-1;
}
.ec-product-else h2::after{
	content:"";
	display:block;
	width:100%;
	height:1px;
	background:var(--main-color);
	flex:1;
    right: calc(var(--bs-gutter-x) * -.5);
    position: relative;
	z-index:1;
}

.ec-related .ec-shelfGrid__item:first-child::before{
	display:none;
}
.ec-productRole__banner{
	margin-top:24px;
}
.ec-productRole__banner a{
	text-align:center;
	display:block;
	max-width:740px;
	margin:0 auto;
}
@media screen and (max-width: 768px) {
	.ec-related .ec-shelfGrid__item:nth-child(-n+2){
		padding-top:10px;
	}
	.ec-related .ec-shelfGrid__item:nth-child(2)::before{
		top:10px;
		height: calc(100% - 30px);
	}
}
@media print{
	.item_visual .slide-item:not(:first-child){
		display:none;
	}
}
@media print, (min-width: 769px) {
	.ec-grid2{
		display:flex;
		gap:50px;
	}
	.ec-productRole .ec-grid2{
		margin-top:78px;
	}
	.ec-grid2 .ec-grid2__cell{
		width:calc((100% - (50px / 2)) / 2);
	    min-height: 0;
	    min-width: 0;
	}
	.ec-sliderItemRole{
		padding:30px;
		background:var(--sub-color02);
	}
	.ec-catlist{
		font-size:0.875rem;
		/*margin-top:5px;*/
	}
	.ec-sliderItemRole::before{
		display:none;
	}
	.item_nav{
		gap:6px;
	}
	.item_nav .slideThumb{
		width:calc( (100% - (6px * 5)) / 6 )
	}
	.ec-productRole{
		margin-bottom:80px;
	}
	.ec-productRole__productname h1{
		margin-top:5px;
	}
	.ec-productRole__table{
		//width:unset;
		min-width:355px;
		font-size:0.875rem;
	}
	.ec-productRole__table th,
	.ec-productRole__table td{
		padding-top:5px;
		padding-bottom:5px;
	}
	.product_name{
		font-size:1.25rem;
		line-height:1.225em;
	}
	.ec-price{
		margin-bottom:30px;
	}
	.ec-price .ec-price__price {
	    font-size: 1.25rem;
		font-weight:normal;
	}
	.ec-price .ec-price__tax {
		font-size:0.875rem;
	    line-height: 1.22em;
	    padding: 0px 9px;
		font-weight:normal;
	}
	.price02-default{
		font-size:1.125rem;
	}
	.ec-productRole__profile h2{
		font-size:1.125rem !important;
		margin-top:30px;
		margin-bottom:20px;
	}
	.ec-productRole__banner{
		margin-top:60px;
	}
	.item_detail{
        padding-top: 77px;
        padding-bottom: 77px;
	}
	.item_detail.bg-gray{
		position:relative;
	}
	.item_detail.bg-gray::before{
		content:"";
		background:var(--sub-color02);
		width:100vw;
		height:100%;
		position:absolute;
		top:0;
		left:50%;
		transform:translateX(-50%);
		z-index:-1;
	}
	.item_detail_img{
		max-width:740px;
        margin: 0 auto;
	}
	.item_detail_img + .item_detail_img{
		margin-top:50px;
	}
	.item_detail_img figcaption{
		margin-top:14px;
	}
	.item_detail .item_detail_img img{
		padding:10px;
	}
	.ec-product-else h2{
		font-size:1.25rem !important;
		font-weight:normal;
		margin-top:80px;
	}
	.ec-product-else h2:first-child{
		margin-top:90px;
	}
	.ec-product-else h2::after{
		right:0;
	}
	.ec-product-else h2 span{
		padding-left:22px;
		padding-top:8px;
		padding-bottom:8px;
		padding-right:27px;
	}
	.ec-product-else h2 span::after{
		left:0;
		width:calc(100% + 30px);
	}
	.btn-more{
		font-size:1.125rem;
		padding: 4px 21px;
		padding-right: 44px;
	}
}
@media print , (max-width: 991px) and (min-width: 769px){
	.ec-productRole__table{
		min-width:unset;
	}
}
@media screen and (min-width: 992px) {
	.ec-related .ec-shelfGrid__item:nth-child(-n+4){
		padding-top:0;
	}
	.ec-related .ec-shelfGrid__item:nth-child(-n+4)::before{
		top:0;
		height: calc(100% - 30px);
	}
}
@media print, (max-width: 991px) and (min-width: 769px) {
	.ec-productRole__productname h1{
		font-size:1.75rem;
	}
	.ec-productRole__profile .store_reserve_btns{
		flex-direction:column;
	}
	.ec-related .ec-shelfGrid__item:nth-child(-n+3){
		padding-top:0;
	}
	.ec-related .ec-shelfGrid__item:nth-child(-n+3)::before{
		top:0;
		height: calc(100% - 30px);
	}
}

.ec-progress .is-complete .ec-progress__number{
	background:var(--main-color);
}
.ec-progress .is-complete .ec-progress__label{
	color:var(--main-color);
}
.ec-blockBtn--action{
    background-color:var(--main-color);
    border-color:var(--main-color);
}
.ec-totalBox .ec-totalBox__paymentTotal .ec-totalBox__price,
.ec-totalBox .ec-totalBox__paymentTotal .ec-totalBox__taxLabel,
.ec-cartRole .ec-cartRole__totalAmount{
	color:var(--main-color);
}

#page_news_detail .ec-off1Grid__cell{
    width: 100%;
    margin-left: unset;
}

.page_column{
    margin-top: 60px;
}

.page_column a{
    background: var(--sub-color02);
    display: block;
    margin-bottom: 1.5rem;
	position:relative;
}
.page_column a::after{
	content:"";
	display: block;
    border:1px solid var(--main-color);
    width: 8px;
    height: 8px;
    position: absolute;
    bottom: 5px;
    right: 5px;
    border-top: unset;
    border-left: unset;
    transition: 0.3s;
}
.page_column a:hover::after{
    bottom: 3px;
    right: 3px;
}
.page_column figure+p{
	margin-top:0;
}
.page_column p{
    padding:0.5rem;
}
.page_column .page_column_img{
	margin:0;
}
.page_column .page_column_img img{
    aspect-ratio: 4 / 3;
    width: 100%;
    height: auto;
    object-fit: cover;
}
.is-hide{
	display:none;
}
.cmn_campaign:has( .cmn_campaign_top.is-hide){
	padding-top:35px;
}
@media screen and (max-width: 768px) {
	.page_column a{
	    margin-left: 20px;
	    margin-right: 20px;
	}
}