@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,wght@0,500;1,600&display=swap');

/* FONT size
---------------------------------------------------------------------
[ px ]	[ % ]
10px 	72  %		19px 	136 %
11px 	79  %		20px 	143 %
12px 	86 %		21px 	150 %
13px 	93 %		22px 	158 %
14px 	100 %		23px 	165 %
15px 	108 %		24px 	172 %
16px 	115 %		25px 	179 %
17px 	122 %		26px 	186 %
18px 	129 %
---------------------------------------------------------------------*/




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 共通項目 */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
*{margin:0;padding:0;text-decoration:none}fieldset{border:0}body{line-height:1.8}body,dd,dl,dt,form,h1,h2,h3,h4,h5,h6,input,li,ol,p,select,ul{margin:0;padding:0}img{border:0;vertical-align:top}a{text-decoration:none}em{font-style:normal}ul li{list-style-type:none;list-style-image:none}address{font-style:normal}
html{font-size: 62.5%;}
body{font-size: 1.6em;}



/* マージン */
.margin02 {	margin-bottom: 2px; }
.margin05 {	margin-bottom: 5px; }
.margin06 {	margin-bottom: 6px; }
.margin08 {	margin-bottom: 8px; }
.margin10 {	margin-bottom: 10px; }
.margin15 {	margin-bottom: 15px; }
.margin20 {	margin-bottom: 20px; }
.margin30 {	margin-bottom: 30px; }
.margin40 {	margin-bottom: 40px; }


/* 文字装飾 */
strong {
	font-weight: bold;
}


ul li {
	list-style:none;	
}


/* box-sizing */ 
* {
	box-sizing: border-box;
}



/* img */ 
img {
	width: 100%;
	height: auto;
}



/* sp */ 
.sp {
	display: none;
}



/* リンク */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
a {
	color: #231815;
	text-decoration: none;
	transition: 0.3s;
	-webkit-transition: 0.3s;
}
a:hover {
	opacity: 0.7;
}


/* テキスト装飾 */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 小文字 */
.cap {
	line-height: 1.5;
	font-size: 1.2rem;
}



/* 横幅 */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
body {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", 'Noto Sans JP','Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
	font-weight: 500;
	color: #362E2E;
	padding: 0;
	margin: 0;
	letter-spacing: 0.1em;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt";
	text-align: justify;
	text-justify: inter-ideograph;
	-ms-text-justify: inter-ideograph;
}




/* フォント */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.en {
	font-family: 'Bodoni Moda', serif;
	font-weight: 500;
}




/* flex */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.flex {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.flex-start {
	display: flex;
	display: -webkit-flex;
	justify-content: space-between;
}
.flex-end {
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	 -ms-flex-direction: row-reverse;
		 flex-direction: row-reverse;
}
.flex-center {
	display: flex;
	justify-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header {
}
	#header .logo {
		position: absolute;
		top: 35px;
		left: 30px;
		z-index: 100001;
	}
		#header .logo a {
			display: block;
		}
			#header .logo a img {
				width: 200px;
				height: auto;
			}

		#header .logo .name {
			width: 200px;
			display: block;
			font-size: 1.6rem;
			letter-spacing: 0.1em;
			line-height: 1.4em;
			color: #fff;
			position: absolute;
			top: -8px;
			left: 220px;
		}
			#header .logo .name span {
				font-size: 1.2rem;
			}
	



	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */


/* main */
#main {
	display: block;
	padding-top: 120px;
	padding-right: 100px;
	padding-bottom: 120px;
}
.inner {
	width: 1200px;
	margin: 0 auto;
	position: relative;
	z-index: 10;
}


/* set */
.set {
	padding-bottom: 80px;
}
.set:nth-last-child(1) {
	padding-bottom: 0;
}
	.set .cell {
		margin-bottom: 35px;
		padding-bottom: 35px;
		border-bottom: dashed 1px #ddd;
	}
	.set .cell:nth-last-child(1) {
		margin-bottom: 0;
		padding-bottom: 0;
		border-bottom: none;
	}

	.set .list_icon {
		padding-top: 10px;
	}
		.set .list_icon li {
			margin-top: 5px;
			font-size: 1.5rem;
			line-height: 30px;
			position: relative;
			padding-left: 14px;
		}
		.set .list_icon li:before {
			content: "";
			width: 8px;
			height: 8px;
			background: #8ED84C;
			border-radius: 50%;
			position: absolute;
			top: 11px;
			left: 0;
		}

	.set ol.NoList {
		list-style-type: decimal;
		margin-top: 10px;
		padding-left: 20px;
		line-height: 30px;
	}
		.set ol.NoList li {
			padding-left: 10px;
			font-size: 1.5rem;
			position: relative;
		}




	
	.set .column2 li {
		width: 49%;
		margin-right: 2%;
		margin-bottom: 30px;
	}
	.set .column2 li:nth-child(2n) {
		margin-right: 0;
	}

	
	.set .column3 li {
		width: 32%;
		margin-right: 2%;
		margin-bottom: 30px;
	}
	.set .column3 li:nth-child(3n) {
		margin-right: 0;
	}

	
	.set .column4 li {
		width: 23.5%;
		margin-right: 2%;
		margin-bottom: 30px;
	}
	.set .column4 li:nth-child(4n) {
		margin-right: 0;
	}


/* txt */
.txt {
	font-size: 1.5rem;
	line-height: 30px;
}


/* btn */
.btn {
	width: 220px;
}
	.btn a {
		display: block;
		background: #8ED84C;
		height: 66px;
		font-size: 1.4rem;
		color: #fff;
		text-align: center;
		line-height: 66px;
		position: relative;
	}
	.btn a:before,
	.btn a:after{
		content: "";
		width: 10px;
		height: 1px;
		background: #fff;
		position: absolute;
		top: 50%;
		left: 0;
		margin-top: -0.5px;
		transition: 0.3s;
		-webkit-transition: 0.3s;
	}
	.btn a:after {
		left: auto;
		right: 0;
	}
	.btn a:hover {
		opacity: 1.0;
		letter-spacing: 0.2em;
	}
	.btn a:hover:before,
	.btn a:hover:after {
		width: 0;
	}


/* sns */
#sns {
	text-align: center;
	padding-right: 100px;
	padding-bottom: 30px;
}
	#sns .head {
		width: 152px;
		margin: auto;
		padding-bottom: 10px;
	}

	#sns ul li {
		margin-right: 10px;
	}
	#sns ul li:nth-last-child(1) {
		margin-right: 0;
	}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* サイドナビ */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#sidenav {
	width: 100px;
	height: 100vh;
	border-left: solid 1px rgba(255,255,255,0.3);
	position: fixed;
	top: 0;
	right: 0;
	z-index: 100;
}
	#sidenav .contact {
		position: absolute;
		top: 50%;
		right: 0;
		transform: rotate(90deg);
		margin-top: -30px;
	}
		#sidenav .contact a {
			display: block;
			font-size: 1.6rem;
			color: #fff;
		}

#sidenav.is-animation {
	background: #fff !important;
	border-left: solid 1px #ddd !important;
}
	#sidenav.is-animation .menu {
		width: 100px !important;
		height: 100px !important;
		background: #362E2E !important;
	}

	#sidenav.is-animation .contact a {
		color: #362E2E !important;
	}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 下層タイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */

/* pagetitle */
#pagetitle {
	width: 100%;
	height: 550px;
}
#pagetitle.detail {
	width: 100%;
	height: 300px;
}
	#pagetitle h1 {
		font-size: 6.0rem;
		color: #fff;
		letter-spacing: 0.2em;
		line-height: 1;
		padding-top: 220px;
		padding-bottom: 20px;
	}
	#pagetitle.detail h1 {
		padding-top: 145px;
		font-size: 3.6rem;
		padding-bottom: 10px;
	}

	#pagetitle .jp {
		font-size: 2.0rem;
		color: #fff;
		letter-spacing: 0.2em;
		line-height: 1;
	}

	#pagetitle .detail.jp {
		font-size: 1.6rem;
	}



/* title */
.title {
	margin-bottom: 40px;
}
	.title h2 {
		font-size: 5.0rem;
		letter-spacing: 0.15em;
		line-height: 1;
		padding-bottom: 10px;
	}

	.title .jp {
		font-size: 1.3rem;
		letter-spacing: 0.15em;
		line-height: 1;
	}


/* h2_tit */
.h2_tit {
	font-size: 2.8rem;
	line-height: 1.5em;
	padding-left: 14px;
	background: url("../img/icon_tit.png") no-repeat left 14px;
	margin-bottom: 15px;
}


/* h2_tit */
.h3_tit {
	font-size: 2.0rem;
	line-height: 1.4em;
	margin-bottom: 10px;
}


/* h2_tit */
.h4_tit {
	padding-top: 10px;
	font-size: 1.7rem;
	line-height: 1.4em;
}


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
	width: 100%;
	background: #362E2E;
	padding: 50px 100px 45px 0;
}
#footer .inner_max {
	padding: 0 5%;
}
	#footer .text {
		width: 400px;
	}
		#footer .text .logo {
			position: relative;
		}
			#footer .text .logo a {
				display: block;
			}
				#footer .text .logo a img {
					width: 200px;
					height: auto;
				}

			#footer .text .logo .name {
				display: block;
				font-size: 1.6rem;
				letter-spacing: 0.1em;
				line-height: 1.4em;
				color: #fff;
				position: absolute;
				top: -8px;
				left: 220px;
			}
				#footer .text .logo .name span {
					font-size: 1.2rem;
				}

		#footer .text .access {
			padding-top: 20px;
			padding-left: 57px;
			font-size: 1.1rem;
			color: #fff;
			letter-spacing: 0.06em;
		}


	#footer .info {
		padding-top: 20px;
		width: -webkit-calc(100% - 400px);
		width: calc(100% - 400px);
	}
		#footer .info .link {
			text-align: right;
		}
			#footer .info .link a {
				font-size: 1.4rem;
				color: #fff;
			}


		#footer .info .copyright {
			padding-top: 30px;
			font-size: 1.0rem;
			text-align: right;
			color: #fff;
			letter-spacing: 0.06em;
			opacity: 0.3;
		}







/* 1380px */
@media screen and (max-width: 1380px) {
	

/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */


.inner {
	width: 100%;
	padding: 0 5%;
	z-index: 10;
}
	
	
	
}






/* 1024px */
@media screen and (max-width: 1024px) {


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
	padding: 50px 100px 25px 0;
}
#footer .inner_max {
	display: block;
}
	#footer .text {
		width: 100%;
	}
		#footer .text .logo {
			position: relative;
			text-align: center;
		}
			#footer .text .logo a {
				display: block;
			}

			#footer .text .logo .name {
				position: static;
				padding-top: 10px;
			}

		#footer .text .access {
			padding-top: 20px;
			padding-left: 0;
			font-size: 1.1rem;
			text-align: center;
		}


	#footer .info {
		width: 100%;
		padding-top: 0;
	}
		#footer .info .link {
			display: none
		}
		#footer .info .copyright {
			padding-top: 30px;
			text-align: center;
		}






}

	







/* max 767px */
@media screen and (max-width: 767px) {


.sp {
	display: block;
}
.pc {
	display: none;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header {
	width: 100%;
	background: #fff;
	height: 60px;
	position: fixed;
	z-index: 100;
}
	#header .logo {
		position: absolute;
		top: 20px;
		left: 15px;
		z-index: 100001;
	}
		#header .logo a {
			display: block;
		}
			#header .logo a img {
				width: 120px;
				height: auto;
			}

		#header .logo .name {
			width: 120px;
			font-size: 1.4rem;
			line-height: 1.2em;
			letter-spacing: 0;
			color: #000;
			left: 130px;
		}
			#header .logo .name span {
				font-size: 1.0rem;
			}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* サイドナビ */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#sidenav {
	display: none
}
	



	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */


/* main */
#main {
	padding-top: 80px;
	padding-right: 0;
	padding-bottom: 80px;
}


/* set */
.set {
	padding-bottom: 60px;
}
	.set .cell {
		margin-bottom: 25px;
		padding-bottom: 25px;
	}

	.set .list_icon {
		padding-top: 10px;
	}
		.set .list_icon li {
			font-size: 1.4rem;
			line-height: 1.8em;
		}
		.set .list_icon li:before {
			top: 9px;
		}

	.set ol.NoList {
		list-style-type: decimal;
		margin-top: 10px;
		padding-left: 30px;
		line-height: 25px;
	}
		.set ol.NoList li {
			padding-left: 10px;
			font-size: 1.3rem;
			position: relative;
		}


	
	.set .column3 li {
		width: 32%;
		margin-right: 2%;
		margin-bottom: 30px;
	}
	.set .column3 li:nth-child(3n) {
		margin-right: 0;
	}

	
	.set .column4 li {
		width: 49%;
		margin-right: 2%;
		margin-bottom: 30px;
	}
	.set .column4 li:nth-child(2n) {
		margin-right: 0;
	}


/* txt */
.txt {
	font-size: 1.4rem;
	line-height: 2em;
}


/* btn */
.btn {
	width: 80%;
	margin: auto;
}


/* sns */
#sns {
	padding-right: 0;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 下層タイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */

/* pagetitle */
#pagetitle {
	height: 250px;
}
#pagetitle.detail {
	height: 200px;
}
	#pagetitle h1 {
		font-size: 3.0rem;
		padding-top: 125px;
		padding-bottom: 10px;
	}
	#pagetitle.detail h1 {
		font-size: 3.0rem;
		padding-top: 100px;
	}

	#pagetitle .jp {
		font-size: 1.6rem;
	}
	#pagetitle.detail.jp {
		font-size: 1.6rem;
	}

/* title */
.title {
	margin-bottom: 30px;
	text-align: center;
}
	.title h2 {
		font-size: 3.6rem;
	}

	.title .jp {
		font-size: 1.2rem;
	}


/* h2_tit */
.h2_tit {
	font-size: 2.4rem;
	background: url("../img/icon_tit.png") no-repeat left 10px;
}


/* h2_tit */
.h3_tit {
	font-size: 2.0rem;
}


/* h2_tit */
.h4_tit {
	font-size: 1.5rem;
}


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
	padding: 50px 0 25px 0;
}




}






.fadein {
    opacity : 0;
    transform : translate(0, 50px);
    transition : all 1000ms;
 }
.fadein.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}