@charset "utf-8";

/* common
****************************************************/
*{ margin:0; padding:0; word-break:break-all; word-wrap:break-word; box-sizing: border-box; }
body{ font-size:18px; line-height:180%; color:#333; font-family: "UD新ゴ", "R/UD新ゴ M", sans-serif; }
img{ border:none; font-size:0; vertical-align:top; }
ul{ list-style-type:none; }
a{ text-decoration:none; color:#333; }
a:hover{ text-decoration:none; }
/*a:hover img{ opacity: 0.5; transition:all 0.3s ease; }*/
h1{ font-size:12px; font-weight:normal; }
address{ font-style: normal; }

/* margin
****************************************************/
.mt10, .mt10ul li{ margin-top:10px; }
.mt20, .mt20ul li{ margin-top:20px; }
.mt30, .mt30ul li{ margin-top:30px; }
.mt40, .mt40ul li{ margin-top:40px; }
.mt50{ margin-top:50px; }
.mt60{ margin-top:60px; }
.mt75{ margin-top:75px; }
.mt100{ margin-top:100px; }
.mt150{ margin-top:150px; }
.mt1em{ margin-top: 1em; }
.mt2em{ margin-top: 2em; }

/* text-align
****************************************************/
.tar{ text-align:right; }
.tac{ text-align:center; }
.tal{ text-align:left; }
.ti1{ text-indent:1em; }
.ti2, .ti2ul li{ text-indent:-1em; padding-left:1em; }
.ti3, .ti3ul li{ text-indent:-1.5em; padding-left:1.5em; }

/* color
****************************************************/
.col_red{ color:red; }
.col_white{ color:white; }
.col_bleck{ color:black; }
.col1, .col1ul li:before, .col1icon:before{ color: #0D1E5F; }

/* background
****************************************************/
/* color */
.bg1col{ background-color: #0D1E5F; }
.bg2col{ background-color: #EFF2F5; }

/* icon
****************************************************/
.icon1:before, .icon1ul li:before, .icon1dl dt:before{ content:"▶"; margin-right: .5em; }
.icon2:before, .icon2ul li:before, .icon2dl dt:before{ content:"●"; margin-right: .5em; }
.icon3:before, .icon3ul li:before, .icon3dl dt:before{ content:"■"; margin-right: .5em; }
.icon4:before, .icon4ul li:before, .icon4dl dt:before{ content:"◆"; margin-right: .5em; }
.icon5:before, .icon5ul li:before, .icon5dl dt:before{ content:"▲"; margin-right: .5em; }
.icon6:before, .icon6ul li:before, .icon6dl dt:before{ content:"※"; margin-right: .5em; }

/* font-size
****************************************************/
.fs_s{ font-size:small; }
.fs26{ font-size:26px; }

/* border-radius
****************************************************/
.br05, .br05ul li{ border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px; }
.br10, .br10ul li{ border-radius:10px; -webkit-border-radius:10px; -moz-border-radius:10px; }
.br15, .br15ul li{ border-radius:15px; -webkit-border-radius:15px; -moz-border-radius:15px; }
.br25, .br25ul li{ border-radius:25px; -webkit-border-radius:25px; -moz-border-radius:25px; }
.br50{ border-radius:50px; -webkit-border-radius:50px; -moz-border-radius:50px; }

/* list-style
****************************************************/
.ls_adj{ margin-left: 1em; }
.ls_disc{ list-style:disc; margin-left: 1.5em; }

/* column
****************************************************/
.ofh1, .ofh2{ overflow: hidden; }
.ofh1 .fl, .ofh2 li{ float: left; }
.ofh1 .fr{ float: right; }
/* flexBox */
[class*="fbCom"]{ display: flex; flex-wrap: wrap; }
.fbCom1{ justify-content: space-between; }

/* list
****************************************************/
.lst1c li{ padding-left: 50px; overflow:hidden; }
.lst1c li span{ display:block; float:left; margin-left: -50px; }

/* headline
****************************************************/
.hl1{ border-bottom: 2px solid #0D1E5F; text-align: center; color: #0D1E5F; padding-bottom: .5em; }

/* sitemap
****************************************************/
#sitemap li a:before{ content: '●'; color: #0D1E5F; margin-right: .5em; }

/* 404
****************************************************/
.error404{ text-align:center; color:red; padding:100px 0; }
.standby{ text-align:center; padding:100px 0; }

/* breadcrumbs
****************************************************/
.breadcrumbs ol{ list-style: none; overflow: hidden; font-size: 12px; }
.breadcrumbs li{ float: left; }
.breadcrumbs li::after{ content: '>'; display: inline-block; padding: 0 10px; }
.breadcrumbs li:last-child::after{ display: none; }

/* link & button & band
****************************************************/
[class*="lnk"]{ transition : all 0.75s; display: inline-block; }
[class*="lnk"]:hover{ opacity: .8; transition : all 0.75s; }
.lnk1btn{ background-color: #0D1E5F; color: #fff; position: relative; line-height: 20px; padding: 29px 0; border: 1px solid #0D1E5F; }
.lnk1btn:after{
	content: "〉";
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -9px;
}
.lnk1btn:hover{ background-color: #EFF2F5; color: #0D1E5F; }


/* page title
****************************************************/
[class*="ppTtl"]{
	background: url(images/midashi@2x.png) no-repeat center center #FFF5D3;
	background-size:cover;
	color: #fff;
	text-align: center;
}

/* notice
****************************************************/
#notice{ height:100%; overflow:auto; }
#notice::-webkit-scrollbar {
	all:unset;
	width:6px;
	background:transparent;
}
#notice::-webkit-scrollbar-track {
	all:unset;
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.2);
	background: transparent;
}
#notice::-webkit-scrollbar-thumb {
	all:unset;
	background:#0D1E5F;
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.2);
	border-radius: 8px;
}
#notice::-webkit-scrollbar-thumb:hover {
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.5);
	background: transparent;
}
#notice li{ margin: 10px 0; }

/* about
****************************************************/
#about dt{ color: #0D1E5F; font-size: 21px; }
#about dd{ margin:15px 15px 50px; }





/**************************************************

	600px over

**************************************************/
@media only screen and (min-width:600px), print{

	/* common
	****************************************************/
	.wrap{ margin-left: auto; margin-right: auto; width: 1000px; }
	.sp{ display: none!important; }

	/* header
	****************************************************/
	header{ width: 100%; position: fixed; z-index: 99999; }
	header .inner{ padding: 10px 0 0 20px; color: #fff; }
	.mvIndex{ background: url("images/main@2x.png") no-repeat center; background-size: cover; height: 100vh; }
	
	/* overflow:hidden;
	****************************************************/
	.ofh1pc, .ofh2pc{ overflow:hidden; }
	.ofh1pc .fl, .ofh2pc li{ float:left; }
	.ofh1pc .fr{ float:right; }
	/* flexBox */
	[class*="fbPc"]{ display: flex; flex-wrap: wrap; }
	.fbPc1{ justify-content: space-between; }
	.fbPc2{ justify-content: center; }

	/* width
	****************************************************/
	.w300{ width: 300px; }
	.w650{ width: 650px; }
	
	/* contents
	****************************************************/
	.spa1com{ padding: 120px 0; }
	.spa2com{ padding-bottom: 120px; }
	#index .sec1 .fbPc1{ align-items: center; }
	#index .sec1 .lef{ background-color: #0D1E5F; color: #fff; width: 220px; text-align: center;  align-items: center; }
	#index .sec1 h2{ display: flex; align-items: center; justify-content:center; height: 220px; }
	#index .sec1 .rig{ width: 760px; border: 1px solid #0D1E5F; padding: 20px 30px; height: 220px; }
	
	/* nav
	****************************************************/
	.gNav{ background-color: #0D1E5F; display: flex; align-items: center; padding-top: 120px; }
	.gNav a{ color: #fff; font-size: 30px; }
	.gNav .rig{ width: 50%; }
	.gNav ul{ padding: 0 5%; }
	.gNav li{ padding: 1em 0; text-align: center; }
	.gNav .lef{ width: 50%; height: 100%; background: url("images/menuBg.png") no-repeat center center; background-size: cover; }

	/* page title
	****************************************************/
	[class*="ppTtl"]{
		height: 500px;
		font-size: 38px;
		line-height: 50px;
		padding-top: 225px;
	}
	
	/* content
	****************************************************/
	/* common */
	.spaCont{ padding: 60px 0 100px; }
	#index .sec2 .txt{ width: 50%; padding: 100px 40px 0; }
	#index .sec2 .img{ height: 400px; width: 50%; background-size: cover; background-repeat: no-repeat; background-position: center; }
	#index .sec2 .box1 .img{ background-image: url("images/top_image01.png"); border-radius: 0 25px 25px 0; }
	#index .sec2 .box2 .img{ background-image: url("images/top_image02.png"); border-radius: 25px 0 0 25px; order: 1; }
	#index .sec2 .box3 .img{ background-image: url("images/top_image03.png"); border-radius: 0 25px 25px 0; }
	#index .sec3{ padding: 75px 0; }
	#index .sec3 .w650{ background: url("images/top_toi01@2x.png") no-repeat bottom right / auto 100%; padding-top: 20px; }
	/* contents */
	.cont1{ padding: 30px; }
	.cont1 dt, .cont1 dd{ border-bottom: 1px solid #81A8D0; padding: .5em; }
	.cont1 dt{ width: 25%; }
	.cont1 dd{ width: 75%; }
	.cont2{ background: url("images/toi_illust@2x.png") no-repeat left center / 480px 240px; height: 240px; padding-left: 50%; }
	
	/* sitemap
	****************************************************/
	#sitemap ul{ margin-top: -1em; }
	#sitemap li{ padding-top: 1em; }
	
	/* footer
	****************************************************/
	footer .sec1{ padding: 30px 0; }
	footer .sec1 .fbPc1{ align-items: center; }
	footer .sec2{ justify-content: center; padding: .5em 0; }
	footer .sec2 li{ margin: 0 1em; }
	address{ font-size: 14px; padding: .5em; }
	
	/* breadcrumbs
	****************************************************/
	.breadcrumbs ol{ margin: 5px 0 0 0; }
}





/**************************************************

	600px under

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

	/* common
	****************************************************/
	body{ font-size:16px; }
	.wrap{ padding: 15px; line-height: 1.5em; }
	img{ max-width:100%; height:auto; }
	.pc{ display:none!important; }
	.tacSp{ text-align:center; }
	
	/* overflow:hidden;
	****************************************************/
	.oh_clm2sp, .oh_clm3sp, .oh_sp{ overflow:hidden; }
	.oh_clm2sp li{ width: 48%; }
	.oh_clm3sp li{ width: 32%; margin-right: 2% !important; margin-top: 2% !important; }
	.oh_clm3sp li:nth-child(3n){ margin-right: 0 !important; }
	.oh_sp .fl, .oh_clm2sp li:nth-child(odd), .oh_clm3sp li{ float: left; }
	.oh_sp .fr, .oh_clm2sp li:nth-child(even), .oh_clm3sp li:nth-child(3n){ float: right; }
	
	/* link botton
	****************************************************/
	.lnk1btn{ width: 80%; }
	
	/* margin
	****************************************************/
	.mt150{ margin-top: 60px; }
	.mt1emSp{ margin-top: 1em; }
	
	/* nav
	****************************************************/
	header{ width:100%; position:fixed; top: 0px; left: 0px; z-index: 999; }
	header .inner{ padding: 0 20px; width: 70%; }
	.mvIndex{ background: url("images/SP_main@2x.png") no-repeat center; background-size: cover; height: 100vh; }
	h1{ color: #fff; padding-top: .5em; }
	.menu{ position:fixed; top: 0px; right: 0px; z-index: 999; }
	.gNav{ background-color: #0D1E5F; }
	.gNav a{ color: #fff; }
	.gNav ul{ padding: 10% 10% 0; margin-top: 15%; }
	.gNav li{ font-size: 20px; padding: 1em 0; text-align: center; }
	
	/* title
	****************************************************/
	[class*="ppTtl"]{
		background: url("images/sp_midashi@2x.png") no-repeat center;
		font-size: 27px;
		padding: 30% 0 15%;
		background-size: cover;
	}

	/* content
	****************************************************/
	.spaCont{ padding-top: 60px; padding-bottom: 60px; }
	#index .sec1 h2{ background-color: #0D1E5F; color: #fff; text-align: center; padding: .5em 0; }
	#index .sec1 .rig{ border: 1px solid #0D1E5F; padding: 15px; height: 220px; margin-top: 20px; }
	#index .sec1 .rig ul{ padding-right: 15px; }
	#index .sec2 .img{ width: 100%; background-size: cover; background-repeat: no-repeat; background-position: center; padding-top: 85%; }
	#index .sec2 .box1 .img{ background-image: url("images/top_image01.png"); }
	#index .sec2 .box2 .img{ background-image: url("images/top_image02.png"); }
	#index .sec2 .box3 .img{ background-image: url("images/top_image03.png"); }
	#index .sec2 .txt{ padding: 30px 15px; }
	#index .sec3{ padding: 50px 0; }
	#index .sec3 .mt20ul{ text-align: center; }
	#index .sec3 .w650{ margin-top: 40px; background: url("images/top_toi01@2x.png") no-repeat bottom center / 80% auto; padding-bottom: 65%; }
	/* contents */
	.cont1{ padding: 5px 20px 30px; }
	.cont1 dt{ border-bottom: 1px solid #81A8D0; padding: .5em; margin: 20px 0 .5em; }
	.cont2{ background: url("images/toi_illust@2x.png") no-repeat bottom center / 100% auto; padding-bottom: 60%; }

	/* footer
	****************************************************/
	footer .sec1 p{ padding: 10px 0; text-align: center; }
	footer .sec2{ padding: 10px 20px 20px; }
	footer .sec2 li{ width: 50%; margin-top: 10px; }
	address{ padding: 10px; font-size: 10px; line-height: 150%; }
	
	/* breadcrumbs
	****************************************************/
	.breadcrumbs ol{ font-size: 10px; }
	
	/* footerSp
	****************************************************/
	#footerSp{ width:100%; border-collapse:collapse; position:fixed; z-index:999; bottom:0px; left:0px; background-color: #289A46; border: 5px solid #289A46; }
	#footerSp tr td:nth-of-type(1){ width: 50%; border-right: 1px solid #EAFAFC; }
	#footerSp a{ display: block; text-align:center; padding: 10px 0; color: #fff; }
	
	/* form
	****************************************************/
	form dd{ margin-top: 10px; }
	form dd span{ display: block; margin-top: 10px; }

}

html{ overflow-x: hidden; }
/* nav */
.gNav{
	position: fixed;
	height: 100%;
	width: 100%;
	z-index: 998;
	transition: all 0.5s;
	right: -100%;
	top: 0;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
}
.gNav.active{ right: 0%; }
.gNavBk{
	position: fixed;
	background:rgba(0, 0, 0, .8);
	right: -100%;
	top: 0;
	height: 100%;
	width: 100%;
}
.gNavBk.active{ right: 0%; }
.gNav::-webkit-scrollbar{ display: none; }

/* menu
****************************************************/
.menu {
	position: relative;
	background: #0D1E5F;
	cursor: pointer;
	width: 80px;
	height: 90px;
	border: 1px solid #0D1E5F;
}
.menu span {
	display: inline-block;
	transition: all .4s;
	position: absolute;
	height: 2px;
	border-radius: 2px;
	background: #fff;
	width: 60%;
    left: 50%;
    transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.menu span:nth-of-type(1){ top:15px; }
.menu span:nth-of-type(2){ top:30px; }
.menu span:nth-of-type(3){ top:45px; }
.menu p{ position: absolute; bottom: 0; font-size: 10px; text-align: center; width: 100%; color: #fff; }
.menu .close{ display: none; }
.menu.active .open{ display: none; }
.menu.active .close{ display: inline-block; }

/* btn01
****************************************************/
#btn01.active span:nth-of-type(1) {
top: 24px;
left: 20%;
transform: translateY(6px) rotate(-45deg);
width: 60%;
}
#btn01.active span:nth-of-type(2) { opacity: 0; }
#btn01.active span:nth-of-type(3) {
top: 36px;
left: 20%;
transform: translateY(-6px) rotate(45deg);
width: 60%;
}
