@charset "utf-8";

@media screen and (max-width: 768px) {
.sp_only {
  display: block;
}
.pc_only {
  display: none;
}

/* layout_common */
.btn_reserve {
  display: none;
}
.global {
  position: absolute;
  right: 80px;
  width: 50px;
}
.footer_area_block {
  display: flex;
  flex-flow: column wrap;
}
.footer_area_block > div.logo {
  margin: 0 auto 30px;
}
.footer_area_block > div.info {
  width: 100%;
  margin: 0 auto 30px;
  text-align: center;
}
.footer_area_block > div.nav {
  display: none;
}
p.read {
  font-size: 1.6rem;
}

/* layout_index */
.mainimg_wrap {
  position: relative;
  width: 100%;
	height: 400px;
  margin: 0 0 60px;
}
.main_video {
	overflow: hidden;
	position: absolute;
	top: 90px;
	left: 0;
	width: 100%;
	height: 400px;
}
.main_video video {
	height: 400px;
}
.box_sound {
	position: absolute;
	right: 20px;
	bottom: 10px;
}

.mainimg_ttl p {
  font-size: 3rem;
  letter-spacing: .3em;
}
.contents_title1 {
  margin: 0 0 40px;
}
.top_contents_naranoya {
  display: flex;
  flex-flow: column wrap;
  width: 90%;
  padding: 80px 0;
}
.top_contents_naranoya .pct {
  width: 100%;
  margin: 0 0 50px;
}
.top_contents_naranoya .pct img {
  width: 100%;
  height: auto;
}
.top_contents_naranoya .txt {
  width: 100%;
  margin: 0;
}

.top_contents_about {
  position: relative;
  display: flex;
  flex-flow: column wrap;
  width: 90%;
  margin: 0 auto 80px;
}
.top_contents_about .pct1 {
  position: static;
  width: 100%;
  margin: 0 0 50px;
}
.top_contents_about .pct1 img {
  width: 100%;
  height: auto;
}
.top_contents_about .txt {
  width: 100%;
  margin: 0 0 50px;
}
.top_contents_about .pct2 {
  position: static;
  top: 0;
  left: 0;
  width: 100%;
  margin: 0 0 20px;
}
.top_contents_about .pct2 img {
  width: 100%;
  height: auto;
}
.top_contents_about .pct3 {
  width: 100%;
  margin: 0;
}

.top_contents_facility_wrap {
  width: 100%;
  padding: 80px 0;
}

.top_contents_insta {
  width: 100%;
  padding: 80px 0;
}
.top_block_insta {
  display: flex;
  flex-wrap: wrap;
  width: 92%;
  margin: 0 auto 30px;
}
.top_block_insta > div {
  display: block;
  position: relative;
  width: 48%;
  margin: 0 1% 2%;
}

.contents_contact_wrap {
  position: relative;
  width: 100%;
  padding: 80px 0;
}
.contents_contact {
  position: relative;
  display: flex;
  flex-flow: column wrap;
  justify-content: space-between;
  width: 90%;
  margin: 0 auto;
  z-index: 2;
}
.contents_contact > div {
  width: 100%;
  margin: 0 0 20px;
  padding: 50px;
}


/* layout_about */
.about_list li {
	margin-bottom: 50px;
}
.about_list_img {
	width: 100%;
  height: auto;
	padding: 0;
}
.about_list_img img {
	width: 100%;
  height: 100%;
  object-fit: cover;
}
.about_list .about_list2 .about_list_img {
	width: 100%;
	margin-left: 0;
	padding: 0;
}
.about_list_text {
	position: relative;
	margin-top: 0;
	padding: 0;
	z-index: 1;
}
.about_list_text_inner {
	display: inline-block;
	width: 100%;
	padding: 30px 20px;
  background: rgba(255,255,255,.7);
}
.about_list_title {
	margin-bottom: 20px;
	font-size: 2.4rem;
}

.tbl_detail th {
  display: block;
	width: 100%;
  padding: 20px;
  border-top: 1px solid #acb6b5;
  color: #677173;
	font-weight: normal;
  text-align: left;
}
.tbl_detail td {
  display: block;
	width: 100%;
  padding: 0 20px 20px;
	border-top: none;

}



/* layout_facility */
.facility_list_inner {
  display: flex;
  flex-flow: column wrap;
  justify-content: space-between;
  width: 100%;
}
.facility_list_img {
  width: 100%;
}
.facility_list_img img {
	width: 100%;
  height: auto;
  object-fit: cover;
}
.facility_list_text {
  width: 100%;
}
.facility_list_text_inner {
	display: inline-block;
	padding: 30px 20px;
}
.facility_list_title {
	margin-bottom: 20px;
	font-size: 2.4rem;
}

.facility_list2 {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  width: 100%;
}
.facility_list2 li {
	width: 49%;
	margin: 0 0 2%;
}
.facility_list2 li:nth-child(3n) {
	margin: 0 0 2%;
}
.facility_list2_text {
  padding: 30px 20px;
}
.facility_list2_title {
	font-size: 2rem;
}




/* layout_access */
.access_info > div.pct {
  width: 100%;
  order: 2;
}
.access_info > div.info {
  width: 100%;
  margin: 0 0 30px;
  padding-left: 0;
  order: 1;
}
.access_map {
  margin: 0 auto 30px;
}


/* layout_contact */
.tbl_contact td,
.tbl_contact th {
  display: block;
}
.tbl_contact th {
  width: 100%;
  padding: 15px 15px 0;
  border: none;
}
.tbl_contact td {
  width: 100%;
}


}


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

.mainimg_wrap {
  position: relative;
  width: 100%;
  height: 320px;
  margin: 0 0 60px;
}
.main_video {
	overflow: hidden;
	position: absolute;
	top: 90px;
	left: 0;
	width: 100%;
	height: 320px;
}
.main_video video {
	height: 320px;
}
 
}

