@charset "utf-8";

/*=================================================================
COMMON
==================================================================*/

* {
	box-sizing: border-box;
}

body {
	font: 1rem/2 "Yu Gothic UI", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;
	color: #333;
}


img {
	max-width: 100%;
}

a {
	text-decoration: none;
}

p+p {
	margin-top: 15px;
}

p.tright {
	text-align: right;
	font-size: 0.8em;
}

small {
	font-size: 0.7em;
}

.pc {
	display: block;
}

.sp {
	display: none;
}

.kv {
	margin-bottom: 40px;
	text-align: right;
	p{
		font-size: 14px;
	}
}

.fnt14{
	font-size: 12px;
}

.lead_big {
	font-size: 42px;
	width: 100%;
	color: #3471B6;
	font-weight: bold;
	text-align: center;
	line-height: 1.3;
	sup{
		vertical-align: text-top;
	}
}


.lead_txt,
.link-box {
	width: 100%;
	margin: 0 auto 40px auto;
	font-size: 16px;
	/* background-image: linear-gradient(90deg, rgb(222, 227, 232), rgb(232, 232, 232)); */
	padding: 30px;

}

.link-box {
	margin: 40px auto;
	text-align: center;
	border: 2px solid #102341;
}

.link_box_u {
	background-color: #102341;
	padding: 10px 32px;
	color: #fff;

}


.link-box a {
	display: block;
	color: #102341;
	text-decoration: underline;
	padding: 20px;
}

.link_area {
	position: relative;
	display: flex;
	align-items: center;
    flex-direction: column;
}


figcaption {
	font-size: 0.8em;
	line-height: 1.6;
	margin-top: 10px;
	text-align: center;
	/* font-weight: bold; */
}

figcaption span {
	font-size: 16px;
	display: inline-block;
}


/*=================================================================
PC
==================================================================*/
.main-contents {
	width: 100%;
	max-width: 680px;
	margin: 0 auto;
	padding: 20px 0 20px 0;
}

.noticeTxt {
	font-size: 80%;
	margin-bottom: 50px;
}


.bnr {
	width: 400px;
	margin: 30px auto 30px auto;
}

.bnr img {
	width: 400px;
	margin: 0px auto 0px auto;
	text-align: center;
}


.inner {
	width: 100%;
	max-width: 1040px;
	margin: 0 auto;
	/* padding: 0 20px; */
}

.flex_box {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	/* margin-bottom: 40px; */
}

.flex_box > .info_area { order: 1; }
.flex_box > .img_area { order: 2; }
.flex_box > .info_area_2 { order: 3; }


.w100 {
	width: 100% !important;
	margin-bottom: 30px;
}

.sec-ttl {
	font-size: 1.2em;
	color: #1e2d66;
	margin-bottom: 40px;
	font-weight: bold;
	line-height: 1.6;
    border-bottom: 1px solid #b5bcd7;
	padding: 12px;
  	background: rgb(222, 231, 239);
  	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.23);
    /* border-left: 12px solid #70a17b;
    background-color: #d9ef8f; */
}

.sec-ttl span {
	font-size: 0.8em;
	color: #1e2d66;
    /* border-bottom: 1px solid #70a17b;
    border-left: 12px solid #70a17b;
    background-color: #d9ef8f; */
}

.name_a {
	font-size: 20px;
	font-weight: bold;
	color: #ff988d;
}

.name_b {
	font-size: 20px;
	font-weight: bold;
	color: #67a6f5;
}


.name_c {
	font-size: 20px;
	font-weight: bold;
	color: #67a6f5;
}

.flex_box .info_area {
	width: 54%;
	/* margin-left: 32px; */
	margin-bottom: 40px;
}


.flex_box .info_area_2 {
	width: 100%;
	/* margin-left: 32px; */
	margin-bottom: 40px;
}

.flex_box .info_area sub {
	vertical-align: inherit;
}

/* .flex_box .info_area .w100 {
	width: 100%;
	margin-bottom: 0 !important;
} */

.flex_box .img_area {	
	width: 45%;
	margin: 0 auto 0 auto;
	text-align: center;
}

.flex_box .img_area img{
	width: 100%;
}

.flex_box .img_area img.imgleft {
	padding-right:24px;
}

.flex_box .img_area img.imgright {
	padding-left:24px;
}

.flex_box .img_area p{
	font-weight: 600;
	font-size: 18px;
}
.flex_box .w100 img{
	width: 100%;
}

.flex_box .img_area_2 {
	margin: 20px auto 40px auto;
	text-align: center;
}
.flex_box .img_area_2 img{
	width: 65%;
}

.flex_box .img_area_f{	
	margin: 20px auto 40px auto;
	text-align: center;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
.flex_box .img_area_f figure{
	width: 75%;
}
.flex_box .caption {
	margin: 10px auto;
	text-align: left;
	font-size: 1em;
	padding: 8px 8px 2px 8px;
	background-color: #E6E6E6;

}

.flex_box--harf .img_area {
	width: 44%;
	min-width: 360px;
}

.flex_box--harf .info_area {
	width: 48%;

}

.logo {
	width: 500px;
	margin: 100px auto 80px auto;
}

.logo img {
	width: 100%;
}


.obligations-list {
	display: flex;
	justify-content: space-between;
	margin: 20px 0 40px;
	padding: 20px;
	border: 1px solid #72A865;
	flex-direction: column;
}


.obligations-list li {
	list-style-type: disc;
	margin-left: 20px;
}

.name-list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 20px 0 40px;
}

.name-list li {
	line-height: 1.4;
	font-size: 14px;
}

.name-list li b {
	color: #0095c4;
	font-weight: bold;
}

.name-list li span {
	font-size: 16px;
	display: block;
	margin-top: 5px;
}

.book_area {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
	background-color: #f6f6f6;
	padding: 40px;
	margin-top: 40px;
}

.book_area img {
	width: 25%;
}

.book_area p {
	width: 65%;
	font-size: 18px;
	line-height: 2.4;
}

.btn {
	display: inline-block;
	width: 300px;
	height: 80px;
	line-height: 1.4;
	text-align: center;
	text-decoration: none;
	outline: none;
	transition: all 0.3s;
	background-color: #3c7395;
	color: #fff;
	position: relative;
	letter-spacing: .05em;
	font-weight: bold;
	font-size: 18px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 80px auto 40px;
	border-radius: 100px;
}


.btn:hover {
	background-color: #DEDEDE;
	color: #1d27e0;
}


.btnp02 {
	display: inline-block;
	width: 300px;
	height: 60px;
	line-height: 1.4;
	text-align: center;
	text-decoration: none;
	outline: none;
	transition: all 0.3s;
	background-color: #3c7395;
	color: #fff;
	position: relative;
	letter-spacing: .05em;
	font-weight: bold;
	font-size: 18px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0px auto 0px;
	border-radius: 100px;
}

.btnp02:hover {
	background-color: #DEDEDE;
	color: #1d27e0;
}

.btn_box{
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}

.btn2{
	background-color: #fea904;
    color: #fff;
    padding: 10px 18px;
    font-weight: 600;
}
.btn2:hover{
	opacity: 0.8;
}
.r_gt{
	font-size: 20px;
}
.m-t40{
	margin-top: 40px;
}
.m-b60{
	margin-bottom: 60px;
}
.tc {
	text-align: center;
}


/* add */
.figure02 {
	margin: 0 0px 0 36px;
	float: right;
	text-align: center;
	width: 220px;
}

.figure02 span {
	display: block;
	margin: 16px 0 0 0;
	font-size: 0.8em;
	line-height: 1.2em;
	text-align: center;

}

.figure02 strong {
	font-size: 1em;
	font-weight: 600;
	text-align: center;
}


.figure03 {
	margin: 30px auto;
	text-align: center;
}

.figure03 p {
	width: 626px;
	display: block;
	text-align: left;
	font-size: 14px;
	padding: 8px;
	margin: 0px auto 30px auto;
}

.figure04 {
	/* margin: 0px 0px 30px 0px; */
}

.mb_80{
	margin-bottom: 80px;
}
.mb_60s{
	margin-bottom: 60px;
}
.mt_20{
	margin-top: 0;
}
/*=================================================================
SP
==================================================================*/

@media screen and (max-width: 768px) {
	.kv {
		p{
			font-size: 12px;
		}
	}

	.lead_big {
		font-size: 28px;
		line-height: 1.5;
	}
	p.tright {
	text-align: left;
	}
	
	.sec-ttl {
		font-size: 20px;
		line-height: 1.5;
		padding: 10px 20px;
		margin: 10px 10px 20px 10px;
	}

	.lead_txt,
	.link-box {
		margin-bottom: 30px;
		padding: 20px;
		font-size: 16px;

	}

	.inner {
		width: 100%;
	}

	.pc {
		display: none;
	}

	.sp {
		display: block;
	}

	.w100 {
		order: 1;
	}

	.fnt14{
		font-size: 14px;
	}

	.flex_box {
		flex-direction: column;
	}


	.flex_box > .img_area { order: 1; }
	.flex_box > .info_area { order: 2; }
	.flex_box > .info_area_2 { order: 3; }



	.flex_box.mb_s {
		margin-bottom: 30px;
	}

	.flex_box .info_area {
		width: 100%;
		padding:16px;
	}

	.flex_box .info_area_2 {
		width: 100%;
		padding:16px;
	}

	.flex_box .img_area {
		width: 100%;
		margin: 0px auto 10px;
		padding:16px;
	}

	.flex_box .img_area img.imgleft {
	padding-right:0px;
	}

	.flex_box .img_area img.imgright {
	padding-left:0px;
	}


	.flex_box .img_area_2 {
		width: 100%;
		margin: 0px auto 10px;
	}

	.flex_box .img_area_f {
		width: 100%;
		margin: 0px auto 10px;
	}
	.flex_box .img_area_f figure{
		width: 100%;
		margin-bottom: 30px;
	}

	.flex_box--harf .img_area {
		width: 100%;
		margin-bottom: 10px;
	}

	.flex_box--harf .info_area {
		order: 2;
	}



	.logo {
		width: 80%;
		margin: 50px auto;
	}

	.name-list li {
		width: 100%;
	}

	.name-list li:not(:last-child) {
		margin-bottom: 15px;
	}


	.book_area {
		padding: 20px;
		margin-top: 40px;
	}

	.book_area img {
		width: 35%;
		margin: 0 auto 20px;
	}

	.book_area p {
		width: 100%;
		font-size: 14px;
		line-height: 1.8;
	}

	.btn {
		width: 100%;
		font-size: 16px;
		height: 80px;
	}

	.bnr {
		width: 100%;
		margin: 30px auto 30px auto;
	}

	.bnr img {
		width: 100%;
		margin: 0px auto 0px auto;
		text-align: center;
	}

	.linkBnr {
		text-align: center;
		border: solid 1px #999;
		padding: 10px;
		color: #bb183c;
		width: 100% !important;
		margin: 0px auto 0px auto;
	}

	.linkBnr span {
		font-weight: bold;
	}

	/* add */
		/* BOX */
		.figure,
		.figure02,
		.figure03 {
			margin: 0px auto 20px auto !important;
			width: 100% !important;
			float: none !important;
			text-align: center;
		}
	
		.figure img,
		.figure02 img {
			width: 90% !important;
			max-width: 768px;
		}

		.figure02s {
			margin: 0px auto 20px auto !important;
			width: 65% !important;
			float: none !important;
			text-align: center;
		}
	
		.figure03 img {
			width: 100% !important;
			max-width: 768px;
			margin: 20px auto;
		}
	
		.figure03 p {
			width: 100% !important;
			max-width: 768px;
		}

		.mb_60{
			margin-bottom: 30px;
		}
		.mb_60s{
			margin-bottom: 20px;
		}
		.mt_20{
			margin-top: 20px;
		}
}




.linkBnr {
	text-align: center;
	border: solid 1px #999;
	padding: 10px;
	color: #bb183c;
	width: 70%;
	margin: 0px auto 0px auto;
}

.linkBnr span {
	font-weight: bold;
}