@charset "utf-8";
.eyecatch{
	width: 100%;
	height: calc(100vh - 100px);
	height: calc(var(--vh2, 1vh) * 100 - 100px);
	background-image: url(../img/index/eye_bg.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media only screen and (max-width: 767px){
	.eyecatch{
		width: 100%;
		height: calc(100vh - 70px);
		height: calc(var(--vh2, 1vh) * 100 - 70px);
	}
}
.eyecatch .eye_inner{
	width: 480px;
	height: auto;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}
@media only screen and (max-width: 767px){
	.eyecatch .eye_inner{
		width: 90%;
	}
}
.eyecatch .eye_inner img{
	width: 100%;
	height: auto;
	display: block;
}
@media only screen and (max-width: 767px){
	.eyecatch .eye_inner img{
		width: 58.5%;
		min-width: 197px;
	}
}
.eyecatch .eye_inner h2{
	font-size: 22px;
	line-height: 32px;
	letter-spacing: 0.06em;
	color: #FFFFFF;
	text-align: center;
	margin-top: 40px;
}
@media only screen and (max-width: 767px){
	.eyecatch .eye_inner h2{
		font-size: 20px;
		line-height: 30px;
		margin-top: 25px;
	}
}
.eyecatch .eye_inner h2 span{
	font-size: 18px;
	line-height: 32px;
	letter-spacing: 0.06em;
}
@media only screen and (max-width: 767px){
	.eyecatch .eye_inner h2 span{
		font-size: 16px;
		line-height: 30px;
	}
}

.contents01{
	width: 100%;
	height: auto;
	display: block;
	margin: 120px auto 0;
}
@media only screen and (max-width: 767px){
	.contents01{
		margin: 60px auto 0;
	}
}
.contents01 .contents01_01{
	width: 980px;
	height: auto;
	margin: 0 auto;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01{
		width: 90%;
		max-width: 375px;
	}
}
.contents01 .contents01_01 h3{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size: 18px;
	line-height: 38px;
	letter-spacing: 0.1em;
	color: #214486;
}
.contents01 .contents01_01 h3 img{
	width: 58px;
	height: auto;
	display: block;
	margin-right: 14px;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01 h3 img{
		width: 50px;
		margin-right: 10px;
	}
}
.contents01 .contents01_01 h4{
	font-size: 44px;
	line-height: 64px;
	letter-spacing: 0.04em;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01 h4{
		font-size: 24px;
		line-height: 32px;
	}
}
.contents01 .contents01_01 h4 span{
	font-size: 34px;
	line-height: 64px;
	letter-spacing: 0.04em;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01 h4 span{
		font-size: 18px;
		line-height: 32px;
	}
}
.contents01 .contents01_01 .text01{
	font-size: 16px;
	line-height: 32px;
	letter-spacing: 0.06em;
	margin-top: 20px;
	width: 100%;
	height: auto;
	display: flex;
	justify-content: flex-starts;
	align-items: flex-start;
	flex-direction: column;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01 .text01{
		font-size: 15px;
		line-height: 28px;
	}
}
.contents01 .contents01_01 .text01 span{
	display: block;
	height: 1em;
}
.contents01 .contents01_01 .link01{
	width: 100%;
	height: auto;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin-top: 50px;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01 .link01{
		margin-top: 40px;
	}
}
.contents01 .contents01_01 .link01 a{
	width: 106px;
	height: auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 15px;
	line-height: 42px;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01 .link01 a{
		width: 95px;
		font-size: 13px;
	}
}
.contents01 .contents01_01 .link01 img{
	width: 22px;
	height: auto;
	display: block;
}
@media only screen and (max-width: 767px){
	.contents01 .contents01_01 .link01 img{
		width: 21px;
	}
}
/*.contents01ここまで*/


/*.contents02ここから*/
.contents02{
	width: 100%;
	height: auto;
	display: block;
}
.contents02 .contents02_bg{
	width: 100%;
	height: auto;
	display: block;
	background-image: url(../img/index/bg01.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 70px 0 100px;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_bg{
		background-image: url(../img/index/bg01_sp.jpg);
		padding: 50px 0 60px;
	}
}
.contents02 .contents02_01{
	width: 1180px;
	height: auto;
	margin: 0 auto;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01{
		width: 90%;
		max-width: 375px;
	}
}
.contents02 .contents02_01 h3{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size: 18px;
	line-height: 38px;
	letter-spacing: 0.1em;
	color: #fff;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01 h3{
		font-size: 14px;
		line-height: 30px;
	}
}
.contents02 .contents02_01 h3 img{
	width: 58px;
	height: auto;
	display: block;
	margin-right: 14px;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01 h3 img{
		width: 50px;
		margin-right: 10px;
	}
}
.contents02 .contents02_01 h4{
	font-size: 44px;
	line-height: 64px;
	letter-spacing: 0.04em;
	color: #fff;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01 h4{
		font-size: 24px;
		line-height: 32px;
	}
}
.contents02 .contents02_01 h4 span{
	font-size: 34px;
	line-height: 64px;
	letter-spacing: 0.04em;
}
.contents02 .contents02_01 .contents02_01_01{
	width: 100%;
	height: auto;
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	margin-top: 30px;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01 .contents02_01_01{
		width: 100%;
		display: block;
	}
}
.contents02 .contents02_01 .contents02_01_01 .box01{
	width: 566px;
	height: auto;
	padding: 45px 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background-color: #fff;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01 .contents02_01_01 .box01{
		width: 100%;
		padding: 40px 20px;
	}
	.contents02 .contents02_01 .contents02_01_01 .box01:first-of-type{
		margin-bottom: 30px;
	}
}
.contents02 .contents02_01 .contents02_01_01 h5{
	width: 100%;
	height: auto;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size: 32px;
	line-height: 64px;
	letter-spacing: 0.02em;
	margin-bottom: 30px;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01 .contents02_01_01 h5{
		flex-direction: column;
		font-size: 22px;
		line-height: 1;
		margin-bottom: 30px;
	}
}
.contents02 .contents02_01 .contents02_01_01 h5 img{
	margin-right: 30px;
	width: 100px;
	height: auto;
	display: block;
}
@media only screen and (max-width: 767px){
	.contents02 .contents02_01 .contents02_01_01 h5 img{
		margin-right: 0;
		margin-bottom: 15px;
		width: 72px;
	}
}
ul.column-list {
	width: 100%;
	height: auto;
	margin-left: 20px;
	column-count: 2;/* 2列にする */
	column-gap: 40px;/* 列間の余白 */
}
@media only screen and (max-width: 767px){
	ul.column-list {
		width: 100%;
		height: auto;
		margin-left: 0;
		column-count: 1;/* 1列にする */
		column-gap: initial;
	}
}
ul.column-list li {
  break-inside: avoid;/* 項目が途中で切れないように */
  margin-bottom: 10px;
  width: auto;
  height: auto;
}
ul.column-list li a {
  display: inline-block;
  color: #183d85;
  font-size: 15px;
  line-height: 20px;
  letter-spacing: 0.02em;
}
@media only screen and (max-width: 767px){
	ul.column-list li a {
	  font-weight: 400;
	}
}

ul.column-list li img {
  margin-right: 8px;
  width: 1em;
  height: auto;
}
/*.contents02ここまで*/

/*.contents03(お知らせ)ここから*/
.contents03{
	width: 100%;
	height: auto;
	display: block;
}
.contents03 .contents03_01{
	width: 980px;
	height: auto;
	margin: 0 auto 120px;
}
@media only screen and (max-width: 767px){
	.contents03 .contents03_01{
		width: 90%;
		max-width: 375px;
		margin: 0 auto 80px;
	}
}
.contents03 .contents03_01 h3{
	width: 100%;
	height: auto;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 40px;
	letter-spacing: 0.04em;
	line-height: 64px;
	text-align-last: center;
	margin-bottom: 54px;
}
@media only screen and (max-width: 767px){
	.contents03 .contents03_01 h3{
		font-size: 24px;
		line-height: 32px;
		margin-bottom: 36px;
	}
}
.contents03 .contents03_01 ul{
	width: 100%;
	height: auto;
}
.contents03 .contents03_01 ul li{
	width: 100%;
	height: auto;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	border-bottom: 1px solid #D3D3D3;
	padding: 0 26px;
}
@media only screen and (max-width: 767px){
	.contents03 .contents03_01 ul li{
		display: block;
		padding: 0 0 20px 0;
    margin-top: 20px;
	}
}
.contents03 .contents03_01 ul li a{
	text-decoration: underline;
}
.contents03 .contents03_01 ul li a,
.contents03 .contents03_01 ul li span{
	padding: 19px 0;
	font-size: 16px;
	line-height: 26px;
}
@media only screen and (max-width: 767px){
	.contents03 .contents03_01 ul li a,
	.contents03 .contents03_01 ul li span{
		padding: 0;
		font-size: 14px;
		line-height: 24px;
		display: block;
	}
}
.contents03 .contents03_01 ul li .date{
	margin-right: 72px;
	width: 142px;
	height: auto;
	flex-shrink: 0;
}
@media only screen and (max-width: 767px){
	.contents03 .contents03_01 ul li .date{
		margin-right: 0;
		width: 100%;
		flex-shrink: initial;
		display: block;
		padding-bottom: 0;
	}
}







