@charset "utf-8";

/* common
****************************************************/
*{ margin:0; padding:0; word-break:break-all; word-wrap:break-word; box-sizing:border-box; }
body{ font-size: 19px; color: #333; font-family:"游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif; }
img{ border:none; font-size:0; vertical-align:top; }
ul{ list-style-type:none; }
h1{ font-size:12px; font-weight:normal; }
address{ font-style:normal; }
section p{ line-height: 200%; }
a{ text-decoration:none; color:#333; line-height: 100%; }
a:hover{ text-decoration:none; }

/* margin
****************************************************/
.mt0li li:first-child{ margin-top: 0; }
.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; }
.mt70{ margin-top:70px; }
.mt80{ margin-top:80px; }
.mt100{ margin-top:100px; }
.mb20{ margin-bottom: 20px; }
.mt1em{ margin-top: 1em; }
.mt2em{ margin-top: 2em; }
.adj1mt{ margin-top: 150px; }

/* 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
****************************************************/
.col1, .col1ul li:before, .col1icon:before{ color: #FFF; }
.col2, .col2ul li:before, .col2icon:before{ color: #001E62; }
.col3, .col3ul li:before, .col3icon:before{ color: #CF001B; }
/* background */
.bg1col{ background-color: #EFF9FF; }

/* icon
****************************************************/
[class*="icon"] li{ text-indent: -1.5em; padding-left: 1.5em; }
.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
****************************************************/
.fwB{ font-weight: bold; }
.fsS{ font-size: 22px; }
.fsM{ font-size: 26px; }
.fsL{ font-size: 30px; }
.fs12{ font-size: 12px; }
.fs16{ font-size: 16px; }
.fs19{ font-size: 19px; }
.lh200{ line-height: 200%; }

/* border-radius
****************************************************/
.br05, .br05ul li{ border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px; }
.br10, .br10ul li, .br10a a{ 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; }
.br30, .br30ul li{ border-radius: 30px; -webkit-border-radius: 30px; -moz-border-radius: 30px; }
.br50{ border-radius:50px; -webkit-border-radius:50px; -moz-border-radius:50px; }

/* list-style
****************************************************/
.lstAdj{ margin-left:1em; }
.lstDisc{ list-style:disc; margin-left:1em; }
.lst1c li{ background: url("images/01_pic10@2x.png") no-repeat left top 5px / 18px 18px; padding-left: 28px; }

/* 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; }
.fbComCen{ align-items: center; justify-content: center; align-content: center; }
.fbComCen2{ align-items: center; align-content: center; }

/* headline
****************************************************/
.pp1ttl, h1, h2, h3, h4, .gNav, footer .sec2{ font-family: "リュウミン M-KL", "Ryumin Medium KL"; line-height: 150%; }
.hl1{ background: url("images/hl1bg.png") no-repeat center bottom; padding-bottom: 15px; text-align: center; }
.hl2{ border-bottom: 1px solid #001E62; color: #001E62; padding-bottom: 10px; }
.hl3{ background-color: #80B3D3; color: #FFF; padding: 10px; }

/* page title
****************************************************/
.pp1ttl{
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #FFF;
}

/* link & button & band
****************************************************/
[class*="lnk"], .listLnk a{ transition : all 0.75s; display: inline-block; }
[class*="lnk"]:hover, .listLnk a:hover{ opacity: .8; transition : all 0.75s; }
.lnk1{ background-color: #FFF; border: 1px solid #525252; color: #333; padding-top: 14px; padding-left: 20px; line-height: 30px; position: relative; height: 60px; }
.lnk1:hover{ background-color: #001E62; border-color: #001E62; color: #FFF; opacity: 1; }
.lnk1:after {
	content: "＞";
	position: absolute;
	top: 50%;
	right: 20px;
	font-size: 20px;
	margin-top: -14px;
}
.lnk2{ background-color: #CF001B; color: #FFF; text-align: center; padding: 10px; }
.lnk3{
	background: url("images/01_button@2x.png") no-repeat center center / 328px 100px;
	width: 328px;
	height: 100px;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	align-content: center;
	font-weight: bold;
}

/* content
****************************************************/
/* common */
.posRelCom{ position: relative; }
.pad10{ padding: 10px; }
.pad30{ padding: 30px; }
.pad40{ padding: 40px; }
.box1c{ background-color: #001E62; color: #fff; }
.box2c{ border: 1px solid #707070; }
.box3c{ border: 1px solid #001E62; }
.box4c{ padding: 25px 80px; }
/* index */
#index .sec1 .lnk2{ width: 100px; }
#index .sec1 .w714 li{ border-bottom: 2px dotted #B2B2B2; padding: 20px; }
.posts li a{ display: block; border-bottom: 2px dotted #DDD; padding: 30px 0; }
#single .hl2{ margin-bottom: 30px; }

/* site
****************************************************/
#site dt:before{ content:"▶ "; color: #CF001B; }
#site dd{ margin:15px 15px 50px; }

/* sitemap
****************************************************/
.wsp-pages-list li, #sitemap p{ margin-bottom: 30px; }
.wsp-pages-list li:before, #sitemap p:before{ content:"▶"; color: #CF001B; margin-right:.5em; }
.wsp-pages-list .children{ overflow: hidden; }
.wsp-pages-list .children li{ float: left; width: 25%; margin: 20px 0 0; }
.wsp-pages-list .children li:before{ content: ""; }
.wsp-pages-list li a:hover{ text-decoration: underline; }

/* footer
****************************************************/
footer{ border-top: 1px solid #B4B4B4; }
footer .sec2 *{ color: #333; }
address{ padding: 10px 0; text-align: center; font-size: 16px; color: #FFF; background-color: #001E62; }

/* 404
****************************************************/
#error404{ text-align:center; color:red; 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; }

/* pagetop
****************************************************/
.pagetop{
	display:none;
	position:fixed;
	bottom:5px;
	right:10px;
	z-index: 2;
}
.pagetop a{
	display:block;
	padding:5px;
	background-color: #001E62;
	border-radius:5px;
	opacity:.5;
}
.pagetop a:hover, .pagetop a:hover img{ opacity:1.0; }



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

	600px over

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

	/* common
	****************************************************/
	.wrap{ margin-left: auto; margin-right: auto; width: 1100px; }
	.sp{ display: none!important; }
	/* margin */
	.mt1adj{ margin-top: 150px; }
	/* list */
	.lst1pc li{ padding-left: 150px; overflow:hidden; }
	.lst1pc li span{ display: block; float: left; width: 150px; margin-left: -150px; }

	/* 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; }

	/* width
	****************************************************/
	.w300{ width: 300px; }
	.w328, .w328ul li{ width: 328px; }
	.w520, .w520ul li{ width: 520px; }
	.w714{ width: 714px; }

	/* main
	****************************************************/
	.mv img{ width: 100%; height: auto; }
	.pp1ttl{ background: url("images/title_back@2x.png") no-repeat center center / cover; height: 200px; }

	/* header
	****************************************************/
	header{ background: rgba(255, 255, 255, 1); min-width: 100%; min-height: 190px; position: fixed; top: 0px; left: 0px; z-index: 9; display: flex; justify-content: space-between; }
	@media only screen and (max-width: 1350px){ header{ width: 1350px; }}
	header .rig{ margin-left: 15px; margin-top: 5px; }
	header .rig img{ margin-top: 10px; }
	header .rig p{ margin-top: 10px; }
	header .lef{ position: relative; width: 820px; }
	header [class^="ads"]{ position: absolute; }
	header .ads1{ top: 40px; left: 0; }
	header .ads2{ top: 40px; left: 130px; }
	header .ads3{ top: 40px; left: 260px; }
	header .ads4{ top: 40px; left: 390px; }
	header .ads5{ top: 40px; right: 30px; }
	header .ads6{ top: 110px; right: 0; line-height: 30px; z-index: 99999; }

	/* nav
	****************************************************/
	.gNav{ line-height: 20px; }
	.gNav ul{ padding: 10px 0 10px 0; letter-spacing: -0.4em; }
	.gNav li{ display: inline-block; letter-spacing: normal; vertical-align: top; margin-right: 30px; }
	.gNav li ul li{ display: block; }
	.gNav ul a{ display: block; color: #333; padding: 15px 0 20px; }
	.gNav ul a:hover, .gNav ul .stay{ color: #CF001B; }
	/* parent　*/
	.gNav{ position: relative; }
	.gNav .parent:hover .typ1,
	.gNav .parent:hover .typ2{ visibility: visible; }
	.gNav .parent .typ1,
	.gNav .parent .typ2{
		font-size: 16px;
		visibility: hidden;
		position: absolute;
		top: 60px;
		right: 0;
		z-index: 9999;
		padding: 20px 15px 15px 30px;
		width: 1100px;
		background: rgba(255, 255, 255, 0.95);
		text-align: left;
		display: flex;
		flex-wrap: wrap;
	}
	.gNav .parent .typ1 li{ min-width: 22%; }
	.gNav .parent .typ1 a{ color: #333; width: 100%; }
	.gNav .parent .typ1 a:hover{ color: #CF001B; }
	.gNav .parent ul a:after{ content: "＞"; margin-left: 8px; }
	.gNav .parent .typ2 a{ padding: 10px 0; }

	/* content
	****************************************************/
	/* common */
	.spa1{ padding: 60px 0 150px; }
	.spa2{ padding: 90px 0 150px; }
	.spa3{ padding: 150px 0 150px; }
	.pc3clm li, .pc3clmD div{ margin-right: 58px; }
	.pc3clm li:nth-child(3n), .pc3clmD div:nth-child(3n){ margin-right: 0; }
	.pc5clm li{ min-width: 20%; padding-right: 5%; }
	.box4c li{ width: 33%; margin: 15px 0; }

	/* index */
	[class*="adsPc"]{ position: absolute; }
	#index .sec1{ padding: 60px 0; }
	#index .sec1 .adsPc1{ top: 0; right: 0; }
	#index .sec2{ padding: 60px 0; background: url("images/index2no1.png") repeat-x top center; }
	#index .sec2 .blk1{ background: url("images/01_pic01@2x.png") no-repeat center top / 1920px 440px; height: 440px; }
	#index .sec2 .blk1 .adsPc{ top: 140px; right: 0; }
	#index .sec3{ padding: 40px 0 100px; }
	#index .sec3 .blk1{ height: 275px; }
	#index .sec3 .blk1 li:first-child{ margin-top: 0; }
	#index .sec4{ background: url("images/01_pic11@2x.png") no-repeat top center / 1920px 1087px #EFF9FF; padding: 60px 0 100px; }
	#index .sec4 .w714{ margin-left: 386px; }
	#index .sec5{ padding: 60px 0 100px; }
	#index .sec5 .blk1{ background: url("images/01_pic13@2x.png") no-repeat center top / 1920px 440px; height: 440px; }
	#index .sec5 .blk1 .adsPc{ top: 140px; right: 0; }
	#index .sec5 .blk2{ background: url("images/01_pic14@2x_20250122.png") no-repeat center top / 1920px 440px; height: 440px; }
	#index .sec5 .blk2 .adsPc{ top: 140px; left: 0; }
	#index .sec5 .blk3{ background: url("images/01_pic15@2x.png") no-repeat center top / 1920px 440px; height: 440px; }
	#index .sec5 .blk3 .adsPc{ top: 140px; right: 0; }
	/* greeting */
	#greeting .sec1{ background: url("images/02_pic01@2x.png") no-repeat top center / 1920px 730px; }
	#greeting .sec1 .w714{ margin-left: 386px; }

    /* sitemap
	****************************************************/
	#sitemap .child{ overflow:hidden; }
	#sitemap .child li{ float:left; width: 25%; }

	/* footer
	****************************************************/
	footer .sec1, footer .sec1 .fbPc1{ padding-top: 60px; }
	footer .sec1 .lef, footer .sec1 .rig{ width: 520px; }
	footer .sec1 .lef .box{ width: 520px; float: right; }
	footer .sec1 .lef .box .box1c{ width: 478px; margin: 95px auto 0; }
	footer .sec1 .rig .box{ width: 520px; }
	footer .sec2{ font-size: 16px; text-align: center; padding: 20px 100px; }
	footer .sec2 .fbCom1{ justify-content: center; }
	footer .sec2 a{ display: block; padding: 10px; }

	/* tracking
	****************************************************/
	.trk1{ position: fixed; top: 200px; right: 0px; }

	/* breadcrumbs
	****************************************************/
	.breadcrumbs ol{ margin: 5px 0 0 0; }

	/* gmap
	****************************************************/
	.gmap{
		width: 100%;
		position: relative;
		padding-bottom: 600px;
		height: 0;
		overflow: hidden;
	}
	.gmap iframe, .gmap object, .gmap embed{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 600px;
	}

	/* tracking
	****************************************************/
	[class*="trk"]{ position: fixed; transition: all 1s; z-index: 2; }
	[class*="trk"] a{ display: flex; }
	[class*="trk"] a:hover{ opacity: 1; }
	[class*="trk"]:hover{ right: 0; opacity: .6; }
	.trk1{ top: 190px; right: 0; }
	.trk2{ top: 320px; right: 0; }
	.trk3{ top: 450px; right: 0; }
	.trk4{ top: 580px; right: 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; }
	.sp_tac{ text-align:center; }

	/* font-size
	****************************************************/
	.fsS{ font-size: 19px; }
	.fsM{ font-size: 22px; }
	.fsL{ font-size: 26px; }

	/* 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
	****************************************************/
	.lnk1btn, .lnk2btn, .lnk3btn, .lnk4btn{ display: block; }
	.lnk1{ width: 80%; }

	/* nav
	****************************************************/
	html{ overflow-x: hidden; }
	#headerSp{ width:100%; background-color: #fff; position:fixed; top: 0px; left: 0px; z-index: 999; }
	#headerSp .inner{ padding: 15px 10px 10px; }
	#headerSp .logo{ margin: 0 80px 10px 0; }
	#headerSp table{ width:100%; border-collapse: separate; border-spacing: 5px; }
	#headerSp th{ background-color: #001e62; color: #FFF; text-align: center; padding: 5px 0; }

	/* nav */
	.gNav{
		background:rgba(255, 255, 255, 1);
		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%; }
	.gNav li{ border-bottom: 1px solid #B4B4B4; }
	.gNav li a{ display: block; padding: 15px; color: #463D35; }
	.gNavBk{
		position: fixed;
		background:rgba(0, 0, 0, .8);
		right: -100%;
		top: 0;
		height: 100%;
		width: 100%;
	}
	.gNavBk.active{ right: 0%; }
	/* 追記 */
	/* accordion */
	.gNav .parent .typ1,
	.gNav .parent .typ2{ display: none; background-color: #EAEAEA; margin-top: 0; }
	.gNav .parent .typ1 li,
	.gNav .parent .typ2 li{ border-top: 1px solid #B4B4B4; border-bottom: none; }
	.gNav .parent .typ1 a{ border-bottom: none; margin: 0!important; padding: 15px; color: #333; }
	.gNav .parent .typ1 a:after,
	.gNav .parent .typ2 a:after,
	.gNav .parent .hl2:after{ content: "＞"; margin-left: .5em; }
	.gNav .switch{ cursor:pointer; display: block; position: relative; }
	.gNav .switch a{ pointer-events: none; }
	.gNav .switch:after{ content: url("images/sp_nav1bg.png"); position: absolute; right: 10px; top: 50%; transform: translateY(-50%); }
	.gNav .switch.active:after{ content: url("images/sp_nav2bg.png"); color: #FFF; }
	.gNav .switch.active{ background-color: #CF001B; color: #FFF; }
	.gNav .switch.active a{ color: #FFF; }
	.gNav .hl2{ background-color: #DAEBF5; border: none; padding: 15px; }

	/*=============================
	.btn-trigger
	=============================*/
	.btn-trigger {
		position: fixed;
		top: 10px;
		right: 10px;
		z-index: 9999;
		background: #001E62;
		cursor: pointer;
		width: 50px;
		height:50px;
		border: 1px solid #001E62;
	}
	.btn-trigger span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
	background: #fff;
  	width: 45%;
	}
	.btn-trigger span:nth-of-type(1){ top:15px; }
	.btn-trigger span:nth-of-type(2){ top:23px; }
	.btn-trigger span:nth-of-type(3){ top:31px; }

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

	/* title
	****************************************************/
	.pp1ttl{ background: url("images/sp_title_back@2x.png") no-repeat center center /cover; height: 150px; }

	/* content
	****************************************************/
	/* common */
	.spa1, .spa2, .spa3{ padding-top: 30px; padding-bottom: 100px; }
	.pa40{ padding: 20px; }
	.box4c{ padding: 0 15px 15px; }
	.box4c li{ margin-top: 15px; }
	/* index */
	#index .sec1{ margin-top: 30px; padding-bottom: 50px; }
	#index .sec1 .adsPc1{ text-align: center; margin-top: 30px; }
	#index .sec1 .w328{ text-align: center; margin-top: 50px; }
	#index .sec2{ padding-top: 20px; padding-bottom: 50px; }
	#index .sec2 .blk1 .adsPc{ background-color: #001E62; padding: 30px 15px; margin: 20px -15px 0; }
	#index .sec2 .blk2{ margin-top: 30px; }
	#index .sec2 .blk2 li{ width: 50%; background-color: red; }
	#index .sec2 .blk2 li a{ display: block; }
	#index .sec2 .blk3{ justify-content: space-between; }
	#index .sec2 .blk3 li{ width: 49%; margin-top: 10px; }
	#index .sec2 .blk3 .lnk3{ background: url("images/sp_01_button@2x.png") no-repeat center center / contain; width: 100%; padding: 15px; line-height: 150%; }
	#index .sec3{ padding-bottom: 50px; }
	#index .sec3 li{ margin-top: 10px; }
	#index .sec3 li:first-child{ margin-top: 0; }
	#index .sec3 figure img{ width: 100%; }
	#index .sec4{ background-color: #EFF9FF; padding: 50px 0; }
	#index .sec4 .blk1{ margin: 50px -15px 0; }
	#index .sec4 .tar{ text-align: left; }
	#index .sec5{ padding-top: 50px; margin-bottom: -15px; }
	#index .sec5 .mt100{ margin-top: 50px; }
	#index .sec5 .adsPc{ background-color: #001E62; padding: 30px 15px; margin: 20px -15px 0; }
	/* greeting */
	#greeting .sec1 .blk1{ margin: 0 -15px 30px; }
	#greeting .sec1 .tar{ text-align: left; }

	/* footer
	****************************************************/
	footer .sec1 h3{ padding: 30px 0; }
	footer .sec1 .gmap{ margin-bottom: 30px; }
	footer .sec2{ padding: 15px; border-top: 1px solid #B4B4B4; margin-top: 15px; line-height: 200%; }
	footer .sec2 li{ width: 50%; }

	/* breadcrumbs
	****************************************************/
	.breadcrumbs ol{ font-size: 10px; }

	/* gmap
	****************************************************/
	.gmap{
		position: relative;
		padding-bottom: 80%;
		height: 0;
		overflow: hidden;
		margin-top: 20px;
	}
	.gmap iframe, .gmap object, .gmap embed{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}

	/* footerSp
	****************************************************/
	#footerSp{ width: 100%; border-collapse: collapse; position: fixed; z-index: 990; bottom: 0; left: 0; }
	#footerSp tr td:nth-of-type(1){ width: 12.5%; background-color: #001E62; }
	#footerSp tr td:nth-of-type(2){ width: 25%; background-color: #CF001B; }
	#footerSp tr td:nth-of-type(3){ width: 25%; background-color: #333333; }
	#footerSp tr td:nth-of-type(4){ width: 25%; background-color: #80B3D3; }
	#footerSp tr td:nth-of-type(5){ width: 12.5%; background-color: #FFF; }
	#footerSp tr td:nth-of-type(5) a{ border: 1px solid #333333; }
	#footerSp a{ display: block; text-align:center; padding: 7.5px 0; color: #FFF; }
	#footerSp img{ vertical-align: -10px; }
}