/* スタジアム */
.stadium {
	width: 100%;
	padding-top: 40px;
	padding-bottom: 40px;
	color: var(--team-primary-color);
	background: #FFF;
}

.stadium_title {
	margin: 0px;
	margin-bottom: 8px;
}

.stadium_sub {
	margin: 0px;
	margin-bottom: 20px;
}


/* マップ */
.map_tab_block {
	padding: 0px;
	margin: 0px;
	text-align: center;
	display: flex;
	flex-wrap: nowrap;
	line-height: 1.0;
}
.map_tab_block li {
	list-style: none;
}
.map_tab {
	margin-right: 10px;
	width: 260px;
	height: 50px;
	font-size: 18px;
	border-style: solid;
	border-color: var(--team-primary-color);
	border-width: 1px;
	border-bottom-width: 0px;
	vertical-align: middle;
	cursor: pointer;
	user-select: none;
	-webkit-user-select: none;
}
.map_tab a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	text-decoration: none;
	margin: 0px;
	padding: 0px;
	color: var(--team-primary-color);
	background: #FFF;
	font-weight: 500;
}
.map_tab a.map_select {
	color: #FFF;
	background: var(--team-primary-color);
}
.map_block {
	padding: 0px;
	margin: 0px;
	width: 100%;
	height: 500px;
	color: var(--team-primary-color);
	background: #FFF;
	border-top: var(--team-primary-color);
	border-bottom: var(--team-primary-color);
	border-top-width: 1px;
	border-bottom-width: 1px;
	border-left-width: 0px;
	border-right-width: 0px;
	border-style: solid;
}
.map_block li {
	list-style: none;
}
.googlemap {
	width: 100%;
	height: 100%;
	list-style: none;
}
@media screen and (max-width: 480px) {
	.map_tab {
		width: 150px;
		height: 35px;
		font-size: 13px;
	}
}




/* ショップ・ジャンル */
.shop {
	padding-top: 50px;
}

.shop_genres {
	padding-left: 0px;
	margin-left: 40px;
	font-size: 14px;
	text-align: center;
	display: flex;
	flex-wrap: wrap;
	line-height: 1.0;
}
@media screen and (max-width: 480px) {
	.shop_genres {
		margin-left: 20px;
	}
}
.shop_genre {
	margin-right: 8px;
	padding-left: 12px;
	padding-right: 12px;
	height: 24px;
	color: var(--genre-color);
	background: #FFF;
	border-style: solid;
	border-radius: 24px;
	border-color: var(--genre-color);
	border-width: 1px;
	list-style: none;
	vertical-align: middle;
	cursor: pointer;
	user-select: none;
	-webkit-user-select: none;
}
.shop_genre.select {
	color: #FFF;
	background: var(--team-primary-color);
}
.shop_genre.select a{
	color: #FFF;
}
.shop_genre a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	text-decoration: none;
	margin: 0px;
	padding: 0px;
}
/*
.shop_block {
}
*/
.shop_stadium {
	font-family: Cabin,"Noto Sans JP";
	font-size: 24px;
	padding-bottom: 0px;
	user-select: none;
	-webkit-user-select: none;
}
.shop_genre_text {
	font-size: 20px;
	margin-bottom: 30px;
	user-select: none;
	-webkit-user-select: none;
}
@media screen and (max-width: 480px) {
	.shop_stadium {
		font-size: 18px;
	}
	.shop_genre_text {
		font-size: 13px;
	}
}


/* ショップリスト */
/*
.shop_list_block {
}
*/
.shop_list {
	width: 100%;
	padding: 0px;
	margin: 0px;
	list-style: none;
	overflow: hidden;
	justify-content: center;
	display: inline-block;
}
.shop_col {
	width: calc((100% - 60px) / 3);
	margin-left: 10px;
	margin-right: 10px;
    padding-top: 50px;
    padding-bottom: 0px;
	display: flex;
	float: left;
	
	border-style: solid;
	border-color: #FFF;
	border-bottom-color: var(--team-primary-color);
	border-top-width: 0px;
	border-bottom-width: 1px;
	border-left-width: 0px;
	border-right-width: 0px;
}
.shop_item {
	padding: 0px;
	width: 100%;
	height: 100%;
	font-size: 16px;
	color: var(--shop-title-color);
}
.shop_image {
	padding-top: 10px;
	width: 170px;
	height: 170px;
	float: left;
}
.shop_googlemap {
	width: 100%;
	height: 270px;
	padding-bottom: 20px;
}
.shop_title {
	font-size: 18px;
}
.shop_title, .shop_address, .shop_phone, .shop_site {
	height: 48px;
	text-overflow: ellipsis;
	overflow: visible;
	vertical-align: middle;
	display: inline-flexbox;
}
.shop_phone {
	height: 32px;
}
.shop_site {
	height: 32px;
}
.shop_title span, .shop_address span, .shop_phone span, .shop_site span {
	display: inline-block;
	vertical-align: middle;
}
.shop_title span p, .shop_address span p, .shop_phone span p, .shop_site span p {
	margin: 0px;
	line-break: anywhere;
	overflow-wrap: break-word;
}
.shop_text {
	inline-size: calc(100% - 60px);
}
.shop_icon_address {
	width: 24px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.shop_icon {
	width: 24px;
	height: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.shop_r {
	padding-left: 4px;
}
.shop_address img {
	width: 16px;
	height: 24px;
}
.shop_phone img {
	width: 16px;
	height: 24px;
}
.shop_site img {
	width: 24px;
	height: 22px;
}
.shop_site a {
	text-decoration: none;
}
.shop_comment {
	padding-top: 4px;
	padding-left: 8px;
	height: 220px;
	display: flex;
	text-overflow: ellipsis;
	overflow: hidden;
	color: var(--shop-message-color);

	line-height: 1.75;
}
@media screen and (max-width: 1280px) {
	.shop_col {
		width: calc((100% - 40px) / 2);
		margin-left: 10px;
		margin-right: 10px;
	}
	.shop_image {
		width: 170px;
		height: 170px;
	}
	.shop_comment {
		height: 250px;
	}
}
@media screen and (max-width: 884px) {
	.shop_col {
		width: 100%;
		margin-left: 0px;
		margin-right: 0px;
		padding-top: 30px;
	    padding-bottom: 30px;
	}
	.shop_comment {
		height: 170px;
	}
}
@media screen and (max-width: 480px) {
	.shop_col {
		width: 100%;
		margin-left: 0px;
		margin-right: 0px;
    	padding-top: 30px;
	    padding-bottom: 30px;
	}
	.shop_item {
		font-size: 13px;
	}
	.shop_title {
		height: 32px;
		font-size: 14px;
	}
	.shop_image {
		width: 120px;
		height: 120px;
	}
	.shop_address img {
		width: 13.33px;
		height: 20px;
	}
	.shop_phone img {
		width: 13.33px;
		height: 20px;
	}
	.shop_site img {
		width: 19.64px;
		height: 18px;
	}
	.shop_comment {
		font-size: 12px;
		height: 130px;

		line-height: 1.83;
	}
}
