/* CSS Document */

html{
	font-size: 62.5%;
	}

body{
	height: 100vh;
	background-attachment: fixed;
	background-size: 5em;
	background: #ffb2cb;
	color: #2b2926;
	fill: #2b2926;
	font-feature-settings: "palt";
	text-align: justify;
	word-break: break-all;
	line-height: 1em;
	overflow: hidden;
	transition: background 0.2s ease-out;
	}
	body.done{
		height: auto;
		background-image: none;
		overflow: inherit;
		}
	body *{
		line-height: inherit;
		}

a{
	color: #26221f;
	fill: #26221f;
	text-decoration: underline;
	transition-property: color,text-decoration,background,background-color,background-size,border,border-color,box-shadow,fill,filter,opacity;
	transition-duration: 0.2s;
	transition-timing-function: ease-out;
	}
	a:hover{
		color: #4263EA;
		fill: #4263EA;
		}

main{}
	main p{
		line-height: 1.6em;
		}
	main p+p{
		margin-top: 1em;
		}

img{
	-webkit-backface-visibility: hidden;
	}

#wrapper{
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	width: 100%;
	max-width: 1400px; 
	min-height: 100vh;
	margin: auto;
	background: #fff;
	opacity: 0;
	transition: opacity 0.2s ease-out;
	z-index: 0;
	}
	.done #wrapper{
		opacity: 1;
		}
	do #wrapper{
		opacity: 0;
		}
	done #wrapper{
		-webkit-animation: wrapper 0.5s ease-in forwards;
		animation: wrapper 0.5s ease-in forwards;
		}

#header{
	top: 0;
	left: 0;
	width: 100%;
	line-height: 3em;
	padding-right: env(safe-area-inset-right);
	padding-left: env(safe-area-inset-left);
	background: #000035;
	color: #fff;
	z-index: 100;
	order: 1;
	}
	#header h1{
		float: left;
		font-family: a-otf-jun-pro,sans-serif;
		font-weight: 300;
		font-style: normal;
		}
	#header ul{
		display: -ms-flexbox;
		display: flex;
		-ms-flex-align-items: center;
		align-items: center;
		-ms-flex-pack: end;
		justify-content: flex-end;
		}
	#header li{
		position: relative;
		list-style: none;
		margin-left: 1em;
		}
		#header li iframe,#header li .fb-like span{
			vertical-align: middle !important;
			}
		#header li:last-child{
			padding-right: 1.2em;
			font-weight: bold;
			}
	#header a{
		color: #fff;
		text-decoration: none;
		}
		#header a:hover{
			color: #00F3FF;
			}
	#header i{
		position: absolute;
		right: 0;
		top: 50%;
		}
	#header svg{
		width: 1em;
		height: 1em;
		margin-top: -0.5em;
		fill: #fff;
		vertical-align: top;
		opacity: .8;
		}

#siteName{}
	#siteName a{
		color: transparent;
		}
	#siteName svg{
		width: 100%;
		}

#nav{
	order: 3;
	}
	#nav ul{
		list-style: none;
		}
	#nav li{
			font-family: a-otf-jun-pro, sans-serif;
			font-weight: 300;
			font-style: normal;
			}
		#nav li:last-child{
			display: none;
			}
		#nav li img{
			width: 2.5em;
			}
	#nav a{
		font-weight: bold;
		text-decoration: none;
		display: flex;
		align-items: center;
		}
	#nav i{
		display: flex;
		align-content: center;
		margin-right: 0.5em;
		vertical-align: middle;
		}
	#nav svg{
		width: 1.5em;
		height: 1.5em;
		margin: -0.25em 0;
		fill: #fff;
		}

#hero{
	order: 2;
	overflow: hidden;
	}

#main{
	margin-bottom: auto;
	order: 4;
	}

#subject{
	padding: 0;
	color: #002a4a;
	font-weight: bold;
	text-align: center;
	}

#pagenation{
	overflow: hidden;
	}
	#pagenation ul,
	#pagenation ol{
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		list-style: none;
		margin: -0.5em;
		}
	#pagenation li{
		margin: 0.5em;
		}
	#pagenation a{
		position: relative;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 0.8em;
		text-decoration: none;
		background: #0068b6;
		color: #fff;
		fill: #fff;
		}
		#pagenation a:hover{
			opacity: 0.7;
			}
		#pagenation a i{
			position: relative;
			display: flex;
			align-content: center;
			margin-bottom: -0.1em;
			}
	#pagenation [rel="prev"]{}
		#pagenation [rel="prev"] i{
			margin-right: 0.5em;
			transform: scale(-1,1);
			}
	#pagenation [rel="next"]{}
		#pagenation [rel="next"] i{
			margin-left: 0.5em;
			}
	#pagenation .lsc-current-page{
		background: #ccc;
		color: #fff;
		}

#pageTop{
	position: -webkit-sticky;
	position: sticky;
	bottom: 0;
	z-index: 100;
	order: 5;
	text-align: center;
	}
	#pageTop a{
		display: block;
		font-size: 2.4em;
		background: rgba(66,99,234,0.6);
		fill: #fff;
		}
		#pageTop a:hover{
		background: rgba(66,99,234,0.4);
			}

	#pageTop svg{
		vertical-align: top;
		}

#footer{
	order: 6;
	}

#fNav{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	display: none;
	}
	#fNav li{
		list-style: none;
		}
	#fNav a{
		display: flex;
		line-height: 1.4em;
		}
		#fNav a:hover{
			color: #e50012;
			fill: #e50012;
			}
		#fNav a i{
			display: flex;
			align-items: center;
			margin-right: 0.2em;
			}

#copyright{
	display: flex;
	align-items: center;
	height: 3em;
	padding-bottom: env(safe-area-inset-bottom);
	background: #000035;
	box-sizing: content-box;
	}
	#copyright p{
		margin: 0;
		padding: 0;
		color: #fff;
		font-size: 0.8em;
		line-height: 1.2em;
		text-align: center;
		}

.wrap{
	width: calc(100% - 2em);
	margin: 0 auto;
	}
	.wrap div+div{
		margin-top: 2em;
		}

.headline{
	margin: 0;
	padding: 0.8em;
	font-weight: bold;
	text-align: center;
	line-height: 1.4em;
	font-family: a-otf-jun-pro,sans-serif;
	font-weight: 300;
	font-style: normal;
	}
	.headline+*{
		margin-top: 2em;
		}
	.headline img{
		display: block;
		margin: auto;
		}

.title{
	margin: 0;
	padding: 0;
	color: #0068b7;
	font-weight: bold;
	line-height: 1.4em;
	}
	.title+*{
		margin-top: 1em;
		}

.subTitle{
	margin: 0;
	padding: 0.5em 0;
	border-bottom: 1px solid #999;
	border-top: 3px solid #999;
	font-weight: bold;
	line-height: 1.4em;
	}
	.subTitle:before{
		content: "";
		margin-right: 10px;
		border-radius: 3px;
		border: solid #333;
		border-width: 0 3px;
		}
	.subTitle+*{
		margin-top: 1em;
		}

.buttonSet{
	display: flex;
	list-style: none;
	}
	.buttonSet li{
		display: flex;
		}

.linkBut{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.8em 1em;
	background: #0068b6;
	border: none;
	color: #fff;
	fill: #fff;
	font-family: inherit;
	font-size:  inherit;
	font-weight: bold;
	text-decoration: none;
	line-height: 1.4em;
	}
	.linkBut:hover{
		background: #e50012;
		color: #fff;
		fill: #fff;
		}
	.linkBut i{
		display: flex;
		align-content: center;
		margin-right: 0.5em;
		}
	.linkBut[data-icon="more"]{}
		.linkBut[data-icon="more"] i{
			margin: 0 0 0 0.5em;
			}

.linkText{
	display: inline-flex;
	align-items: center;
	}
	.linkText i{
		display: flex;
		align-items: center;
		}
	.linkText[data-icon="popup"]{}
		.linkText[data-icon="popup"] span{
			display: flex;
			align-items: center;
			margin-right: 0.2em;
			opacity: 0.5;
			}
		.linkText[data-icon="popup"] svg{
			width: 0.8em;
			}

.list{
	list-style: none;
	}
	.list > li{
		line-height: 1.4em;
		text-indent: 0;
		}
		.list > li > .list{
			margin-top: 0.5em;
			}
			.list > li:not(:last-child){}
				.list > li:not(:last-child) > .list:last-child{
					margin-bottom: 1em;
					}
		.list > li > .list.count{}
			.list > li > .list.count > li{
				padding-left: 2.8em;
				}
				.list > li > .list.count > li:before{
					content: "（"counter(count)"）";
					}
	.list > li+li{
		margin-top: 0.5em;
		}
	.list.point{}
		.list.point > li{
			display: flex;
			align-items: flex-start;
			}
			.list.point > li:before{
				content: "●";
				margin-right: 0.2em;
				color: #0068b7;
				transform: scale(0.7);
				}
	.list.notes{}
		.list.notes > li{
			padding-left: 1em;
			text-indent: -1em;
			}
	.list.count{
		counter-reset: count;
		}
		.list.count > li{
			position: relative;
			padding-left: 1.5em;
			}
			.list.count > li:before{
				counter-increment: count;
				content: counter(count)".";
				position: absolute;
				left: 0;
				}
	.list+*,
	*+.list{
		margin-top: 1em;
		}

.table{}
	table.table{
		width: 100%;
		border-collapse: collapse;
		}
		table.table thead{
			background: rgba(0,104,182,0.1);
			}
		table.table th,
		table.table td{
			padding: 0.8em;
			border: 1px solid #ccc;
			line-height: 1.4em;
			vertical-align: middle;
			}
		table.table th{
			background: rgba(0,0,0,0.05);
			}
	dl.table{
		display: flex;
		flex-wrap: wrap;
		}
		dl.table > dt,
		dl.table > dd{
			padding: 0.8em;
			margin-top: 1px;
			line-height: 1.4em;
			}
		dl.table > dt{
			width: 10em;
			background: rgba(0,104,182,0.1);
			}
		dl.table > dd{
			width: calc(100% - 10em);
			background: rgba(0,0,0,0.05);
			}
	.table+*,
	*+.table{
		margin-top: 1em;
		}

.googlemap{
	position: relative;
	}
	.googlemap iframe{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		}
	.googlemap div+div{
		margin-top: auto;
		}

.youtube{
	position: relative;
	padding-top: 56.25%;
	}
	.youtube iframe{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		}

.anchor{
	position: absolute;
	opacity: 0;
	}




/* for all */
@media (max-width: 1199px) {
/*1199px以下*/
}
@media (max-width: 991px) {
/*991px以下*/
body{}
	body:not(.nav){}
		body:not(.nav) #nav{
			left: 100vw;
			}
#header{
	position: -webkit-sticky;
	position: sticky;
	display: flex;
	justify-content: space-between;
	align-items: center;
	}
	#header h1{
		margin-left: 1em;
		}
#headerMie{}
	#headerMie li:last-child{
		display: none;
		}
#navButton{
	position: relative;
	flex: 0 0 1em;
	width: 1em;
	height: 1em;
	margin: 0;
	padding: 0;
	background: #000035;
	border: none;
	color: transparent;
	text-align: center;
	box-sizing: border-box;
	overflow: hidden;
	cursor: pointer;
	outline: none;
	}
	.nav #navButton{}
		.nav #navButton i:nth-child(1){
			top: 50%;
			transform: rotate(-45deg);
			}
		.nav #navButton i:nth-child(2){
			left: 100%;
			}
		.nav #navButton i:nth-child(3){
			top: 50%;
			transform: rotate(45deg);
			}
	#navButton span{
		position: absolute;
		bottom: 0.5em;
		left: 0;
		width: 100%;
		color: #fff;
		font-size: 0.2em;
		font-weight: bold;
		text-transform: uppercase;
		line-height: 1em;
		}
	#navButton i{
		position: absolute;
		content: "";
		display: block;
		left: 25%;
		width: 50%;
		height: 2px;
		margin-top: -1px;
		background: #fff;
		border-radius: 1px;
		transition: all 0.2s ease-out;
		z-index: 100000;
		}
		#navButton i:nth-child(1){
			top: 30%;
			}
		#navButton i:nth-child(2){
			top: 50%;
			}
		#navButton i:nth-child(3){
			top: 70%;
			}
#nav{
	position: fixed;
	top: 0;
	left:100vw;
	padding-bottom: constant(safe-area-inset-bottom);
	padding-bottom: env(safe-area-inset-bottom);
	background: rgba(255,255,255,.8);
	transition: left 0.2s ease-out;
	overflow-y: scroll;
	z-index: 110;
	}
	#nav ul{
		text-align: center;
		}
	#nav li{
		background: #fff;
		}
		#nav li:last-child{
			display: block;
			padding: 1em 0.5em;
			}
			#nav li:last-child a{
				background: #4263EA;
				border-radius: 50px;
				color: #fff;
				justify-content: center;
				}
				#nav li:last-child a:hover{
					background: #fff;
					border: 1px solid #4263EA;
					color: #4263EA;
					}
		#nav li img{
			margin-right: 0.5em;
			}
	#nav li+li{
		border-top: 1px solid #ccc;
		}
	#nav a{
		padding: 1em;
		}
		#nav a:hover{
			background: rgba(0,0,0,.1);
			}
}




/* for mobile */
@media (max-width: 767px) {
/*767px以下*/
body{
	font-size: 1rem;
	}
main > *,
article,
article section,
article header,
article footer{
	padding-top: 2em;
	padding-bottom: 2em;
	}
	article header+section{
		padding-top: 0;
		}
#pagePath{
	display: none;
	}
#fNav{
	padding: 2em 0;
	}
	#fNav li+li{
		margin-top: 0.5em;
		}
	#fNav a{
		fill: #0068b6;
		}
.headline{
	font-size: 1.6em;
	}
	.headline img{
		width: 2em;
		margin-bottom: 0.25em;
		}
.title{
	font-size: 1.4em;
	}
.subTitle{
	font-size: 1.2em;
	}
}
@media (max-width: 767px) and (orientation:portrait) {
/*767px以下 縦向き*/
html{
/*	font-size: 4vw;*/
/*	font-size: 6vw;*/
	}
#header{
	height: 15vw;
	}
#siteName{}
	#siteName svg{
		font-size: 10vw;
		}
#navButton{
	font-size: 15vw;
	}
#nav{
	top: 15vw;
	left: 0;
	width: 100vw;
	height: calc(100% - 15vw);
	}
.buttonSet{
	flex-direction: column;
	align-items: stretch;
	}
	.buttonSet *+*{
		margin-top: 1em;
		}
.table{}
	dl.table{}
		dl.table > dt,
		dl.table > dd{
			width: 100%;
			}
		dl.table > dt+dd{
			margin-top: 0;
			}
.googlemap{
	height: 100vw;
	}
.anchor{
	margin-top: calc(-15vw - 1em);
	}
}
@media (max-width: 767px) and (orientation:landscape) {
/*767px以下 横向き*/
html{
	font-size: 2.5vw;
	}
#header{
	height: 8vw;
	}
#siteName{}
	#siteName svg{
		font-size: 5vw;
		}
#navButton{
	font-size: 8vw;
	}
#nav{
	top: 8vw;
	left: 60vw;
	width: 40vw;
	height: calc(100% - 8vw);
	}
#fNav{}
	#fNav ul{
		column-count: 2;
		column-gap: 1em;
		}
.buttonSet{
	justify-content: center;
	}
	.buttonSet *+*{
		margin-left: 1em;
		}
.googlemap{
	height: 70vh;
	}
.anchor{
	margin-top: calc(-8vw - 1em);
	}
}


/* for tablet */
@media (min-width: 768px) {
/*768px以上*/
html{
	font-size: 62.5%;
	}
#pagePath{
	padding: 1em 0;
	}
	#pagePath a{
		overflow: hidden;
		white-space: nowrap;
		text-overflow: ellipsis;
		}
		#pagePath a:hover{
			text-decoration: none;
			}
	#pagePath ul{
		display: flex;
		flex-wrap: wrap;
		list-style: none;
		}
	#pagePath li{
		display: flex;
		align-items: center;
		min-width: 1em;
		font-size: 0.875em;
		line-height: 1em;
		}
		#pagePath li:last-child{
			font-weight: bold;
			}
	#pagePath i{
		display: flex;
		align-content: center;
		margin: 0 0.3em;
		opacity: 0.5;
		}
#footer{
	background: #f2f2f2;
	}
#fNav{
	padding: 2em 0;
	}
	#fNav li+li{
		margin-top: 1em;
		}
	#fNav a{
		color: #26221f;
		}
.buttonSet{
	justify-content: center;
	}
	.buttonSet *+*{
		margin-left: 1em;
		}
.headline{
	font-size: 1.8em;
	}
	.headline img{
		width: 2em;
		margin-bottom: 0.25em;
		}
.title{
	font-size: 1.6em;
	}
.subTitle{
	font-size: 1.4em;
	}
}
@media (min-width: 768px) and (max-width: 1199px) {
/*768px～1200px*/
body{
	font-size: 1.4rem;
	}
}
@media (min-width: 768px) and (max-width: 991px) {
/*768px～991px*/
main > *,
article,
article section,
article header,
article footer{
	padding-top: 3em;
	padding-bottom: 3em;
	}
	article header+section{
		padding-top: 1.5em;
		}
#header{
	height: 4em;
	}
#siteName{}
	#siteName svg{
		font-size: 3em;
		}
#navButton{
	font-size: 4em;
	}
#nav{
	top: 4em;
	left: calc(100% - 20em);
	width: 20em;
	height: calc(100% - 4em);
	}
	#nav .wrap{
		width: 100%;
		}
#fNav{}
	#fNav ul{
		column-count: 3;
		column-gap: 2em;
		}
.wrap{
	max-width: 720px;
	}
.googlemap{
	height: 30em;
	}
.anchor{
	margin-top: calc(-4em - 2em);
	}
}


/* for PC */
@media (min-width: 992px) {
/*992px以上*/
main > *,
article,
article section,
article header,
article footer{
	padding-top: 4em;
	padding-bottom: 4em;
	}
	article header+section{
		padding-top: 2em;
		}
#navButton{
	display: none;
	}
#siteName{}
	#siteName svg{
		font-size: 3em;
		}
#nav{}
	#nav a{
		color: #26221f;
		}
	#nav ul{
		position: sticky;
		display: flex;
		justify-content: space-between;
		top: 1em;
		}
	#nav li{
		margin-bottom: 1em;
		position: relative;
/*		display: inline-block;*/
		}
		#nav li:after{
			position: absolute;
			bottom: 0;
			left: 0;
			content: '';
			width: calc(100% + 0.5em);
			height: 2px;
			background: #4263EA;
			transform: scale(0, 1);
			transform-origin: left top;
			transition: transform .2s;
			}
			#nav li:hover::after {
				transform: scale(1, 1);
				}
		#nav li:last-child{}
			#nav li:last-child a{
				padding: 2em 1.5em;
				}
	#nav a{
		padding: 2em 0 1em;
		text-align: center;
		}
		#nav a:hover{
			color: #4263EA;
			}
		#nav a[href="index.html"],
		#nav a[href="index.html"]{
			background: #000;
			color: #fff;
			}
#main{
	-ms-grid-column: 2;
	grid-column: 2;
	-ms-grid-row: 3;
	rid-row: 3;
	}
#pagePath{
	-ms-grid-column: 2;
	grid-column: 2;
	-ms-grid-row: 2;
	grid-row: 2;
	margin: 0 0 1em 0;
	}
	#pagePath .wrap{
		max-width: 100%;
		}
#pageTop{
	-ms-grid-column: 1;
	-ms-grid-column-span: 2;
	grid-column-start: 1;
	grid-column-end: 3;
	-ms-grid-row: 5;
	grid-row: 5;
	margin: 0;
	padding: 0;
	}
	#pageTop a{
		padding: 0.166em 0;
		font-size: 3em;
		}
#footer{
	position: relative;
	-ms-grid-column: 1;
	-ms-grid-column-span: 2;
	grid-column-start: 1;
	grid-column-end: 3;
	-ms-grid-row: 4;
	grid-row: 4;
	}
#fNav{
	padding: 3em 0;
	}
	#fNav ul{
		column-count: 4;
		column-gap: 3em;
		}
.googlemap{
	height: 40em;
	}
.anchor{
	margin-top: calc(-4em - 2em);
	}
}
@media (min-width: 992px) and (max-width: 1199px) {
/*992px～1199px*/
.wrap{
	max-width: 940px;
	}
}
@media (min-width: 1200px) {
/*1200px以上*/
body{
	font-size: 1.6rem;
	}
.wrap{
	max-width: 1140px;
	}
}


/* Edge */
@supports (-ms-ime-align:auto) {
body{
	text-justify: distribute;
	}
}


/* ie */
@media all and (-ms-high-contrast: none) {
body{
	text-justify: inter-cluster;
	}
}


/* animation */
@-webkit-keyframes wrapper {
	0%{opacity: 0}
	100%{opacity: 1}
	}
@keyframes wrapper {
	0%{opacity: 0}
	100%{opacity: 1}
	}




/* --------------------------------------------- */
/* 　　　　　　　　　　LSC用　　　　　　　　　　 */
/* --------------------------------------------- */




/* for all */
@media (max-width: 1199px) {
/*1199px以下*/
}
@media (max-width: 991px) {
/*991px以下*/
}


/* for mobile */
@media (max-width: 767px) {
/*767以下px*/
}
@media (max-width: 767px) and (orientation:portrait) {
/*767px以下 縦向き*/
}
@media (max-width: 767px) and (orientation:landscape) {
/*767px以下 横向き*/
}


/* for tablet */
@media (min-width: 768px) {
/*768px以上*/
}
@media (min-width: 768px) and (max-width: 1199px) {
/*768px～1199px*/
}
@media (min-width: 768px) and (max-width: 991px) {
/*768px～991px*/
}


/* for PC */
@media (min-width: 992px) {
/*992px以上*/
}
@media (min-width: 992px) and (max-width: 1199px) {
/*992px～1199px*/
}
@media (min-width: 1200px) {
/*1200px以上*/
}


/* Edge */
@supports (-ms-ime-align:auto) {
}


/* ie */
@media all and (-ms-high-contrast: none) {
}




