@charset "utf-8";
.pgTtl{
	position:relative;
	line-height:1.0;
	text-align:center;
}
.pgTtl img{margin:0 auto;}
.pgTtl,
.pgTtl:after,
.pgTtl > *{position:relative;}
.pgTtl:not([data-line="none"]):after{
	content:"";
	display:block;
	width:100%;
	height:2px;
	background-color:#edd3c5;
}
.pgTtl .numTtl{
	display:table;
	position:absolute;
	line-height:1.0;
	color:#fff;
	z-index:0;
}
.txtBox{position:relative;z-index:1;}
section:not(#contactCorp) p strong{color:#d29576;}
#mainFV{
	position:relative;
	width:100%;
	overflow:hidden;
}
#mainFV img{
	width:100%;
	height:100%;
	object-fit:cover;
	object-position:center center;
}
#mainFV figcaption{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:10;
}
#mainFV figcaption{
	display:flex;
	justify-content:center;
	align-items:center;
	flex-direction:column;
}
#mainFV figcaption h2:after{
	content:"";
	display:block;
	margin:0 auto;
	background-color:#d29576;
}
#mainFV h2 > *{
	display:block;
	margin:0 auto;
	line-height:1.0;
	color:#000;
	text-align:center;
}
#mainFV h2 strong{color:#d29576;}
#mainFV h2 svg > *{fill:#000;}
#mind:before{
	content:"";
	display:block;
	position:absolute;
	background:url("../img/page-about/mind-bg01.svg") no-repeat center top / contain;
	z-index:-1;
}
#mind .pgTtl{margin:0 auto;}
#mind .fg{position:relative;}
#mind .fg:before{
	content:"";
	display:block;
	position:absolute;
	background:url("../img/page-about/mind-bg02.svg") no-repeat center top / contain;
	z-index:-1;
}
#mind .fg{
	position:relative;
	z-index:1;
}
#mind .txtBox p{line-height:2.2;}
#mind .txtBox strong{
	display:inline-block;
	color:#d29576;
	text-decoration:underline;
}
#safety .pgTtl:before{
	content:"";
	display:block;
	position:absolute;
	background:url("../img/page-about/safety-ttl-bg.svg") no-repeat;
	background-size:contain;
	z-index:0;
}
#technol .pgTtl:before{
	content:"";
	display:block;
	position:absolute;
	background:url("../img/page-about/technol-ttl-bg.svg") no-repeat;
	background-size:contain;
	z-index:0;
}
#technol .fg{text-align:center;}
#technol p{line-height:2.1;}
#support .pgTtl:before{
	content:"";
	display:block;
	position:absolute;
	background:url("../img/page-about/support-ttl-bg.svg") no-repeat;
	background-size:contain;
	z-index:0;
}
#support .txtBox .serviceListBox{
	display:table;
	margin-left:auto;
	text-align:left!important;
	border-radius:10px;
	background-color:#fff;
}
#support .txtBox .serviceListBox h3{color:#d29576;}
#support .txtBox .serviceListBox p{text-align:left!important;}
#mviBox .pgTtl:before{
	content:"";
	display:block;
	position:absolute;
	background:url("../img/page-about/mvi-ttl-bg.svg") no-repeat;
	background-size:contain;
	z-index:0;
}
#mvi{overflow:hidden;}
#mviBox #mvi{position:relative;}
#mviBox #mvi:before{
	width:100%;
	content:"";
	display:block;
	height:0;
	padding-top:56.25%;
}
#mviBox #mvi iframe{
	position:absolute;
	width:100%;
	height:100%;
	top:0;
	left:0;
}
#aboutSec{background-color:#fff;}
#aboutSec .menuTtl > *{
	display:block;
	line-height:1.0;
}
#aboutSec .aboutList a{
	color:#d29576;
	text-decoration:none;
}
#aboutSec .aboutList a:hover{opacity:0.7;}
#aboutSec .aboutList a,
#aboutSec .aboutList span{display:block;}
#aboutSec .aboutList li span:after{
	content:"";
	display:inline-block;
	background:url(../img/common/slider-next.svg) no-repeat center center / contain;
}
@media screen and (max-width:1159.999px){
	main > *[data-flex]:not([data-flex="reverse"]) .fg{margin-left:-6vw;}
	main > *[data-flex="reverse"] .fg{margin-right:-6vw;}
	main > *[data-flex] .txtBox{margin:42px 3.466vw 0;}
 	main > *[data-flex] .txtBox p+p{margin-top:28px;}
	.pgTtl:not([data-line="none"]){margin-bottom:28px;}
	.pgTtl:not([data-line="none"]):after{margin-top:18px;}
	#mainFV{height:112vw;}
	#mainFV figcaption h2:after{
		width:36px;
		height:3px;
		margin:13px auto 0;
		border-radius:2px;
	}
	#mainFV h2 strong{
		display:block;
		font-size:3.0rem;
	}
	#mainFV h2 svg{
		display:block;
		width:150px;
		margin-top:16px;
		margin-bottom:-13px;
	}
	#mainFV h2 small{
		margin-top:30px;
		font-size:1.4rem;
	}
	#mind{padding:70px 0 72px;}
	#mind:before{
		width:245px;
		height:249px;
		left:-73px;
		top:-211px;
	}
	#mind .pgTtl{
		width:100vw;
		margin:0 -6vw 45px;
	}
	#mind .pgTtl img{
		width:338px;
		margin:0 auto;
	}
	#mind .fg{
		width:315px;
		margin:0 auto;
		text-align:right;
	}
	#mind .fg img{
		width:263px;
		margin-left:auto;
	}
	#mind .fg:before{
		width:130px;
		height:131px;
		left:0;
		bottom:-28px;
	}
	#mind .txtBox{
		margin-top:54px;
		text-align:center;
	}
	#mind .txtBox p{font-size:1.6rem;}
	#mind .txtBox strong{text-underline-offset:6px;}
	#safety .fg img{border-radius:16px 0 0 16px;}
	#safety .pgTtl:before{
		width:86px;
		height:92px;
		top:3px;
		left:-40px;
	}
	#safety .pgTtl .numTtl{
		top:-23px;
		left:-20px;
	}
	#technol{margin-top:75px;}
	#technol .fg img{
		width:100vw;
		max-width:initial;
		height:53.333vw;
		object-fit:cover;
		object-position:center center;
		margin:0 -6vw;
	}
	#technol .pgTtl{
		margin-top:44px;
		padding-left:0;
	}
	#technol .pgTtl:before{
		width:95px;
		height:71px;
		bottom:-10px;
		right:17px;
	}
	#technol .pgTtl .numTtl{
		top:-23px;
		left:-20px;
	}
	#support{margin-top:75px;}
	#support .fg img{border-radius:0 16px 16px 0;}
	#support .pgTtl:before{
		width:83px;
		height:84px;
		top:-27px;
		left:-45px;
	}
	#support .pgTtl .numTtl{
		top:-23px;
		left:-20px;
	}
	#support .txtBox .serviceListBox{
		margin-top:24px;
		padding:16px 30px;
		text-align:left;
	}
	#support .txtBox .serviceListBox h3{font-size:1.4rem;}
	#support .txtBox .serviceListBox p{
		margin-top:10px;
		font-size:1.1rem;
	}
	#mviBox{margin-top:100px;}
	#mviBox .pgTtl:before{
		width:62px;
		height:63px;
		top:-27px;
		left:-45px;
	}
	#mviBox .pgTtl .numTtl{
		top:-23px;
		left:-20px;
	}
	#mvi{
		width:88vw;
		margin:24px auto 0;
		border-radius:16px;
	}
	#aboutSec{
		width:88vw;
		max-width:328px;
		margin-top:60px;
		border-radius:16px;
		padding:40px 0 32px;
	}
	#aboutSec .menuTtl{
		padding-bottom:28px;
		text-align:center;
	}
	#aboutSec .menuTtl strong{font-size:3.0rem;}
	#aboutSec .menuTtl small{
		margin-top:16px;
		font-size:1.2rem;
	}
	#aboutSec .aboutList{
		display:table;
		margin:0 auto;
		padding-top:38px;
		border-top:1px dashed #707070;
	}
	#aboutSec .aboutList li{
		width:240px;
		margin:0 auto;
	}
	#aboutSec .aboutList li+li{margin-top:34px;}
	#aboutSec .aboutList li span{
		margin-top:16px;
		font-size:1.6rem;
	}
	#aboutSec .aboutList li span:after{
		width:24px;
		height:24px;
		margin-left:12px;
		vertical-align:-5px;
	}
}
@media screen and (min-width:1160px){
	main{background:url("../img/page-about/main-bg.svg") no-repeat center 1836px;}
	main > *[data-flex] .fg{width:490px;}
	main > *[data-flex] .fg img{width:880px;}
	main > *[data-flex] .txtBox{width:600px;}
	main > *[data-flex] .txtBox p+p{margin-top:36px;}
	.pgTtl:not([data-line="none"]):after{margin-top:24px;}
	.pgTtl .numTtl{font-size:10.0rem;}
	#mainFV{height:800px;}
	#mainFV h2{padding-top:95px;}
	#mainFV figcaption h2:after{
		width:30px;
		height:4px;
		margin:24px auto 0;
		border-radius:2px;
	}
	#mainFV h2 strong{
		margin-top:38px;
		font-size:4.2rem;
	}
	#mainFV h2 svg{
		width:270px;
		margin-top:26px;
	}
	#mainFV h2 small{
		margin-top:42px;
		font-size:2.0rem;
	}
	#mind{
		max-width:1346px;
		display:flex;
		justify-content:space-between;
		flex-wrap:wrap;
		flex-direction:row-reverse;
		padding:148px 0 64px;
	}
	#mind:before{
		width:448px;
		height:454px;
		left:-324px;
		top:-293px;
	}
	#mind .pgTtl{
		width:100%;
		margin-bottom:80px;
	}
	#mind .pgTtl img{width:705px;}
	#mind .fg{width:632px;}
	#mind .fg:before{
		width:312px;
		height:316px;
		left:-143px;
		bottom:-64px;
	}
	#mind .txtBox{width:calc(100% - 706px);}
	#mind .txtBox p{font-size:2.0rem;}
	#mind .txtBox strong{text-underline-offset:8px;}
	#safety{margin-top:165px;}
	#safety .fg img{
		margin-right:-390px;
		border-radius:20px 0 0 20px;
	}
	#safety .txtBox{padding-top:42px;}
	#safety .pgTtl:before{
		width:104px;
		height:110px;
		top:15px;
		left:249px;
	}
	#safety .pgTtl .numTtl{
		top:-78px;
		left:-28px;
	}
	#technol{margin-top:150px;}
	#technol .pgTtl{
		width:1000px;
		margin:92px auto 46px;
		padding-left:0;
	}
	#technol .pgTtl:before{
		width:130px;
		height:98px;
		top:15px;
		left:253px;
	}
	#technol .pgTtl .numTtl{
		top:-73px;
		left:-29px;
	}
	#technol p{
		width:1000px;
		margin:0 auto;
	}
	#technol .fg{margin-top:45px;}
	#technol .fg img{border-radius:20px;}
	#support{margin-top:156px;}
	#support .pgTtl .numTtl{
		top:-73px;
		right:-29px;
	}
	#support .fg img{
		margin-left:-390px;
		border-radius:0 20px 20px 0;
	}
	#support .txtBox .pgTtl *,
	#support .txtBox p{text-align:right;}
	#support .txtBox .serviceListBox{
		margin-top:30px;
		padding:12px 26px;
		text-align:left;
	}
	#support .txtBox .serviceListBox h3{font-size:1.5rem;}
	#support .txtBox .serviceListBox p{
		margin-top:10px;
		font-size:1.3rem;
	}
	#support .pgTtl:before{
		width:110px;
		height:112px;
		top:14px;
		right:106px;
	}
	#mviBox{
		width:860px;
		margin:175px auto 0;
	}
	#mviBox .pgTtl .numTtl{
		top:-70px;
		left:-24px;
	}
	#mviBox .pgTtl:before{
		width:116px;
		height:96px;
		top:-30px;
		left:295px;
	}
	#mviBox .pgTtl .numTtl{
		top:-70px;
		left:-23px;
	}
	#mviBox #mvi{
		margin-top:61px;
		border-radius:20px;
	}
	#aboutSec{
		width:1068px;
		height:472px;
		margin-top:120px;
		padding:60px 132px 0 142px;
		background:url("../img/page-about/about-bg-pc.svg") no-repeat center top;
	}
	#aboutSec .menuTtl{
		display:table;
		margin:0 auto 35px 120px;
		text-align:right;
	}
	#aboutSec .menuTtl strong{font-size:4.2rem;}
	#aboutSec .menuTtl small{
		margin-top:20px;
		font-size:1.6rem;
	}
	#aboutSec .aboutList{
		display:flex;
		justify-content:space-between;
	}
	#aboutSec .aboutList li{width:180px;}
	#aboutSec .aboutList li span{
		margin-top:14px;
		font-size:1.2rem;
	}
	#aboutSec .aboutList li span:after{
		width:12px;
		height:12px;
		margin-left:6px;
		vertical-align:-2px;
	}
}
@media screen and (min-width:1160px) and (max-width:1579.98px){
	#technol .fg img{
		width:calc(100% + 2vw);
		max-width:initial;
		margin:0 -1vw;
	}
}
@media screen and (min-width:1580px){
	#technol .fg img{
		max-width:1550px;
		margin:0 auto;
	}
}