@charset "utf-8";

.mainVisual {
	width: 100%;
	overflow: hidden;
	background: url(../-image/concept/mv_bg.png) no-repeat 50% 100%;
    background-size: cover;
	padding-bottom: 50px;
}

/*.mainVisual .mvBg {
    background: url(../-image/concept/mv_bg.jpg) no-repeat 0 0;
    background-size: cover;
    width: 150%;
    height: 54vw;
    border-radius: 50% / 0 0 100% 100%;
    margin: 0 -25% 20px;
    box-shadow: 0 0 13px 10px #dedede;
}*/

.mainVisual .flexBox {
	max-width: 1120px;
	margin: 0 auto;
	align-items: center;
	border-bottom: 1px solid #727171; 
	padding: 110px 0 55px;
}

.mainVisual .flexBox .rejoice {
	max-width: 640px;
	width: 56%;
	margin: 0 auto;
	border-right: 1px solid #727171;
}

.mainVisual .flexBox .rejoice img {
	max-width: 570px;
	width: 88%;
}

.mainVisual .flexBox .leftText {
	max-width: 490px;
	width: 44%;
	padding-left: 60px;
}

.mainVisual .flexBox .leftText p {
    line-height: 3;
    letter-spacing: 4px;
	font-weight: 500;
	font-size: 15px;
}

.mainVisual h2 {
    text-align: center;
    font-size: 40px;
    width: 30%;
	max-width: 620px;
    margin: 80px auto;
}

.moreText {
	display: flex;
	justify-content: center;
	flex-direction: column;
	height: 260px;
	width: 50%;
	margin: -40px 0 80px auto;
	border-left: 1px solid #595757;
	position: relative;
    z-index: -1;
}

.moreText p {
	margin-left: 30px;
	font-size: 16px;
	line-height: 26px;
	letter-spacing: 3px;
	font-weight: 500;
}

.posiRelative {
    position: relative;
}

.posiRelative .img01 {
	position: absolute;
	top:-20%;
	left:10%;
}

.posiRelative .img02 {
	position: absolute;
	top:45%;
	left:20%;
}

.posiRelative .img03 {
    position: absolute;
    top: 50%;
    left: 34%;
    width: 80px;
}

.posiRelative .img04 {
    position: absolute;
    top: 30%;
    right: 20%;
    width: 125px;
}

.posiRelative .img05 {
    position: absolute;
    top: -55%;
    right: 11%;
    width: 85px;
}

.bgColor04  {
    max-width: 1200px;
    margin: 0 auto 60px;
}

.bgColor04 h4,.bgColor04 h5,.bgColor04 p {
	color: #fff;
}

#concept01 .bgColor04 .title {
    padding: 65px 50px 110px 30px;
}

#concept02 .bgColor04 .title {
    padding: 65px 50px 50px 30px;
}

#concept03 .bgColor04 .title {
    padding: 40px 50px 55px 30px;
}

#concept .bgColor04 h4 {
	font-size: 75px;
	position: relative;
	padding-right: 46px;
	line-height: 1;
	letter-spacing: 8px;
	margin-bottom: 15px;
}

#concept .bgColor04 h4:after {
    content: "";
    width: 46px;
    height: 63px;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}

#concept01 .bgColor04 h4:after {
	background: url("../-image/concept/no01.png") no-repeat 0 0;
	background-size: 100%;
}

#concept02 .bgColor04 h4:after {
	background: url("../-image/concept/no02.png") no-repeat 0 0;
	background-size: 100%;
}

#concept03 .bgColor04 h4:after {
	background: url("../-image/concept/no03.png") no-repeat 0 0;
	background-size: 100%;
}

.bgColor04 .midashiJp {
	letter-spacing: 4px;
}

.bgColor04 h5 {
	font-size: 28px;
	letter-spacing: 7px;
	margin-bottom: 20px;
}

.bgColor04 h5 {
	font-size: 28px;
	letter-spacing: 7px;
	margin-bottom: 20px;
}

.bgColor04 .text {
    font-size: 16px;
    letter-spacing: 3px;
    line-height: 1.8;
}

.detailBtn {
    padding: 140px 0 45px;
    text-align: center;
}

#concept02 .detailBtn,#concept03 .detailBtn {
    padding: 75px 0 45px;
    text-align: center;
}

.detailBtn a {
    background: #b3ab8c;
    padding: 25px 130px 25px 70px;
    position: relative;
    color: #fff;
    letter-spacing: 3px;
    font-size: 16px;
}

.detailBtn a:hover {
	opacity: 1;
	filter: brightness(1.1);
}

.detailBtn a:after {
	content:"";
	position: absolute;
	right:30px;
	top:50%;
	transform: translateY(-50%);
	background: url("../-image/common/arrow04.svg") no-repeat 50% 50%;
	background-size: 100%;
	width: 38px;
	height: 38px;
}

.freePlan {
    width: 580px;
    margin-left: -260px;
    margin-top: -50px;
}

.leftPhoto {
    width: 470px;
    text-align: center;
}

.point {
    padding: 0 25px;
    margin-top: -30px;
}

.rightPhoto {
    margin-right: -62px;
}

.concept03Image {
    position: relative;
}

.abso01 {
    position: absolute;
    bottom: 15%;
    left: -10%;
}

.abso02 {
    position: absolute;
    top: 16%;
    right: -15%;
}


@media screen and (max-width: 767px)  {	
	
	.sp {
		display: block!important;
	}
	
	.mainVisual .flexBox {
		padding: 40px 0;
		width: 90%;
	}	
	
	.mainVisual .flexBox .rejoice {
		width: 60%;
		padding-bottom: 40px;
		margin: 0 auto 40px;
		border-bottom: 1px solid #727171;
		border-right: none;
		text-align: center;
	}	
	
	.mainVisual .flexBox .leftText {
		width: 100%;
		padding-left: 0;
		margin: 0 auto;
	}	
	
	.mainVisual .flexBox .leftText p {
		line-height: 2.2;
		letter-spacing: 2px;
		font-size: 14px;
	}	

	.mainVisual h2 {
		width: 80%;
		margin: 40px auto;
	}	
			
	.moreText {
		height: 220px;
		width: 85%;
		margin: -40px 0 40px auto;
	}	

	.moreText p {
		margin-left: 26px;
		font-size: 15px;
		letter-spacing: 2px;
	}	
	
	.posiRelative .img01,.posiRelative .img02,.posiRelative .img03 {
		display: none;
	}	
	
	.posiRelative .img04 {
		top: 70%;
		right: 8%;
		width: 100px;
	}	
	
	.posiRelative .img05 {
		top: -20%;
		right: 5%;
		width: 65px;
	}	

	#concept01 .bgColor04 .title,#concept02 .bgColor04 .title {
		padding: 30px;
	}	
	
	#concept .bgColor04 h4 {
		font-size: 30px;
		padding-right: 42px;
		margin-bottom: 10px;
	}	
	
	#concept .bgColor04 h4:after {
		content: "";
		width: 21px;
		height: 30px;
		right: 25px;
	}	
	
	.bgColor04 .midashiJp {
		letter-spacing: 3px;
		font-size: 10px;
	}
	
	.midashi {
		margin-bottom: 20px;
	}	
	
	.bgColor04 h5 {
		font-size: 20px;
		letter-spacing: 2px;
		margin-bottom: 20px;
		text-align: left;
	}	

	.bgColor04 .text {
		text-align: left;
	}	

	.detailBtn,#concept03 .detailBtn {
		padding: 40px 0 40px;
		text-align: center;
	}
	
	.detailBtn a {
		padding: 15px 100px 15px 40px;
		letter-spacing: 2px;
		font-size: 16px;
	}	

	.bgColor04 {
		margin: 0 auto 40px;
	}	
	
	.freePlan {
		width: 70%;
		margin-left: 30px;
		margin-top: 0;
	}	
	
	.point {
		margin-top: -37px;
		margin-bottom: 40px;
	}	
	
	.rightPhoto {
		width: 93%;
		margin: 0 0 0 auto;
	}
	
	.abso01 {
		width: 25%;
		bottom: 30%;
		left: 0;
	}	
	
	.abso02 {
		top: -5%;
		right: 0;
		width: 30%;
	}	

	
	
	
	
	
	
	
}

@media screen and (min-width: 768px) and (max-width: 1024px) {	
	
	
	.mainVisual .flexBox {
		padding: 40px 0;
		width: 90%;
	}	
	
	.mainVisual .flexBox .rejoice {
		width: 45%;
		padding-bottom: 40px;
		margin: 0 auto 40px;
		border-bottom: 1px solid #727171;
		border-right: none;
		text-align: center;
	}	
	
	.mainVisual .flexBox .leftText {
		width: 100%;
		padding-left: 0;
		margin: 0 auto;
		max-width: none;
	}	
	
	.mainVisual .flexBox .leftText p {
		line-height: 2.2;
		letter-spacing: 2px;
		font-size: 14px;
		text-align: center;
	}	

	.mainVisual h2 {
		width: 55%;
		margin: 40px auto;
	}	
			
	.moreText {
		height: 220px;
		width: 85%;
		margin: -60px 0 40px auto;
	}	

	.moreText p {
		margin-left: 26px;
		font-size: 15px;
		letter-spacing: 2px;
	}	
	
	.posiRelative .img01,.posiRelative .img02,.posiRelative .img03 {
		display: none;
	}	
	
	.posiRelative .img04 {
		top: 70%;
		right: 8%;
		width: 100px;
	}	
	
	.posiRelative .img05 {
		top: -20%;
		right: 5%;
		width: 65px;
	}	

	#concept01 .bgColor04 .title,#concept02 .bgColor04 .title {
		padding: 30px;
	}	
	
	#concept .bgColor04 h4 {
		font-size: 30px;
		padding-right: 42px;
		margin-bottom: 10px;
	}	
	
	#concept .bgColor04 h4:after {
		content: "";
		width: 21px;
		height: 30px;
		right: 25px;
	}	
	
	.bgColor04 .midashiJp {
		letter-spacing: 3px;
		font-size: 10px;
	}
	
	.midashi {
		margin-bottom: 20px;
	}	
	
	.bgColor04 h5 {
		font-size: 20px;
		letter-spacing: 2px;
		margin-bottom: 20px;
		text-align: left;
	}	

	.bgColor04 .text {
		text-align: left;
	}
	
	.right {
		width: 100%;
	}

	.detailBtn,#concept03 .detailBtn {
		padding: 40px 0 40px;
		text-align: center;
	}
	
	.detailBtn a {
		padding: 15px 100px 15px 40px;
		letter-spacing: 2px;
		font-size: 16px;
	}	

	.bgColor04 {
		margin: 0 auto 40px;
	}	
	
	.leftPhoto {
		width: 100%;
		text-align: center;
		position: relative;
	}
	
	.freePlan {
		width: 40%;
		margin-left: 24px;
		margin-top: 0;
		position: absolute;
		bottom: 18%;
	}
	
	.point {
		margin: -120px 0 40px auto;
		width: 60%;
	}
	
	.rightPhoto {
		width: 93%;
		margin: 0 0 0 auto;
	}
	
	.abso01 {
		width: 25%;
		bottom: 30%;
		left: 0;
	}	
	
	.abso02 {
		top: -5%;
		right: 0;
		width: 30%;
	}	
	
	
	
	
	
	
	
	
	
	
}

@media screen and (min-width: 1025px) and (max-width: 1279px) {	
	
	.mainVisual .flexBox .rejoice {
		width: 45%;
	}
	
	.mainVisual .flexBox .leftText {
		width: 55%;
		padding-left: 30px;
	}	
	
	.mainVisual h2 {
		width: 50%;
	}	
	
	.posiRelative .img04 {
		top: 76%;
	}		
	
	.bgColor04 {
		width: 90%;
	}
	
	#concept01 .bgColor04 .title {
		padding: 50px 50px 50px 30px;
	}
	
	#concept .bgColor04 h4 {
		font-size: 50px;
		padding-right: 26px;
	}
	
	#concept .bgColor04 h4:after {
		width: 31px;
		height: 46px;
	}
	
	.title .right {
		margin: 40px 0 0 auto;
	}	
	
	.detailBtn {
		padding: 80px 0 45px;
		text-align: center;
	}	
	
	.leftPhoto {
		width: 100%;
		text-align: center;
	}	
	
	.freePlan {
		width: 450px;
		margin-left: -30px;
		margin-top: -50px;
	}	
	
	.point {
		padding: 0px 25px;
		margin: -25% 0 40px auto;
		width: 60%;
	}	
	
	.rightPhoto {
		margin: 0 0 0 auto;
		width: 90%;
	}
	
	.abso01 {
		bottom: 35%;
		left: -4%;
	}
	
	.abso02 {
		top: 6%;
		right: -5%;
	}

	
}


@media screen and (min-width: 1280px) and (max-width: 1479px) {	
	
	.mainVisual .flexBox .rejoice {
		width: 48%;
	}	

	.mainVisual .flexBox .leftText {
		width: 50%;
		padding-left: 40px;
	}	
	
	.mainVisual h2 {
		width: 40%;
	}
	
	.leftPhoto {
		width: 430px;
	}
	
	.freePlan {
		width: 450px;
		margin-left: -25px;
	}
	
	.rightPhoto {
		margin-right: -36px;
	}	
	
	.abso01 {
		bottom: 30%;
		left: -3%;
	}	
	
	.abso02 {
		top: 19%;
		right: -3%;
	}	
	
	
	
	
	
	
	
	
}

@media screen and (min-width: 1480px) and (max-width: 1679px) {	
	
	.posiRelative .img04 {
		right: 10%;
	}
	
	.abso02 {
		top: 16%;
		right: -8%;
	}
	

	
	
}

@media screen and (min-width: 1680px) and (max-width: 1839px) {	
	
	.posiRelative .img04 {
		right: 10%;
	}

	.posiRelative .img05 {
		top: -45%;
		right: 4%;
	}	
	
	
}


