@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mv {
	padding: 212px 0 90px;
	background: url("../img/index/mv_bg.jpg") no-repeat center center;
	background-size: cover;
}
#main .mv h2 {
	margin: 0 auto 52px;
	width: 400px;
}
#main .mv p {
	margin-bottom: 96px;
	text-align: center;
	font-size: 2.6rem;
	font-weight: 700;
}
#main .mv .btnUl li {
	margin: 0 10px;
	width: 250px;
}
#main .mv .btnUl li a {
	padding: 14px 5px 15px;

	font-size: 1.8rem;
	font-weight: 700;
	display: block;
	border-radius: 40px;
	text-align: center;
}
#main .mv .btnUl li a {
		transition: color .5s ease, background .5s ease, border .5s ease;
}

#main .nosql {
	padding: 72px 0 72px;
}
#main .nosql .cTxt {
	margin-bottom: 24px;
	text-align: center;
	font-size: 1.7rem;
	line-height: 1.5;
}
#main .nosql .cTxt span {
	font-weight: 700;
	font-size: 1.9rem;
}
#main .nosql .cTxt01 {
/*	margin-bottom: 144px;	*/
}
#main .imgBox {
	margin-bottom: 72px;
	align-items: flex-start;
}
#main .imgBox01 {
	margin-bottom: 83px;
}
#main .imgBox .photoBox {
	width: 437px;
}
#main .imgBox .photoBox span {
	padding-bottom: 87%;
	display: block;
	border-radius: 8px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
#main .imgBoxR .photoBox {
	order: 1;
}
#main .imgBox .textBox {
	margin-top: 3px;
	width: 562px;
}
#main .imgBoxR .textBox {
	width: 579px;
}
#main .imgBox .textBox p {
	margin-bottom: 25px;
	line-height: 1.68;
}
#main .imgBox .textBox p:last-child {
	margin-bottom: 0;
}
#main .imgBox .textBox p span {
	font-weight: 700;
	font-size: 1.6rem;
}
#main .imgBox .textBox dt {
	font-weight: 700;
	font-size: 1.6rem;
}
#main .imgBox .textBox dd {
	margin-bottom: 25px;
}
#main .imgBox .textBox dd:last-child {
	margin-bottom: 0;
}
#main .features {
	padding: 72px 0 85px;
	background: #F6F6F6;
}
#main .features .content {
	width: 1140px;
}
#main .features .headLine01 {
	margin-bottom: 41px;
}
#main .features .cTxt {
	margin-bottom: 70px;
	text-align: center;
	font-size: 1.7rem;
	line-height: 1.38;
}
#main .features .cTxt span {
	font-weight: bold;
	font-size: 1.9rem;
}
#main .features .featuresList {
	margin-top: -64px;
	margin-bottom: 82px;
}
#main .features .featuresList::after {
	content: '';
	width: 330px;
}
#main .features .featuresList li {
	margin-top: 64px;
	width: 330px;
}
#main .features .featuresList li .photo {
	margin-bottom: 19px;
}
#main .features .featuresList li .photo span {
	padding-bottom: 69.2%;
	display: block;
	border-radius: 8px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
#main .features .featuresList li .ttl {
	margin-bottom: 12px;
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 1.5;
}
#main .features .featuresList li .ttl .txt {
	display: block;
	font-size: 2.5rem;
}
#main .features .featuresList li .ttl .txt .num {
	margin-left: 7px;
	font-size: 3.6rem;
}
#main .scene {
/*	padding: 72px 0 101px;	*/
	padding: 72px 0 24px;
}
#main .scene .content {
	width: 1122px;
}
#main .scene .headLine01 {
	margin-bottom: 37px;
}
#main .scene .headLine01 .col {
	font-size: 6rem;
}
#main .scene .cTxt {
	margin-bottom: 72px;
	text-align: center;
	font-size: 1.7rem;
	line-height: 1.42;
}
#main .scene .cTxt span {
	font-weight: 700;
	font-size: 1.9rem;
}
#main .scene .cTxt a {
	font-size: 1.8rem;
	font-weight: 700;
	text-decoration: underline;
}
#main .scene .cTxt a:hover {
	text-decoration: none;
}
#main .scene .linkList {
	margin-bottom: 90px;
}
#main .scene .linkList li {
	margin-right: 95px;
	width: 207px;
	text-align: center;
	line-height: 1.5;
}
#main .scene .linkList li:nth-child(4n) {
	margin-right: 0;
}
#main .scene .linkList li a {
	display: block;
}
#main .scene .linkList li a:hover {
	opacity: 0.7;
}
#main .scene .linkList li .pho {
	margin-bottom: 2px;
}
#main .scene .linkList li .pho span {
	padding-bottom: 100%;
	display: block;
	border-radius: 50%;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
#main .scene .linkList li .ttl {
	margin-bottom: 5px;
	font-size: 2.6rem;
	font-weight: 700;
}
#main .scene .linkList li .ttl span {
	font-size: 3.5rem;
}
#main .scene .linkList li .txt {
	font-weight: 700;
}
#main .scene .imgBox {
	margin: 0 28px 60px;
}
#main .scene .imgBox01 {
	margin-bottom: 92px;
}
#main .scene .imgBox .photoBox {
	width: 501px;
}
#main .scene .imgBox .photoBox span {
	padding-bottom: 65.1%;
	display: block;
	border-radius: 8px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
#main .scene .imgBox .textBox {
	width: 465px;
}
#main .scene .imgBox .textBox .headLine02 {
	margin-bottom: 19px;
	font-size: 3rem;
}
#main .scene .imgBox .textBox .headLine02 .txt {
	display: block;
	margin-bottom: 12px;
}
#main .scene .imgBox .textBox .headLine02 .num {
	margin-left: 5px;
	font-size: 4rem;
}
#main .scene .imgBox .textBox p {
	line-height: 1.65;
}
@media all and (max-width: 896px) {
	#main .mv {
		padding: 0;
		height: 100vh;
		min-height: 560px;
		display: flex;
		align-items: center;
	}
	#main .mv .inner {
		width: 100%;
		padding: 60px 15px;
		box-sizing: border-box;
	}
	#main .mv h2 {
		margin: 0 auto 52px;
		width: 268px;
	}
	#main .mv p {
		margin-bottom: 50px;
		font-size: 2.1rem;
	}
	#main .mv .btnUl {
		margin: 0 auto;
		width: 230px;
		display: block;
	}
	#main .mv .btnUl li {
		margin: 0 0 20px;
		width: auto;
	}
	#main .mv .btnUl li:last-child {
		margin-bottom: 0;
	}
	#main .mv .btnUl li a {
		padding: 16px 5px;
		font-size: 1.6rem;
	}
	#main .nosql {
		padding: 54px 0;
	}
	#main .nosql .cTxt {
		margin-bottom: 24px;
		font-size: 1.5rem;
		line-height: 1.86;
	}
	#main .nosql .cTxt span {
		font-size: 1.6rem;
	}
	#main .nosql .cTxt01 {
		margin-bottom: 60px;
	}
	#main .imgBox {
		margin-bottom: 30px;
		display: block;
	}
	#main .imgBox01 {
		margin-bottom: 30px;
	}
	#main .imgBox .photoBox {
		margin-bottom: 32px;
		width: auto;
		text-align: center;
	}
	#main .imgBox .textBox {
		margin-top: 0;
		width: auto;
	}
	#main .imgBoxR .textBox {
		width: auto;
	}
	#main .imgBox .textBox p {
		line-height: 1.8;
	}
	#main .imgBox .textBox p span {
		font-size: 1.4rem;
	}
	#main .imgBox .textBox dt {
		font-size: 1.4rem;
	}
	#main .imgBox .textBox dd {
		margin-bottom: 15px;
	}
	#main .imgBox .textBox dd:last-child {
		margin-bottom: 0;
	}
	#main .features {
		padding: 54px 0;
	}
	#main .features .headLine01 {
		margin-bottom: 15px;
	}
	#main .features .cTxt {
		margin-bottom: 34px;
		font-size: 1.4rem;
		line-height: 1.8;
	}
	#main .features .cTxt span {
		font-size: 1.5rem;
	}
	#main .features .featuresList {
		margin: 0 0 60px;
		display: block;
	}
	#main .features .featuresList::after {
		display: none;
	}
	#main .features .featuresList li {
		margin: 0 0 40px;
		width: auto;
	}
	#main .features .featuresList li:last-child {
		margin-bottom: 0;
	}
	#main .features .featuresList li .photo {
		margin-bottom: 8px;
	}
	#main .features .featuresList li .ttl {
		margin-bottom: 15px;
		font-size: 1.8rem;
	}
	#main .features .featuresList li .ttl .txt {
		font-size: 2.2rem;
	}
	#main .features .featuresList li .ttl .txt .num {
		margin-left: 5px;
		font-size: 3.2rem;
	}
	#main .features .featuresList li .text {
		line-height: 1.8;
	}
	#main .scene {
		padding: 54px 0 80px;
	}
	#main .scene .headLine01 {
		margin-bottom: 17px;
	}
	#main .scene .headLine01 .col {
		font-size: 3.1rem;
	}
	#main .scene .cTxt {
		margin-bottom: 50px;
		font-size: 1.4rem;
		line-height: 1.8;
	}
	#main .scene .cTxt span {
		font-size: 1.5rem;
	}
	#main .scene .cTxt a {
		font-size: 1.4rem;
	}
	#main .scene .cTxt a:hover {
		text-decoration: underline;
	}
	#main .scene .linkList {
		margin-top: -35px;
		margin-bottom: 70px;
		justify-content: space-between;
	}
	#main .scene .linkList li {
		margin: 35px 0 0;
		width: 45%;
	}
	#main .scene .linkList li .ttl {
		margin-bottom: 3px;
		font-size: 1.7rem;
	}
	#main .scene .linkList li .ttl span {
		font-size: 2.4rem;
	}
	#main .scene .linkList li .txt {
		font-size: 1.1rem;
	}
	#main .scene .imgBox {
		margin: 0 0 50px;
	}
	#main .scene .imgBox01 {
		margin-bottom: 50px;
	}
	#main .scene .imgBox .photoBox {
		margin-bottom: 10px;
		width: auto;
	}
	#main .scene .imgBox .textBox {
		width: auto;
	}
	#main .scene .imgBox .textBox .headLine02 {
		margin-bottom: 15px;
		font-size: 1.9rem;
	}
	#main .scene .imgBox .textBox .headLine02 .txt {
		font-size: 1.9rem;
		margin-bottom: 7px;
	}
	#main .scene .imgBox .textBox .headLine02 .num {
		font-size: 2.5rem;
	}
	#main .scene .imgBox .textBox p {
		line-height: 1.8;
	}
}
@media all and (max-width: 359px) {
	#main .mv p {
		font-size: 1.8rem;
	}
}

.mvPhrase{
	background: rgba(102,102,102,0.4);
	color:#fff;
}
