@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Old+Mincho:wght@400;500;600&display=swap');

/*================================

全体

================================*/

#wrapper{
	overflow: clip;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	}


/*================================

内容

================================*/

#intro{
	position: sticky;
	top: 55px;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	width: 100%;
	height: calc(100svh - 85px);
	will-change: opacity, transform, filter;
}
@media screen and (max-width: 640px) {
	#intro{
		top: 45px;
		height: calc(100svh - 45px);
	}
	}

#intro h2.jph{
	writing-mode: vertical-rl;
	display: inline-block;
	text-align: left;
	font-size: 1.8em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	letter-spacing: .2em;
	}
@media screen and (max-width: 640px) {
#intro h2.jph{
		font-size: 1.6em;
	}
	}

#intro > h2.enh{
	display: none;
	}
html[lang="en"] #intro > h2.enh {
	display: inline-block;
	text-align: center;
	font-size: 1.3em;
	line-height: 1.8em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	padding-left: 20px;
	padding-right: 20px;
	}

#intro .fade-text span{
	opacity: 0;
	display: inline-block;
	transform: translateY(10px);
	transition: opacity 0.6s ease, transform 0.6s ease;
	}

#intro .fade-text span.show{
	opacity: 1;
	transform: translateY(0);
	}

#intro .ss-scrolldown{
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 50px;
	background: rgba(0, 0, 0, .5);
	}

#intro .ss-scrolldown > div{
	position: absolute;
	left: 0;
	bottom: 0;
	width: 1px;
	height: 50px;
	}

#intro .ss-scrolldown::after{
	content: "";
	position: absolute;
	top: 0;
	width: 1px;
	height: 50px;
	background: rgba(255, 255, 255, .8);
	animation: linemove 2s ease-in-out infinite;
	opacity:0;
	}

@keyframes linemove{
	0%{
		height:0;
		top:0;
		opacity: 0;
	}
	50%{
		height:50px;
		top:0;
		opacity: 1;
	}
	100%{
		height:0px;
		top:50px;
		opacity: 1;
	}
	}


.story_lead{
	width: 100%;
	text-align: center;
	padding: 300px 0 100px;
	}
@media screen and (max-width: 640px) {
.story_lead{
	padding: 200px 0 100px;
	}
	}

.story_lead p{
	font-size: 1.05em;
	line-height: 2.2em;
	}
@media screen and (max-width: 640px) {
.story_lead p{
	font-size: .85em;
	line-height: 2em;
	width: 92%;
	margin: auto;
	}
	}

.story_lead p span.line {
	display: block;
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.8s ease, transform 0.8s ease;
}

.story_lead p span.line.show {
	opacity: 1;
	transform: translateY(0);
}



.mainvisual_stories{
	position: relative;
	width: 100%;
	max-height: 800px;
	aspect-ratio: 5 / 2;
	margin: 0 auto;
	overflow: hidden;
	}
@media screen and (max-width: 640px) {
.mainvisual_stories{
	max-height: auto;
	aspect-ratio: 1;
	}
	}

.mainvisual_stories .kv_stories{
	position: relative;
	width: 100%;
	height: 100%;
	background-position: center right;
	background-repeat: no-repeat;
	background-size: cover;
	}
@media screen and (max-width: 640px) {
.mainvisual_stories .kv_stories{
	background-position: center center;
	}
	}


/*
_index
*/

.stories ._index{
	position: relative;
	width: 100%;
	margin: 0;
	padding-bottom: 80px;
	}
@media screen and (max-width: 640px) {
.stories ._index{
	padding-bottom: 30px;
	}
	}

.stories ._index h3{
	font-size: 1.7em;
	line-height: 1em;
	font-weight: 500;
	text-align: center;
	padding: 100px 0;
	}
@media screen and (max-width: 640px) {
.stories ._index h3{
	font-size: 1.3em;
	padding: 80px 0;
	}
	}

.stories ._index ul{
	margin: 0;
	padding: 0;
	text-align: center;
	width: 90%;
	margin: 0 auto;
	}

.stories ._index ul li{
	margin-bottom: 50px;
	}

.stories ._index ul li a{
	}


.stories ._index ul li p.no{
	display: inline-block;
	margin-bottom: 1em;
	font-size: 1em;
	font-weight: 500;
	color: #ccc;
	}
@media screen and (max-width: 640px) {
	}

.stories ._index ul li a p.no{
	color: #000;
	}

.stories ._index ul li p.ent{
	text-align: center;
	display: inline-block;
	font-size: 1.2em;
	line-height: 1.3em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	color: #ccc;
	border-bottom: 1px solid transparent;
	margin-bottom: .5em;
	-webkit-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}
@media screen and (max-width: 640px) {
.stories ._index ul li p.ent{
	font-size: .8em;
	}
	}

.stories ._index ul li a p.ent{
	color: #000;
	}

.stories ._index ul li p.jpt{
	text-align: center;
	display: inline-block;
	font-size: 1.6em;
	line-height: 1.3em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	color: #ccc;
	border-bottom: 1px solid transparent;
	-webkit-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}
@media screen and (max-width: 640px) {
.stories ._index ul li p.jpt{
	font-size: 1.2em;
	}
	}

.stories ._index ul li a p.jpt{
	color: #000;
	}


.stories ._index ul li a:hover p.ent,
.stories ._index ul li a:hover p.jpt{
	border-bottom: 1px solid #000;
	}



/*

.stories ._index ul li p{
	text-align: center;
	display: inline-block;
	font-size: 1.7em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	color: #ccc;
	border-bottom: 1px solid transparent;
	}
@media screen and (max-width: 640px) {
.stories ._index ul li p{
	font-size: 1.3em;
	}
html[lang="en"] .stories ._index ul li p {
	font-size: 1.1em;
	}
	}

.stories ._index ul li a p{
	color: #000;
	padding-bottom: 10px;
	-webkit-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}

.stories ._index ul li a:hover p{
	border-bottom: 1px solid #000;
	}

.stories ._index ul li p span{
	display: block;
	font-family: "Zen Old Mincho", serif;
	font-size: .6em;
	font-weight: 400;
	margin-bottom: 1.5em;
	color: #ccc;
	}
@media screen and (max-width: 640px) {
.stories ._index ul li p span{
	font-size: .8em;
	}
	}


.stories ._index ul li a p span{
	color: #000;
	font-size: .6em;
	-webkit-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}
@media screen and (max-width: 640px) {
.stories ._index ul li a p span{
	font-size: .8em;
	}
	}

*/


.stories ._index._post{
	border-top: 1px solid #dedede;
	background: white;
	}

.stories ._index._post h3{
	font-size: 1.5em;
	line-height: 1em;
	font-weight: 500;
	text-align: center;
	padding: 100px 0;
	}
@media screen and (max-width: 640px) {
.stories ._index._post h3{
	font-size: 1.1em;
	padding: 60px 0;
	}
	}

.stories ._index._post ul {
	width: 94%;
	margin: 0;
	margin: 0 auto;
	padding: 0;
	text-align: center;
	}

.stories ._index._post ul li{
	margin-bottom: 30px;
	}

.stories ._index._post ul li a{
	}


.stories ._index._post ul li p.no{
	display: inline-block;
	margin-bottom: 1em;
	font-size: 1em;
	font-weight: 500;
	color: #ccc;
	}
@media screen and (max-width: 640px) {
	}

.stories ._index._post ul li a p.no{
	color: #000;
	}

.stories ._index._post ul li p.ent{
	text-align: center;
	display: inline-block;
	font-size: 1.2em;
	line-height: 1.3em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	color: #ccc;
	border-bottom: 1px solid transparent;
	margin-bottom: .5em;
	-webkit-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}
@media screen and (max-width: 640px) {
.stories ._index._post ul li p.ent{
	font-size: .8em;
	}
	}

.stories ._index._post ul li a p.ent{
	color: #000;
	}

.stories ._index._post ul li p.jpt{
	text-align: center;
	display: inline-block;
	font-size: 1.6em;
	line-height: 1.3em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	color: #ccc;
	border-bottom: 1px solid transparent;
	-webkit-transition: all .6s;
	-ms-transition: all .6s;
	transition: all .6s;
	}
@media screen and (max-width: 640px) {
.stories ._index._post ul li p.jpt{
	font-size: 1.2em;
	}
	}

.stories ._index._post ul li a p.jpt{
	color: #000;
	}


.stories ._index._post ul li a:hover p.ent,
.stories ._index._post ul li a:hover p.jpt{
	border-bottom: 1px solid #000;
	}



/*================================

post

================================*/


.mainvisual_post{
	position: sticky;
	top: -180px;
	left: 0;
	width: 1100px;
	height: 800px;
	margin: 0 auto;
	overflow: hidden;
	}
@media screen and (max-width: 640px) {
.mainvisual_post{
	top: 0;
	max-width: 100%;
	height: 60svh;
	}
	}

.mainvisual_post .kv_post{
	position: relative;
	width: 100%;
	height: 100%;
	margin: auto;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	}

.mainvisual_post .ss-scrolldown{
	display: none;
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1px;
	height: 50px;
	background: rgba(0, 0, 0, .5);
	}
@media screen and (max-width: 640px) {
.mainvisual_post .ss-scrolldown{
	display: none;
	}
	}

.mainvisual_post .ss-scrolldown > div{
	position: absolute;
	left: 0;
	bottom: 0;
	width: 1px;
	height: 50px;
	}

.mainvisual_post .ss-scrolldown::after{
	content: "";
	position: absolute;
	top: 0;
	width: 1px;
	height: 50px;
	background: rgba(255, 255, 255, .8);
	animation: linemove2 2s ease-in-out infinite;
	opacity:0;
	}

@keyframes linemove2{
	0%{
		height:0;
		top:0;
		opacity: 0;
	}
	50%{
		height:50px;
		top:0;
		opacity: 1;
	}
	100%{
		height:0px;
		top:50px;
		opacity: 1;
	}
	}

.titles {
	padding: 20px 0 90px;
	}
@media screen and (max-width: 640px) {
.titles {
	padding: 20px 0 60px;
	}
	}

.titles > p{
	text-align: center;
	font-size: 1em;
	font-weight: 500;
	font-style: normal;
	line-height: 1em;
	}
@media screen and (max-width: 640px) {
.titles > p{
	font-size: .8em;
	}
	}

.titles > h2{
	margin-top: 80px;
	text-align: center;
	font-size: 2.1em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	line-height: 1em;
	}
@media screen and (max-width: 640px) {
.titles > h2{
	margin-top: 60px;
	font-size: 1.4em;
	}
	}

.storybody{
	background: white;
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 60px 0 80px;
	}
@media screen and (max-width: 640px) {
.storybody{
	width: 100%;
	padding: 50px 0;
	}
	}

.storybody h2{
	width: 740px;
	margin: 0 auto;
	text-align: center;
	font-size: 1.9em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	}
@media screen and (max-width: 640px) {
.storybody h2{
	width: 90%;
	font-size: 1.4em;
	}
	}

.storybody p{
	width: 740px;
	margin: 0 auto;
	font-size: 1.1em;
	line-height: 2em;
	text-align: justify;
	text-justify: inter-ideograph;
	}
@media screen and (max-width: 640px) {
.storybody p{
	width: 90%;
	font-size: 1em;
	line-height: 1.8em;
	}
	}

.storybody.onlyen p {
	text-align: left;
	}

.related{
	border-top: 1px solid #dedede;
	background: white;
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: 80px 0;
	}
@media screen and (max-width: 640px) {
.related{
	width: 100%;
	padding: 60px 0 30px;
	}
	}

.related h3{
	width: 740px;
	margin: 0 auto;
	padding-bottom: 80px;
	text-align: center;
	font-size: 1.4em;
	font-family: "Zen Old Mincho", serif;
	font-weight: 500;
	font-style: normal;
	}
@media screen and (max-width: 640px) {
.related h3{
	width: 90%;
	font-size: 1.1em;
	padding-bottom: 50px;
	}
	}

.related > p{
	width: 740px;
	margin: 0 auto;
	font-size: 1em;
	font-weight: 600;
	line-height: 1em;
	}
@media screen and (max-width: 640px) {
.related > p{
	width: 90%;
	font-size: .9em;
	}
	}

.related > .slist{
	width: 740px;
	margin: 0 auto;
	margin-top: 20px;
	margin-bottom: 30px;
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	flex-wrap: wrap;
	flex-direction: row;
	column-gap: 30px;
	row-gap: 20px;
	}
@media screen and (max-width: 640px) {
.related > .slist{
	width: 90%;
	column-gap: 20px;
	row-gap: 20px;
	}
	}

.related > .slist div{
	width: calc((100% - 90px) / 4);
	}
@media screen and (max-width: 640px) {
.related > .slist div{
	width: calc((100% - 40px) / 3);
	}
	}

.related > .slist div a{
	display: block;
	width: 100%;
	height: 100%;
	}

.related > .slist div a img{
	width: 100%;
	border: 1px solid #ccc;
	box-sizing: border-box;
	}

.related > .slist div a p{
	margin-top: 10px;
	font-size: .8em;
	line-height: 1.5em;
	}

.ext{
	position: relative;
	width: 100%;
	margin: auto;
	padding: 60px 0;
	background:white;
	border-top: 1px solid #dedede;
	background: #f3f3f3;
	}
@media screen and (max-width: 640px) {
.ext{
	padding: 50px 0;
	}
	}

.ext > .inner{
	width: 740px;
	margin: auto;
	}
@media screen and (max-width: 640px) {
.ext > .inner{
	width: 90%;
	}
	}

.ext > .inner h4{
	font-size: 1.4em;
	line-height: 1em;
	text-align: center;
	font-weight: 500;
	}
@media screen and (max-width: 640px) {
.ext > .inner h4{
	font-size: 1.1em;
	}
	}

.ext > .inner h5{
	margin-top: 20px;
	font-size: 1em;
	line-height: 1em;
	text-align: center;
	}
@media screen and (max-width: 640px) {
.ext > .inner h5{
	font-size: .9em;
	}
	}

.ext > .inner img{
	display: block;
	width: 740px;
	margin: auto;
	margin-top: 60px;
	}
@media screen and (max-width: 640px) {
.ext > .inner img{
	width: 100%;
	margin-top: 50px;
	}
	}

.ext > .inner > p{
	margin-top: 30px;
	font-size: 1em;
	line-height: 1.7em;
	text-align: left;
	}


.more {
	position: relative;
	margin-top: 30px;
	}

.more a{
	display: block;
	width: 200px;
	margin: auto;
	height: auto;
	border-bottom: 1px solid #ccc;
	text-align: center;
	}
@media screen and (max-width: 640px) {
.more a{
	width: 150px;
	}
	}

.more a:hover{
	border-bottom: 1px solid #333;
	}

.more a p{
	display: inline-block;
	font-size: .9em;
	line-height: 3em;
	text-align: center;
	}
@media screen and (max-width: 640px) {
.more a p{
	font-size: .8em;
	}
	}



/*================================

パンくず

================================*/

#breadcrumb {
	position: relative;
	width: 100%;
	height: auto;
	border-bottom: 1px solid #dedede;
	background-color: #fff;
	padding: 1.5em 3%;
	font-size: .8em;
	line-height: 1em;
	z-index: 1;
	}
@media screen and (max-width: 640px) {
#breadcrumb{
	display: none;
	}
	}

#breadcrumb span{
	display: inline-block;
	width: 1em;
	margin: 0 1em;
	font-size: .8em;
	height: 1em;
	background-position: left bottom;
	background-repeat: no-repeat;
	background-image: url(../images/arrow-right-s-line-black.svg);
	background-size: 1em;
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	}
@media screen and (max-width: 640px) {
#breadcrumb span{
	margin: 0 .5em;
	}
	}

#breadcrumb a:hover{
	text-decoration: underline;
	}




