@charset "utf-8";
main{
	display: flex;
	top:0;
	flex-wrap:wrap;
	/* width: 100%; */
	gap:10px;
}
main h2{
	letter-spacing: 5px;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-size:18px;
	margin-bottom:0;
	margin-top: 0px;
}
main .h2-wrap{
	background-color:#FFF;
	padding-top: 10px;
	padding-bottom:10px;
	width:100%;
	border-bottom: 1px solid #000;
	position: sticky;
	top: 0;
	z-index: 2;
}
.shop-list-warap {
	height:calc(100% - 60px);
	position:sticky;
	top:60px;
	border:1px solid #000;
	width: 100%;
	display:flex;
	flex-wrap:wrap;
}

div#gmap {
	height: 100%;
}
#shop-list-table{
	overflow-y:auto;
	scrollbar-color: #a43024 #f3e4ed;
	scrollbar-width: thin;
}
#shop-list-table ul{
	margin:0;
	padding:0;
	list-style:none;
}
#shop-list-table .shop {
	display:flex;
	flex-direction:column;
	padding-bottom:15px;
	gap:5px;
	padding-left: 10px;
	padding-right: 10px;
}
#shop-list-table .shop:not(:first-child) {
	padding-top:15px;
}
#shop-list-table .shop:not(:last-child) {
	border-bottom:1px solid #CCC;
}

#shop-list-table .shop h3{
	margin:5px 0;
	font-size:16px;
	font-family: "Noto Serif JP", serif;
	color:#a33223;
	border-left: 3px solid #a33223;
	padding-left: 10px;
	display: flex;
	justify-content: space-between;
}
#shop-list-table .shop{
	font-size:14px;
	background-color:#FFF;
	transition:0.8s;
	cursor: pointer;
}
#shop-list-table .shop.active,
#shop-list-table .shop:hover{
	background-color:#e6cbea;
}
#shop-list-table .shop .business-data{
	display:flex;
	gap: 5px 15px;
	align-items:center;
	flex-wrap:wrap;
}
#shop-list-table .tit{
	color:#FFFFFF;
	background-color:#2488a6;
	padding:3px 5px;
	position:relative;
	width:70px;
}
#shop-list-table .tit:after{
	position:absolute;
	display:block;
	content:'';
	width:0;
	height:0;
	border-style:solid;
	border-width:7px 0 7px 7px;
	border-color:transparent transparent transparent #2488a6;
	margin:auto;
	right:-6px;
	top:0;
	bottom:0;
}
#shop-list-table .shop .icon-wrap {
	display:flex;
	align-items:center;
}
#shop-list-table .shop .icon-wrap a{
	text-align:center;
	padding:3px;
}
#shop-list-table .data.access{
	display:flex;
	gap:5px;
	width: 100%;
}
#shop-list-table .data.access a{
	text-align:center;
	text-decoration:none;
	padding: 2px 2px;
}
#shop-list-table .shop .icon-wrap a,
#shop-list-table .data.access a{
	background-color:#1fa21d;
	border-bottom:1px solid #0a7208;
	border-right:1px solid #0a7208;
	border-top:1px solid #44c742;
	border-left:1px solid #44c742;
	color:#FFF;
	text-decoration:none;
	border-radius:4px;
	text-shadow:-1px -1px 1px rgba(0,0,0,.3);
	transition:0.3s;
}
#shop-list-table .shop .icon-wrap a:hover,
#shop-list-table .data.access a:hover{
	background-color:#68c967;
	border-bottom:1px solid #3fa93e;
	border-right:1px solid #3fa93e;
	border-top:1px solid #9de09d;
	border-left:1px solid #9de09d;
	text-shadow:-1px -1px 1px rgba(0,0,0,.0);
	text-decoration:none;
}

#shop-list-table i{
	margin-right:3px;
}

.pc .a-tel {
	pointer-events:none;
	color:#000;
	text-decoration:none;
}
#shop-list footer{
	width:100%;
	left:0;
	position:relative;
}
#footer-nav{
	padding-top:10px;
	padding-bottom: 10px;
}
@media screen and (min-width:641px){
	.is-sp{
		display:none;
	}
}
@media screen and (min-width:801px){
	main{
		height: calc(100dvh );
	}
	#shop-list-map {
		order:2;
		width:calc(100% - 360px);
		height: calc(100% - 60px);
	}
	#shop-list-table {
		order:1;
		width:350px;
		height: calc(100% - 60px);
	}
	#shop-list-table .data.access a{
		width:58px;
	}
	#shop-list-table .data.access .a-home-link{
		width:120px;
	}
	#shop-list-table .shop .icon-wrap a{
		width:100%;
	}
	#shop-list-table .data{
		width:calc(100% - 85px);
	}
	#return-page-top{
		display:none;
	}
	#shop-list-table .shop .icon-wrap {
		gap:10px;
	}
}
@media screen and (max-width:800px){
	main{
		/* max-height: 100%; */
	}
	#shop-list-map {
		position:sticky;
		top: 45px;
		width:100%;
		height: calc(40dvh);
		z-index:1;
		padding-bottom:10px;
		background-color:#FFF;
	}
	#shop-list-table {
		width:100%;
		max-height: calc(60dvh - 50px);
		/* position: sticky; */
		/* top: calc(30dvh + 45px); */
	}
	#shop-list-table .data.access a{
		width: calc(100% / 3);
	}
	#shop-list-table .tit{
		display:none;
	}
	#shop-list-table .data{
		width:100%;
	}
	#shop-list-table .shop .icon-wrap a{
		width:50%;
	}
	.h2-wrap .tit-search-area-wrap{
		position:absolute;
		right: -10px;
		text-align:right;
		top: 15px;
		/* background-color:#FFF; */
		font-size: 16px;
		overflow: hidden;
	}
	.h2-wrap .tit{
		line-height:1;
		padding:2px 5px;
		display: block;
		position:relative;
		z-index:2;
		margin-right: 10px;
		transition:0.3s;
		border: 1px solid #004e87;
		border-radius:4px;
		color: #004e87;
		background-color: #eef8ff;
		text-align:center;
	}
	[name="tit-search-area-open"]{
		display:none;
	}
	[name="tit-search-area-open"]:checked ~ .tit{
		border: 1px solid #a53023;
		border-radius:4px;
		color: #a53023;
		background-color: #fffbfb;
	}
	[name="tit-search-area-open"]:checked ~ .tit-search-area {
		/* display:flex; */
		right: 0px;
	}
	.tit-search-area{
		display: flex;
		flex-direction:column;
		padding:10px;
		box-shadow:1px 1px 1px rgba(0,0,0,.3);
		position:relative;
		z-index:1;
		background: #FFF;
		right: -100%;
		transition:0.3s;
		border-top: 1px solid #a53023;
		border-left: 1px solid #a53023;
		border-bottom: 1px solid #a53023;
		margin-top:3px;
		border-radius:5px 0 0 5px;
	}
	.tit-search-area a{
		text-decoration:none;
		text-align:left;
		color:#a53023;
		border-bottom:1px solid #e98b80;
	}
	.tit-search-area a.active{
		color:#e5968d;
		pointer-events:none;
	}
	.tit-search-area a:not(:first-child){
		margin-top:5px;
	}
	#shop-list-table .shop .icon-wrap {
		gap:5px;
	}
	#shop-list-table {
		margin-bottom:70px;
	}
	#shop-list footer{
		position:fixed;
		bottom:0;
		left:0;
	}
	.gm-control-active,
	.gmnoprint{
		display:none !important;
	}
}
@media screen and (max-width:640px){
	.is-pc{
		display:none;
	}
	main h2{
		font-size: 16px;
	}
	.h2-wrap .tit{
		font-size: 14px;
	}
}
@media screen and (max-width:460px){
	main h2{
		font-size: 4vw;
	}
	.h2-wrap .tit{
		font-size: 3.5vw;
	}
}
iframe{
	width:100%;
	height: 100%;
}

h3 .name{
	width:calc(100% - 35px);
}
h3 .btn-shop-favorite{
	width: 20px;
	height: 20px;
	border-width:0;
	background-color:transparent;
	box-sizing:border-box;
	background-repeat:no-repeat;
	background-size:contain;
	background-position: center center;
	font-size:min(3.5vw,14px);
	text-align:center;
	color:#000;
	/* padding-top:50px; */
	text-decoration:none;
	font-size:12px;
	transition: .3s;
	display: block;
	cursor: pointer;
}
h3 .btn-shop-favorite[data-favo="0"]{
	background-image:url(/img/shop/common/heart_plus.webp);
}
h3 .btn-shop-favorite[data-favo="1"]{
	background-image:url(/img/shop/common/heart02.webp);
}


div#mapContainer {
	width: 100%;
	height: 100%;
}