@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@300;400&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Zen+Kurenaido&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Yomogi&display=swap');
/*
'Roboto' is licensed under the Apache License 2.0.
(http://www.apache.org/licenses/LICENSE-2.0)

You can download the original font from here.
https://fonts.google.com/specimen/Roboto+Condensed
*/


/* 基本設定 */
:root {
	--color1: #e0e8ee;
	--color2: #5e87b1;
}
html {
	background: transparent;
	font-size: 62.5%;
}
body {
	min-height: 100vh;
	padding-top: 10px;
	background: #ffffff;
	color: #443E3B;
	/*font-family: "Yomogi", cursive;*/
	font-family: "Zen Kurenaido", sans-serif;
	font-size: 1.6rem;
	letter-spacing: 0.2em;
	overflow: hidden;
}
body.scroll{
	overflow: visible;
}
a {
	text-decoration: none;
}
h2,
h3,
h4,
.mainNav,
.headerNav,
.back,
.long_new .longImage,
.new {
	font-family: 'Satisfy', cursive;
	font-family: 'Roboto Condensed', sans-serif;
}
h2 {
	position: relative;
	padding-top: 50px;
	margin: 0 0 80px;
	color: #3e555a;
	font-size: 1.3em;
	font-weight: normal;
	text-align: center;
}

h3 {
	margin: 30px 0;
	font-size: 1.1em;
}
h3 > span {
	display: inline-block;
	padding: 2px 3px;
	border-bottom: var(--color2) solid 2px;
	color: #5c6772;
	font-weight: normal;
	line-height: 25px;
}
h4 {
	display: flex;
	 align-items: center;
	margin: 1em .5em;
	color: #5c6772;
	font-weight: normal;
}
h4::before {
	content: '';
	display: inline-block;
	width: 20px;
	height: 20px;
	margin-right: 15px;
	background: linear-gradient(-45deg, var(--color2) 50%, #ffffff00 50%);
}
.ja {
	font-size: 90%;
}

em {
	background: #ffffff;
	background: repeating-linear-gradient(-50deg, var(--color1) 0, var(--color1) 1px, #fff 1px, #fff 5px);
	font-style: normal;
}

ul,
ol {
	list-style: none;
}
input[type],
textarea {
	border: solid 1px #bbbbbb;
	border-radius: 0;
	box-shadow: none;
	font-size: 95%;
}

p {
	padding: 0 2em;
}


img{
	user-drag: none;
	-webkit-user-drag: none;
	-moz-user-select: none;
}















section{
	text-align: center;
	margin: 0 auto;
}

section:not(.articleText) img{
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}
section.brown{
	background: #f7f3f0;
}
section.blue{
	background: #b5e6de;
	margin-bottom: 0px!important;
}

section.footer_bottom{
	padding-bottom: 30px;
}




.contentsWrap {
	padding: 10px 0 0;
}
.contentsWrap a {
	color: #7FC5BC;
}
.index {
	position: relative;
	width: 100%;
	padding-top: 1vw;
	margin-top: 100vh;
	background: #fff;
	z-index: 2;
}
.page {
	width: 100%;
	 min-width: 700px;
	padding: 10px 0 0;
	margin: 10vh auto 0;
}
.contents {
	width: 80%;
	 min-width: 700px;
	padding: 10px 0;
	margin: 0 auto 10vh;
}




























.main_video{
	width: 100vw;
	height: 100vh;
	background-color: #fff;
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 9998;;
	pointer-events: none;
}
.main_video video{
	width: 100vw;
	height: 100vh;
}
.skipbtn.opc{
	filter: opacity(0);
	transition: filter 1s 6s ease-in;
}
.main_video.opc {
	filter: opacity(0);
	transition: filter 1s 7s ease-in;
}
.skipvideo.opc {
	filter: opacity(0);
	transition: filter 1s 7s ease-in;
}
.skipbtn{
	position: fixed;
	top: 80%;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #B7EAE3;
	text-shadow: 1px 1px 0px #fff;
	font-weight: bold;
	padding: 10px 20px;
	border-radius: 50px;
	cursor: pointer;
	z-index: 9999;
	transition: all 0.5s ease;
}
/*
.skipbtn{
	position: fixed;
	top: 10px;
	right: 10px;
	background-color: #B7EAE3;
	text-shadow: 1px 1px 0px #fff;
	font-weight: bold;
	padding: 7px 15px;
	border-radius: 50px;
	cursor: pointer;
	z-index: 9999;
	transition: all 0.5s ease;
}
*/
.skipbtn:hover{
	color: #7E7E7E;
	background-color: #CAF3EC;
	transition: all 0.5s ease;
}
.skipbtn.skip,
.skipvideo.skip,
.main_video.skip,
video.skip {
	filter: opacity(0);
	transition: all 0.5s 0s ease-in;
	opacity: 0
}

.top_midashi {
  display: inline;
  position: relative;
  background-image: linear-gradient(90deg, #CCEFE9, #CCEFE9);
  background-repeat: no-repeat;
  background-position: bottom left;
  background-size: 0 30%;
  transition: all 1s ease-in-out;
  font-size: min(6vw, 36px);
  padding: 0 10px 0;
}

.top_midashi.marker {
  background-size: 100% 30%;
}


.top_midashi::after {
	position: absolute;
	content: "";
	background-image: url("../img/pen_after.png");
	bottom: 5px;
	right: -25px;
	width: 20px;
	height: 29px;

}











.top_logo{
	margin-bottom: -50px;
}


.top_logo img{
	max-width: 400px!important;
}


.top_text{
	margin: 0px auto 60px;
	line-height: 30px;
}

.head_logo{
	margin: 0 auto;
	text-align: center;
}
.head_logo img{
	max-width: 200px;
}


.box {
	padding: 20px;
	margin: 5vh auto;
}
.top_banner{
	width: 100%;
	margin: 0 auto;
	text-align: center;
}



.boxboreder{
	border-top: #B39E8C dashed 1px;
	margin: 100px 0;
}


ul.newslist{
	width: 700px;
	max-width: 95%;
	margin: 80px auto;
	line-height: 24px;
}

ul.newslist li a{
	display: grid;
	grid-template-columns: 100px 1fr;
	grid-row: 50px;
	font-size: 1.8rem;
	color: #5A4635;
	padding: 10px;
	transition: 0.5s all;
}
ul.newslist li a:hover{
	color: #5A4635;
	background: rgba(204,239,233,0.40);
	border-radius: 10px;
}
ul.newslist li {
	padding: 10px 2px;
	margin: 0 25px 0 15px;
	text-align: left;

}
ul.newslist li:not(:first-child) {
	border-top: #B39E8C dashed 1px;
}
ul.newslist li span.date {
	font-size: 12px;
	align-content: center;
}
ul.newslist li a span.date {
}
ul.newslist li span.title {
	font-size: 15px;
	display: block;
}





svg{
	width: 100%;
	max-width: 640px;
}
#svg-animation-genkan .cls-1{
	fill:none;
	stroke:#FFFFFF;
	stroke-width:180;
	stroke-linecap:round;
	stroke-linejoin:round;
	stroke-miterlimit:10;
}

svg{
	width: 100%;
	max-width: 640px;
}
#svg-animation-senpuki .cls-1{
	fill:none;
	stroke:#FFFFFF;
	stroke-width:180;
	stroke-linecap:round;
	stroke-linejoin:round;
	stroke-miterlimit:10;
}


.character-grid{
	max-width: 720px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-gap: 60px;
	margin: 0 auto 50px;
	padding: 20px;
}
.character-grid img{
	border-radius: 50%;
}
.chr_name{
	font-weight: bold;
	margin: 24px 0 12px;
}
.chr_name{
	font-weight: bold;
}
.chr_text{
	line-height: 30px;
}


.footer-grid{
	max-width: 800px;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-gap: 30px;
	margin: 10px auto 30px;
}





.mainHeader {
	display: flex;
	 justify-content: center;
	 align-items: center;
	position: fixed;
	 top: 0;
	 left: 0;
	width: 100%;
	height: 100vh;
	background: linear-gradient(0deg, rgba(183,234,227,1) 50%, rgba(255,255,255,1) 50%);
	box-sizing: border-box;
	overflow: hidden;
	text-align: center;
}
.mainHeader::before {
	content: '';
	display: block;
	position: absolute;
	 top: 0;
	 left: 0;
	width: 100%;
	height: 100vh;
	background: url('../img/main_img.jpg') center center;
	background-repeat: no-repeat;
	z-index: 2;
}
.mainHeaderInner {
	display: flex;
	 flex-direction: column;
	 justify-content: center;
	 align-items: center;
	position: relative;
	margin-bottom: -330px;
	box-sizing: border-box;
	z-index: 3;
}

.banner-img {
  width: 100%;
  vertical-align: bottom;
  opacity: 0; 
  -webkit-backface-visibility: hidden; 
  -webkit-filter: blur(8px);
  filter: blur(8px);
}

























h1 {
	font-size: 2em;
	font-weight: normal;
}
.headerURL {
	color: #6d7e85;
	font-size: 1.1rem;
	letter-spacing: 1.5px;
}

.headerNav {
	padding-bottom: 0;
	font-size: 1.1em;
	margin: 0 auto;
}
.headerNav ul {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	 justify-content: center;
	box-sizing: border-box;
	max-width: 800px;
	margin: 0 auto;
}
.headerNav li {
	margin: 30px auto;
}
.headerNav li a {
	display: inline-block;
	padding: 5px 10px;
	box-sizing: border-box;
	color: #41505a;
	display: inline;
	background-image: linear-gradient(90deg, #DEF4F1, #DEF4F1);
	background-repeat: no-repeat;
	background-position: left bottom;
	background-size: 0 40%;
	transition: all 0.5s ease;
	cursor: pointer;
}
.headerNav li a img {
	width: 100px;
}
.headerNav li a:hover {
	background-size: 100% 30%;
	color: #829C98;
}



.top_sns{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-gap: 30px;
}

.top_sns_img{
}
.top_sns_img img{
	width: 40px;
	transition: all 0.5s ease;
}
.top_sns_img img:hover{
	opacity: 0.6;
	filter: brightness(1.2);
	transition: all 0.5s ease;
}


.mainNav {
	 justify-content: flex-end;
	 align-items: center;
	position: fixed;
	 top: 0;
  left: 50%;
	width: 100%;
	padding: 0 10%;
	box-sizing: border-box;
	font-size: 1.2em;
	transition: .5s;
	z-index: 3;
}
.mainNav ul {
	display: flex;
	 flex-wrap: wrap;
	 align-items: center;
	 margin: 0 auto;
	padding: 1em 0;
	box-sizing: border-box;
	transition: .5s;
}
.mainNav li {
	margin: 0 1rem;
	font-size: 1em;
}
.mainNav li a {
	position: relative;
	padding: 5px;
	color: #41505a;
	transition: .3s;
	z-index: 2;
}
.mainNav li a:hover {
	filter: blur(1px);
}
.mainNav::before {
	content: '';
	position: absolute;
	 top: 0;
	 left: 0;
	width: 100%;
	height: 100%;
	opacity: .5;
}





.indexNav {
	top: -65px;
	visibility: hidden;
}
.view .indexNav {
	transform: translateY(65px);
	visibility: visible;
}




.back {
	position: fixed;
	 bottom: -8px;
	 right: 10px;
	z-index: 3;
}
#backTop {
	display: inline-block;
	color: #5e7370;
	transition: .8s;
}
#backTop img {
	width: 128px;
}





.indexBack #backTop {
	opacity: 0;
	transform: translateY(50px);
	visibility: hidden;
}
.view .indexBack #backTop {
	opacity: 1;
	transform: translateY(0px);
	visibility: visible;
}
.indexBack {
	opacity: 1;
	transition: all 0.5s ease;
}
.indexBack:hover {
	opacity: 0.6;
}




.sub_bg{
	background: url("../img/news_senpuki.jpg") fixed repeat-x left bottom;
	background-size: 100%;
	background-repeat: no-repeat;
	width:100%;
}







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

記事

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






#article_box{
	padding: 0px!important;
	margin: 0px!important;
}


#article {
	position: relative;
	background: rgba(255,255,255,0.9);
	max-width: 800px;
	margin: 0px auto 30vw;
	padding: 50px;
	box-shadow: 0px 0px 10px rgba(77,100,97,0.10);
	text-align: left;
}

.articleDate {
	display: inline-block;
	text-align: left;
	padding: 5px 12px;
	font-size: 1.5rem;
	font-weight: bold;
	color: #fff;
	background: #92C3BB;
	border-radius: 50px;
	font-size: 12px;
}

.articleTitle {
	text-align: left;
	padding: 10px 0;
	margin: 0px auto 40px;
	font-size: 1.8rem;
	font-weight: bold;
	text-shadow: 0px 3px 3px #fff;
	color: #406A63;
	border-bottom: 2px dashed #88B4B8;
	line-height: 25px;
}

.articleText {
	margin: 0px auto;
	padding: 0px 0px 30px;
	font-size: 1.6rem;
	text-align: left;
	text-shadow: 0px 0px 1px #C4DDDA;
	line-height: 35px;
	letter-spacing: 1px;
}

.articleText a {
	color: #C85284!important;
	transition: 0.5s;
	text-shadow: 0px 0px 1px #B16384;
}

.articleText a:hover {
	color: #CF8AA6!important;
}

.articleText h3 {
	color: #71C3C7;
	font-weight: normal;
	font-size: 1.8rem;
	border: none;
}

.mdbar {
	display: inline-block;
	margin: 30px 0;
	background: #B5A098;
	border-radius: 50px;
	font-size: 1.6rem;
	color: #FFFFFF;
	padding: 0px 20px;
	font-weight: bold;
}

.mdbox {
	margin: 20px 0 40px;
	padding: 20px;
	border: 3px solid #95CCC3;
	background: #FFFCF7;
}

strong {
	width: 100%;
	margin: 16px auto;
	font-weight: bold;
}

.articleText img {
	display: block;
	margin: 10px auto 20px!important;
	max-width: 640px!important;
	height: auto;
	box-shadow: 0px 0px 10px rgba(77,100,97,0.20);
}

.articleFooter {
	text-align: center;
	display: flex;
	justify-content: center;
	margin: 80px 0 30px;
	padding: 30px 0px 0px;
	border-top: 1px solid #88B4B8;
}

.articleFooter span {
	list-style-type: none;
	flex-grow: 1;
	text-align: center;
	width: 100%;
}

.articleFooter span a {
	color: inherit;
}

.articleFooter span+span {
	border-left: 1px solid #88B4B8;
}

.articleFooter span:nth-child(1)::before {
	content: "◀";
	margin-right: 15px;
}

.articleFooter span:nth-child(2)::after {
	content: "▶";
	margin-left: 15px;
}

.articleShare {
	display: flex;
	justify-content: flex-end;
	margin: 60px 40px;
	padding: 30px 30px 60px;
	border-bottom: 1px solid;
}

.articleShare_cp {
	display: flex;
	justify-content: flex-end;
	margin: 60px 40px 0;
	padding: 30px;
}

table {
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	margin: 20px 0 40px;
}

th, td {
	padding: 16px;
	font-weight: normal;
	border-left: 1px solid #fff;
	border-bottom: 1px solid #fff;
}

th,td:nth-child(1) {
	color: #fff;
	background-color: #92C3BB;
}




.swiper {
	text-align: center;
	margin: 0 auto;
}

.swiper-slide img {
	width: 100%;
	height: 100%;
	margin-bottom: 30px;
}

.swiper-pagination {
	filter: saturate(0)brightness(0);
}

.articleText ul li img{
	width: 100%!important;
	height: auto!important;
}

















.fade {
	transition: 0.75s ease-in-out 0s;
	transform: translateY(30px);
	opacity: 0;
}
.fade.fade_on{
	transform: translateY(0);
	opacity: 1.0;
}

.fade0 {
	transition: 0.75s ease-in-out 0s;
	transform: translateY(0px);
	opacity: 0;
}
.fade1 {
	transition: 0.75s ease-in-out 0.3s;
	transform: translateY(30px);
	opacity: 0;
}
.fade2 {
	transition: 0.75s ease-in-out 0.6s;
	transform: translateY(30px);
	opacity: 0;
}
.fade3 {
	transition: 0.75s ease-in-out 0.9s;
	transform: translateY(30px);
	opacity: 0;
}
.fade4 {
	transition: 0.75s ease-in-out 1.2s;
	transform: translateY(30px);
	opacity: 0;
}
.fade0.fade_on ,
.fade1.fade_on ,
.fade2.fade_on ,
.fade3.fade_on ,
.fade4.fade_on {
	transform: translateY(0);
	opacity: 1.0;
}












@media screen and (max-width:1300px) {
	.box {
		margin: 5vh auto;
		text-align: center;
	}
	.columns {
		columns: 2;
	}
}


@media screen and (max-width:768px) {
	body {
		font-size: 1.2rem;
	}
	h2 {
		margin-bottom: 30px;
		font-size: 1.1em;
	}
	h2::before {
		width: 50px;
		height: 50px;
		top: 35px;
		left: calc(50% - 25px);
	}
	h3 {
		margin: 20px 0;
		font-size: 1em;
	}
	h3 > span {
		padding: 0 1px;
		line-height: 20px;
	}
	h4 {
		font-size: 1.1em;
	}
	h4::before {
		width: 15px;
		height: 15px;
	}
	.mailForm .enter {
		width: 80%;
		min-width: 200px;
	}
	p {
		padding: 0 1em;
	}
	.box {
		padding: 10px;
		margin: 20px 0;
	}
	.page {
		width: 100%;
		 min-width: 200px;
		 max-width: 100%;
		margin: auto;
	}
	.contents {
		width: 90%;
		 max-width: 500px;
		 min-width: 200px;
		margin: 30px auto;
	}
	.index {
		padding-top: 100px;
	}
	.nameChange {
		margin: 1em 0;
	}
	.nameChangeForm {
		display: flex;
		 flex-wrap: wrap;
		 justify-content: center;
	}
	.columns {
		columns: 1;
		margin-top: 40px;
	}
	.columns ul {
		margin-top: 60px;
	}
	.columns ul:first-of-type {
		margin-top: 0;
	}
	.siteMenu {
		width: 100%;
	}
	.mainHeader::before {
	}
	.mainHeaderInner {
		flex-direction: column;
		width: 80%;
		 max-width: 300px;
		height: 50vh;
		 max-height: 350px;
		padding: 40px;
		background-size: contain;
	}
	.mainHeaderInner::after {
		content: none;
	}
	.siteInfo {
		margin-bottom: 20px;
	}
	h1 {
		font-size: 1.8em;
	}
	.headerURL {
		font-size: 1rem;
	}
	.headerNav {
		width: 100%;
		font-size: 1.1em;
	}
	.mainNav {
		justify-content: center;
		height: 40px;
		padding: 0 1em;
		margin: 0 auto;
		text-align: center;
		left: 0;
	}
	.mainNav::before {
		background-position: left top;
		-webkit-mask-size: 80%;
		mask-size: 80%;
		opacity: .3;
	}
	.mainNav ul {
		justify-content: flex-start;
	}
	.mainNav li {
		font-size: 1.3rem;
	}
	#backTop::after {
		bottom: -40px;
		right: -40px;
		border-width: 40px;
		box-shadow: none;
	}
	#backTop span {
		bottom: -18px;
		padding-top: 5px;
	}
	
	#backTop img {
		width: 80px;
	}

	.top_logo img{
		max-width: 60%!important;
	}

	.character-grid{
		grid-template-columns: repeat(1, 1fr);
		grid-gap: 60px;
		margin: 0 auto 50px;
		padding: 20px;
	}
	.character-grid img{
		border-radius: 50%;
		width: 80%;
	}
	.chr_name{
		font-weight: bold;
		margin: 10px 0;
	}
	.chr_name{
		font-weight: bold;
	}


	.character-grid div{
		display: grid;
		grid-template-columns: 30% 1fr;
		align-items: center;
		text-align: left;
		grid-gap: 20px;
	}

	.character-grid div div{
		display: grid;
		grid-template-columns: repeat(1, 1fr);
		grid-gap: 0px;
	}

	.index_news_bg {
		bottom: 0;
		background-image: url("../img/news_senpuki.jpg");
  width: 100%;
  height: 0;
  padding-top: calc(720 / 1280 * 100%);
  /*calc(画像の高さ / 画像の幅 * widthの値)*/
  background-image: url('bg-image.jpg');
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
	}




	#article {
		margin: 0px auto 50vw;
		padding: 20px;
	}
	.articleText img {
	}


    
	#article th{
		padding: 5px 10px;
		/*
		border-radius: 50px;
		display: inline-block;
		*/
	}
	#article td{
		width: inherit;
		padding: 20px 10px;
		letter-spacing: 0px;
	}
	#article table, td, th {
		outline: none;
		outline-offset: none;
		border-collapse: collapse;
	}
	#article td, th {
		display: block;
	}
	#article th {
		border-bottom: 2px solid #DDF4FF;
	}
    



	.sub_bg{
		background-image: url("../img/news_senpuki_sp.jpg")!important;
	}





}






@media screen and (min-width:1700px) {




	.sub_bg{
		background-image: url("../img/news_senpuki_vw.jpg");
	}




}

