@charset "utf-8";

/**
 *
 *  店舗一覧
 *
 */

/*--------------------------------------------------------------------------
   overwrite
---------------------------------------------------------------------------*/
.em{
	font-weight: bold;
}


/*--------------------------------------------------------------------------
 #Main
---------------------------------------------------------------------------*/
#Main{
	background: url(/shared/images/bg_content.jpg) no-repeat top right;
	border-bottom: 1px solid #CCC;
}
#Shop{
	background: #f8f8f8;
}

@media screen and (max-width: 767px){

	#Main{
		background: none;
		border-bottom: none;
	}

}

/* .shop-nav
-----------------------------------------------------------------*/
#shop-nav{
	margin-top: 20px;
	border-bottom: 1px solid #e7e7e7;
	background: #fff;
}
.area-menu{
	height: 52px;
	background: #383838;
}
.area-list{
	overflow: hidden;
	display: table;
	width: 950px;
	height: 55px;
	margin: 0 auto;
	letter-spacing: -0.4em;
}
.area-list li{
	display: inline-block;
	width: 12.5%;
	margin-top: -3px;
	text-align: center;
	/display: inline;
	/zoom: 1;
	letter-spacing: 0em;
	line-height: 1;
}
.area-list li p{
	display: block;
	height: 55px;
	margin-top: 3px;
	color: #fff;
	cursor: pointer;
}
.area-list p:hover,
.area-list p.select{
	background: url(../images/btn_bg_area02.png) no-repeat center top;
}
.area-list li span{
	display: inline-block;
	width: 100%;
	height: 10px;
	margin-top: 20px;
	border-left: 1px solid #999;
	line-height: 1;
}
.area-list li:first-child span{
	border-left: none;
}
.area-list li:last-child span{
	width: 100%;
}

.pref-menu{
	overflow: hidden;
	height: 52px;
}
.tab-cont{
	overflow: hidden;
	height: 52px;
}
.tab-cont ul{
	height: 52px;
	text-align: center;
	letter-spacing: -0.4em;
}
.tab-cont li{
	padding: 20px;
	display: inline-block;
	/display: inline;
	/zoom: 1;
	letter-spacing: 0em;
	line-height: 1;
}
.tab-cont li a{
	vertical-align: middle;
	color: #333;
	text-decoration: none;
}
.tab-cont li a:hover{
	text-decoration: underline;
}

@media screen and (max-width: 767px){

	#shop-nav{
		margin-top: 20px;
	}
	.area-menu{
		height: auto;
		padding-left: 1px;
	}
	.area-list{
		display: block;
		width: 320px;
		height: auto;
		margin: 0 auto;
	}
	.area-list li{
		display: inline-block;
		float: left;
		width: 106px;
		margin: -1px 0 0 -1px;
		border: 1px solid #555;
		border-right: none;
	}
	.area-list li:last-child{
		width: 105px;
		border-right: 1px solid #555;
	}
	.area-list li p{
		height: 45px;
		margin-top: 0;
	}
	.area-list p:hover,
	.area-list p.select{
		background-image: none;
		background-color: #2b2b2b;
	}
	.area-list li span{
		margin-top: 17px;
		border: none;
	}
	.area-list li:last-child span{
		border: none;
	}

	.pref-menu{
		height: auto;
	}
	.pref-wrap{
		width: 320px;
		height: auto;
		margin: 0 auto;
		padding: 22px 0 5px;
		background: url(../images/ico_pref.png) no-repeat center 11px;
		background-size: 16.5px 9px;
	}
	.tab-cont{
		display: none;
		height: auto;
	}
	.tab-cont ul{
		width: 100%;
		height: auto;
		text-align: left;
	}
	.tab-cont li{
		display: inline-block;
		width: 33%;
		margin: 10px 0;
		padding: 0;
	}
	.tab-cont li a{
		display: block;
		padding: 2px 0;
		font-size: 12px;
		text-align: center;
		border-right: 1px solid #ccc;
	}
	.tab-cont li:nth-child(3n) a{
		border-right: none;
	}

}

/* .cont-wrap
-----------------------------------------------------------------*/
.cont-wrap{
	width: 950px;
	margin: 0 auto;
	padding: 0 0 40px 0;
}
.cont-wrap a{
	text-decoration: none;
	color: #000;
}

@media screen and (max-width: 767px){

	.cont-wrap{
		width: 280px;
		padding: 0;
	}

}

/* 共通
-----------------------------------------------------------------*/
.sec-ttl{
	position: relative;
	margin-bottom: 40px;
	padding: 20px 0;
	text-align: center;
}
.sec-ttl:after{
	position: absolute;
	left: 50%;
	bottom: 0;
	content: "";
	width: 28px;
	height: 2px;
	margin-left: -14px;
	background: #c0c0c0;
}

/* #Flagship
-----------------------------------------------------------------*/
#Flagship{
	padding-top: 30px;
}
#Flagship .sec-ttl img{
	width: 214px;
	height: auto;
}

/* .flagship
-----------------------------------------------------------------*/

.flagship .inbox{
	overflow: hidden;
	background: #fff;
	margin-bottom:10px;
}
.flagship .photo{
	float: left;
}
.Pc .flagship .inbox:hover .photo img{
	opacity: 0.7;
	-ms-filter: 'alpha(opacity=70)';
}
.flagship .txt-box{
	overflow: hidden;
	padding: 25px;
	font-size: 13px;
}
.flagship .txt-box .shop-name{
	margin-bottom: 5px;
	font-size: 16px;
	line-height: 1.4;
}
.Pc .flagship .inbox:hover .shop-name{
	text-decoration: underline;
}
.flagship  .txt-box .address{
	margin-bottom: 5px;
	line-height: 1.3;
}
.flagship  .txt-box .tel{
	font-weight: bold;
	margin-bottom: 20px;
}

/* business */
.flagship .txt-box .business{
	margin-bottom: 25px;
}
.flagship .txt-box .business dl{
	margin-bottom: 5px;
}
.flagship .txt-box .business dl dt,
.flagship .txt-box .business dl dd{
	display: inline-block;
	/display: inline;
	/zoom: 1;
	vertical-align: top;
}
.flagship .txt-box .business dl dt{
	width: 80px;
	font-weight: bold;
}
.flagship .txt-box .business dl dd{
	width: 320px;
}

.shop-box .txt-box .map{
	width: 88px;
	height: 28px;
	text-indent: -999px;
}
.shop-box .txt-box .map a{
	display: block;
	width: 88px;
	height: 28px;
	border: 1px solid #565656;
	background: url(../images/btn_map01.png) no-repeat center center;
}
.Pc .shop-box .txt-box .map:hover{
	width: 90px;
	height: 30px;
	background: #000;
}
.Pc .shop-box .txt-box .map:hover a{
	border: 1px solid #000;
	background: url(../images/btn_map01_on.png) no-repeat center center;
}

@media screen and (max-width: 767px){

	#Flagship{
		padding: 0;
	}
	#Flagship .sec-ttl{
		margin-bottom: 25px;
		padding: 30px 0 12px;
	}
	#Flagship .sec-ttl img{
		width: 151px;
		height: auto;
	}

	.flagship .photo{
		float: none;
	}
	.flagship .photo img{
		width: 280px;
		height: auto;
	}
	.flagship .txt-box{
		padding: 20px 15px;
		font-size: 12px;
	}
	.flagship .txt-box .shop-name{
		margin-bottom: 10px;
	}

	/* business */
	.flagship .txt-box .business{
		margin-bottom: 20px;
	}
	.flagship .txt-box .business dl dt{
		width: 60px;
	}
	.flagship .txt-box .business dl dd{
		width: auto;
	}

	.shop-box .txt-box .map{
		width: 70px;
		height: 24px;
	}
	.shop-box .txt-box .map a{
		width: 70px;
		height: 24px;
		background: url(../images/btn_map01_sp.png) no-repeat center center;
		-webkit-background-size: 24px 9px;
		background-size: 24px 9px;
	}
}


/* #Fair
-----------------------------------------------------------------*/
#Fair{
	padding-bottom: 35px;
}
#Fair .sec-ttl img{
	width: 242px;
	height: auto;
}
#Fair .no-fair{
	padding: 30px 0;
	font-size: 13px;
	text-align: center;
}
.fair .inbox{
	overflow: hidden;
	width: 100%;
	min-height: 210px;
	background: #fff;
}
.fair .inbox+.inbox{
	margin-top: 35px;
}
.fair .inbox a{
	display: block;
	overflow: hidden;
}
.fair .photo{
	float: left;
}
.Pc .fair .inbox > a:hover .photo img{
	opacity: 0.7;
	-ms-filter: 'alpha(opacity=70)';
}
.fair .txt-box{
	position: relative;
	overflow: hidden;
	min-height: 210px;
	padding: 25px 70px 25px 30px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.fair .inbox > a .txt-box:after{
	position: absolute;
	top: 50%;
	right: 20px;
	content: "";
	width: 14px;
	height: 24px;
	margin-top: -12px;
	background: url(../images/ico_arrow.png) no-repeat 0 0;
}
.fair .fair-shop{
	color: #7f7f7f;
	font-size: 13px;
	font-weight: bold;
}
.fair .fair-shop .pref{
	position: relative;
}
.fair .fair-shop .pref:after{
	content: "/";
	margin: 0 10px;
	font-weight: normal;
}
.fair .fair-ttl{
	height: 64px;
	margin-top: 5px;
	font-size: 18px;
	color: #323232;
}
.Pc .fair .inbox > a:hover .fair-ttl{
	text-decoration: underline;
}
.fair .fair-txt{
	margin-top: 20px;
	font-size: 13px;
}



@media screen and (max-width: 767px){

	#Fair{
		padding: 0 0 30px;
	}
	#Fair .sec-ttl{
		margin-bottom: 25px;
		padding: 30px 0 12px;
	}
	#Fair .sec-ttl img{
		width: 162px;
		height: auto;
	}

	.fair .photo{
		float: none;
	}
	.fair .photo img{
		width: 280px;
		height: auto;
	}
	.fair .txt-box{
		min-height: 0;
		padding: 20px 15px;
		font-size: 12px;
	}
	.fair .inbox > a .txt-box:after{
		display: none;
	}
	.fair .fair-shop .pref{
		display: block;
	}
	.fair .fair-shop .pref:after{
		display: none;
	}
	.fair .fair-ttl{
		height: auto;
		font-size: 16px;
		line-height: 1.6;
	}
	.fair .fair-txt{
		margin-top: 15px;
	}
}

/* .concept
-----------------------------------------------------------------*/
.concept .inblock{
	overflow: hidden;
	margin: -5px;
}
.concept .inbox{
	float: left;
	width: 308px;
	min-height: 370px;
	margin: 5px;
	background: #fff;
}
.Pc .concept .inbox:hover .photo img{
	opacity: 0.7;
	-ms-filter: 'alpha(opacity=70)';
}
.concept .txt-box{
	padding: 20px;
	font-size: 13px;
}
.concept .txt-box .shop-name{
	margin-bottom: 5px;
}
.Pc .concept .inbox:hover .shop-name{
	text-decoration:underline;
}
.concept .txt-box .address{
	min-height: 30px;
	margin-bottom: 5px;
	line-height: 1.3;
}
.concept .txt-box .tel{
	font-weight:bold;
	margin-bottom: 10px;
}

@media screen and (max-width: 767px){

	.concept{
		/*padding-bottom: 20px;*/
	}
	.concept .inblock{
		margin: 0;
	}
	.concept .inbox{
		position: relative;
		float: none;
		width: auto;
		min-height: 350px;
		margin: 0 0 15px 0;
		background: #fff;
	}
	.concept .inbox .photo img{
		width: 280px;
		height: auto;
	}
	.concept .txt-box .address{
		min-height: auto;
		margin-bottom: 10px;
	}
	.concept .txt-box .tel{
		margin-bottom: 30px;
	}
	.concept .txt-box .map{
		position: absolute;
		bottom: 15px;
		left: 20px;
	}

}

/* #Area
-----------------------------------------------------------------*/
#Area{
	padding: 20px 0 50px 0;
	background: #fff;
}
.area-wrap{
	padding-top: 45px;
}
.area-wrap h2{
	position: relative;
	margin-bottom: 15px;
	padding-bottom: 10px;
	font-size: 24px;
	text-align: center;
}
.area-wrap h2:after{
	position: absolute;
	left: 50%;
	bottom: 0;
	content: "";
	width: 28px;
	height: 2px;
	margin-left: -14px;
	background: #c0c0c0;
}


/* .shop-box */
#Area .shop-box{
	margin-top: 25px;
	margin-bottom: 40px;
}

/* .flagship */
#Area .flagship .inbox{
	border: 1px solid #dcdcdc;
}
#Area .flagship .ttl{
	margin-bottom: 15px;
}
#Area .flagship .ttl img{
	width: 160px;
	height: auto;
}

/* .concept */
#Area .concept .inbox{
	border: 1px solid #dcdcdc;
}
#Area .concept .ttl{
	margin-bottom: 15px;
}
#Area .concept .ttl img{
	width: 164px;
	height: auto;
}

.area-box{
	overflow: hidden;
	padding: 20px 0;
	border-bottom: 1px solid #ddd;
}
.area-box h3{
	float: left;
	width: 75px;
	margin-top: 6px;
	line-height: 2;
}
.area-box dl{
	float: right;
	width: 875px;
	margin: 7px 0;
	letter-spacing:-0.4em;
}
.area-box dl dt,
.area-box dl dd{
	display: inline-block;
	/display: inline;
	/zoom: 1;
	letter-spacing: 0;
	vertical-align: top;
}
.area-box dl dt.name{
	width: 200px;
	margin-right: 10px;
	font-size: 13px;
}
.area-box dl dd{
	font-size: 13px;
}
.area-box dl .ico{
	width: 90px;
}
.area-box dl .ico img{
	vertical-align: middle;
}
.area-box dl .address{
	width: 388px;
	margin-right: 20px;
}
.area-box dl .tel{
	width: 100px;
	margin-right: 10px;
}
.area-box dl .map{
	margin-right: 0;
	text-indent: -9999px;
	border: 1px solid #646464;
}
.Pc .area-box dl .map:hover{
	background: #000;
	border: 1px solid #000;
}
.area-box dl .map a{
	display: block;
	width: 55px;
	height: 20px;
	background: url(../images/btn_map02.png) no-repeat center center;
}
.Pc .area-box dl .map a:hover{
	background: url(../images/btn_map02_on.png) no-repeat center center;
}


@media screen and (max-width: 767px){

	#Area{
		padding: 0 0 50px 0;
	}
	.area-wrap{
		padding-top: 30px;
	}
	.area-wrap h2{
		margin-bottom: 15px;
		padding-bottom: 5px;
		font-size: 19px;
	}

	/* .shop */
	#Area .shop-box{
		margin-bottom: 0;
	}
	#Area .shop-box + .shop-box{
		margin-top: 40px;
	}

	/* .flagship */
	#Area .flagship .ttl{
		margin-bottom: 10px;
	}
	#Area .flagship .ttl img{
		width: 121px;
		vertical-align: middle;
	}

	/* .concept */
	#Area .concept .ttl{
		margin-bottom: 10px;
	}
	#Area .concept .ttl img{
		width: 115px;
		vertical-align: middle;
	}

	.area-box{
		overflow: hidden;
		padding: 10px 0;
		border-bottom: none;
	}
	.area-box h3{
		float: none;
		width: 100%;
		margin-top: 0;
		padding: 2px 0;
		background: #2b2b2b;
		color: #fff;
		font-size: 14px;
		text-align: center;
	}
	.area-box dl{
		float: none;
		width: 100%;
		margin: 0;
		padding: 15px 0 20px;
		border-bottom: 1px solid #ddd;
	}
	.area-box dl:last-child{
		border-bottom: none;
	}
	.area-box dl dt.name{
		width: 100%;
		margin: 10px 0 0 0;
		font-size: 15px;
		line-height: 1.2;
	}
	.area-box dl .ico{
		width: 100%;
		height: auto;
		margin-bottom: 5px;
	}
	.area-box dl .ico img{
		width: 50px;
		height: auto;
	}
	.area-box dl .address{
		width: 100%;
		margin: 0 0 10px 0;
		font-size: 11px;
	}
	.area-box dl .tel{
		width: 220px;
		margin: 0;
	}
	.area-box dl .map a{
		background: url(../images/btn_map02_sp.png) no-repeat center center;
		-webkit-background-size: 24px 9px;
		background-size: 24px 9px;
	}

}