@charset "utf-8";
/* CSS Document */

/* ---------------------------------
  下層ページ共通
------------------------------------*/
/* common.cssへ移動
.content_title {
	padding: 3em 0;
	display: flex;
	flex-direction: column-reverse;}
.content_title .content_title_ja {
	color: #006150;
	font-size: 1.8rem;
	font-weight: 700;
	text-align: center;}
.content_title .content_title_en {
	margin-bottom: 0.25em;
	font-family: "ab-kirigirisu", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 2.7em;
	text-align: center;}
.content_title .content_title_en span { display: inline-block;}
.content_title .content_title_en span::first-letter {
	color: #33b458;}

@media screen and (max-width: 640px){

.content_title {
	padding: 2em 0;}

}*/

/*--------------------------------
	『ショップガイド』ページ用CSS
---------------------------------*/

#food {
	margin-top: -110px;
	padding-top: 110px;}

.shopguide_list .food_title {
	margin: 0 auto 2em auto;
	padding: 0.25em 0;
	width: 1100px;
	height: 1.8em;
	line-height: 1.8em;
	color: #fff;
	background-color: #006150;
	font-size: 1.9rem;
	font-weight: 700;
	text-indent: 1em;}

#shopguide a.btn-floorguide {
	margin: 0 auto 1em auto;
	padding: 0 5% 0 5%;}
#shopguide a.btn-floorguide:last-of-type {
	margin-bottom: 3em;}
.shopguide_list .container {
	border-top: solid 1px #ccc;
	border-left: solid 1px #ccc;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 3em;}
.shopguide_list .shoplist_box {
	padding: 15px;
	border-right: solid 1px #ccc;
	border-bottom: solid 1px #ccc;
	display: flex;
	flex-direction: column;
	width: 275px;
	box-sizing: border-box;}
.shopguide_list .shoplist_box .shoplist_name {
	margin-bottom: 15px;
	position: relative;
	display: flex;
	flex-flow: row-reverse;
	justify-content: space-between;
	order: 2;
	height: 70px;}
.shopguide_list .shoplist_box .shoplist_name h2 {
	width: calc(100% - 85px);
	font-size: 1.1em;
	color: #603813;}
.shopguide_list .shoplist_box.nologo .shoplist_name h2 {
	width: 100%;}
.shopguide_list .shoplist_box .shoplist_name .shoplist_additional {
	position: absolute;
	bottom: 0;
	right: 0;
	display: flex;
	align-items: flex-end;
	gap: 10px;
	width: calc(100% - 85px);}
.shopguide_list .shoplist_box.nologo .shoplist_name .shoplist_additional {
	width: 100%;}
.shopguide_list .shoplist_box .shoplist_name .shoplist_category img {
	width: 30px;
	height: 30px;}
.shopguide_list .shoplist_location span {
	margin-right: 0.5em;
	padding: 0 1em;
	display: inline-block;
	height: 1.4em;
	line-height: 1.4em;
	font-size: 1.3rem;
	font-weight: 600;
	border-radius: 0.7em;}
.shopguide_list .shoplist_location span.location_1f {
	background-color: #f4b8c3;}
.shopguide_list .shoplist_location span.location_2f {
	background-color: #ffde8d;}
.shopguide_list .shoplist_location span.location_outdoor {
	background-color: #b8d9f2;}
.shopguide_list .shoplist_logo {
	max-width: 70px;
	max-height: 70px;}
.shopguide_list .shoplist_logo img {
	width: auto;
	height: auto;
	max-width:100%;
	max-height:100%;
	margin:auto;}
.shopguide_list .shoplist_box .shoplist_photo {
	margin-bottom: 15px;
	order: 1;}
.shopguide_list .shoplist_box .shoplist_photo img {
	width: 100%;
	border-radius: 0.5em;}
.shopguide_list .shoplist_box .shoplist_info {
	order: 3;}
.shopguide_list .shoplist_box dl {
	margin-bottom: 1em;
	display: flex;
	flex-wrap: wrap;
	line-height: 1.4;}
.shopguide_list .shoplist_box dl dt {
	width: 5em;}
.shopguide_list .shoplist_box dl dd {
	width: calc(100% - 5em);}
.shopguide_list .shoplist_box .btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #eeeeee;
	box-sizing: border-box;
	border-radius: 1em;
	width: 100%;
	height: 2em;
	padding: 0 12% 0 6%;
	font-size: 0.9em;
	text-align: left;
	text-decoration: none;
	position: relative;
	transition-duration: 0.2s;
}
.shopguide_list .shoplist_box .btn a:before {
	content: "";
	display: inline-block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 8px;
	border-color: transparent transparent transparent #333333;
	position: absolute;
	top: 50%;
	right: 6%;
	margin-top: -5px;
}

@media screen and (max-width: 640px){

.shopguide_list .food_title {
	margin: 0 1.2em 2em 1.2em;
	width: auto;}
#shopguide a.btn-floorguide {
	width: 90%;
}
.shopguide_list .container {
	margin: 0 1.2em;
	padding: 0;
	width: auto;}
.shopguide_list .shoplist_logo {
	display: none;}
.shopguide_list .shoplist_box {
	padding: 10px;
	width: 50%;}
.shopguide_list .shoplist_box .shoplist_name {
	flex-flow: column;
	height: auto;}
.shopguide_list .shoplist_box .shoplist_name h2 {
	margin-bottom: 0.5em;
	width: 100%;
	text-align: left;}
.shopguide_list .shoplist_box .shoplist_name .shoplist_additional {
	position: relative;
	bottom: inherit;
	right: inherit;
	width: 100%;}
.shopguide_list .shoplist_box dl {
	flex-direction: column;}
.shopguide_list .shoplist_box dl dd {
	width: 100%;}
}



/*--------------------------------
	『ショップガイド ショップ詳細』ページ用CSS
---------------------------------*/
#shopguide_title {
	padding: 0 0 1em 0;
}
#shopguide_title .container {
	display: flex;
	justify-content: space-between;
	padding: 2em 0;
}
#shopguide_title .content_title {
	padding: 0;
}
#shopguide_title .content_title .content_title_ja {
	text-align: left;
}
#shopguide_title .content_title .content_title_en {
	text-align: left;
}
@media screen and (max-width: 640px){
	#shopguide_title .container {
		padding: 2em 0 0;
		flex-direction: column;
		align-items: center;
	}
	#shopguide_title .content_title .content_title_ja {
		text-align: center;
	}
	#shopguide_title .content_title .content_title_en {
		text-align: center;
	}
	#shopguide_title .container > div {
		margin-bottom: 2em;
	}
}

#shopguide_shopname {
	padding: 0 0 1em 0;
}
#shopguide_shopname .container {
	padding-bottom: 15px;
	border-bottom: solid 3px #006150;
	position: relative;
	display: flex;
	align-items: center;
}	
#shopguide_shopname .container::after {
	content: "";
	position: absolute;
	width: 70%;
	border-bottom: solid 3px #ccc;
	bottom: -3px;
	right: 0px;
}
#shopguide_shopname h1 {
	order: 2;
	color: #006150;
	font-size: 2.4rem;}
#shopguide_shopname .shopname_logo {
	margin-right: 15px;
	order: 1;}
#shopguide_shopname .shopname_logo img {
	max-height: 60px;
	max-width: 100px;}
#shopguide_shopname .shopname_category {
	margin-left: auto;
	order: 3;
	display: flex;
	flex-direction: row-reverse;
	align-items: flex-end;}
#shopguide_shopname .shopname_category img {
	margin-left: 10px;
	width: 50px;}
/*#shopguide_shopname .shopname_additional .shopname_location span {
	margin-top: 0.5em;
	padding: 0 1em;
	display: block;
	height: 1.4em;
	line-height: 1.4em;
	font-size: 1.3rem;
	font-weight: 600;
	border-radius: 0.7em;}
#shopguide_shopname .shopname_additional .shopname_location span.location_1f {
	background-color: #f4b8c3;}
#shopguide_shopname .shopname_additional .shopname_location span.location_2f {
	background-color: #ffde8d;}
*/

#shopguide_shopinfo .container {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-start;
}
#shopguide_shopinfo .shopinfo_location {
	width: 100%;
	display: flex;
	justify-content: flex-end;
	margin-bottom: 1em;
}
#shopguide_shopinfo .shopinfo_location span {
	padding: 0 1em;
	display: block;
	height: 1.4em;
	line-height: 1.4em;
	font-size: 1.3rem;
	font-weight: 600;
	border-radius: 0.7em;
	margin-left: 0.5em;}
#shopguide_shopinfo .shopinfo_location span.location_1f {
	background-color: #f4b8c3;}
#shopguide_shopinfo .shopinfo_location span.location_2f {
	background-color: #ffde8d;}
#shopguide_shopinfo .shopinfo_location span.location_outdoor {
	background-color: #b8d9f2;}


#shopguide_shopinfo .shopinfo_mainphoto {
	width: 60%;
	margin-bottom: 2em;
}
#shopguide_shopinfo .shopinfo_mainphoto img {
	width: 100%;
}
#shopguide_shopinfo .shopinfo_intro {
	width: 35%;
	margin-bottom: 2em;
}
#shopguide_shopinfo .shopinfo_intro h2 {
	color: #006150;
	line-height: 1.3;
	margin-bottom: 1em;
}
#shopguide_shopinfo dl.shop-detail {
	width: 60%;
	display: flex;
	flex-wrap: wrap;
	border-top: 1px solid #ccc;
}
#shopguide_shopinfo dl.shop-detail dt, #shopguide_shopinfo dl.shop-detail dd {
	border-bottom: 1px solid #ccc;
	padding: 1em 0;
	line-height: 1.2;
}
#shopguide_shopinfo dl.shop-detail dt {
	color: #603813;
	font-weight: 600;
	width: 20%;
}
#shopguide_shopinfo dl.shop-detail dd {
	width: 80%;
}
#shopguide_shopinfo .shopinfo_subphoto {
	width: 35%;
}
#shopguide_shopinfo .shopinfo_subphoto img {
	width: 100%;
}
@media screen and (max-width: 640px){
	#shopguide_shopinfo .container {
		flex-direction: column;
	}
	#shopguide_shopinfo .shopinfo_mainphoto {
		width: 100%;
		margin-bottom: 1em;
	}
	#shopguide_shopinfo .shopinfo_intro {
		width: 100%;
		margin-bottom: 1em;
	}
	#shopguide_shopinfo .shopinfo_intro h2 {
		text-align: left;
		margin-bottom: 0.5em;
	}
	#shopguide_shopinfo dl.shop-detail {
		width: 100%;
		margin-bottom: 1em;
	}
	#shopguide_shopinfo dl.shop-detail dt {
		width: 30%;
	}
	#shopguide_shopinfo dl.shop-detail dd {
		width: 70%;
	}
	#shopguide_shopinfo .shopinfo_subphoto {
		width: 100%;
	}
}

#shopguide_shopnews {
	padding-top: 110px;
	margin-top: -110px;
}
#shopguide_shopnews .content_title {
	padding: 0;
}
#shopguide_shopnews .content_title .content_title_ja {
	text-align: left;
}
#shopguide_shopnews .content_title .content_title_en {
	text-align: left;
}
#shopguide_shopnews .news-wrapper {
	background-color: #d6f0de;
	border-radius: 10px;
	padding: 2em;
	display: flex;
	justify-content: flex-start;
	margin: 2em 0 0;
}
#shopguide_shopnews .news-wrapper img {
	max-width: 400px;
	margin-right: 2em;
}
#shopguide_shopnews .news-wrapper h2 {
	color: #006150;
	margin-bottom: 1em;
}
#shopguide_shopnews a.btn-floorguide {
	margin-top: 4em;
}
@media screen and (max-width: 640px){
	#shopguide_shopnews .content_title .content_title_ja {
		text-align: center;
	}
	#shopguide_shopnews .content_title .content_title_en {
		text-align: center;
	}
	#shopguide_shopnews .news-wrapper {
		flex-direction: column;
		padding: 1em;
		margin: 1.5em 0 0;
	}
	#shopguide_shopnews .news-wrapper img {
		width: 100%;
		margin-right: 0;
	}
	#shopguide_shopnews .news-wrapper h2 {
		margin: 0.5em 0;
		text-align: left;
	}
	#shopguide_shopnews a.btn-floorguide {
		margin-top: 2em;
	}
}



/*--------------------------------
	『インフォメーション』ページ用CSS
---------------------------------*/

#information section.shopinfo {
	margin-top: -130px;
	padding-top: 130px;}

#information section.shopinfo h2 {
	margin-bottom: 0.5em;
	height: 1.8em;
	line-height: 1.8em;
	color: #fff;
	background-color: #006150;
	font-size: 1.9rem;
	padding: 0.25em 0;
	text-indent: 1em;}
#information section.shopinfo .date {
	text-align: right;
	color: #33b458;
	font-weight: 500;
}
#information section.shopinfo .info-wrapper {
	padding: 1em 0 2em;
	border-bottom: 1px solid #ccc;
	display: flex;
	align-items: flex-start;
}
#information section.shopinfo .info-wrapper img {
	margin-right: 2em;
	max-width: 300px;
}
#information section.shopinfo .info-wrapper a.btn {
	width: fit-content;
}

@media screen and (max-width: 640px){

#information section.shopinfo {
	margin-top: -90px;
	padding-top: 90px;}

#information section.shopinfo h2 {
	margin-bottom: 0.5em;
	padding: 0.5em 1em;
	height: auto;
	line-height: 1.4;
	text-align: left;
	text-indent: 0;}
#information section.shopinfo .info-wrapper {
	flex-flow: column;}
#information section.shopinfo .info-wrapper img {
	margin: 0 0 1em 0;
	width: 100%;
	max-width: inherit;}

}


/*--------------------------------
	『ショップニュース』ページ用CSS
---------------------------------*/
#shopnews ul.shopnews-list {
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
}
#shopnews ul.shopnews-list li {
	width: 350px;
	border: 2px solid #96c958;
	border-radius: 10px;
	background-color: #fff;
	padding: 1em;
	margin-bottom: 1em;
	margin-right: 25px;
	box-sizing: border-box;
}
#shopnews ul.shopnews-list li:nth-of-type(3n){
	margin-right: 0;
}
#shopnews ul.shopnews-list li dt img {
	width: 100%;
}
#shopnews ul.shopnews-list li dt {
	display: flex;
	flex-direction: column;
	border-bottom: 2px solid #cccccc;
	margin-bottom: 0.5em;
}
#shopnews ul.shopnews-list li dt a.title {
	display: flex;
	align-items: center;
	margin: 0.5em 0;
	color: #006150;
	font-weight: 600;
}
#shopnews ul.shopnews-list li dt a.title img {
	width: 30px;
	margin-right: 0.2em;
}
#shopnews ul.shopnews-list li dd {
	font-weight: 600;
	color: #603813;
	line-height: 1.2;
}
#shopnews ul.shopnews-list li dd.date {
	color: #96c958;
	font-size: 90%;
	margin-top: 0.5em;
}
@media screen and (max-width: 640px){
	#shopnews ul.shopnews-list li {
		width: 48%;
		box-sizing: border-box;
		padding: 0.5em;
		margin-right: 4%;
	}
	#shopnews ul.shopnews-list li dt a.title img {
		width: 25px;
	}
	#shopnews ul.shopnews-list li:nth-of-type(3n){
		margin-right: 4%;
	}
	#shopnews ul.shopnews-list li:nth-of-type(2n){
		margin-right: 0;
	}
}



/*--------------------------------
	『営業時間』ページ用CSS
---------------------------------*/
#hours h2 {
	margin-bottom: 1.5em;;
	height: 1.8em;
	line-height: 1.8em;
	color: #fff;
	background-color: #006150;
	font-size: 1.9rem;
	padding: 0.25em 0;
	text-indent: 1em;}

#hours_shop ul {
	border: solid 1px #ccc;}
#hours_shop ul li:nth-child(odd) {
	background-color: #EDF7F2;}
#hours_shop ul li dl {
	display: flex;
	line-height: 1.4;}
#hours_shop ul li dl dt {
	padding: 0.75em 1em;
	border-right: solid 1px #ccc;
	width: 20%;}
#hours_shop ul li dl dd {
	padding: 0.75em 1em;
	width: 70%;}
#hours_shop ul li dl dd.tel {
	width: 10%;
}
@media screen and (max-width: 640px){
	#hours_shop ul li dl {
		flex-direction: column;}
	#hours_shop ul li dl dt {
		font-weight: 600;
		color: #006150;
		padding: 0.5em 1em;
		border-right: 0;
		width: 100%;}
	#hours_shop ul li dl dd {
		padding: 0.5em 1em;
		width: 100%;}
	#hours_shop ul li dl dd.tel {
		width: 100%;
	}
}



/*--------------------------------
	『フロアガイド』ページ用CSS
---------------------------------*/
#floorguide a.btn-shopguide {
	padding: 0 5% 0 5%;
	margin: 0 auto 3em;
}
#floorguide h2 {
	margin-bottom: 1.5em;;
	height: 1.8em;
	line-height: 1.8em;
	color: #fff;
	background-color: #006150;
	font-size: 1.9rem;
	padding: 0.25em 0;
	text-indent: 1em;
}
#floorguide img.map {
	width: 100%;
}
#floorguide ul.shop-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	margin-top: 1em;
}
#floorguide ul.shop-list li {
	width: 22%;
	margin-top: 0.5em;
	margin-right: 3%;
}
#floorguide ul.shop-list li dl {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-bottom: solid #ccc 2px;
	padding: 0.5em;
}
#floorguide ul.shop-list li dl dt {
	line-height: 1;
	color: #603813;
	font-weight: 600;
	display: flex;
	align-items: center;
}
#floorguide ul.shop-list li dl dd img {
	height: 30px;
}
#floorguide .circle_number {
	 width: 22px;
	 height: 22px;
	 padding-top: 1px;
	 background-color: #603813;
	 color: #fff;
	 border-radius: 50%;
	 text-align: center;
	 box-sizing: border-box;
	 margin-right: 0.25em;
}
#pictogram .pictogram_wrapper {
	background-color: #fcfae3;
	border: 2px solid #cccccc;
	padding: 1em;
	display: flex;
	justify-content: space-around;
	align-items: center;
	flex-wrap: wrap;
	margin: 2em 0;
}
#pictogram .pictogram_wrapper dl {
	display: flex;
	align-items: center;
	flex-direction: row-reverse;
}
#pictogram .pictogram_wrapper dl dd img{
	height: 30px;
	margin-right: 0.25em;
}
@media screen and (max-width: 640px){
	#floorguide a.btn-shopguide {
		width: 90%;
	}
	#floorguide h2 {
		text-align: left;
		padding-left:1em;
	}
	#floorguide ul.shop-list {
		flex-direction: column;
		margin-top: 0.5em;
	}
	#floorguide ul.shop-list li {
		width: 100%;
		margin-right: 0;
	}
	#floorguide ul.shop-list li dl {
		padding: 0.25em 0.5em;
	}
	#floorguide ul.shop-list li dl dd img {
		height: 25px;
	}
	#pictogram .pictogram_wrapper {
		padding: 0.25em 1em;
	}
	#pictogram .pictogram_wrapper dl {
		width: 50%;
		margin: 0.25em 0;
		justify-content: center;
	}
}



/*--------------------------------
	『アクセス』ページ用CSS
---------------------------------*/
#access h2 {
	margin-bottom: 1.5em;;
	height: 1.8em;
	line-height: 1.8em;
	color: #fff;
	background-color: #006150;
	font-size: 1.9rem;
	padding: 0.25em 0;
	text-indent: 1em;
}
#access-info iframe {
	width: 100%;
}
#access-info ul {
	margin: 2em 0;
}
#access-info ul li {
	border-bottom: 1px solid #ccc;
	padding: 1.5em 0;
}
#access-info dl {
	display: flex;
}
#access-info dl dt {
	font-weight: 600;
	color: #603813;
	margin-right: 2em;
}
#access-info dl dd {
	line-height: 1.5;
}
#access-info .parking_wrapper {
	border: 1px solid #ccc;
	padding: 1em;
	margin: 2em 0;
}
@media screen and (max-width: 640px){
	#access h2 { 
		text-align:left;
		padding-left: 1em;
	}
	#access-info iframe {
		height: 400px;
	}
	#access-info dl {
		flex-direction: column;
	}
	#access-info dl dt {
		margin-right: 0;
		margin-bottom: 0.5em;
	}

}



/*--------------------------------
	『採用情報』ページ用CSS
---------------------------------*/
#recruit h2 {
	margin-bottom: 1.5em;;
	height: 1.8em;
	line-height: 1.8em;
	color: #fff;
	background-color: #006150;
	font-size: 1.9rem;
	padding: 0.25em 0;
	text-indent: 1em;
}
#recruit .shop_wrapper {
	margin-bottom: 4em;
}
#recruit .shop_wrapper h3 {
	color: #006150;
	
	height: 1.8em;
	line-height: 1.8em;
	background-color: #d6ede8;
	padding: 0.25em 0;
	text-indent: 1em;
}
#recruit .shop_wrapper dl {
	border: 1px solid #ccc;
	margin-top: 0.5em;
	display: flex;
	flex-wrap: wrap;
}
#recruit .shop_wrapper dl dt, #recruit .shop_wrapper dl dd {
	padding: 1em;
	border-bottom: 1px solid #ccc;
	box-sizing: border-box;
	line-height: 1.5;
}
#recruit .shop_wrapper dl dt:last-of-type, #recruit .shop_wrapper dl dd:last-of-type {
	border-bottom: 0;
}
#recruit .shop_wrapper dl dt {
	width: 20%;
	font-weight: 500;
}
#recruit .shop_wrapper dl dd {
	width: 80%;
}
@media screen and (max-width: 640px){
	#recruit .shop_wrapper dl {
		flex-direction: column;
	}
	#recruit .shop_wrapper dl dt, #recruit .shop_wrapper dl dd {
		width: 100%;
	}
	#recruit .shop_wrapper dl dt {
		border-bottom: 0;
		font-weight: 600;
		padding-bottom: 0;
	}
}



/*--------------------------------
	『サイトマップ』ページ用CSS
---------------------------------*/
#sitemap-page dl dt{
	padding: 1em 0;
	font-weight: 600;
}
#sitemap-page dl dd {
	padding: 1em;	
}
#sitemap-page dl dt {
	border-bottom: 1px solid #ccc;
}
#sitemap-page dl dd {
	margin-bottom: 1em;
}
#sitemap-page .arrow_s {
  position: relative;
  display: inline-block;
  padding-left: 15px;
}
#sitemap-page .arrow_s:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 10px;
  border-color: transparent transparent transparent #33b458;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}
#sitemap-page ul {
	margin-top: 2em;
}
#sitemap-page ul li {
	margin-bottom: 1em;
}



/*--------------------------------
	『お問合せ』ページ用CSS
---------------------------------*/
#contact h2 {
	margin-bottom: 1.5em;;
	height: 1.8em;
	line-height: 1.8em;
	color: #fff;
	background-color: #006150;
	font-size: 1.9rem;
	padding: 0.25em 0;
	text-indent: 1em;
}
#contact_inquiry dl {
	margin-bottom: 1em;
	padding: 1.5em;
	border: solid 1px #ccc;}
#contact_inquiry dl dt {
	margin-bottom: 0.5em;
	color: #603813;
	font-size: 1.1em;
	font-weight: 700;}
#contact_inquiry dl dd {
	line-height: 1.4;}
