@charset "UTF-8";


h2 {
  text-align: center;
}
h3 {
	margin: 0 0 35px;
	font-size: 28px;
	font-weight: 300;
  text-align: left;
  line-height: 1.2em;
}
h4 {
	margin: 0 0 25px;
	font-size: 19px;
	font-weight: 400;
  color: #54585B;
  text-align: left;
  line-height: 1.2em;
}
.restaurants_list article {
	aspect-ratio: 2 / 1;
	}


.restaurants_list article .information_area {
	padding: 0;
	}
.restaurants_list article .information_area div {
	max-width: calc(100% - 40px);
	}
.restaurants_list article .information_area h3 {
	margin: 0 0 20px;
	font-size: 21px !important;
	line-height: 1.4;
}

.information_area .bdc_wh {
	font-size: 15px;
}

#first_text_section h2 {
  text-align: left;
}
#page p {
  line-height: 1.45em;
}
@media screen and (max-width: 768px) {
	.restaurants_list > article {
		}
		.restaurants_list > article > img {
			order: 1;
			}
		.restaurants_list > article > dl.attention {
			order: 2;
			}
		.restaurants_list > article > .information_area {
			order: 3;
			margin: 0;
			padding: 0 0 20px;
		}
		.restaurants_list > article > .information_area > div {
			}
			.restaurants_list > article > .information_area > div > p {
				order: 2;
				}
			.restaurants_list > article > .information_area > div > p.floor_level {
				order: 2;
				}
			.restaurants_list > article > .information_area > div > h3 {
				order: 1;
				width: 100%;
				margin: 20px 0;
				line-height: 1.2;
				}
			.restaurants_list > article > .information_area > div > div {
				order: 3;
				}
			.restaurants_list > article > .information_area > div > .btn_detail {
				order: 4;
				}
			.restaurants_list > article > .information_area > div > .btn_tel {
				margin-top: 10px;
				order: 5;
				}
			.restaurants_list > article > .information_area > div > .information {
				}
}



/* floorguide */
#floorguide {}
#floorguide .wrap_f {
  justify-content: space-between;
  align-items: flex-start;
}
#floorguide picture {
	width: 47%;
}
#floorguide picture img {
  width: 100%;
  height: auto;
}

#floorguide .facilities_list {
	width: 47%;
}

#floorguide .facilities_list dl {
  padding: 0;
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
}
#floorguide .facilities_list dl dt {
  background-color: #E8E8E8;
  margin: 0;
  margin-bottom: 12px;
  padding: 0;
  text-align: center;
  position: absolute;
  width: 60px;
}
#floorguide .facilities_list dl dd {
	overflow: hidden;
	padding: 0;
	padding-left: 70px;
	margin: 0;
	margin-bottom: 15px;
}
#floorguide .facilities_list dl dd a {

}
#floorguide .facilities_list dl dd ul li a {
	text-decoration: underline;
}
#floorguide .facilities_list dl dd ul li ul {
  margin-left: 20px;
}

@media screen and (max-width:1024px) {
  #floorguide picture {
    width: 100%;
    margin-bottom: 20px;
  }
  #floorguide .facilities_list {
    width: 100%;
  }
}
@media screen and (max-width:768px) { 
}
@media screen and (max-width:600px) { 
}
@media screen and (max-width:480px) { 
}




/* clublounge */
#clublounge {
  padding: 0;
}
#clublounge .container {
  position: relative;

  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
#clublounge .container picture {
  padding: 0;
  margin: 0;
  width: 100%;
  background-color: #000;
}
#clublounge .container picture img {
  opacity: 0.7;
  line-height: 0.1em;
}
#clublounge .container h2 {
  color: #fff;
  position: absolute;
  margin-bottom: 0;
  line-height: 1.2em;
}

@media screen and (max-width:1024px) {
}
@media screen and (max-width:768px) { 
}
@media screen and (max-width:600px) { 
  #clublounge .container picture {
    position: relative;
    overflow: hidden;
  }
  #clublounge .container picture::before {
    content: '';
    display: block;
    padding-top: 50%;
  }
  #clublounge .container picture img {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    top: 0;
  }
}
@media screen and (max-width:480px) { 
}




/* indoor_facilities */
#indoor_facilities {}
#indoor_facilities ul {
  margin-top: 25px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
}
#indoor_facilities ul li {
  width: calc((100% - 60px) / 3);
  margin: 10px;
  position: relative;
}
#indoor_facilities picture {
  position: relative;
  overflow: hidden;
}
#indoor_facilities picture::before {
  content: '';
  display: block;
  padding-top: 100%;
}
#indoor_facilities picture img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 1 / 1;
}
#indoor_facilities .info {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: left;
  background-color: rgba(0,0,0,0.58);
  color: #fff;
  padding: 10px 12px;
}
#indoor_facilities .info .info_inn {
  display: block;
  padding: 10px;
  padding-bottom: 30px;
  position: relative;
}
#indoor_facilities .info span {
  border: 1px solid #fff;
  padding: 0 8px;
  line-height: 1em;
  font-size: 15px;
  margin: 0 10px 5px 0;
  display: inline-block;
}
#indoor_facilities .info span p {}
#indoor_facilities .info .btn_more {
  display: inline-block;
  position: absolute;
  right: 10px;
  bottom: 10px;
  font-size: 15px;
}
#indoor_facilities .info .btn_more:hover {
	text-decoration: underline;
	}

@media screen and (max-width:1024px) {
}
@media screen and (max-width:768px) { 
  #indoor_facilities ul li {
    width: 100%;
    max-width: 480px;
    margin: 0 auto;
    margin-bottom: 20px;
  }
  #indoor_facilities picture::before {
    padding-top: 65%;
  }
}
@media screen and (max-width:600px) { 
}
@media screen and (max-width:480px) { 
}


#floor_lounge {
	
	}
	#floor_lounge h2 {
		text-align: center;
		}
		#floor_lounge a {
			display: block;
			position: relative;
			width: 90%;
			max-width: 768px;
			margin: 0 auto;
			}
			#floor_lounge a img {
				width: 100%;
				}
				#floor_lounge a p {
					position: absolute;
					top: calc(50% - 12px);
					left: 0;
					width: 100%;
					color: #fff;
					font-size: 24px;
					font-weight: 400;
					text-align: center;
					z-index: 2;
					}
@media screen and (max-width:768px) { 
  #floor_lounge a {
    width: 100%;
    max-width: none;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  #floor_lounge a p {
    top: auto;
    font-size: 22px;
  }
}





#fitness {
	
	}
	#fitness .container {
		padding: 70px 32px;
		}
	
	.fitness_list {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: 30px 0 0;
		}
		.fitness_list article {
			position: relative;
			width: calc(50% - 10px);
			margin-bottom: 20px;
			padding: 0;
			}

			.fitness_list article iframe {
				width: 100%;
				height: auto;
				aspect-ratio: 16 / 9;
				}
			.fitness_list article h3 {
				font-size: 17px;
				line-height: 1.6;
				}
@media screen and (max-width: 600px) {
	.fitness_list article {
		width: 100%;
	}
}

#fitness_info {
	background-color: rgb(236,236,235);
	}
	#fitness_info .container {
		padding: 70px 32px;
		}
		#fitness_info .container h2 {
			text-align: center;
			}




/* ******************************************
	lr_list
****************************************** */
.lr-list article {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	}
	.lr-list article img {
		width: 50%;
		object-fit: cover;
		aspect-ratio: 3 / 2;
		order: 1;
		}
	.lr-list article:nth-of-type(2n) img {
		order: 2;
		}
	.lr-list > article > div {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		width: 50%;
		padding: 50px 100px 50px 50px;
		background-color: rgb(236,236,235);
		order: 2;
		}

	.lr-list > article:nth-of-type(2n) > div {
		padding: 50px 50px 50px 100px;
		order: 1;
		}
		.lr-list > article > div > div,
		.lr-list > article:nth-of-type(2n) > div > div {
			width: 100%;
			padding: 0;
			}
		.lr-list article div h3 {
			font-size: 28px;
			}
			.lr-list article div h3 span {
				font-size: 18px;
				}
		.lr-list article div p {
			margin: 30px 0 0;
			line-height: 1.5;
			}
@media screen and (max-width: 768px) {
	.lr-list article div {
		padding: 30px;
    }
	.lr-list article:nth-of-type(2n) div {
		padding: 30px;
    }
}
@media screen and (max-width: 600px) {
	.lr-list article img {
		width: 100%;
		aspect-ratio: 5 / 2;
    }
	.lr-list article div {
		width: 100%;
    }
	.lr-list article:nth-of-type(2n) img {
		order: 1;
    }
	.lr-list article:nth-of-type(2n) div {
		order: 2;
    }
}
 
@media screen and (max-width: 768px) {
	.information_area div h3 {
		order: 1;
	}
	.information_area div p {
		order: 2;
	}
	.information_area div a.btn {
		order: 3;
	}
}


