/* ---------------------------------------------------------------
start TOP CSS
--------------------------------------------------------------- */

/* --------------- common --------------- */




/* --------------- top --------------- */

.col_topMain {
	width: 100%;
	height: 1420px;
	margin: 0;
	padding: 0;
	background-image: url(../img/top/mainimg.jpg);
	background-repeat: no-repeat;
	background-position: top right;
	background-size: 90% auto;
	background-color: #001568;
	position: relative;
	z-index: 0;
}

.col_topMain::before {
	content: "";
	width: 188px;
	height: 188px;
	background-color: #f2f2f2;
	transform: rotate(45deg);
	transform-origin: 100% 0;
	display: block;
	position: absolute;
	top: 205px;
	left: -60px;
	z-index: -1;
}

.col_topMain::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 1420px 0 0 1420px;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	top: 74px;
	left: 0;
	z-index: -2;
}

.inner_topMain {
	width: 92%;
	height: 100%;
	margin: 0 auto;
	padding: 395px 0 0 0;
	position: relative;
	z-index: 0;
}

dl.catch_topMain {
	margin: 0;
	padding: 0;
	color: #fff;
	text-align: center;
	position: absolute;
	top: 21vw;
	right: 8%;
}

dl.catch_topMain dt {
	margin: 0 0 10px;
	padding: 0;
	font-size: 3.7vw;
	font-weight: 300;
	line-height: 1.2;
	letter-spacing: 0.18em;
	text-indent: 0.18em;
}

dl.catch_topMain dd {
	width: 46.2vw;
	margin: 0 auto;
	padding: 0;
}

dl.cont_topMain {
	margin: 0;
	padding: 0;
}

dl.cont_topMain dt {
	width: 312px;
	margin: 0 0 50px;
	padding: 0;
}

dl.cont_topMain dd {
	margin: 0;
	padding: 0;
	color: #666666;
	font-weight: 400;
	line-height: 2;
}

.col_topAbout {
	margin: 0 0 -450px;
	padding: 0 0 100px;
	position: relative;
	top: -450px;
}

/*
.col_topAbout::after {
	content: "";
	width: 850px;
	height: 773px;
	background-image: url(../img/top/deco_main_01.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top left;
	opacity: 0.16;
	position: absolute;
	top: -668px;
	left: calc(4% - 260px);
}
*/

.inner_topAbout {
	width: 92%;
	margin: 0 auto;
	padding: 0;
	position: relative;
	z-index: 0;
}

.mds_top1 {
	margin: 0 0 40px;
	padding: 0;
	line-height: 1.4;
}

.mds_top1 .en {
	margin: 0 0 10px;
	padding: 0;
	display: block;
}

.mds_top1 .ja {
	margin: 0;
	padding: 0;
	font-size: 16px;
	font-weight: 400;
	display: block;
}

.col_topAbout .mds_top1 .en {
	max-width: 212px;
}

.wrap_topAbout {
	margin: 0;
	padding: 0;
	display: flex;
	position: relative;
	z-index: 0;
}

.grad_topAbout {
	width: 60%;
	padding: 60px 0 65px;
	color: #fff;
	position: relative;
	z-index: 1;
}

.grad_topAbout::after {
	content: "";
	width: 850px;
	height: 1160px;
	background-image: url(../img/top/deco_main.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top left;
	opacity: 0.16;
	position: absolute;
	top: -770px;
	left: -240px;
	z-index: -1;
}

.grad_topAbout::before {
	content: "";
	width: 120%;
	height: 100%;
	background: rgb(0, 49, 129);
	/* Old browsers */
	background: -moz-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* FF3.6-15 */
	background: -webkit-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(135deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#003181', endColorstr='#189b84', GradientType=1);
	/* IE6-9 fallback on horizontal gradient */
	position: absolute;
	z-index: -1;
	top: 0;
	right: 0;
	transform: skewX(-15deg);
}

.grad_topAbout dl {
	margin: 0 0 60px;
	padding: 0;
}

.grad_topAbout dl dt {
	margin: 0 0 14px;
	padding: 0 0 0 0.8em;
	font-weight: 400;
	font-size: 34px;
	line-height: 1.5;
	transform: skewX(-10deg);
}

.grad_topAbout dl dd {
	margin: 0;
	padding: 0;
	font-weight: 300;
	line-height: 2;
	transform: skewX(-10deg);
}

.grad_topAbout .skew {
	transform: skewX(10deg);
	display: inline-block;
}

.grad_topAbout ul,
.grad_topBusiness ul,
.grad_topEfforts ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	position: relative;
	left: -1.2em;
}

.grad_topAbout ul li,
.grad_topBusiness ul li,
.grad_topEfforts ul li {
	width: 166px;
	margin: 0 12px 0 0;
	padding: 0;
	transform: skewX(-15deg);
}

.grad_topAbout ul li:last-of-type,
.grad_topEfforts ul li:last-of-type {
	margin-right: 0;
}

.grad_topAbout ul li a,
.grad_topBusiness ul li a,
.grad_topEfforts ul li a {
	width: 100%;
	height: 48px;
	color: #189c84;
	line-height: 1;
	text-decoration: none;
	background-color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: .2s;
}

.grad_topAbout ul li a span,
.grad_topBusiness ul li a span,
.grad_topEfforts ul li a span {
	display: inline-block;
	transform: skewX(15deg);
}

.grad_topAbout ul li a span img,
.grad_topBusiness ul li a span img,
.grad_topEfforts ul li a span img {
	width: auto;
	height: 14px;
}

.img_topAbout1 {
	width: 370px;
	position: absolute;
	top: -213px;
	right: -428px;
}

.img_topAbout2 {
	width: 40%;
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 0;
}

.img_topAbout2 img,
.img_topBusiness2 img,
.img_topEfforts2 img {
	display: none;
}

.img_topAbout2::before {
	content: "";
	width: calc(115% + 205px);
	height: 434px;
	background-image: url(../img/top/img_topabout2.png);
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 100px;
	left: -205px;
	z-index: -1;
}

.col_topBusiness {
	margin: 0;
	padding: 100px 0 160px;
	position: relative;
	top: 0;
}

.inner_topBusiness {
	width: 92%;
	margin: 0 auto;
	padding: 0;
}

.col_topBusiness .mds_top1 .en {
	max-width: 196px;
}

.wrap_topBusiness {
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: row-reverse;
}

.grad_topBusiness {
	width: 60%;
	padding: 60px 0 65px 80px;
	color: #fff;
	position: relative;
	top: -100px;
	z-index: 1;
}

.grad_topBusiness::before {
	content: "";
	width: 120%;
	height: 100%;
	background: rgb(0, 49, 129);
	/* Old browsers */
	background: -moz-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* FF3.6-15 */
	background: -webkit-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(135deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#003181', endColorstr='#189b84', GradientType=1);
	/* IE6-9 fallback on horizontal gradient */
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	transform: skewX(-15deg);
}

.grad_topBusiness::after {
	content: "";
	width: 850px;
	height: 1160px;
	background-image: url(../img/top/deco_main.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top left;
	transform: scale(-1, 1);
	opacity: 0.16;
	position: absolute;
	top: -205px;
	right: -230px;
	z-index: -1;
}

.grad_topBusiness dl {
	margin: 0 0 60px;
	padding: 0;
}

.grad_topBusiness dl dt {
	margin: 0 0 14px;
	padding: 0 0 0 0.8em;
	font-weight: 400;
	font-size: 34px;
	line-height: 1.5;
	transform: skewX(-10deg);
}

.grad_topBusiness dl dd {
	margin: 0;
	padding: 0;
	font-weight: 300;
	line-height: 2;
	transform: skewX(-10deg);
}

.grad_topBusiness .skew {
	transform: skewX(10deg);
	display: inline-block;
}

.img_topBusiness1 {
	width: 390px;
	position: absolute;
	bottom: -240px;
	left: 125px;
}

.img_topBusiness2 {
	width: 40%;
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 0;
}

.img_topBusiness2::before {
	content: "";
	width: calc(115% + 205px);
	height: 434px;
	background-image: url(../img/top/img_topbusiness2.png);
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 0;
	right: -205px;
	z-index: -1;
}

.col_topEfforts {
	margin: 0;
	padding: 0 0 260px;
	position: relative;
	top: 0;
}

.inner_topEfforts {
	width: 92%;
	margin: 0 auto;
	padding: 0;
}

.col_topEfforts .mds_top1 .en {
	max-width: 212px;
}

.wrap_topEfforts {
	margin: 0;
	padding: 0;
	display: flex;
}

.grad_topEfforts {
	width: 60%;
	padding: 60px 0 110px;
	color: #fff;
	position: relative;
	z-index: 1;
}

.grad_topEfforts::before {
	content: "";
	width: 120%;
	height: 100%;
	background: rgb(0, 49, 129);
	/* Old browsers */
	background: -moz-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* FF3.6-15 */
	background: -webkit-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(135deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
	/* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#003181', endColorstr='#189b84', GradientType=1);
	/* IE6-9 fallback on horizontal gradient */
	position: absolute;
	z-index: -1;
	top: 0;
	right: 0;
	transform: skewX(-15deg);
}

.grad_topEfforts::after {
	content: "";
	width: 850px;
	height: 1160px;
	background-image: url(../img/top/deco_main.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top left;
	opacity: 0.16;
	position: absolute;
	top: -405px;
	left: -230px;
	z-index: -1;
}

.grad_topEfforts dl {
	margin: 0 0 33px;
	padding: 0;
}

.grad_topEfforts dl dt {
	margin: 0 0 40px;
	padding: 0 0 0 0.8em;
	font-weight: 400;
	font-size: 34px;
	line-height: 1.5;
	transform: skewX(-10deg);
}

.grad_topEfforts dl dd {
	margin: 0;
	padding: 0;
	font-weight: 300;
	line-height: 2;
	transform: skewX(-10deg);
}

.grad_topEfforts .skew {
	transform: skewX(10deg);
	display: inline-block;
}

.grad_topEfforts [class*="line"] {
	position: relative;
}

.grad_topEfforts .line1 {
	left: 1.2em;
}

.grad_topEfforts .line2 {
	left: 0.8em;
}

.grad_topEfforts .line3 {
	left: 0.8em;
}

.grad_topEfforts .line4 {
	left: 0.4em;
}

.grad_topEfforts .line5 {
	left: 0em;
}

.img_topEfforts1 {
	width: 412px;
	position: absolute;
	bottom: -190px;
	left: -115px;
}

.img_topEfforts2 {
	width: 40%;
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 0;
}

.img_topEfforts2::before {
	content: "";
	width: calc(115% + 205px);
	height: 434px;
	background-image: url(../img/top/img_topefforts2.png);
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 100px;
	left: -205px;
	z-index: -1;
}

.col_topCompany {
	width: 100%;
	height: 356px;
	margin: 0;
	padding: 0 0 20px;
	color: #fff;
	display: flex;
	align-items: center;
	background-image: url(../img/top/bg_company.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: relative;
	z-index: 1;
}

.inner_topCompany {
	width: 94%;
	max-width: 1260px;
	margin: 0 auto;
	padding: 0;
}

.mds_topCompany {
	margin: 0 0 40px;
	padding: 0;
	text-align: center;
}

.mds_topCompany .en {
	max-width: 386px;
	margin: 0 auto 20px;
	display: block;
}

.mds_topCompany .ja {
	color: #fff;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.45;
	letter-spacing: 0.3em;
	text-indent: 0.3em;
	text-align: center;
	display: block;
}

.btn_topCompany {
	width: 190px;
	margin: 0 auto;
	padding: 12px 10px;
	color: #fff;
	text-align: center;
	text-decoration: none;
	border: solid 1px #fff;
	display: block;
	position: relative;
	z-index: 0;
	transition: .2s;
}

.btn_topCompany::after {
	content: "";
	width: 5px;
	height: 5px;
	border-top: solid 1px #fff;
	border-right: solid 1px #fff;
	position: absolute;
	top: calc(50% - 3px);
	right: 16px;
	transform: rotate(45deg);
}

.col_topNews {
	margin: 0;
	padding: 75px 0 115px;
}

.inner_topNews {
	width: 94%;
	max-width: 870px;
	margin: 0 auto;
	padding: 0;
}

.mds_topNews {
	margin: 0 0 48px;
	padding: 0;
	text-align: center;
}

.mds_topNews .en {
	max-width: 120px;
	margin: 0 auto 10px;
	display: block;
}

.mds_topNews .ja {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.45;
	text-align: center;
	display: block;
}

.wrap_topNews {
	margin: 0;
	padding: 0;
}

ul.tab_topNews {
	width: 100%;
	margin: 0 0 25px;
	padding: 0;
	display: flex;
}

ul.tab_topNews li {
	width: 25%;
	height: 58px;
	margin: 0;
	padding: 0 0 9px;
	color: #666;
	font-size: 17px;
	font-weight: 500;
	line-height: 1.4;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 0;
	transition: .3s;
	cursor: pointer;
}

ul.tab_topNews li:after {
	content: "";
	width: 1px;
	height: 50px;
	background-color: #919191;
	position: absolute;
	right: 0;
	top: 0;
}

ul.tab_topNews li:first-of-type:before {
	content: "";
	width: 1px;
	height: 50px;
	background-color: #919191;
	position: absolute;
	left: 0;
	top: 0;
}

ul.tab_topNews li.active {
	color: #fff;
	background: rgb(0, 98, 170);
	/* Old browsers */
	background: -moz-linear-gradient(left, rgba(0, 98, 170, 1) 0%, rgba(34, 181, 115, 1) 100%);
	/* FF3.6-15 */
	background: -webkit-linear-gradient(left, rgba(0, 98, 170, 1) 0%, rgba(34, 181, 115, 1) 100%);
	/* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to right, rgba(0, 98, 170, 1) 0%, rgba(34, 181, 115, 1) 100%);
	/* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#0062aa', endColorstr='#22b573', GradientType=1);
	/* IE6-9 */
}

ul.tab_topNews li [class*="mask"] {
	width: calc(50% - 8px);
	height: 8px;
	background-color: #fff;
	position: absolute;
	bottom: 0;
}

ul.tab_topNews li [class*="mask"]:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
	top: 0;
}

ul.tab_topNews li .mask_l {
	left: 0;
}

ul.tab_topNews li .mask_l:before {
	border-width: 8px 0 0 8px;
	border-color: transparent transparent transparent #fff;
	right: -8px;
}

ul.tab_topNews li .mask_r {
	right: 0;
}

ul.tab_topNews li .mask_r:before {
	border-width: 0 0 8px 8px;
	border-color: transparent transparent #fff transparent;
	left: -8px;
}

.cont_topNews {
	margin: 0;
	padding: 0;
	color: #666666;
}

.list_topNews {
	width: 100%;
	margin: 0;
	padding: 24px 30px 24px 14px;
	color: #666;
	text-decoration: none;
	border-bottom: solid 1px #919191;
	display: flex;
	align-items: center;
	position: relative;
	z-index: 0;
	transition: .2s;
}

.list_topNews::after {
	content: "";
	width: 7px;
	height: 7px;
	border-top: solid 2px #424242;
	border-right: solid 2px #424242;
	position: absolute;
	top: calc(50% - 3px);
	right: 10px;
	transform: rotate(45deg);
	transition: .2s;
}

.list_topNews .date {
	width: 158px;
	flex-shrink: 0;
}

.list_topNews .tag {
	width: 78px;
	padding: 1px 0;
	color: #fff;
	font-size: 13px;
	text-align: center;
	flex-shrink: 0;
}

.list_topNews .tag.news {
	background-color: #86abe2;
}

.list_topNews .tag.event {
	background-color: #98d600;
}

.list_topNews .tag.recruit {
	background-color: #ec7672;
}

.list_topNews .txt {
	padding: 0 0 0 40px;
}

.txt_noNews {
	padding: 40px 0;
	text-align: center;
}

.link_topNews {
	margin: 20px 6px 0 0;
	padding: 0;
	text-align: right;
}

.link_topNews a {
	padding: 0 25px 0 0;
	color: #666666;
	font-weight: 500;
	text-decoration: none;
	position: relative;
	z-index: 0;
	display: inline-block;
}

.link_topNews a::after {
	content: "";
	width: 6px;
	height: 6px;
	border-top: solid 1px #424242;
	border-right: solid 1px #424242;
	position: absolute;
	top: calc(50% - 3px);
	right: 0;
	transform: rotate(45deg);
}

.col_topRecruit {
	margin: 0;
	padding: 0 0 100px;
}

.inner_topRecruit {
	width: 94%;
	max-width: 1260px;
	margin: 0 auto;
	padding: 0;
}

.bnr_topRecruit {
	width: 100%;
	max-width: 834px;
	margin: 0 auto;
	padding: 10px;
	color: #003067;
	text-decoration: none;
	display: flex;
	align-items: center;
}

.bnr_topRecruit dl {
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 30px 48% 25px 0;
	background-color: #e6e6e6;
	background-image: url(../img/top/img_recruit.png);
	background-repeat: no-repeat;
	background-size: 430px auto;
	background-position: right bottom;
	transition: .2s;
}

.bnr_topRecruit dl dt {
	margin: 0 0 24px;
	padding: 0;
}

.bnr_topRecruit .big {
	width: 348px;
	margin: 0 auto 10px;
	display: block;
}

.bnr_topRecruit .small {
	width: 344px;
	margin: 0 auto;
	display: block;
}

.bnr_topRecruit dl dd {
	width: 190px;
	margin: 0 auto;
	padding: 17px 10px;
	color: #fff;
	font-weight: 500;
	line-height: 1.3;
	text-align: center;
	background-color: #003067;
	position: relative;
	z-index: 0;
	transition: .2s;
}

.bnr_topRecruit dl dd::after {
	content: "";
	width: 5px;
	height: 5px;
	border-top: solid 1px #fff;
	border-right: solid 1px #fff;
	position: absolute;
	top: calc(50% - 3px);
	right: 16px;
	transform: rotate(45deg);
}


/* ---------------------------------------------------------------
	start max 1200px
--------------------------------------------------------------- */

@media screen and (max-width: 1200px) {

	.col_topAbout::after {
		left: calc(2% - 260px);
	}

	.inner_topAbout,
	.inner_topBusiness,
	.inner_topEfforts {
		width: 96%;
	}

	.grad_topBusiness {
		padding-left: 40px;
	}

	.grad_topAbout ul,
	.grad_topBusiness ul,
	.grad_topEfforts ul {
		padding-left: 20px;
	}

	.grad_topAbout ul li,
	.grad_topBusiness ul li,
	.grad_topEfforts ul li {
		width: 154px;
	}

	.img_topAbout2::before,
	.img_topEfforts2::before {
		height: 360px;
		left: -150px;
	}

	.img_topBusiness2::before {
		height: 390px;
		right: -150px;
	}

}

/* ---------------------------------------------------------------
	end max 1200px
--------------------------------------------------------------- */

/* ---------------------------------------------------------------
	start max 1033px
--------------------------------------------------------------- */

@media screen and (max-width: 1033px) {

	.col_topMain {
		height: 1000px;
	}

	.col_topMain::before {
		width: 160px;
		height: 160px;
		top: 187px;
		left: -46px;
	}

	.col_topAbout {
		margin-bottom: -30px;
		padding-bottom: 0;
		top: -100px;
	}

	.col_topAbout::after {
		content: none;
	}

	.inner_topAbout,
	.inner_topBusiness,
	.inner_topEfforts {
		width: 100%;
	}

	.mds_top1 {
		margin-bottom: 20px;
		text-align: center;
	}

	.mds_top1 .en {
		margin: 0 auto 10px;
	}

	.wrap_topAbout,
	.wrap_topBusiness,
	.wrap_topEfforts {
		padding: 60px 0;
		background: rgb(0, 49, 129);
		/* Old browsers */
		background: -moz-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
		/* FF3.6-15 */
		background: -webkit-linear-gradient(-45deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
		/* Chrome10-25,Safari5.1-6 */
		background: linear-gradient(135deg, rgba(0, 49, 129, 1) 0%, rgba(0, 98, 170, 1) 45%, rgba(24, 155, 132, 1) 100%);
		/* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
		filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#003181', endColorstr='#189b84', GradientType=1);
		/* IE6-9 fallback on horizontal gradient */
		flex-direction: column;
		overflow: hidden;
	}

	.wrap_topAbout:after,
	.wrap_topBusiness::after,
	.wrap_topEfforts::after {
		content: "";
		width: 100%;
		height: 100%;
		;
		background-image: url(../img/top/sp/bg_about.png);
		background-repeat: no-repeat;
		background-size: cover;
		background-position: top left;
		position: absolute;
		top: 0;
		left: 0;
	}

	.wrap_topBusiness::after {
		transform: scale(-1, 1);
	}

	.grad_topAbout,
	.grad_topBusiness,
	.grad_topEfforts {
		width: 100%;
		padding: 100px 4% 0;
		order: 1;
		top: 0;
	}

	.grad_topAbout::before,
	.grad_topBusiness::before,
	.grad_topEfforts::before,
	.grad_topAbout::after,
	.grad_topBusiness::after,
	.grad_topEfforts::after {
		content: none;
	}

	.grad_topAbout dl,
	.grad_topBusiness dl,
	.grad_topEfforts dl {
		margin-bottom: 30px;
	}

	.grad_topAbout dl dt,
	.grad_topBusiness dl dt,
	.grad_topEfforts dl dt {
		margin-bottom: 20px;
		padding: 0;
		text-align: center;
		line-height: 1.45;
		transform: skewX(0deg);
	}

	.grad_topAbout dl dd,
	.grad_topBusiness dl dd,
	.grad_topEfforts dl dd {
		transform: skewX(0deg);
	}

	.grad_topAbout .skew,
	.grad_topBusiness .skew,
	.grad_topEfforts .skew {
		transform: skewX(0deg);
		display: inline;
	}

	.grad_topAbout dl dd br,
	.grad_topBusiness dl dd br,
	.grad_topEfforts dl dd br {
		display: none;
	}

	.grad_topAbout ul,
	.grad_topBusiness ul,
	.grad_topEfforts ul {
		padding: 0;
		justify-content: center;
		left: 0;
	}

	.grad_topAbout ul li,
	.grad_topBusiness ul li,
	.grad_topEfforts ul li {
		width: 170px;
		margin-right: 20px;
		transform: skewX(0deg);
	}

	.grad_topAbout ul li a span,
	.grad_topBusiness ul li a span,
	.grad_topEfforts ul li a span {
		transform: skewX(0deg);
	}

	.img_topAbout1,
	.img_topBusiness1,
	.img_topEfforts1 {
		width: 44%;
		top: -18vw;
		bottom: auto;
		left: auto;
		right: -25px;
	}

	.img_topBusiness1 .sp_none,
	.img_topEfforts1 .sp_none {
		display: none;
	}

	.img_topAbout2,
	.img_topBusiness2,
	.img_topEfforts2 {
		width: 86%;
		order: 0;
		z-index: 1;
	}

	.img_topAbout2::before,
	.img_topBusiness2::before,
	.img_topEfforts2::before {
		content: none;
	}

	.img_topAbout2 img,
	.img_topBusiness2 img,
	.img_topEfforts2 img {
		display: inline;
	}

	.col_topBusiness {
		margin-bottom: 70px;
		padding: 0;
	}

	.col_topEfforts {
		margin-bottom: 70px;
		padding: 0;
	}




}

/* ---------------------------------------------------------------
	end max 1033px
--------------------------------------------------------------- */


/* ---------------------------------------------------------------
	start max 850px
--------------------------------------------------------------- */

@media screen and (max-width: 850px) {


	.col_topMain::before {
		width: 135px;
		height: 135px;
		top: 170px;
		left: -40px;
	}

	.list_topNews .date {
		width: 135px;
	}

	.list_topNews .txt {
		padding-left: 25px;
	}

	.bnr_topRecruit dl {
		padding-right: 40vw;
		background-size: 47vw auto;
	}

	.bnr_topRecruit .big {
		width: 41vw;
	}

	.bnr_topRecruit .small {
		width: 41vw;
	}

	.bnr_topRecruit dl dd {
		width: 175px;
		padding: 13px 10px;
	}


}

/* ---------------------------------------------------------------
	end max 850px
--------------------------------------------------------------- */
/* ---------------------------------------------------------------
	start min 701px
--------------------------------------------------------------- */

@media print,
screen and (min-width: 701px) {


	.grad_topAbout ul li a:hover,
	.grad_topBusiness ul li a:hover,
	.grad_topEfforts ul li a:hover {
		background-color: #f2fff2;
	}

	.btn_topCompany:hover {
		background-color: #189c84;
	}

	ul.tab_topNews li:hover {
		background-color: #f2fff2;
	}

	.list_topNews:hover {
		background-color: #f2fff2;
	}

	.link_topNews a:hover {
		text-decoration: underline;
	}

	.list_topNews .txt {
		padding: 0 0 0 40px;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
		-webkit-text-overflow: ellipsis;
		-o-text-overflow: ellipsis;
	}

	.bnr_topRecruit:hover dl {
		background-color: #d3d3d3;
	}

	.bnr_topRecruit:hover dl dd {
		background-color: #0065db;
	}


}

/* ---------------------------------------------------------------
	end min 701px
--------------------------------------------------------------- */
/* ---------------------------------------------------------------
	start max 700px
--------------------------------------------------------------- */

@media print,
screen and (max-width: 700px) {

	.col_topMain {
		height: auto;
		padding: 0 0 60px;
		background-image: url(../img/top/sp/mainimg.jpg);
		background-size: 100% auto;
	}

	.col_topMain::after {
		top: 76vw;
	}

	.col_topMain::before {
		width: 100px;
		height: 100px;
		top: 145px;
		left: -30px;
	}

	.inner_topMain {
		width: 90%;
		padding-top: 124vw;
	}

	dl.cont_topMain dt {
		width: 58vw;
		margin-bottom: 7vw;
	}

	dl.catch_topMain {
		top: 59vw;
		right: 5%;
	}

	dl.catch_topMain dt {
		margin-bottom: 1.2vw;
		font-size: 5.5vw;
	}

	dl.catch_topMain dd {
		width: 80vw;
	}

	.col_topAbout {
		margin-bottom: 50px;
		top: 0;
	}

	.col_topAbout .mds_top1 .en {
		max-width: 182px;
	}

	.col_topBusiness .mds_top1 .en {
		max-width: 160px;
	}

	.col_topEfforts .mds_top1 .en {
		max-width: 176px;
	}

	.wrap_topAbout,
	.wrap_topBusiness,
	.wrap_topEfforts {
		padding: 45px 0;
	}

	.grad_topAbout,
	.grad_topBusiness,
	.grad_topEfforts {
		padding: 60px 5% 0;
	}

	.grad_topAbout dl dt,
	.grad_topBusiness dl dt,
	.grad_topEfforts dl dt {
		margin-bottom: 16px;
		font-size: 28px;
	}

	.grad_topAbout dl dd,
	.grad_topBusiness dl dd,
	.grad_topEfforts dl dd {
		line-height: 1.8;
	}

	.grad_topAbout ul li,
	.grad_topBusiness ul li,
	.grad_topEfforts ul li {
		margin-right: 10px;
	}

	.grad_topAbout ul li a,
	.grad_topBusiness ul li a,
	.grad_topEfforts ul li a {
		height: 44px;
	}

	.col_topBusiness {
		margin-bottom: 50px;
	}

	.col_topEfforts {
		margin-bottom: 50px;
	}

	.col_topCompany {
		height: 280px;
		padding-bottom: 0;
		background-image: url(../img/top/sp/bg_company.jpg);
	}

	.mds_topCompany {
		margin-bottom: 25px;
	}

	.mds_topCompany .en {
		width: 90%;
		max-width: 340px;
	}

	.btn_topCompany {
		width: 175px;
		padding-top: 6px;
		padding-bottom: 6px;
	}

	.col_topNews {
		padding: 55px 0 55px;
	}

	.inner_topNews {
		width: 90%;
	}

	.mds_topNews {
		margin-bottom: 25px;
	}

	ul.tab_topNews {
		margin-bottom: 15px;
	}

	ul.tab_topNews li {
		height: 50px;
		font-size: 15px;
	}

	ul.tab_topNews li:after {
		height: 42px;
	}

	.list_topNews {
		padding: 20px 0px 20px 10px;
		flex-wrap: wrap;
	}

	.list_topNews::after {
		content: none;
	}

	.list_topNews .date {
		width: 125px;
	}

	.list_topNews .tag {
		width: 72px;
		padding: 0;
	}

	.link_topNews {
		margin-top: 15px;
		margin-right: 10px;
	}

	.list_topNews .txt {
		width: 100%;
		margin: 5px 0 0 0;
		padding: 0;
		line-height: 1.65;
	}

	.link_topNews a {
		padding-right: 15px;
	}

	.inner_topRecruit {
		width: 90%;
	}

	.bnr_topRecruit {
		max-width: 540px;
		height: 520px;
		padding: 8px;
	}

	.bnr_topRecruit dl {
		padding: 40px 20px 20px;
		background-size: 102% auto;
	}

	.bnr_topRecruit .big {
		width: 340px;
		margin-bottom: 15px;
	}

	.bnr_topRecruit .small {
		width: 340px;
	}

	.bnr_topRecruit dl dd {
		width: 170px;
		font-size: 16px;
	}

	.bnr_topRecruit dl dd::after {
		width: 7px;
		height: 7px;
		top: calc(50% - 4px);
	}


}

/* ---------------------------------------------------------------
	end max 700px
--------------------------------------------------------------- */
/* ---------------------------------------------------------------
	start max 600px
--------------------------------------------------------------- */

@media print,
screen and (max-width: 600px) {


	.bnr_topRecruit {
		max-width: 96%;
		height: auto;
	}

	.bnr_topRecruit dl {
		padding: 6vw 20px 46vw;
	}

	.bnr_topRecruit dl dt {
		margin-bottom: 4vw;
		line-height: 1;
	}

	.bnr_topRecruit .big {
		width: 56vw;
		margin-bottom: 3vw;
	}

	.bnr_topRecruit .small {
		width: 56vw;
	}

}

/* ---------------------------------------------------------------
	end max 600px
--------------------------------------------------------------- */

/* ---------------------------------------------------------------
	start max 450px
--------------------------------------------------------------- */

@media screen and (max-width: 450px) {



	.wrap_topAbout,
	.wrap_topBusiness,
	.wrap_topEfforts {
		padding: 30px 0;
	}

	.mds_top1 .en {
		margin-bottom: 8px;
	}

	.col_topAbout .mds_top1 .en {
		max-width: 152px;
	}

	.col_topBusiness .mds_top1 .en {
		max-width: 140px;
	}

	.col_topEfforts .mds_top1 .en {
		max-width: 132px;
	}

	.grad_topAbout,
	.grad_topBusiness,
	.grad_topEfforts {
		padding-top: 14%;
	}

	.grad_topAbout dl dt,
	.grad_topBusiness dl dt,
	.grad_topEfforts dl dt {
		font-size: 21px;
	}

	.grad_topAbout ul,
	.grad_topBusiness ul,
	.grad_topEfforts ul {
		flex-wrap: wrap;
	}

	.grad_topAbout ul li,
	.grad_topBusiness ul li,
	.grad_topEfforts ul li {
		width: 132px;
		margin-bottom: 10px;
	}

	.col_topCompany {
		height: 240px;
	}

	ul.tab_topNews {
		margin-bottom: 5px;
	}

	ul.tab_topNews li {
		font-size: 14px;
	}




}

/* ---------------------------------------------------------------
	end max 450px
--------------------------------------------------------------- */