@charset "UTF-8";
/* CSS Document */

/*
	secondArea
-----------------------------------------------------------------------------------------------*/
.secondArea{
	width:800px;
	margin: 0 auto ;
	font-size:1.2rem;
	text-align:justify;
}
.secTit{
	font-size: 5.4rem;
	margin: 40px auto;
}
.secTit span{
	font-size: 115%;
	vertical-align: -0.2rem;
}
.secTit img{
	padding: 22px 10px 0 10px;
}
.secTit.feature img{
	padding: 22px 0 0 0;
}
.secondArea .kvBox{
	background: #eef4f7;
	padding: 40px;
	margin: 0 auto 40px auto;
}
.secondArea .tit{
	text-align: center;
	font-weight: bold;
	font-size:2.2rem;
	padding: 0 0 20px 0;
}
.secondArea .tit span{
	color: #2d31aa;
}
.columnArea {
	display: flex;
	margin: 0 auto 60px auto;
}
.columnArea.last{
	margin: 0 auto 80px auto;
}
.just{
	letter-spacing: 0.15rem;
}

.columnArea.fea:nth-child(even) {
	flex-flow: row-reverse;
}
.columnArea .tit{
	font-size:1.8rem;
	font-weight: bold;
	color: #2d31aa;
	text-align: left;
}
.columnArea img{
	margin: 0 0 0 30px;
}
.columnArea.fea:nth-child(even) img {
	margin: 0 30px 0 0;
	height: 260px;
}
.secondBigTit{
	font-size:2.4rem;
	color: #ffffff;
	font-weight:bold;
	text-align: center;
	padding: 20px 0;
	margin: 0 auto 25px auto;
	background-size: auto auto;
	background-color: rgba(45, 49, 170, 1);
	background-image: repeating-linear-gradient(-45deg, transparent, transparent 2px, rgba(81, 86, 224, 1) 2px, rgba(81, 86, 224, 1) 4px );
}
.pointBox{
	border: 1px solid #c9c9ca;
	margin: 0 auto 60px auto;
	position: relative;
}
.pointBox::after{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 24px 25px 0 25px;
	border-color: #8986f5 transparent transparent transparent;
	position: absolute;
	left: 46%;
	bottom: -42px;
}
.pointBox.last{
	margin: 0 0 80px 0;
}
.pointBox.last::after{
	content: none;
}

.pointBox .titArea{
	background: #f0f5c8;
	display: flex;
	justify-content:space-between;
	height: 90px;
}
.pointBox .titArea .num{
	background:#8986f5;
	width: 8%;
	position: relative;
}
.pointBox .titArea .num img{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.pointBox .titArea .titBox{
	padding:20px 8% 20px 0;
	text-align: center;
	width: 92%;
	margin: 0 auto;
}
.pointBox .titArea .titBox .tit{
	font-size: 2.0rem;
	padding: 0;
}
.pointBox .titArea .titBox .subTit{
	font-size: 1.2rem;
	font-weight:bold;
	color: #ffffff;
	background:rgba(0,0,0,0.3);
	width: 230px;
	border-radius: 12px;
	margin: 0 auto;
}
.poinPic{
	padding:20px 40px;
	display: flex;
	justify-content:space-between;
}
.poinPic li{
	margin: 0 auto;
	text-align: center;
	width:50%;
	position: relative;
	font-size: 1.4rem;
}
.poinPic li .picBg{
	height: 140px;
	background: #eef4f7;
	padding: 30px;
	margin: 0 auto 10px auto;
}
.poinPic li .picBg.five{
	padding:16px 30px 30px 30px;
}
.poinPic li.arrow{
	width: 10%;
	background: rgba(0,0,0,0.0);
}
.poinPic li.arrow img{
	position: absolute;
	top: 40%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.dxSubTit{
	padding:10px 0;
	background:rgba(45,49,170,0.1);
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
	margin: 0 auto 20px auto;
}
.legacy{
	display: flex;
	justify-content:space-between;
	width: 100%;
	margin: 0 auto 80px auto;
}
.legacy li{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 250px;
	border-radius: 12px;
	border: 2px solid #2d31aa;
	color: #2d31aa;
	font-size: 1.4rem;
	font-weight: bold;
	padding: 20px;
	text-align: center;
}
.legacyTxt{
	margin: 20px auto;
}
.checkLi{
	background:#f0f5c8;
	padding: 30px;
	font-weight: bold;
	font-size: 1.4rem;
}
.checkLi li{
	margin: 0 auto 20px auto;
	position: relative;
	padding: 0 0 0 24px;
}
.checkLi li::before{
	content: "";
	display: inline-block;
	background: url(../images/icon_dx_check.svg) no-repeat center left;
	width: 18px;
	height: 16px;
	position: absolute;
	left: 0;
	bottom: 3px;
}
.checkLi li span{
	background:-webkit-linear-gradient(transparent 70%, #f5e514 0%);
	background:-o-linear-gradient(transparent 70%, #f5e514 0%);
	background:linear-gradient(transparent 70%, #f5e514 0%);	
}

.checkLi li:last-child{
	margin: 0 auto;
}
.triangleArea{
	background: #e1ede8;
	margin: 0 0 70px 0;
}
.triangleArea .triangleTit{
	background:#5eb98a;
	color: #ffffff;
	font-size: 1.5rem;
	font-weight: bold;
	padding: 10px 0;
	text-align: center;
}
.triangleLi {
	display: flex;
	justify-content:center;
	flex-wrap:wrap;
	padding: 20px 40px 40px 40px;
	background: url(../images/bg_dx_triangle.svg) no-repeat center center; 
}
.triangleLi li{
	width:calc((100% - 40px) / 2);
	background:rgba(255,255,255,0.8);
	margin: 0px 40px 40px 0;
	text-align: center;
	padding: 20px;
	colo:#4e4f4f;
	font-size: 1.4rem;
	font-weight: bold;
	border-radius: 3px;
}
.triangleLi li:nth-of-type(2),.triangleLi li:nth-of-type(3){
	margin-right:0;
}
.triangleLi li:nth-of-type(3){
	margin-bottom: 0;
}
.triangleLi .txtL{
	color:#5f9c7d;
	font-size:1.8rem;
}
.triangleLi .txtBox{
	border:1px solid #72c198;
	border-radius: 5px;
	margin: 10px auto 0 auto;
	padding: 10px;
}

.feaTxtBox{
	width:700px;
	margin: 0 auto 40px auto;
}
.txtSmall{
	margin: 10px auto 0 auto;
	font-size:1.0rem;
}

.feaImgArea{
	margin-bottom: 60px;
}
.feaImgArea .txtSmall{
	text-align: right;
	background: #dcedf4;
	margin: 0 auto;
	padding: 0 10px 10px 0;
}
.feaImgGr{
	box-sizing: border-box;
	border-bottom: 150px solid #dfeadf;
	border-left: 70px solid transparent;
	border-right: 70px solid transparent;
	position: relative;
	height: 150px;
	filter: drop-shadow(0px 6px 6px rgba(0,0,0,0.4));
	z-index: 30;
}
.feaImgGr .tit,.feaImgBl .tit{
	font-size:2.0rem;
	padding: 8px 0 0 0;
	color:#589358;
}
.feaImgBl .tit{
	color:#1899c6;
}
.feaImgLi{
	width: 800px;
	display:flex;
	justify-content:space-between;
	position: absolute;
	top:50px;
	left: -69px;
	margin: 0 auto;
}
.feaImgGr .feaImgLi li,.feaImgBl .feaImgLi li{
	width:calc((100% - 40px) / 3);
	background: #589358;
	border-radius: 8px;
	border:1px solid #ffffff;
	color: #ffffff;
	padding: 20px;
	font-weight: bold;
	margin: 0 10px 0 0;
	text-align: center;
}
.feaImgGr .feaImgLi li:last-of-type{
	margin: 0;
}
.feaImgBl{
	box-sizing: border-box;
	border-bottom: 150px solid #dcedf4;
	border-left: 70px solid transparent;
	border-right: 70px solid transparent;
	position: relative;
	height: 150px;
	z-index: 29;
}
.feaImgBl .feaImgLi li{
	width:calc((100% - 20px) / 2);
	background: #1899c6;
}
.feaImgBl .feaImgLi li:nth-child(2){
	padding-top: 30px;
	margin: 0;
}
.feaImgLiNum{
	background:#dcedf4;
	height: 140px;
	display: flex;
	margin: 0 auto;
}
.feaImgLiNum li{
	width:calc((100% - 30px) / 3);
	padding: 20px;
	margin: 0 auto;
	text-align: center;

}
.feaImgLiNum li .tit{
	font-size:1.8rem;
	position: relative;
	padding: 0;
}
.feaImgLiNum li .tit.num01::after{
 content: '';
	display: inline-block;
	background: url(../images/icon_feature_01.svg) no-repeat center left;
	width: 15px;
	height: 24px;
	position: absolute;
	right: 40px;
	bottom: 3px;
}
.feaImgLiNum li .tit.num01::before {
	width: 64%;
  left: calc(50% - 60px)
}
.feaImgLiNum li .tit.num03::before {
	width: 94%;
  left: calc(50% - 90px)
}
.feaImgLiNum li .tit.num02::after{
 content: '';
	display: inline-block;
	background: url(../images/icon_feature_02.svg) no-repeat center left;
	width: 24px;
	height: 20px;
	position: absolute;
	right: -8px;
	bottom: 5px;
}
.feaImgLiNum li .tit.num03::after{
 content: '';
	display: inline-block;
	background: url(../images/icon_feature_03.svg) no-repeat center left;
	width: 20px;
	height: 18px;
	position: absolute;
	right: 4px;
	bottom: 6px;
}
.feaImgLiNum li .tit::before {
  content: '';
  width: 100%;
  height: 2px;
  display: inline-block;
  background-color: #1899c6;
  position: absolute;
  bottom: -2px;
  left: calc(50% - 100px)
}
.feaImgLiNum li .num{
	font-size:5.8rem;
	color: #1899c6;
	font-weight: bold;
	margin: -10px 0 0 0;
}
.feaImgLiNum li .num span{
	font-size:2.4rem;
	color: #000000;
}
.secondSubTit{
	font-size:2.2rem;
	font-weight: bold;
	text-align: center;
	margin: 40px auto 20px auto;
	color: #2d31aa;
}
.feaLast{
	background: #f4f8cc;
	padding:20px 30px 30px 30px;
	margin: 20px auto 70px auto;
}
.feaLast .tit{
	font-size: 1.8rem;
	font-weight: bold;
	text-align: center;
	color: #2d31aa;
}
.feaLastLi{
	display:flex;
	width: 100%;
	justify-content:space-between;
}
.feaLastLi li{
	width:240px;
	margin: 0 20px 0 0;
	background: #ffffff;
	padding: 15px;
}
.feaLastLi li:last-child{
	margin: 0 ;
}
.feaLastLi li .tit{
	font-weight: bold;
	font-size: 1.8rem;
	text-align: center;
}
.feaLastLi li .tit span{
	background:linear-gradient(transparent 70%, #f0ff95 0%);
	color: #000000;
}

/*
	日立ソリューションズのコーポレートフィロソフィー
-----------------------------------------------------------------------------------------------*/

.mvvPage .secTit {
	font-size: 5.0rem;
}

/* mvvPage .mvvListArea */
.mvvPage .mvvListArea{
	display: flex;
	flex-direction: column;
	gap: 140px;
	margin: 120px 0;
}
.mvvPage .mvvListArea .tit{
	position: relative;
	display: block;
	height: 100px;
	background-color: #ffffff;
	padding: 0 30px;
	top: -50px;
	margin-top: -20px;
}
.mvvPage .mvvListArea .tit img{
	width: auto;
	height: 100%;
}
.mvvPage .mvvListArea .sub{
	text-align: center;
	font-weight: 600;
	font-size: 2.0rem;
	line-height: 200%;
}
.mvvPage .mvvListArea > li .txtBox{
	display: flex;
	align-items: center;
	flex-direction: column;
	border: 4px solid #2d31aa;
	padding: 0px 60px 60px;
}
.mvvPage .mvvListArea > li .cap{
	text-align: center;
	color: #2d31aa;
	font-size: 1.5rem;
	margin-top: 10px;
}

/*listValues*/
.listValues{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 50px;
}
.listValues > li{
	width: calc((100% - 100px)/3);
}
.listValues > li figure{
	width: 150px;
	margin: auto;
}
.listValues > li figure img{
	width: 100%;
	height: 100%;
}
.listValues > li .listTit{
	color: #2d31aa;
	font-weight: 600;
	text-align: center;
	font-size: 1.6rem;
	margin: 20px 0 5px;
}
.mvvPage .columnArea{
	flex-direction: column;	
}
.mvvPage .columnArea img {
	margin: 30px 0 0 0 ;
}

/* mvvPage .mvvListArea_sub */
.mvvPage .mvvListArea_sub{
	display: flex;
	justify-content: space-between;
	width: 100%;
	margin: 0 auto 80px auto;
}
.mvvPage .mvvListArea_sub li{
	display: flex;
	align-items: center;
	flex-direction: column;
	width: calc((100% - 30px)/3);
	border-radius: 12px;
	border: 2px solid var(--clrRed);
	padding: 25px 20px 30px;
}
.mvvPage .mvvListArea_sub li:nth-of-type(3){
	border-color: #4e59c3;
}
.mvvPage .mvvListArea_sub li .tit{
	height: 24px;
	padding: 0 10px;
	margin-bottom: 10px;
}
.mvvPage .mvvListArea_sub li .titTxt{
	width: 100%;
	text-align: center;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--clrLtGray);
}
.mvvPage .mvvListArea_sub li .titSub{
	font-size: 1.8rem;
	font-weight: bold;
	text-align: justify;
	margin-bottom: 10px;
}
.mvvPage .mvvListArea_sub li .tit img{
	width: auto;
	height: 100%;
}


/*
		スマホ
	---------------*/

@media screen and (max-width:812px){
	
	/*
		secondArea
	-----------------------------------------------------------------------------------------------*/
	.secondArea{
		width:100%;
		font-size:1.2rem;
	}
	.secTit{
		font-size: 3.5rem;
		margin: 40px auto;
		height: auto;
		line-height: 150%;
		}
	.secTit img{
		width: 90px;
		padding: 8px 10px 0 10px;
	}
	.secondArea .kvBox{
		padding: 20px;
		margin: 0 auto 40px auto;
	}
	.secondArea .tit{
		font-size:1.8rem;
	}
	.columnArea {
		display: block;
		padding: 0 20px;
		margin: 0 0 40px 0;
	}
	.columnArea .tit{
		font-size:1.6rem;
	}
	.columnArea img{
		margin: 20px 0 0 0;
	}
	.secondBigTit{
		font-size:2.0rem;
		padding: 15px 0;
		margin: 0 auto 15px auto;
	}
	.pointArea{
		padding:0 20px;
	}
	.pointBox{
		border: 1px solid #c9c9ca;
		margin: 0 auto 60px auto;
		position: relative;
	}
	.pointBox::after{
		border-width: 24px 25px 0 25px;
		border-color: #8986f5 transparent transparent transparent;
		position: absolute;
		left: 43%;
		bottom: -42px;
	}

	.pointBox .titArea{
		height: auto;
	}
	.pointBox .titArea .num{
		width: 15%;
	}
	.pointBox .titArea .num img{
		width: 27px;
	}
	.pointBox .titArea .titBox{
		padding:20px 0px;
		width: 85%;
	}
	.pointBox .titArea .titBox .tit{
		font-size: 1.6rem;
		padding: 0;
	}
	.pointBox .titArea .titBox .subTit{
		font-size: 1.1rem;
		width: 220px;
		margin: 5px auto 0 auto;
	}
	.poinPic{
		padding:20px;
		display: block;
	}
	.poinPic li{
		width:100%;
		margin: 0 auto 18px auto;
	}
	.poinPic li:nth-of-type(3){
		margin: 0 auto;
	}
	.poinPic li .picBg{
		height: auto;
		margin: 0 auto 5px auto;
	}
	.picBg.point01 img{
		width:140px;
	}
	.picBg.point02 img{
		width:70px;
	}
	.picBg.point03 img{
		width:90px;
	}
	.picBg.point04 img{
		width:90px;
	}
	.poinPic li .picBg.five{
		padding:30px 30px 0px 30px;
	}
	.picBg.point05 img{
		width:160px;
	}
	.pointBox.last .poinPic li{
		margin: 0;
	}
	.poinPic li.arrow{
	width: 100%;
	height: 40px;
	background: rgba(0,0,0,0.0);
}
	.poinPic li.arrow img{
		width: 28px;
		top: 20%;
		left: 45%;
		transform: translate(-50%,-50%);
		transform: rotate(90deg);
		}
	.dxSubTit{
		font-size: 1.6rem;
	}
	.legacy{
		display: block;
		margin: 0 auto 80px auto;
		padding: 0 20px;
	}
	.legacy li{
		width: 100%;
		margin: 0 0 20px 0;
}
	.legacyTxt{
		padding: 0 20px;
	}
	.checkLi{
		padding: 20px 20px 30px 20px;
	}
	.checkLi li::before{
		left: 0;
		bottom: 3px;
		top:2px;
	}
	.triangleWrappe{
		padding:0 20px;
	}
	.triangleArea{
		margin: 0 0 20px 0;
	}
	.triangleArea .triangleTit{
		font-size: 1.4rem;
	}
	.triangleLi {
		display: flex;
		justify-content:center;
		flex-wrap:wrap;
		padding: 20px 10px;
	}
	.triangleLi li{
		padding: 10px;
		font-size: 1.2rem;
		margin: 0 20px 20px 0;
	}
	.triangleLi .txtL{
		font-size:1.4rem;
	}	
	
	.columnArea.fea:nth-child(even) img{
		margin: 0;
		height: 100%;
	}
	.secTit.feature{
		font-size: 3.0rem;
	}
	.secTit.feature img{
		width: 60px;
		padding:8px 0 0 0;
	}
	.feaTxtBox{
		width:100%;
		padding: 0 20px;
	}
	.feaImgArea{
		margin-bottom: 40px;
	}
	.feaImgArea .txtSmall{
		padding-right: 20px;
	}
	.feaImgGr{
		box-sizing: border-box;
		border-bottom: 250px solid #dfeadf;
		border-left: 40px solid transparent;
		border-right: 40px solid transparent;
		position: relative;
		height: 250px;
		filter: drop-shadow(0px 6px 6px rgba(0,0,0,0.4));
		z-index: 1;
	}
	.feaImgGr .tit,.feaImgBl .tit{
		font-size:1.5rem;
		padding: 15px 0 0 0;
	}
	.feaImgLi{
		width: 100%;
		display:block;
		top:50px;
		left: 0px;
	}
	.feaImgGr .feaImgLi li,.feaImgBl .feaImgLi li{
		width:100%;
		padding: 10px;
		margin: 0 auto 10px auto;
	}
	.feaImgBl .feaImgLi li:nth-child(2){
		padding-top: 10px;
	}
	.feaImgBl{
		box-sizing: border-box;
		border-bottom: 180px solid #dcedf4;
		border-left: 40px solid transparent;
		border-right: 40px solid transparent;
		position: relative;
		height: 180px;
		z-index: 0;
	}
	.feaImgBl .feaImgLi li{
			width:100%;
	}
	.feaImgLiNum{
		background:#dcedf4;
		height: 250px;
		display: block;
	}
	.feaImgLiNum li{
		width: 100%;
		padding: 0px;
		margin: 0 auto 10px auto;
		text-align: center;
	}
	.feaImgLiNum li .tit{
		font-size:1.5rem;
		position: relative;
		padding: 0;
	}
	.feaImgLiNum li .tit.num01::after{
	 content: '';
		display: inline-block;
		background: url(../images/icon_feature_01.svg) no-repeat center left;
		width: 15px;
		height: 24px;
		position: absolute;
		right: 34%;
		bottom: 2px;
	}
	.feaImgLiNum li .tit.num01::before {
		width: 32%;
		left: 50%;
    transform: translateX(-50%);
	}
	.feaImgLiNum li .tit.num03::before {
		width: 44%;
		left: 50%;
    transform: translateX(-50%);
	}
	.feaImgLiNum li .tit.num02::after{
	 content: '';
		display: inline-block;
		background: url(../images/icon_feature_02.svg) no-repeat center left;
		width: 24px;
		height: 20px;
		position: absolute;
		right: 22%;
		bottom: 2px;
	}
	.feaImgLiNum li .tit.num03::after{
	 content: '';
		display: inline-block;
		background: url(../images/icon_feature_03.svg) no-repeat center left;
		width: 20px;
		height: 18px;
		position: absolute;
		right: 27%;
		bottom: 3px;
	}
	.feaImgLiNum li .tit::before {
		content: '';
		width: 51%;
		height: 2px;
		display: inline-block;
		background-color: #1899c6;
		position: absolute;
		bottom: -2px;
		left: 53%;
    transform: translateX(-50%);
	}
	.feaImgLiNum li .num{
		font-size:3.8rem;
		color: #1899c6;
		font-weight: bold;
		margin: -10px 0 0 0;
	}
	.feaImgLiNum li .num span{
		font-size:2.4rem;
		color: #000000;
	}
	.secondSubTit{
		font-size:1.8rem;
		font-weight: bold;
		text-align: center;
		margin: 40px auto 20px auto;
		color: #2d31aa;
	}
	.feaLast{
		background: #f4f8cc;
		padding:20px 30px 30px 30px;
		margin: 20px auto 0 auto;
	}
	.feaLast .tit{
		font-size: 1.8rem;
		font-weight: bold;
		text-align: center;
		color: #2d31aa;
	}
	.feaLastArea{
		margin:0;
	}
	.feaLastLi{
		display:block;
		width: 100%;
		justify-content:space-between;
	}
	.feaLastLi li{
		width:100%;
		margin: 0 0 10px 0;
		background: #ffffff;
		padding: 15px;
	}
	.feaLastLi li:last-child{
		margin: 0 ;
	}
	.feaLastLi li .tit{
		font-weight: bold;
		font-size: 1.8rem;
		text-align: center;
	}
	.feaLastLi li .tit span{
		background:linear-gradient(transparent 70%, #f0ff95 0%);
		color: #000000;
	}

	/*
	日立ソリューションズのコーポレートフィロソフィー
	-----------------------------------------------------------------------------------------------*/

	.mvvPage .secTit {
		display: flex;
		flex-direction: column;
		font-size:	3.0rem;;
	}
	/* mvvPage .mvvListArea */
	.mvvPage .mvvListArea{
		gap: 80px;
		margin: 80px 0 50px 0;
		padding: 0 20px;
	}
	.mvvPage .mvvListArea .tit{
		height: 60px;
		padding: 0 15px;
		top: -25px;
	}
	.mvvPage .mvvListArea .sub {
		font-size: 1.6rem;
		line-height: 160%;
		text-align: justify;
	}
	.mvvPage .mvvListArea > li .txtBox{
		padding: 0px 30px 30px;
	}
	.mvvPage .mvvListArea > li:nth-of-type(3) .txtBox{
		padding: 0px 20px 25px;
	}
	.mvvPage .mvvListArea > li .cap{
		text-align: justify;
		font-size: 1.2rem;
	}
	
	/*listValues*/
	.listValues{
		gap: 20px;
	}
	.listValues > li{
		width: calc((100% - 20px)/2);
	}
	.listValues > li figure {
		width: 80%;
		max-width: 150px;
	}
	.listValues > li .listTit{
		font-size: 1.5rem;
		margin: 15px 0 5px;
	}

	/* mvvPage .mvvListArea_sub */
	.mvvPage .mvvListArea_sub{
		flex-direction: column;
		margin-bottom:  60px;
		padding: 0 20px;
		gap: 30px;
	}
	.mvvPage .mvvListArea_sub li{
		width: 100%;
		padding: 30px 20px;
	}
	.mvvPage .mvvListArea_sub li .tit{
		height: 22px;
	}

}