@charset "UTF-8";

.section-area {
	background: center / cover;
}

.section-area .section-area-inner {
	width: 1100px;
	margin: 0 auto;
	padding: 70px 90px;
}

@media screen and (max-width: 768px) {
	div.section-area {
		padding: 8px 4px;
	}

	div.section-area .section-area-inner {
		width: auto;
		padding: 8px 4px;
	}
}

/*==================================================
 ご挨拶
================================================== */
/* レイアウト
-------------------------------------------------- */
.greeting-section-area {
	background-image: url(../images/top/greeting_area_bg.jpg);
}

.greeting-section-area .section-area-inner {
	width: 750px;
}

/* セクション
-------------------------------------------------- */
.greeting-section .greeting-texts {
	margin: 0 0 70px;
	line-height: 2;
	text-align: center;
}

/* バナー
------------------------- */
.greeting-bnr-list {
	-js-display: flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.greeting-bnr-list li {
	width: 360px;
}

.greeting-bnr-list a {
	padding: 4px;
	border-radius: 6px;
	background:
		url(../images/top/greeting_bnr_arrow.png) right 17px center no-repeat,
		linear-gradient(#004681 50%, #003867)
	;
	-js-display: flex;
	display: flex;
	justify-content: space-between;
}

.greeting-bnr-list a:hover {
	text-decoration: none;
}

.greeting-bnr-list a .texts {
	width: calc(100% - 145px);
	color: #fff;
	font-size: 23px;
	letter-spacing: .1em;
	-js-display: flex;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.greeting-bnr-list a .ruby {
	font-size: 50%;
}

.greeting-bnr-list a .thumb {
	width: 125px;
}

@media screen and (max-width: 768px) {
	.greeting-bnr-list li {
		width: 100%;
		margin: 0 0 8px;
	}
}


/*==================================================
 事業案内
================================================== */
/* レイアウト
-------------------------------------------------- */
.business-section-area {
	background-image: url(../images/top/business_area_bg.png);
}

/* セクション
-------------------------------------------------- */
.business-section .styled-title01 {
	margin-bottom: 155px;
}

@media screen and (max-width: 768px) {
	.business-section .styled-title01 {
		margin-bottom: 28px;
	}
}

/* コンテンツリスト
-------------------------------------------------- */
.business-items-wrap {
	-js-display: flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.business-items-wrap .business-item {
	width: 350px;
	background: #fff;
}

@media screen and (max-width: 768px) {
	.business-items-wrap .business-item {
		width: 100%;
		margin: 0 0 8px;
	}
}

/* コンテンツリスト
------------------------- */
.business-items-wrap .business-item .item-title {
	border-bottom: 1px solid #002e6e;
	-js-display: flex;
	display: flex;
	align-items: center;
}

.business-items-wrap .business-item .item-title .item-title-text {
	padding: 0 0 0 23px;
	color: #002e6e;
	font-size: 30px;
	font-weight: 500;
	letter-spacing: .2em;
	flex-grow: 1;
}

.business-items-wrap .business-item .item-texts {
	padding: 25px;
}

.business-items-wrap .item-case {
	padding: 16px 21px 21px;
	box-shadow: 0 14px 10px -10px rgba(0,0,0,.2) inset;
}

.business-items-wrap .item-case .item-case-title {
	margin: 0 0 8px;
	color: #002e6e;
	letter-spacing: .2em;
	-js-display: flex;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

.business-items-wrap .item-case .item-case-title .text {
	font-size: 26px;
}

.business-items-wrap .item-case .item-case-title .more {
	color: inherit;
	font-size: 12px;
}

.business-items-wrap .item-case .item-case-thumb {
	padding: 54.39% 0 0;
	display: block;
	overflow: hidden;
	position: relative;
}

.business-items-wrap .item-case .item-case-thumb img {
	/*max-width: none;*/
	height: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
}

/*==================================================
 求人募集
================================================== */
/* レイアウト
-------------------------------------------------- */
.recruit-section-area {
	padding: 70px 90px;
	background-image: url(../images/top/recruit_area_bg.jpg);
}

.recruit-section-area .section-area-inner {
	padding: 33px 30px;
	background: rgba(255,255,255,.9);
	box-sizing: border-box;
}

/* セクション
-------------------------------------------------- */
.recruit-section .styled-title01 {
	margin-bottom: 45px;
}

@media screen and (max-width: 768px) {
	.recruit-section .styled-title01 {
		margin: 0 0 24px;
	}
}

/* コンテンツリスト
-------------------------------------------------- */
.recruit-items-wrap {
	-js-display: flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.recruit-items-wrap .recruit-item {
	width: 510px;
	height: 334px;
	padding: 47px;
	letter-spacing: .2em;
	background: center / cover;
	box-sizing: border-box;
	-js-display: flex;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.recruit-items-wrap .recruit-item:hover {
	text-decoration: none;
	opacity: .8;
}

.recruit-items-wrap .recruit-item-recruit {
	background-image: url(../images/top/recruit_item01_bg.jpg);
	align-items: flex-end;
}

.recruit-items-wrap .recruit-item-flow {
	background-image: url(../images/top/recruit_item02_bg.jpg);
	align-items: flex-start;
}

.recruit-items-wrap .item-title {
	margin: 0 0 10px;
	color: #002e6e;
	font-size: 38px;
}

.recruit-items-wrap .item-more {
	width: 150px;
	text-align: center;
	line-height: 31px;
	color: #fff;
	border-radius: 12px;
	background: #002e6e;
	display: block;
}

@media screen and (max-width: 768px) {
	.recruit-items-wrap .recruit-item {
		width: 100%;
		margin: 0 0 8px;
	}
}


/*==================================================
 インフォ
================================================== */
.info-area {
	-js-display: flex;
	display: flex;
	/*display: none;*/
	overflow: hidden;
}

.info-area .info-column {
	width: 50%;
}

.info-area .info-news-column {
	/*padding: 54px 20px 50px calc((100% - 1100px) / 2);*/
	/*padding: 54px 20px 50px calc((100% - 1480px) / 2);*/
	padding: 54px 20px 50px 20px;
	background: url(../images/top/news_area_bg.jpg) top right / 100% 100%;
}

.info-area .info-column-column {
	/*padding: 54px calc((100% - 1100px) / 2) 50px 20px;*/
	/*padding: 54px calc((100% - 1480px) / 2) 50px 20px;*/
	padding: 54px 20px 50px 20px;
	background: url(../images/top/column_area_bg.jpg) top left / 100% 100%;
}

@media screen and (max-width: 768px) {
	.info-area {
		padding: 16px 8px;
		flex-direction: column;
	}

	.info-area .info-column {
		width: 100%;
		margin: 0 0 16px;
		padding: 8px;
		box-sizing: border-box;
	}
}

/* セクション
-------------------------------------------------- */
.info-section .info-section-title {
	margin: 0 0 11px;
	line-height: 1;
	letter-spacing: .2em;
	-js-display: flex;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

.info-section .info-section-title .text {
	color: #002e6e;
	font-size: 30px;
}

.info-section .info-section-title .more {
	font-size: 14px;
}

/* 記事リスト
-------------------------------------------------- */
.info-section-list li {
	width: 100%;
	padding: 20px 0 14px;
	line-height: 1;
	border-bottom: 1px solid #ccc;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.info-section-list span {
	margin: 0 0 12px;
	color: #a3a3a3;
	font-size: 14px;
	display: block;
}

.info-section-list a {
	color: #3f3f3f;
	font-size: 16px;
}

@media screen and (max-width: 768px) {
	.info-section-list span {
		display: inline;
	}
}