@charset "UTF-8";

/* reset */

html, body, div, span, iframe,p,
h1,h2,h3,h4,h5,h6,
a, em, font, img, strong, sub, sup,
dl, dt, dd, ol, ul, li, fieldset,
label, table, caption, tr, td {
	text-align: left;
	line-height: 1;
	margin: 0;
	padding: 0;
	border: none;
	outline: none;
	list-style:none;
	text-decoration: none;
}

html {
	font-size: 62.5%; 
    scroll-behavior: smooth;
	*scroll-padding-top: 62px;
}
img,video {
	max-width: 100%;
	height: auto;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

.clearfix:after {
	content: "";
	display: block;
	clear: both;
}

.clearfix { zoom: 1; }


* {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
}



body {
	color: #666;
	font-size: 1.6rem;
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Meiryo", "Yu Gothic", sans-serif;
	line-height: 1.6;
}

h1 { font-weight: 500; }
strong { font-weight: 500; }



/* -----　ヘッダー　-------------------------- */


header {
	position: fixed !important;
	width: 100%;
	height: 60px;
	margin-top: -60px;
	background: #fff;
	z-index:100; 
	transition: .5s;
	border-bottom: 1px solid #70AEE0;
}

header > .inner > ul {
	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
}

header > .inner > ul > li:nth-child(1) { padding: 21px 0 21px; }

header > .inner > ul > li:nth-child(1) a {
	color: #3789CB;
	transition:0.5s;
}

header > .inner > ul > li:nth-child(1) a:hover {
	opacity:0.6;
	transition:0.5s;
}

header .inner > ul > li.navB { display: none; }



/* SPグローバルナビ */

header nav {
	position: fixed;
	top: 0;
	right: -100%;
	width: 100%;
	height: 100%;
	text-align: left;
	padding: 0;
	background: rgba(255,255,255,1);
	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
	z-index: 100;
}

#navToggle {
	position: fixed;
	top: 10px;
	right: 10px;
	width: 40px;
	height: 40px;
	text-align: center;
	padding: 9px;
	background: none;
	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
	cursor: pointer;
	z-index: 999;
}

#navToggle div {
	position:relative;
	margin-bottom:10px;
}

#navToggle div span {
	display:block;
	position:absolute;/*to div*/
	width:100%;
	border-bottom:solid 2px #333;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
}

#navToggle div span:nth-child(1) { top:0; }
#navToggle div span:nth-child(2) { top:9px; }
#navToggle div span:nth-child(3) { top:18px; }

/* Click Toggle(Button) */
.openNav #navToggle span.menu { display:none; }
.openNav #navToggle div span:nth-child(1) {
	top: 9px;
	border-bottom:solid 2px #fff;
	-webkit-transform:rotate(-45deg);
	-moz-transform:rotate(-45deg);
	transform:rotate(-45deg);
}
.openNav #navToggle div span:nth-child(2),
.openNav #navToggle div span:nth-child(3) {
	top: 9px;
	border-bottom:solid 2px #fff;
*	-webkit-transform:rotate(45deg);
*	-moz-transform:rotate(45deg);
	transform:rotate(45deg);
}

/*header menu*/
.openNav #navToggle { background: none; }
.openNav nav {
	background: #065A9B;
	-moz-transform: translateX(-100%);
	-webkit-transform: translateX(-100%);
	transform: translateX(-100%);
}

header nav > a {
	display: block;
	width: 310px;
	height: 60px;
	color: #fff;
	padding: 21px 0 20px 19px;
	transition:0.5s;
}

header nav > a:hover {
	opacity:0.6;
	transition:0.5s;
}

header nav > ul {
	height: 100%;
	overflow: auto;
	border-top: 1px solid #fff;

}

header nav ul li.more-icon { background: url(/img/common/fmk_plus.png) 93% 18px no-repeat; }
header nav ul li.close-icon { background: url(/img/common/fmk_minus.png) 93% 18px no-repeat; }

header nav ul > li > a {
	display: block;
	color: #fff;
	font-size: 14px;
	line-height: 1;
	text-decoration: none;
	padding: 20px;
	border-bottom: 1px solid #fff;
}

header nav ul li > ul {
	display: none;
	border-bottom: 1px solid #fff;
}

header nav ul li > ul > li > a {
	padding: 15px 10px 15px 32px;
	border-bottom: 1px dotted #fff;
}
header nav ul li > ul > li:last-child > a { border-bottom: none }

header nav ul > li > a:hover,
header nav ul li > ul > li > a:hover { background: #d74f4f; }

header nav ul > li.more-icon > a:hover { background: #d74f4f url(/img/common/fmk_plus.png) 93% 18px no-repeat; }
header nav ul > li.close-icon > a:hover { background: #d74f4f url(/img/common/fmk_minus.png) 93% 18px no-repeat; }



/* SPコンテンツSlide */
header > .inner > ul.openNav,
section.openNav,
footer.openNav {
	-moz-transform: translateX(-100%);
	-webkit-transform: translateX(-100%);
	transform: translateX(-100%);
}




.inner { padding:0 20px; }


#title {
	width: 100%;
	background: url(/img/common/h1_bg.png);
	margin: 60px 0;
	padding: 40px 0 30px;
}

#title .tlinner { position: relative; }

#title h1 {
	color: #3789CB;
	font-size: 2.8rem;
	line-height:1.3;
	margin: 0 0 20px;
	padding: 10px 10px 15px;
	background: #fff;
	border-bottom: 3px solid #D2DDE6;
}

#title h1 p { line-height:1.3; }
#title h1 span {
	color: #666;
	font-size: 1.6rem;
}



/* -----　フッター　-------------------------- */

footer {
	color: #fff;
	margin: 60px 0 0;
	padding: 32px 0 0;
	background: #065A9B;
/*	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
*/
}

footer #toTop { position: relative; }

footer #toTop a {
	display: none;
	position: fixed;
	right: 0;
	bottom: 10px;
	padding: 0;
	z-index: 8;
	transition: 0.5s;
}
footer #toTop a:hover {
	opacity: 0.8;
	transition: 0.5s;
}

/*固定
footer #toTop a.fix-animation {
	position: absolute;
	right: 0;
	bottom: 10px;
}
*/




footer #fNavBl {
	line-height: 1.7;
	margin: 0 0 2em;
	padding: 0;
}

footer #fNavBl > ul > li {
	display: block;
	width:100%;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1;
	margin: 0;
	padding: 20px 10px;
	border-bottom: 1px solid #fff;
	cursor: pointer;
}
footer #fNavBl > ul > li.ttl {
	font-size: 2rem;
	text-align: center;
	padding: 20px 0;
}

footer #fNavBl > ul > li.more-icon { background: url(/img/common/fmk_plus.png) 97% 18px no-repeat; }
footer #fNavBl > ul > li.close-icon { background: url(/img/common/fmk_minus.png) 97% 18px no-repeat; }

footer #fNavBl > ul > li > ul { margin: 20px 10px 0 1em; }

footer #fNavBl > ul > li > ul > li:last-child { padding: 0; }

footer #fNavBl > ul > li > ul > li.useSP { display: list-item !important; }

footer #fNavBl > ul > li > ul > li > a {
	display: block;
	color: #fff;
	font-size: 1.4rem;
	font-weight: normal;
	padding: 10px 0;
}

/*
footer #fNavBl > ul > li:last-child { *padding: 0; }
footer #fNavBl > ul > li:last-child a {
	display: inline-block;
	width: 10em;
	padding: 10px 0 0;
	float: left;
}
*/


footer #fCopyBl {
	width: 100%;
	color: #000;
	font-size: 14px;
	text-align: center;
	padding: 20px 0;
	background: #fff;
}

footer a { color: #fff; }



section { transition: .5s ease-in-out; }
.useSP { display: block; }
.usePC { display: none; }

a { color: #0071E3; }



ul.btBl {
	width: 270px;
	margin: 2em auto 3em;
}
ul.btBl li {
	padding: 0 0 12px;
}

a.btNext,
a.btBack {
	width: 100%;
	max-width: 270px;
	display: inline-block;
	color: #fff;
	font-size: 16px;
	font-weight: 500;
	text-align: center;
	padding: 12px 0;
	border-radius:60px;
	box-shadow: 0px 3px 0px 0px rgba(20,82,154,0.16);
	transition: .5s;
}
a.btNext {
	background: #267EC4 url(/img/common/arrow_white_r.png) 91% 50% no-repeat;
	background-size: 7px 12px;
}

a.btNext:hover {
	background: #b04040 url(/img/common/arrow_white_r.png) 93% 50% no-repeat;
	background-size: 7px 12px;
}

a.btBack {
	background: #267EC4 url(/img/common/arrow_white_l.png) 9% 50% no-repeat;
	background-size: 7px 12px;
}
a.btBack:hover {
	background: #b04040 url(/img/common/arrow_white_l.png) 7% 50% no-repeat;
	background-size: 7px 12px;
}


a.lHeadAjst {
	display: block;
	position: relative;
	top: -60px;
}





/*media Queries Tablet
----------------------------------------------------*/
@media only screen and (min-width:769px) {

.inner { padding:0 40px; }
header .inner { padding:0 20px; }


#title {
	height: 280px;
	margin: 60px 0 80px;
	padding: 70px 0 30px;
}

#title h1 {
	position: relative;
	height: 90px;
	font-size: 3.4rem;
	padding: 0;
}

#title h1 p {
	position: absolute;
	top: -3px;
	left: calc(50% - 380px);
	line-height: 1.2;
}



ul.btBl.bnNav {
	display: flex;
	justify-content: space-between;
	width: 580px;
	margin: 2em auto 3em;
}
ul.btBl.bnNav li {
	width: 270px;
}


a.btNext,
a.btBack {
	font-size: 20px;
	padding: 20px 0;
}



}






/*media Queries PC
----------------------------------------------------*/
@media only screen and (min-width:1025px) {

body { font-size: 1.6rem; }


/* -----　ヘッダー　-------------------------- */

header {
	height: 100px;
	margin-top: -100px;
}
header .inner {
	padding:0 10px;
}

header .inner > ul {
	display: table;
	width: 100%;
	height: 100px;
	transition: .unset;
}

header .inner > ul > li {
	display: table-cell;
	height: 100px;
	vertical-align: middle;
}

header .inner > ul > li:nth-child(1) {
	font-size: 24px;
	padding: 0;
}

header .inner > ul > li.navB {
	display: table-cell;
	padding: 0;
}

header .inner > ul > li.navB > div {
	display: flex;
	justify-content: flex-end;
}

header .inner > ul > li.navB > div > ul { margin: 35px 0 0; }

header .inner > ul > li.navB > div > ul#gNav > li {
	text-align: right;
	padding: 0 0 0 12px;
	float: left;
}

header .inner > ul > li.navB > div > ul#gNav > li > a {
	display: inline-block;
	position: relative;
*	font-size: 1.4rem;
	text-align: center;
	line-height: 1.2;
	color: #707070;
	padding: 0 0 27px 0;
	transition: .5s;
}

header .inner > ul > li.navB > div > ul#gNav > li > a span.hdQz {
	color: #707070;
	font-size: 1.6rem;
	letter-spacing: -1px;
	transition: .5s;
}

header .inner > ul > li.navB > div > ul#gNav > li > a:hover span.hdQz {
	color: #70AEE0;
	transition: .5s;
}


header .inner > ul > li.navB > div > ul#gNav > li > a span {
	color: #70AEE0;
	font-size: 1rem;
}

header .inner > ul > li.navB > div > ul.lang li a:hover,
header .inner > ul > li.navB > div > ul#gNav > li > a:hover {
	color: #70AEE0;
	transition: .5s;
}

header .inner > ul > li.navB > div > ul.lang li a::after,
header .inner > ul > li.navB > div > ul#gNav > li > a::after {
	position: absolute;
	bottom: 14px;
	left: 0;
	content: '';
	width: 100%;
	height: 2px;
	background: #70AEE0;
	opacity: 0;
	visibility: hidden;
	transition: .5s;
}

header .inner > ul > li.navB > div > ul#gNav > li > a:hover::after {
	bottom: 20px;
	opacity: 1;
	visibility: visible;
}


header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont {
	display: none;
	position: absolute;
	width: 100%;
	height: auto;
	top: 100px;
	left: 0;
	padding: 40px 0;
*	background: #70AEE0;
	background: #3789CB;
	z-index: 10;
}

header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul {
	display: table;
	width: 100%;
	max-width: 1000px;
	min-width: 930px;
	margin: 0 auto;
}

header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li {
	display: table-cell;
	vertical-align: top;
}

header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li:nth-child(1) {
	width:320px;
	padding: 0 20px;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li:nth-child(2) { width: calc((100% - 250px) / 3); }

header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li h1 {
	font-size: 2.4rem;
	color: #fff;
	margin: 0 0 16px;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li span {
	font-size: 1.3rem;
	color: #fff;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li:nth-child(1) a {
	display: block;
	position: relative;
	width: 220px;
	color: #fff;
	font-size: 1.4rem;
	margin: 38px 0 0;
	padding: 18px 20px;
	border: 1px solid #fff;
	background: url(/img/common/arrow_w.svg) 96% 50% no-repeat;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li:nth-child(1) a::after {
	position: absolute;
	top: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 100%;
	background: rgba(255, 255, 255, 0.15);
	transform: scale(0, 1);
	transform-origin: right top;
	transition: transform .5s;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList > .gCont > ul > li:nth-child(1) a:hover::after {
	transform-origin: left top;
	transform: scale(1, 1);
}


header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li .bdList {
	width: 33%;
	float: left;
	line-height: 2;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li .bdList a {
	position: relative;
	color: #fff;
}

header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li ul {
	margin: 5px 0 0 2px;
	border-left: 1px solid #fff;
}

header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li ul li { padding: 0 20px 10px 15px; }
header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li ul li:last-child { padding: 0 20px 5px 15px; }

header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li ul li a {
	position: relative;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1.4;
	padding: 0;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li .bdList a:hover,
header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li ul li a:hover { transition: .5s; }

header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li .bdList a::after,
header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li ul li a::after {
	position: absolute;
	bottom: -7px;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #fff;
	opacity: 0;
	visibility: hidden;
	transition: .5s;
}
header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li .bdList a:hover::after,
header .inner > ul > li.navB > div > ul#gNav > li.gList> .gCont > ul > li ul li a:hover::after {
	bottom: -3px;
	opacity: 1;
	visibility: visible;
}





/* SPグローバルナビ */
#navToggle { display: none; }



/* 　アウトライン　 */

.inner {
	max-width:1260px;
	margin: 0 auto;
	padding:0;
}



#title {
	height: 350px;
	margin: 100px 0 80px;
	padding: 70px 0 30px;
}

#title h1 {
	position: relative;
	height: 90px;
	font-size: 3.4rem;
	padding: 0;
}

#title h1 p {
	position: absolute;
	top: -3px;
	left: calc(50% - 400px);
	line-height: 1.2;
}





/* -----　フッター　-------------------------- */

footer {
	margin: 80px 0 0;
	padding: 60px 0 0;
	transition: unset;
}
footer .inner { padding: 0 20px; }

footer #toTop a {
	position: fixed;
	left: auto;
	right: 30px;
	bottom: 30px;
	margin-bottom: 0;
	padding: 0;
}

/*固定*/
footer #toTop a.fix-animation {
	top: -60px;
	background-size: 40px auto;
}


footer #fNavBl {
	display: flex;
	flex-wrap: wrap;
	max-width: 1200px;
	margin: 0 auto 50px;
	padding: 0 10px;
}

footer #fNavBl > ul:first-child {
	display: table;
	width: 72%;
	margin: 0;
}
footer #fNavBl > ul:nth-child(2) {
	width: 16%;
}
footer #fNavBl > ul:nth-child(3) {
	width: 12%;
}

footer #fNavBl > ul:first-child > li {
	display: table-cell;
	width: 28%;
	text-align: left;
	margin: 0;
	padding: 0;
	cursor: inherit;
	vertical-align: top;
	float: none;
}
footer #fNavBl > ul:first-child > li.ttl {
	width: 46%;
}
footer #fNavBl > ul:first-child > li:nth-child(2) {
	width: 26%;
}
footer #fNavBl > ul > li {
	padding: 0 10px 20px 0;
	border: none;
}
footer #fNavBl > ul:nth-child(3) li { padding: 0 0 20px; }

footer #fNavBl > ul > li > ul { margin: 20px 0 0; }

footer #fNavBl > ul > li > ul > li {
	list-style: none;
	padding: 0 0 12px;
}

footer #fNavBl > ul > li > ul > li.useSP { display: none !important; }


footer #fNavBl > ul > li a,
footer #fNavBl > ul > li > ul > li > a,
footer #fUBl ul li a {
	display: inline;
	position: relative;
	padding: 0;
	transition: .5s;
}
footer #fNavBl > ul > li > ul > li > a { font-size: 1.2rem; }

footer #fNavBl > ul > li a:hover,
footer #fNavBl > ul > li > ul > li > a:hover,
footer #fUBl ul li a:hover { transition: .5s; }

footer #fNavBl > ul > li a::after,
footer #fNavBl > ul > li > ul > li > a::after,
footer #fUBl ul li a::after {
	position: absolute;
	bottom: -7px;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #fff;
	opacity: 0;
	visibility: hidden;
	transition: .5s;
}

footer #fNavBl > ul > li a:hover::after,
footer #fNavBl > ul > li > ul > li > a:hover::after,
footer #fUBl ul li a:hover::after {
	bottom: -3px;
	opacity: 1;
	visibility: visible;
	transition: .5s;
}


footer #fNavBl > ul:first-child > li.ttl a.btInq {
	display: block;
	width: 200px;
	font-size: 1.2rem;
	text-align: center;
	margin: 20px 0 0;
	padding: 10px 10px 11px;
	background: url(/img/common/arrow_white_r2.svg) 93% 50% no-repeat;
	border: 1px solid #fff;
	border-radius: 30px;
}
footer #fNavBl > ul:first-child > li.ttl a.btInq:hover {
	color: #065A9B;
	background: #fff url(/img/common/arrow_blue_r3.svg) 93% 50% no-repeat;
	background-size: auto 14px;
}

footer #fNavBl > ul:first-child > li.ttl a.btInq::after { height: 0; }
footer #fNavBl > ul:first-child > li.ttl a.btInq:hover::after { *height: 0; }


footer #fCopyBl {
	max-width: unset;
	margin: 0 auto;
	padding: 20px 0 30px;
}



section { transition: unset; }
.useSP { display: none; }
.usePC { display: block; }





a.lHeadAjst { top: -100px; }




}/* media Queries 769 */





