@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700;900&amp;display=swap');
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700;800;900&amp;display=swap');

.is-ltIE8 .pageWrapper{
	overflow: hidden;
}
.pageBody {
	color: #FFF;
	line-height: 2;
}
.is-ltIE8 .pageBody {
	min-width: 1300px;
}
.noto_serif{
	font-family: 'Noto Serif JP', serif;
}
.cinzel{
	font-family: 'Cinzel', serif;
}


.history_wrap{
	background-color: #122125;
}
.history_inner {
	max-width: 1200px;
	padding: 0 20px;
	box-sizing: border-box;
	margin: 0 auto;
}
.hero {
	display: flex;
	justify-content: flex-end;
	gap: 70px;
	position: relative;

}
.hero_ttl {
	flex: none;
	width: 100%;
	font-family: 'Noto Serif JP', serif;
	position: absolute;
	z-index: 10;
	transform: translate(-50%,-50%);
	top: 50%;
	left: 56%;
	padding-left: 30px;

}
.hero_ttl h1 {
	/* text-indent: -1em; */
	line-height: 1.2;
	font-size: 45px;

}
.hero_img{
	width: 80%;
}
.hero_img img{
	width: 100%;
	height: 600px;
	object-fit: cover;
}
.bg_img{
	position: absolute;
}
.bg_img.-bi01{
	right: -6%;
	bottom: -54%;
	z-index: -1;
}
.bg_img.-bi02{
	right: -6%;
	top: -3%;
	z-index: -1;
}
.bg_img.-bi03{
	left: -3%;
	top: 23%;
	z-index: -1;
}
.intro {
	padding: 150px 0 80px;
}
.intro_wrap{
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 20px;
}
.intro_ttl {
	/* writing-mode: vertical-rl; */
	font-family: 'Noto Serif JP', serif;
	font-size: 27px;
}
.intro_txt {
	/* writing-mode: vertical-rl; */
	text-orientation: upright;
	font-family: 'Noto Serif JP', serif;
	line-height: 2.5;
	font-size: 18px;
	/* height: 328px; */
}
.tateyama_cable {
	padding: 80px 0 10px;
}
.highland_bus {
	padding: 80px 0 10px;
	position: relative;
}
.kurobe_cable {
	padding: 80px 0 10px;
	background-image: url(../png/img-bg02.png);
	background-repeat: repeat;
	background-size: cover;
	color: #333333;
}
.ropeway {
	padding: 10px 0 50px;
	background-image: url(../png/img-bg02.png);
	background-repeat: repeat;
	background-size: cover;
	color: #333333;
}
.tunnel {
	padding: 150px 0;
	position: relative;
}

.sec_ttl {
	text-align: center;
	/* margin-bottom: 30px; */
	color: #333333;
	position: absolute;
	transform: translate(-50%,-50%);
	top: 43%;
	left: 50%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 10px;
	font-family: 'Noto Serif JP', serif;
	width: 100%;
}
.sec_ttl > span{
	font-size: 12px;
}
.sec_ttl_wrap{
	position: relative;
	display: flex;
	justify-content: center;
	margin-bottom: 30px;
}
.main_img {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	/* margin-bottom: 50px; */
}
.img_box {
	position: relative;
	z-index: 10;
}
.img_box img {
	width: 100%;
	height: auto;
}
.img_box figcaption {
	position: absolute;
	left: 0;
	bottom: 0;
	padding: 5px 20px;
	background-color: #122125;
	color: #FFF;
	/* text-align: center; */
}
.en_development .img_box figcaption {
	font-size: 10px;
}
.sec_txt {
	font-size: 16px;
	padding: 50px 0;
}
.sub_img {
	display: grid;
	grid-template-columns: 1fr 1fr;
}
.sub_img.-three {
	grid-template-columns: 1fr 1fr 1fr;
}
.scroll_txt {
	margin-top: -30px;
}
.scroll_txt_wrap {
	overflow: hidden;
}
.scroll_txt_list{
	animation: scroll_text 80s infinite linear 0.5s both;
	display: flex;
}
.scroll_txt_list li{
	/* width: calc(500vw / 3); */
  	font-size: 140px;
	color: rgba(255, 255, 255, 0.1);
	list-style: none;
	flex: none;
	font-family: 'Cinzel', serif;
}
.scroll_txt_list.-white li{
	color: rgba(18, 33, 37, 0.1);
}

@keyframes scroll_text {
	from {
	  transform: translateX(0);
	}
	  to {
	  transform: translateX(-100%);
	}
}
.movie{
	display: flex;
	justify-content: center;
	padding: 20px;
}
.movie iframe{
	/* width: 100%; */
	/* height: auto; */
	aspect-ratio: 16/9;
}


/* タブレット以下設定 */
@media screen and (max-width:999px) {
	.hero {}
	.hero_ttl {
		left: ;
	}
	.intro {}
	.intro_ttl {}
	.intro_txt {}
	.sec_ttl {}
	.main_img {}
	.img_box {}
	.img_box　figcaption {}
	.sec_txt {}
	.sub_img {}
	.scroll_txt {}
	.scroll_txt_wrap {}
	.tateyama_cable {}
	.highland_bus {}
	.kurobe_cable {}
	.ropeway {}
	.tunnel {}

}

/* All SP */
@media screen and (max-width:639px) {
	.sp-dn {
		display: none;
	}
	.hero {
		display: block;
	}
	.hero_ttl {
		top: 50%;
		left: 55%;
		width: 100%;
		padding: 20px 0;
		justify-content: flex-start;
	}
	.hero_ttl h1{
		font-size: 30px;
	}
	.hero_img{
		width: 100%;
	}
	.hero_img img{
		object-position: left;
	}
	.bg_img.-bi01 {
		right: -20%;
		bottom: -41%;
	}
	.bg_img.-bi02{
		display: none;
	}
	.bg_img.-bi03{
		left: -65%;
		top: -6%;
	}
	.intro {
		padding: 55px 0 20px;
	}
	.intro_wrap{
		flex-direction: column;
	}
	.intro_ttl {
		writing-mode: unset;
	}
	.intro_txt {
		writing-mode: unset;
		font-size: 16px;
		line-height: 1.8;
		height: auto;
	}
	.sec_ttl {
		font-size: 85%;
	}
	.sec_ttl > span{
		font-size: 10px;
	}
	.main_img {
		flex-direction: column;
	}
	.img_box {}
	.img_box figcaption {}
	.sec_txt {}
	.sub_img {
		display: flex;
		flex-direction: column;
	}
	.scroll_txt {
		margin-top: -15px;
	}
	.scroll_txt_wrap {}
	.scroll_txt_list li{
		font-size: 50px;
	}
	.tateyama_cable {
		padding-top: 30px;
	}
	.highland_bus {
		padding-top: 20px;
	}
	.kurobe_cable {
		padding-top: 30px;
	}
	.ropeway {
		padding-bottom: 20px;
	}
	.tunnel {
		padding: 40px 0;
	}
	.movie iframe{
		width: 100%;
		height: auto;
		aspect-ratio: 16/9;
	}


}