@charset "utf-8";
/* CSS Document */
#topPage{
	line-height: 2;
}
#mainVisual{
	position: relative;
}
#mainVisual video{
	width: 100%;
	height: 100%;
}

#topPage #news > .contents{
	justify-content: center;
	align-items: flex-start;
}

h2{
	font-size: 38px;
}

@media screen and (max-width: 1440px){
	/*#mainVisual {
		height: 56vw;
	}*/
}
@media screen and (max-width: 767px){
	h2{
		font-size: 3rem;
	}
}

/* ニュース
--------------------------------------------------------------------------- */
#news{
	padding: 110px 0 40px;
}
#news h2{
	margin-left: 50px;
}
#news .detail_box{
	max-width: 700px;
	width: 80%;
	margin-left: 80px;
}

#news .detail_box ul{
	border-top: solid 1px #b6b6b6;
}

#news .detail_box li{
	display: flex;
	align-items: center;
	justify-content: flex-start;
	border-bottom: solid 1px #b6b6b6;
	padding: 13px 0;
}

#news .detail_box li .time{
	margin-left: 14px;
	min-width: 85px;
	font-size: 18px;
	flex-shrink: 0;
}

.detail_box .detail-ttl{
	text-align: left;
	padding: 0 10px 0 18px;
}

@media screen and (max-width: 1040px){
	#news h2{
		margin-left: 30px;
	}

}
@media screen and (max-width: 1023px){
	#news h2{
		margin-left: 0;
		flex-shrink: 0;
	}
	#news .detail_box{
		margin-left: 40px;
	}
}

@media screen and (max-width: 767px){
	#news{
		padding: 40px 0;
	}
	#topPage #news > .contents{
		display: block;
	}
	#news h2{
		text-align: left;
		flex-shrink: 1;
	}
	#news .detail_box{
		max-width: auto;
		width: 100%;
		margin-left: 0;
	}
	#news .detail_box li{
		display: block;
		text-align: left;
		padding: 6px 0 4px;
	}
	#news .detail_box li .time{
		font-size: 1.2rem;
	}
	#news .detail_box li .cat{
		margin-left: 14px;
		vertical-align: middle;
		margin-bottom: 3px;
	}
	.detail_box .detail-ttl{
		padding: 0 10px;
	}
}

/* 会社情報
--------------------------------------------------------------------------- */
#company{
	margin-top: 80px;
	position: relative;
}
	#company::before{
		content: "";
		width: 70%;
		height: 290%;
		background: #f2f2f2;
		position: absolute;
		top: 40px;
		left: 0;
		z-index: -1;
	}

#company .wrap_area{
	padding: 70px 0 50px;
	position: relative;
}
	#company .wrap_area .txt_box{
		text-align: left;
	}

.lead{
	font-size: 22px;
	font-weight: 600;
}

#company .wrap_area .txt_box .lead_link01{
	margin-top: 15px;
}

#company .wrap_area .img_box{
	position: absolute;
	max-width: 800px;
	width: 75%;
	top: 0;
	right: 0;
	text-align: right;
	z-index: -1;
}
@media screen and (max-width: 1120px){
	#company .wrap_area .img_box{
		width: 64%;
		margin-right: -20px;
	}
}
@media screen and (max-width: 900px){
	#company{
		margin: 40px 0;
	}
	#company::before{
		height: 88%;
	}
}
@media screen and (max-width: 767px){
	#company {
		margin: 0;
	}
	#company::before{
		content: none;
	}
	#company .wrap_area{
		display: flex;
		flex-direction: column-reverse;
		margin: 0 -20px 0;
		position: relative;
		padding: 0 0 40px;
	}
	#company .wrap_area .img_box{
		position: inherit;
		max-width: inherit;
		width: 100%;
		margin: auto;
	}
	#company .wrap_area .img_box img{
		width: 100%;
	}
	#company .wrap_area .txt_box{
		margin-left: 0;
		padding: 20px 20px 0;
	}
	
	#company .wrap_area h2.spStyle{
		position: absolute;
		top: 20px;
		left: 20px;
	}
	
	#company .wrap_area .txt_box .lead_link01{
		text-align: right;
		width: 100%;
	}
	.lead{
		font-size: 1.8rem;
	}
}


/* 事業内容
--------------------------------------------------------------------------- */
#business{
	margin-bottom: 40px;
}
#business h3{
	font-size: 22px;
	position: relative;
	display: flex;
	justify-content: flex-start;
	align-items: center;
}

#business .wrap_area > .txt_box{
	/*width: 46%;*/
	width: 100%;
	margin: 80px 0 20px auto;
	text-align: left;
}

#business .business_box ul{
	justify-content: flex-start;
	align-items: stretch;
	flex-wrap: wrap;
	width: 100%;
}
	#business .business_box ul li{
		width: 48%;
		text-align: left;
		position: relative;
		overflow: hidden;
		margin-bottom: 2%;
		z-index: 1;
		margin-right: 4%;
	}
		#business .business_box ul li:nth-child(2n){
			margin-right: 0;
		}

#business .business_box ul li:hover a{
	text-decoration: none;
}
	#business .business_box ul li a figure{
		overflow: hidden;
	}
		#business .business_box ul li a figure img{
			transition: 0.3s all ease;
		}
			#business .business_box ul li:hover a figure img{
				transform: scale(1.1);
			}


@media screen and (max-width: 900px){
	#business{
		background: #f2f2f2;
		padding: 40px 0;
	}
		#business .wrap_area > .txt_box{
			margin: 0 0 20px auto;
			width: 100%;
		}

	#business .business_box ul li a{
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
		#business .business_box ul li a::after{
			position: inherit;
			right: auto;
			bottom: auto;
		}
}

@media screen and (max-width: 767px){
	#business .business_box ul{
		display: block;
	}
		#business .business_box ul li{
			width: 100%;
			max-width: inherit;
			margin-bottom: 30px;
			padding: 0;
		}
			#business .business_box ul li:last-child{
				margin-bottom: 0;
			}
	
		#business .business_box ul li a{
			flex-direction: column-reverse;
			max-width: 380px;
			width: 100%;
			margin: 0 auto;
		}
	
	#business .business_box ul li .txt_box,
	#business .business_box ul li.list01 .txt_box,
	#business .business_box ul li.list03 .txt_box{
		width: 100%;
		margin-right: 0;
	}
	
	#business h3{
		justify-content: space-between;
		align-items: flex-end;
		margin-top: 10px;
		font-size: 1.8rem;
	}
	#business h3::after{
		content: "";
		display: inline-block;
		background: url(/common/img/icon_arrow.png) no-repeat center bottom;
		background-size: contain;
		width: 40px;
		height: 18px;
		margin-bottom: 10px;
	}
	#business h3 .mark02,
	#business .business_box ul li .txt_box p{
		display: none;
	}
}

/* 製品情報
--------------------------------------------------------------------------- */
#product{
	margin-bottom: 100px;
	padding-bottom: 40px;
}
	#product > .contents{
		align-items: stretch;
		padding-top: 100px;
	}
		#product > .contents > .txt_box{
			width: 54%;
			text-align: left;
			background: url("/img/product_bg_visual.jpg") no-repeat right bottom;
			background-size: contain;
			padding-right: 20px;
			padding-bottom: 27%;
		}

.product_box{
	width: 46.299%;
	margin-bottom: -80px;
}

.product_box ul{
}
	.product_box ul li{
		max-width: 500px;
		width: 100%;
		background: #fff;
		margin-bottom: 10px;
		border: solid 1px #b6b6b6;
	}
		.product_box ul li a{
			display: flex;
			justify-content: flex-start;
			align-items: center;
		}
			.product_box ul li a figure{
				flex-shrink: 0;
				overflow: hidden;
			}

.product_box ul li:last-child{
	margin-bottom: 0;
}

.product_box ul li a:hover{
	text-decoration: none;
}

.product_box ul li a .txt_box{
	padding: 10px 20px;
	text-align: left;
	width: 100%;
	position: relative;
}
	.product_box ul li a .txt_box .arrow01{
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%);
		transition: 0.3s all ease;
	}

.product_box ul li a .txt_box .copy{
	font-weight: 700;
}

@media screen and (min-width: 768px){
	.product_box ul li a figure img{
		transition: 0.3s all ease;
	}
	.product_box ul li:hover a figure img{
		transform: scale(1.2);
	}
	.product_box ul li:hover a .txt_box .arrow01{
		right: 10px;
	}
}
@media screen and (max-width: 1024px){
	.product_box ul li a figure{
		width: 140px;
	}
}
@media screen and (max-width: 1023px){
	#product > .contents > .txt_box{
		width: 38%;
		padding-right: 0;
		padding-bottom: 20%;
	}
	.product_box{
		width: 60%;
	}
}
@media screen and (max-width: 900px){
	#product > .contents{
		padding-top: 40px;
	}
}

@media screen and (max-width: 767px){
	#product{
		background: none;
		margin-bottom: 40px;
		padding-bottom: 0;
	}
	#product > .contents{
		display: block;
		position: relative;
		padding-top: 0;
	}
	#product > .contents > figure{
		margin: 0 -20px;
	}
	#product > .contents > .txt_box{
		width: 100%;
		padding: 20px 0;
		background: none;
	}
	#product h2{
		position: absolute;
		top: 20px;
		left: 20px;
		z-index: 1;
	}
	.product_box{
		width: 100%;
		margin-bottom: 0;
	}
	.product_box ul{
		display: flex;
		flex-wrap: wrap;
	}
	.product_box ul li{
		max-width: inherit;
		width: 48%;
		border: none;
	}
		.product_box ul li:nth-child(2n){
			margin-left: 4%;
		}
	
	.product_box ul li a{
		flex-direction: column;
	}
		.product_box ul li a figure{
			flex-shrink: 1;
			width: 100%;
		}
		.product_box ul li a figure img{
			width: 100%;
		}
	
		.product_box ul li a .txt_box{
			padding: 10px 0 0;
			font-size: 1.2rem;
		}
			.product_box ul li a .txt_box .arrow01{
				position: inherit;
				top: auto;
				right: 0;
				transform: none;
				display: block;
				text-align: right;
			}
}


/* 採用情報
--------------------------------------------------------------------------- */
#recruit{
	background: url("/img/recruit_bg_visual.jpg") no-repeat left center;
	background-size: cover;
	margin-bottom: 80px;
	transition: .3s ease-in-out;
}
	#recruit:hover{
		box-shadow: 0px 0px 12px 1px #ccc;
	}

#recruit > a{
	padding: 3.2071vw 0;
	display: block;
}
#recruit > a:hover{
	text-decoration: none;
}

#recruit .contents{
	align-items: flex-start;
}

#recruit h2{
	position: absolute;
    left: 5%;
    top: 10px;
}

#recruit .lead{
	font-weight: 700;
}

#recruit .txt_box{
	text-align: left;
	width: 33%;
}

#recruit .txt_box .lead_link01{
	display: block;
	text-align: right;
}

@media screen and (max-width: 1200px){
	#recruit .txt_box{
		width: 50%;
	}
}

@media screen and (max-width: 767px){
	#recruit{
		background: none;
		height: auto;
		margin-bottom: 40px;
	}
	#recruit > a{
		padding: 0;
	}
	#recruit .contents{
		display: block;
	}
	#recruit .txt_box{
		color: #484848;
		width: 100%;
		padding: 20px 0 0;
	}
	#recruit .sp_mode{
		position: relative;
	}
		#recruit .sp_mode figure{
			margin: 0 -20px;
		}
	
	#recruit h2{
		position: absolute;
		top: auto;
		bottom: 20px;
		left: 0;
		margin-top: 0;
		text-shadow: 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 5px #fff;
	}
	#recruit .txt_box .lead_link01{
		color: #484848;
	}
	#recruit .txt_box .lead_link01 .arrow01::before{
		background: url(/common/img/icon_arrow.png) no-repeat center bottom;
		background-size: contain;
	}
}


/* お問い合わせ・サポート
--------------------------------------------------------------------------- */
#contact{
	background: rgb(32,171,150);
	background: linear-gradient(45deg, rgba(32,171,150,1) 35%, rgba(0,90,68,1) 100%);
	color: #fff;
	padding: 80px 0;
}
#contact h2{
	color: #fff;
}
#contact .btn_box{
	width: 50%
}
#contact .btn_box p{
	text-align: left;
	margin-bottom: 20px;
}

#contact .btn_box a{
	color: #fff;
	width: 100%;
	padding: 15px;
	text-decoration: none;
	font-size: 21px;
	background: #484848;
	border: solid 1px #484848;
	display: inline-block;
}
#contact .btn_box a:hover{
	background: #fff;
	color: #484848;
}
	#contact .btn_box a:hover span::before {
		background: url("/common/img/icon_mail_gy.png") no-repeat center center;
		background-size: contain;
	}

@media screen and (max-width: 1023px){
	#contact .contents.flex{
		display: block;
	}
	#contact .btn_box{
		margin: 20px auto 0;
		width: 60%;
	}
}

@media screen and (max-width: 767px){
	#contact{
		padding: 40px 0;
	}
	#contact .btn_box{
		width: 100%;
	}
}

@media screen and (max-width: 480px){
	#contact h2{
		font-size: 2.4rem;
	}
	#contact .btn_box a{
		font-size: 1.8rem;
	}
	.contact_btn span::before{
		width: 20px;
		height: 16px;
	}
}




