@charset "UTF-8";

[class*="ico-"] {
	position: relative;
	display: block;
	width: 100%;
	height: auto;
}

[class*="ico-"]:before {
	display: block;
	padding-top: 100%;
	width: 100px;
	height: 0;
	content: "";
}

.top-mv {
	height: 500px;
	background: url(../img/top/top_mv.jpg) no-repeat center center;
	background-size: cover;
}

.top-mv__item {
	position: relative;
	margin: 0 auto;
	padding: 108px 14px 0;
	width: 1008px;
	height: calc(100% - 60px);
}

.top-mv__ttl {
	color: #fff;
	text-shadow: 0 0 10px rgba(0, 0, 0, .5);
	font-weight: normal;
	font-style: normal;
	font-size: 20px;
	font-size: 1.25rem;
	font-family: "montserrat","Source Sans Pro","Noto Sans Japanese","メイリオ",Meiryo,sans-serif;
	line-height: 1.4;
}

.top-mv__copy {
	margin-top: 14px;
	margin-bottom: 0;
	color: #fff;
	text-shadow: 0 0 10px rgba(0, 0, 0, .5);
	font-size: 40px;
	font-size: 2.5rem;
	line-height: 1.2;
}

.top-mv__copy span {
	display: inline-block;
}

.top-mv-members {
	position: absolute;
	top: 50%;
	right: 0;
	padding: 26px 16px 32px;
	width: 296px;
	background-color: #eee;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

.top-mv-members__ttl {
	position: relative;
	margin-bottom: 30px;
	padding-top: 15px;
}

.top-mv-members__ttl:before {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 24px;
	height: 4px;
	background-color: #0090d4;
	content: "";
}

.top-mv-members__ttl .en,
.top-mv-members__ttl .ja {
	display: block;
}

.top-mv-members__ttl .en {
	font-weight: 500;
	font-style: normal;
	font-size: 14px;
	font-size: .875rem;
	font-family: "montserrat","Source Sans Pro","Noto Sans Japanese","メイリオ",Meiryo,sans-serif;
	line-height: 1.4286;
}

.top-mv-members__ttl .ja {
	color: #333;
	font-weight: bold;
	font-size: 20px;
	font-size: 1.25rem;
	line-height: 1.4;
}

.top-mv-mlist li {
	list-style: none;
}

.top-mv-mlist li:not(:last-child) {
	margin-bottom: 16px;
	padding-bottom: 32px;
	border-bottom: solid 1px #ccc;
}

.top-mv-mlist__ttl {
	margin-bottom: 10px;
	color: #0090d4;
	font-size: 16px;
	font-size: 1rem;
	line-height: 1.75;
}

.top-mv-mlist__btn {
	margin-bottom: 0;
}

.top-sec {
	position: relative;
	z-index: 2;
	margin: 0 auto;
	max-width: 1140px;
	background-color: #fff;
}

.top-sec .inner {
	margin: 0 auto;
	padding: 60px 14px 100px;
	width: 1008px;
}

.top-sec--gray {
	background-color: #f6f6f6;
}

.top-sec:first-of-type {
	margin-top: -60px;
}

.top-sec__ttl {
	position: relative;
	margin-bottom: 35px;
	padding-top: 7px;
}

.top-sec__ttl:before {
	position: absolute;
	top: 0;
	left: calc(50% - 12px);
	display: block;
	width: 24px;
	height: 4px;
	background-color: #0090d4;
	content: "";
}

.top-sec__ttl .en,
.top-sec__ttl .ja,
.top-sec__ttl .ja2 {
	display: block;
	text-align: center;
}

.top-sec__ttl .en {
	padding: 17px 0 12px;
	font-weight: 500;
	font-style: normal;
	font-size: 40px;
	font-size: 2.5rem;
	font-family: "montserrat","Source Sans Pro","Noto Sans Japanese","メイリオ",Meiryo,sans-serif;
	line-height: 1.4;
}

.top-sec__ttl .ja {
	color: #999;
	font-weight: bold;
	font-size: 14px;
	font-size: .875rem;
	line-height: 1.7143;
}

.top-pslist {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;

	-webkit-justify-content: space-around;

	-ms-flex-pack: distribute;

	justify-content: space-around;
}

.top-pslist li {
	position: relative;
	padding-bottom: 74px;
	width: 200px;
	list-style: none;
}

.top-pslist__ttl {
	position: relative;
	margin-bottom: 26px;
	width: 200px;
	height: 200px;
	border-radius: 50%;
	background-color: #0090d4;
	text-align: center;
}

.top-pslist__ttl a {
	display: block;
	padding-top: 40px;
	height: 100%;
}

.top-pslist__ttl .label {
	color: #fff;
	font-weight: bold;
	font-size: 20px;
	font-size: 1.25rem;
	line-height: 1.6;
}

.top-pslist [class*="ico-"] {
	margin: 0 auto 12px;
	width: 40px;
	background-size: contain;
	background-repeat: no-repeat;
	opacity: .5;
}

.top-pslist .ico-urikake {
	background-image: url(../img/common/ico_ps_urikake.svg);
}

.top-pslist .ico-kyuyo {
	background-image: url(../img/common/ico_ps_kyuyo.svg);
}

.top-pslist .ico-cvs {
	background-image: url(../img/common/ico_ps_cvs.svg);
}

.top-pslist .ico-solution {
	background-image: url(../img/common/ico_ps_solution.svg);
}

.top-pslist .ico-staff {
	background-image: url(../img/common/ico_ps_staff.svg);
}

.top-pslist__txt {
	margin-bottom: 0;
	font-size: 14px;
	font-size: .875rem;
	line-height: 1.7143;
}

.top-pslist__btn {
	position: absolute;
	bottom: 0;
	left: 0;
	margin-bottom: 0;
	width: 100%;
}

.top-pslist .btn-ghost {
	padding-top: 15px;
	padding-bottom: 15px;
	width: 100%;
}

.top-pslist.no-icon .top-pslist__ttl a {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	padding-top: 0;
	text-align: center;

	-webkit-box-align: center;

	-webkit-align-items: center;

	-ms-flex-align: center;

	align-items: center;
}

.top-pslist.no-icon .top-pslist__ttl .label {
	width: 100%;
}

.top-mlist {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;

	-webkit-box-pack: justify;

	-webkit-justify-content: space-between;

	-ms-flex-pack: justify;

	justify-content: space-between;
}

.top-mlist li {
	position: relative;
	padding: 30px 16px 118px;
	width: 456px;
	border-top: solid 8px #0090d4;
	border-bottom: solid 4px #ccc;
	list-style: none;
}

.top-mlist__ttl {
	margin-bottom: 16px;
	font-size: 28px;
	font-size: 1.75rem;
	line-height: 1.5714;
}

.top-mlist__ttl small {
	display: block;
	font-size: 18px;
	font-size: 1.125rem;
	line-height: 1.7778;
}

.top-mlist__txt {
	margin-bottom: 0;
	font-size: 14px;
	font-size: .875rem;
	line-height: 1.7143;
}

.top-mlist__btn {
	position: absolute;
	right: 0;
	bottom: 38px;
	margin-bottom: 0;
	padding-right: 16px;
	width: 100%;
	text-align: right;
}

.top-mlist__btn .btn-prim {
	display: inline-block;
	width: 200px;
}

.top-nlist {
	margin: auto;
}

.top-nlist.list-topics {
	width: 808px;
}

.top-pmark {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	margin-top: 100px;

	-webkit-box-pack: center;

	-webkit-justify-content: center;

	-ms-flex-pack: center;

	justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	-ms-flex-align: center;
	align-items: center;
}

.top-pmark__fig {
	margin-right: 24px;
	margin-bottom: 0;
	width: 100px;
}

.top-pmark__fig a {
	display: block;
}

.top-pmark__txt {
	margin-bottom: 0;
	font-size: 14px;
	font-size: .875rem;
	line-height: 1.7143;
}

@media screen and (max-width: 767px) {
	.top-mv {
		height: 250px;
	}
	.top-mv__item {
		padding-top: 60px;
		padding-right: 30px;
		padding-left: 30px;
		width: 100%;
		height: auto;
	}
	.top-mv__ttl {
		font-size: 14px;
		font-size: .875rem;
		line-height: 1.4286;
	}
	.top-mv__copy {
		margin-top: 4px;
		font-size: 20px;
		font-size: 1.25rem;
		line-height: 1.2;
	}
	.top-mv-members {
		display: none;
	}
	.top-sec {
		margin-right: 10px;
		margin-left: 10px;
		max-width: 100%;
		width: auto;
	}
	.top-sec .inner {
		padding: 40px 20px 60px;
		width: 100%;
	}
	.top-sec:first-of-type {
		margin-top: -30px;
	}
	.top-sec--ps .inner {
		padding-right: 5px;
		padding-left: 5px;
	}
	.top-sec__ttl {
		margin-bottom: 24px;
		padding-top: 8px;
	}
	.top-sec__ttl:before {
		left: calc(50% - 6px);
		width: 12px;
	}
	.top-sec__ttl .en {
		padding-top: 3px;
		padding-bottom: 3px;
		font-size: 20px;
		font-size: 1.25rem;
		line-height: 1.2;
	}
	.top-sec__ttl .ja {
		font-size: 12px;
		font-size: .75rem;
		line-height: 1.6667;
	}
	.top-pslist {
		-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-pack: start;
		-webkit-justify-content: flex-start;
		-ms-flex-pack: start;
		justify-content: flex-start;
	}
	.top-pslist li {
		padding-bottom: 66px;
		width: 50%;
	}
	.top-pslist li:nth-child(1),
	.top-pslist li:nth-child(2) {
		margin-bottom: 40px;
	}
	.top-pslist__ttl {
		margin-right: auto;
		margin-bottom: 12px;
		margin-left: auto;
		width: 128px;
		height: 128px;
	}
	.top-pslist__ttl a {
		padding-top: 16px;
	}
	.top-pslist__ttl .label {
		font-size: 14px;
		font-size: .875rem;
		line-height: 1.5714;
	}
	.top-pslist [class*="ico-"] {
		margin-bottom: 0;
	}
	.top-pslist__txt {
		padding-right: 15px;
		padding-left: 15px;
		font-size: 12px;
		font-size: .75rem;
		line-height: 1.5;
	}
	.top-pslist__btn {
		padding-right: 15px;
		padding-left: 15px;
	}
	.top-pslist .btn-ghost {
		padding-top: 10px;
		padding-bottom: 10px;
	}
	.top-mlist {
		display: block;
	}
	.top-mlist li {
		padding: 11px 15px 18px;
		width: 100%;
		border-width: 4px;
	}
	.top-mlist li:not(:last-child) {
		margin-bottom: 40px;
	}
	.top-mlist__ttl {
		margin-bottom: 11px;
		font-size: 18px;
		font-size: 1.125rem;
		line-height: 1.7778;
	}
	.top-mlist__ttl small {
		font-size: 12px;
		font-size: .75rem;
		line-height: 1.5;
	}
	.top-mlist__txt {
		font-size: 12px;
		font-size: .75rem;
		line-height: 1.5;
	}
	.top-mlist__btn {
		position: relative;
		right: auto;
		bottom: auto;
		padding: 0;
		padding-top: 12px;
	}
	.top-mlist__btn .btn-prim {
		width: auto;
	}
	.top-nlist.list-topics {
		width: auto;
	}
	.top-pmark {
		margin-top: 60px;
	}
	.top-pmark__fig {
		margin-right: 12px;
		width: 50px;
	}
	.top-pmark__txt {
		font-size: 12px;
		font-size: .75rem;
		line-height: 1.5;

		-webkit-box-flex: 1;

		-webkit-flex: 1;

		-ms-flex: 1;

		flex: 1 1;
	}
}
