@charset "UTF-8";

/*--- base ---*/
html { font-size: 62.5%; width: 100%; }
body {
	width: 100%;
	font-size: 1.4rem;
	font-family: -apple-system, BlinkMacSystemFont, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "Helvetica Neue", HelveticaNeue, Helvetica, Arial, "Segoe UI", sans-serif;
	color: #000;
	-webkit-text-size-adjust: 100%;
}
* { box-sizing: border-box; word-wrap: break-word; }
img { width: 100%; }
a { color: #000; }
a:link,
a:visited,
a:active,
a:hover { overflow: hidden; outline: none; }

/* flexbox */
.flex {
	display: -webkit-box; /*Android4.3*/
	display: -moz-box;    /*Firefox21*/
	display: -ms-flexbox; /*IE10*/
	display: -webkit-flex; /*PC-Safari,iOS8.4*/
	display: flex;
	display: -webkit-flexbox;
	flex-wrap: wrap;
	flex-wrap: wrap;
}

/* form style */
/* reset */
input, button, textarea, select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: none;
	font-family: inherit;
	font-size: 100%;
}

/* font */
.maintitle { font-family: 'Jaldi', sans-serif; }

/* title */
.maintitle {
	font-size: 2.5rem;
	font-weight: 400;
	text-align: center;
	border-bottom: 2px solid #000;
	line-height: 1;
	padding-bottom: 7px;
}
.areatitle {
	font-size: 1.2rem;
	text-align: center;
	letter-spacing: .05em;
	margin-bottom: 20px;
}
.areatitle span {
	display: block;
	font-size: 2rem;
	letter-spacing: .25em;
	font-weight: bold;
	margin-bottom: 5px;
}
.bgtitle {
	font-size: 1.6rem;
	text-align: center;
	height: 40px;
	line-height: 40px;
}

/* button */
.btnbase {
	display: block;
	text-align: center;
}
.morelink_btn {
	font-size: 1.6rem;
	max-width: 300px;
	border: 1px solid #999;
	padding: 15px 10px 10px;
}
.btn_pink, 
.btn_orange {
	font-size: 1.8rem;
	width: 100%;
	color: #fff;
	padding: 10px 10px 8px;
	border-radius: 10px;
}
.btn_pink {
	background: #ff96af;
}
.btn_orange {
	background: #ffaf64;
}
.btn_pink i,
.btn_orange i {
	font-size: 2rem;
	margin-left: 2px;
	vertical-align: middle;
}
.btn_green,
.btn_blue,
.btn_black {
	font-size: 1.8rem;
	width: calc(100% / 4 - 5px);
	color: #fff;
	padding: 10px 3px 8px;
	border-radius: 10px;
}
.btn_green {
	background: #32c800;
}
.btn_blue {
	background: #7dc8ff;
	width: calc(100% / 2 - 5px);
}
.btn_black {
	background: #000;
}
.btn_green:not(.active),
.btn_black:not(.active) {
	opacity: .1;
	pointer-events: none;
}

/*--- header ---*/
/* headerlogo */
.bylogo_block {
	display: inline-block;
	font-size: 0;
	vertical-align: bottom;
}
.bylogo_block {
	font-size: 1.4rem;
}
.bylogo_block a {
	display: block;
	line-height: 0;
}
/* Navilist */
#Navilist a {
	display: block;
}
.genrenavi li {
	border-bottom: 1px solid #ccc;
}
.genrenavi a {
	padding: 10px 5px 10px 15px;
}
.genrenavi a i {
	width: 20px;
	text-align: center;
	font-size: 2rem;
	margin-right: 5px;
	vertical-align: middle;
}

/*--- footer ---*/
footer {
	border-top: 2px solid #ff534a;
	text-align: center;
	padding-top: 5px;
}
.footerNavilist {
	margin-bottom: 20px;
}
.footerNavilist li {
	display: inline-block;
	line-height: 1.3;
}
.footerNavilist li + li {
	border-left: 1px solid #000;
}
.footerlogo {
	font-size: 0;
}
.bylogo_inline a {
	display: inline-block;
}
.copyright {
	background: #ff534a;
	color: #fff;
	padding: 4px 10px 3px;
}
.copyright a {
	color: #fff;
	text-decoration: underline;
}

/*--- main_left ---*/
/* twitter */
#twitter {
	border: 2px solid #c9c9c9;
	border-radius: 10px;
	overflow: hidden;
}

/*--- main_right - TOP ---*/
/* mv_slider */
.mvslide {
	line-height: 0;
}
.slider-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	z-index: 1;
}
/* news */
.date, .news_excerpt, .news_shopname, .shop_meta {
	font-size: 1.2rem;
}
.news_img {
	line-height: 0;
}
.date {
	margin-bottom: 10px;
}
.newslist li .news_title {
	font-size: 1.6rem;
	font-weight: bold;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	width: 100%;
	line-height: 1;
	margin-bottom: 10px;
}
.news_excerpt {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	width: 100%;
	margin-bottom: 1em;
}
.news_shopname {
	text-align: right;
	line-height: 1.3;
}
.news_shopname:before {
	content: "\f015";
	font-family: "Font Awesome 5 Free";
	font-weight: 800;
}
.shopname_link {
	text-decoration: underline;
}
.shop_meta_area, .shop_meta_category {
	width: 48.48%;
	background: #f6bcb0;
	padding: 3px 5px;
	text-align: center;
}
.shop_meta_category {
	margin-left: 3.04%;
}
/* shoplist */
.shopbox {
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid #ff534a;
	padding: 10px;
}
.shops_nametitle {
	background: #ff534a;
	color: #fff;
	padding: 10px;
	align-items: center;
}
.shops_category {
	width: 120px;
	font-size: 1.2rem;
	line-height: 1.5;
	background: #fff;
	color: #000;
	padding: 3px 8px;
	text-align: center;
	margin-right: 10px;
}
.shops_name {
	width: calc(100% - 130px);
	font-size: 2rem;
	font-weight: bold;
}
.shops_time {
	background: #ddd;
	font-size: 1.2rem;
	padding: 5px 20px;
	margin-bottom: 20px;
}
.shops_time dl, .shops_time dt, .shops_time dd {
	display: inline-block;
}
.shops_time dl + dl {
	margin-left: 1em;
}
.shops_time dt {
	margin-right: .5em;
}
.shops_time dt i {
	margin-right: 5px;
}
.shops_contact {
	justify-content: space-between;
}
.shops_contact a i {
	font-size: 2.5rem;
	margin-right: .15em;
	vertical-align: middle;
}
.shops_images {
	margin-bottom: 10px;
	align-items: flex-start;
}
.shops_mv_img {
	font-size: 0;
	width: 100%;
	position: relative;
}
.shops_mv_img img{
	object-fit: contain;
	aspect-ratio: 21/10;
}
.shops_text {
	font-size: 1.2rem;
	line-height: 1.5;
	margin-bottom: 5px;
}
.shops_more, .recruit {
	margin-top: 10px;
}



/* company */
#company {
	margin-top: 20px;
}
.company_info {
	width: fit-content;
	margin: 0 auto;
	padding: 10px;
}
.company_info h3 {
	margin-bottom: 10px;
}
.company_info p {
	line-height: 1.5;
}
/* SP style */
@media print, screen and (max-width:768px) {
}
/* PC style */
@media print, screen and (min-width:769px) {
	.company_info h3 {
		font-size: 1.2em;
	}
}

/* SP style */
@media print, screen and (max-width:768px) {
	.sp_view { display: inline-block; }*/
	.pc_view { display: none; }

	/* section */
	.mainsection {
		margin-top: 50px;
	}
　.mainsection2 {
		margin-top: 20px;
	}
	main {
		padding-top: 70px;
	}
	.sp_block {
		width: 90%;
		margin: 0 auto;
	}
	.bannerblock {
		display: block;
		width: 60%;
		max-width: 240px;
		margin: 30px auto;
		font-size: 0;
	}
	.bannerblock li + li {
		margin-top: 10px;
	}
	.add_request a {
		display: block;
		color: #000;
		font-size: 1.2rem;
		text-align: center;
		margin: 20px auto 0;
		width: fit-content;
		border-bottom: 1px solid #000;
	}

	/* title */
	.maintitle {
		margin-bottom: 25px;
	}
	.bgtitle {
		background: #ff534a;
		color: #fff;
	}

	/* button */
	.morelink_btn {
		margin: 20px auto 0;
	}

	/*--- header ---*/
	header {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		background: #fff;
		z-index: 999;
		height: 70px;
		padding: 10px;
		font-size: 0;
	}
	#Navilist {
		display: none;
	}
	#headerlogo {
		width: 160px;
	}
	.bylogo_block {
		width: 23.4%;
		max-width: 89px;
		text-align: left;
		margin-left: .38%;
	}
	.bylogo_block span {
		display: block;
		transform: scale(.6, .6);
		-webkit-transform: scale(.6, .6);
		transform-origin: 0;
		-webkit-transform-origin: 0;
		margin-bottom: -2px;
		width: 160%;
	}
	.sp_searchBtn {
		display: block;
		position: absolute;
		top: 10px;
		right: 10px;
		width: 100px;
		height: 50px;
		line-height: 50px;
		border-radius: 10px;
		background: #ff534a;
		color: #fff;
		font-size: 1.6rem;
		text-align: center;
	}
	#Navilist {
		position: absolute;
		left: 0;
		right: 0;
		top: 70px;
		bottom: 0;
		background: #fff;
		height: calc(100vh - 70px);
		overflow-y: auto;
	}
	.genrenavi a {
		font-size: 1.4rem;
	}

	/*--- footer ---*/
	footer {
		margin-top: 50px;
		padding-top: 10px;
	}
	.footerNavilist li + li {
		padding-left: .5em;
		margin-left: .1em;
	}
	.footerNavilist a {
		font-size: 1.2rem;
	}
	.footerlogo {
		width: 52.5%;
		max-width: 210px;
		margin: 0 auto 5px;
	}
	.bylogo_inline {
		margin-bottom: 20px;
	}
	.bylogo_inline a {
		width: 27.5%;
		max-width: 110px;
		vertical-align: -.7em;
		margin-left: 5px;
	}

	/*--- main_right ---*/
	.main_right p.concept {
		font-size: 1.2rem;
		line-height: 1.5;
		padding: 10px;
	}

	/*--- main_left ---*/
	/* twitter */
	#twitter {
		width: 95%;
		max-width: 380px;
		margin: 0 auto;
	}
	#twitter iframe {
		width: 390px !important;
		min-width: 100px !important;
	}

	/*--- main_left - TOP ---*/
	/* mv_slider */
	.slider-prev {
		left: 10px;
	}
	.slider-next {
		right: 10px;
	}
	/* news */
	#news.mainsection {
		margin-top: 20px;
	}
	.newslist {
		display: block;
	}
	.newsbox {
		padding: 0 5%;
	}
	.newsbox {
		margin-bottom: 20px;
		padding-bottom: 20px;
		border-bottom: 1px solid #999;
	}
	.news_img {
		width: 23.7%;
		line-height: 0;
	}
	.news_text {
		width: 73.3%;
		margin-left: 3%;
	}
	.news_shopname {
		margin-bottom: 6px;
	}
	.date {
		margin-bottom: 5px;
	}
	/* shoplist */
	.shoplist_wrapper {
		margin-top: -70px;
		padding-top: 70px;
	}
	.shoplist_inner {
		padding-top: 25px;
		margin-bottom: 50px;
	}
	.shoplist_inner2 {
		margin-bottom: 50px;
	}
	#shoplist .maintitle {
		margin-bottom: 0;
	}
	.shops {
		display: block;
	}
	.shopbox {
		width: 95%;
		margin: 0 auto;
	}
	.shopbox + .shopbox {
		margin-top: 10px;
	}
	.shops_mv {
		width: 100%;
	}
	.shops_text {
		margin-bottom: 10px;
	}
	.btn_green,
	.btn_blue {
		font-size: 1.4rem;
	}
}

@media print, screen and (max-width:360px) {
	/* shoplist */
	.shops_time dl {
		display: block;
	}
	.shops_time dl + dl {
		margin: 3px 0 0 0;
	}
}


/* PC style */
@media print, screen and (min-width:769px) {
	.sp_view { display: none; }
	/*.pc_view { display: inline-block; }*/

	a[href^="tel:"] {
		pointer-events: none;
	}

	/* section */
	.headerInner, main {
		position: relative;
		max-width: 1200px;
		margin: 0 auto;
	}
	main {
		overflow: hidden;
		width: 98%;
	}
	.main_left {
		float: left;
		width: 240px;
		margin-top: 340px;
	}
	.main_right {
		float: right;
		width: calc(100% - 260px);
	}
	.main_right p.concept {
		line-height: 1.75;
		height: auto;
		margin-bottom: 20px;
	}
	.mainsection {
		margin-top: 90px;
	}
	.mainsection2 {
		margin-top: 30px;
	}
	.sideblock + .sideblock {
		margin-top: 20px;
	}

	/* title */
	.maintitle {
		margin-bottom: 30px;
	}
	#shoplist .maintitle {
		margin-bottom: 0;
	}
	.bgtitle {
		background: #f6bcb0;
	}

	/* button */
	.morelink_btn {
		margin: 40px auto 0;
	}
	.btn_pink,
	.btn_blue, .btn_blue span, 
	.btn_green, .btn_green span,
	.btn_blak, .btn_black span,
	.btn_orange, .btn_orange apan {
		font-weight: bold;
	}

	/*--- header ---*/
	header {
		margin-bottom: 30px;
	}
	.h1text {
		display: block;
		text-align: center;
		background: #ff534a;
		color: #fff;
		padding: 5px;
	}
	.h1text a {
		color: #fff;
	}
	/* headerlogo */
	.headerInner {
		width: calc(100% - 20px);
	}
	#headerlogo a {
		position: absolute;
		width: 240px;
		top: 20px;
		left: 0;
		z-index: 9999;
	}
	.bylogo_block {
		width: 146px;
		margin-left: 17px;
	}
	/* Navilist */
	#Navilist {
		display: block !important;
	}


	/*--- footer ---*/
	footer {
		margin-top: 20px;
		padding-top: 10px;
	}
	.footerNavilist li + li {
		padding-left: .8em;
		margin-left: .5em;
	}
	.footerlogo {
		width: 280px;
		margin: 0 auto 10px;
	}
	.bylogo_inline {
		margin-bottom: 10px;
	}
	.bylogo_inline a {
		width: 146px;
		vertical-align: -1em;
		margin-left: 10px;
	}

	/*--- main_left ---*/
	/* side_genremenu */
	#side_genremenu {
		position: absolute;
		top: 130px;
		left: 0;
		z-index: 9999;
	}
	/* bannerlist */
	.bannerlist {
		font-size: 0;
	}
	.bannerlist li + li {
		margin-top: 10px;
	}
	.add_request {
		margin-top: 15px;
		border: 1px solid #000;
		border-radius: 5px;
	}
	.add_request a {
		display: block;
		text-align: center;
		padding: 10px;
	}

	#twitter iframe {
		width: 250px !important;
		min-width: 100px !important;
	}

	/*--- main_right - TOP ---*/
	/* mv_slider */
	.slider__item {
		opacity: 0.5;
		transition: opacity 0.4s;
	}
	.slick-slide.slick-current .slider__item,
	.slick-slide.is-active-next .slider__item {
		opacity: 1;
	}
	.slick-slide img {
		max-width: 720px;
	}
	.slider-arrow:hover {
		cursor: pointer;
	}
	.slider-prev {
		left: 7%;
	}
	.slider-next {
		right: 7%;
	}
	
	/* news */
	/*.newslist {
		width: 92.8%;
		margin: 0 auto;
	}
	.newsbox {
		width: 100%;
	}
	.newslist li:nth-child(even) {
		margin-left: 4.46%;
	}
	.newslist li:not(:nth-child(-n+2)) {
		margin-top: 40px;
	}
	.news_img {
		width: 21%;
	}
	.news_text {
		width: 76.7%;
		margin-left: 2.3%;
	}
	.news_shopname {
		margin-bottom: 10px;
	}*/

	/* shoplist */
	.shoplist_wrapper {
		margin-bottom: 40px;
	}
	.shoplist_inner {
		padding-top: 25px;
	}
	.shopbox {
		width: 48.93%;
		position: relative;
	}
	.shopbox:nth-child(even) {
		margin-left: 2.14%;
	}
	.shopbox:not(:nth-child(-n+2)) {
		margin-top: 20px;
	}
	.shops_mv {
		width: 100%;
	}
	.shops_text {
		margin-bottom: 5px;
	}
	.shops_contact {
		justify-content: space-between;
	}
}
@media print, screen and (min-width:769px) and (max-width:910px) {
	/* shoplist */
	.shops_time dl {
		display: block;
	}
	.shops_time dl + dl {
		margin: 3px 0 0 0;
	}
}


/* ホテルリスト */
#hotel_list {
 margin-top: 100px;
}
.hotel_bn_wrapper {
	justify-content: space-between;
}
.hotel_bn_wrapper a{
	display: block;
	font-size: 0;
}
/* PC style */
@media print, screen and (min-width:769px) {
	.hotel_bn_wrapper a{
		width: calc(100% / 5 - 5px);
	}
}

/* SP style */
@media print, screen and (max-width:768px) {
	.hotel_bn_wrapper {
		max-width: 460px;
		margin: 0 auto;
		padding: 10px;
	}
	.hotel_bn_wrapper a{
		width: calc(100% / 2 - 5px);
	}
	.hotel_bn_wrapper a:nth-child(n + 3) {
		margin-top: 10px;
	}
}


/* マップ */
#map {
 margin-top: 100px;
}

/* リンク */
.banner_list h3{
	font-weight: 700;
	margin-bottom: .3em;
}
.banner_list li + li{
	margin-top: 40px;
}
.banner_list li p{
	font-size: .8em;
}
.banner_list li .link_code{
	position: relative;
	margin: 0.7em 0;
    padding: 1em;
    background: #efefef;
    width: fit-content;
}
.banner_list li img{
	width: fit-content;
}
.banner_list li code{
	display: block;
	line-height: 1.6;
}
.banner_list li p{
	margin: .5em 0;
}
.btn_area{
	width: 100%;
	margin-bottom: 1em;
	font-size: .9em;
	text-align: right;
}
/* SP style */
@media print, screen and (max-width:768px) {
	.banner_list li img{
		max-width: 100%;
	}
	.banner_list{
		width: 95%;
		margin: auto;
	}
}

.video{
		text-align: center;
		margin-bottom: 30px;
}
.video video {
	width: 70%;
	aspect-ratio: 16 / 9;
    height: auto;
}