@charset "utf-8";
/* CSS Document */


#main_menu .swiper-wrapper{
	padding-left: 100vw;
	opacity: 0;
}

/*NEWS*/
#news{
	overflow: hidden;
	height: 20px;
	padding: 10px;
	position: relative;
	z-index: 9;
}
#news .swiper-slide{
	overflow: hidden;
}
#news .swiper-slide .date,#news .swiper-slide .news_title{
	display: block;
	float: left;
	line-height: 1;
	vertical-align: top;
	text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
#news .swiper-slide .date{
	font-size: 12px;
	width: 28%;
	padding: 3px 1%;
}
#news .swiper-slide .news_title{
	font-size: 14px;
	height: 16px;
	width: 68%;
	padding: 2px 1%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	-webkit-text-overflow: ellipsis;
	-o-text-overflow: ellipsis;
}
#news .box{
	display: none;
}

/* CONTENTS */
#contents{
	position: relative;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	padding: 20vh 0;
}
#contents::after{
	position: absolute;
	z-index: 0;
	content: "";
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}
#contents .fs_wrap{
	position: relative;
	z-index: 1;
}
#contents h3,#contents figure{
	margin-bottom: 20vh;
}

/* PC NEWS */
#pc_news .box{
	padding-top: 20px;
	padding-bottom: 20px;
}
#pc_news .box:last-of-type{
	padding-bottom: 0;
	border-bottom: none;
}
#pc_news .swiper-slide{
	display: none;
}
#pc_news .box figure{
	z-index: 1;
}

/* MAP */
#map{
	position: relative;
	height: 500px;
	overflow: hidden;
}
#map iframe{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
	#main_right header{
		min-height: 100vh;
		box-sizing: border-box;
	}
	header{
		position: relative;
		height: 100vh;
	}
	header #top_link{
		height: 60vh;
		position: relative;
		box-sizing: border-box;
	}
	header #top_link .links_bt{
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%,-50%);
	}
	#contents{
		padding: 10vh 0;
		margin-bottom: 20vh;
	}
	/* PC NEWS */
	#pc_news{
		margin-bottom: 20vh;
	}
/* MAP */
	#map{
		position: relative;
		height: 400px;
		overflow: hidden;
	}
	@media screen and (orientation: landscape){
		header{height: auto;}
		header #top_link{
			min-height: 500px;
		}
	}

}

/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
	#contents{
		padding: 10vh 0;
		height: auto;
	}
	#contents h3{
		margin-bottom: 50px;
	}
/* MAP */
	#map{
		position: relative;
		height: 300px;
		overflow: hidden;
	}
}
