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

/*背景の装飾*/
.bg{
	width: 100%;
	position: relative;
}
.bg::before{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    border-top: 27vw solid #44bbaa;
    border-right: 50vw solid transparent;
	z-index: -1;
}
.bg::after{
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    border-bottom: 27vw solid #eedd0f;
    border-left: 50vw solid transparent;
	z-index: -1;
}
@media (max-width:575.98px){
	.bg::before{
		border-top: 180px solid #44bbaa;
		border-right: 320px solid transparent;
	}
	.bg::after{
		border-bottom: 180px solid #eedd0f;
		border-left: 320px solid transparent;
	}
}


/* メインビジュアル */
.mv{
	position: relative;
	margin: 0 auto;
	width: 100%;
	height: 770px;
}
.mv-img1{
	position: absolute;
	top: 80px;
    left: 46vw;
	z-index: 2;
	mix-blend-mode: normal;
}
.mv-img1-s{
	position: absolute;
	top: 124px;
    left: 46.25vw;
	z-index: 1;
	mix-blend-mode: multiply;
}
.mv-img2{
	position: absolute;
	top: 104px;
    right: 263px;
	z-index: 2;
}
.mv-img2-s{
	position: absolute;
	top: 153px;
    right: 186px;
	z-index: 1;
	mix-blend-mode: multiply;
}
.mv-img3{
	position: absolute;
	top: 265px;
    right: 90px;
	z-index: 2;
}
.mv-img3-s{
	position: absolute;
	top: 314px;
    right: 14px;
	z-index: 1;
	mix-blend-mode: multiply;
}
.mv-img4{
	position: absolute;
	bottom: 190px;
    right: 165px;
	z-index: 2;
}
.mv-img4-s{
	position: absolute;
	bottom: 190px;
    right: 80px;
	z-index: 1;
	mix-blend-mode: multiply;
}
.mv-img5{
	position: absolute;
	bottom: 160px;
    left: 32vw;
	z-index: 2;
}
.mv-img5-s{
	position: absolute;
	bottom: 162px;
    left: 32vw;
	z-index: 1;
	mix-blend-mode: multiply;
}
.mv-img6{
	position: absolute;
	bottom: 280px;
    left: 5vw;
	z-index: 2;
}
.mv-img6-s{
	position: absolute;
	bottom: 280px;
    left: 6vw;
	z-index: 1;
	mix-blend-mode: multiply;
}
.mv-img7{
	position: absolute;
	top: 230px;
    left: 16vw;
	z-index: 2;
}
.mv-img7-s{
	position: absolute;
	top: 274px;
    left: 17vw;
	z-index: 1;
	mix-blend-mode: multiply;
}
@media (max-width:1399.98px){
	.mv-img1{top: 50px;}
	.mv-img1-s{top: 96px;}
	.mv-img2{top: 104px; }
	.mv-img4{bottom: 170px;}
	.mv-img4-s{bottom: 170px;}
	.mv-img6{bottom: 290px;	left: 4vw;}
	.mv-img6-s{bottom: 290px;}
	.mv-img7{top: 138px; left: 12vw;}
	.mv-img7-s{top: 182px; left: 14vw;}
}
@media (max-width:991.98px){
	.mv-img1 img, .mv-img2 img, .mv-img3 img, .mv-img4 img,	.mv-img5 img, .mv-img6 img, .mv-img7 img{height: 77px;}
	.mv-img1-s img,	.mv-img2-s img, .mv-img3-s img,	.mv-img4-s img,	.mv-img5-s img,	.mv-img6-s img,	.mv-img7-s img{height: 50px;}

	.mv-img1{top: 61px;}
	.mv-img1-s{top: 88px;}
	.mv-img2{right: 170px; top: 133px;}
	.mv-img2-s{right: 100px; top: 160px;}
	.mv-img3{top: 215px; right: 50px;}
	.mv-img3-s{top: 239px; right: -13px;}
	.mv-img4-s{right: 87px;}
	.mv-img6{bottom: 205px;}
	.mv-img6-s{bottom: 206px;}
	.mv-img7{left: 3vw; top: 168px;}
	.mv-img7-s{top: 189px; left: 5vw;}
}
@media (max-width:768.98px){

	.mv-img1{top: 10px;	left: 35vw;}
	.mv-img1-s{top: 37px; left: 35.25vw;}
	.mv-img2{top: 60px; right: 100px;}
	.mv-img2-s{top: 88px; right: 39px;}
	.mv-img3{top: 170px; right: 0px;}
	.mv-img3-s{top: 196px; right: -60px;}
	.mv-img4{bottom: 90px; right: 85px;}
	.mv-img4-s{bottom: 89px; right: 17px;}
	.mv-img5{bottom: 180px;}
	.mv-img5-s{bottom: 182px;}
	.mv-img6{bottom: 145px;}
	.mv-img6-s{bottom: 145px; left: 7vw;}
	.mv-img7{top: 110px; left: 10vw;}
	.mv-img7-s {top: 136px; left: 13vw;}
}

.mv-box{
	padding: 50px;
	position: absolute;
	top: 46%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	background: linear-gradient(45deg, #eedd0f, #44bbaa);
	max-width: 800px;
	width: 80%;
	height: 370px;
	outline: 1px solid #fff;
	outline-offset: -10px;
}
.mv .mv-box .ttl{
	font-size: 2.625rem;
	text-align: center;
	color: #fff;
	line-height: 3.5rem;
	margin-bottom: 30px;
	font-weight: 700;
}
.mv .mv-box .subttl{
	font-size: 1.625rem;
	text-align: center;
	color: #fff;
	font-weight: 700;
}
.mv .mv-box .list-area{
	width: 80%;
	margin: 0 auto;
}
.mv .mv-box ul{
	display: flex;
	justify-content: space-between;
	text-align: center;
}
.mv .mv-box ul li{
	list-style: none;
}
.mv .mv-box .list1{
	font-size: 0.9375rem;
	font-weight: 700;
	color: #369688;
	margin-bottom: 18px;
}
.mv .mv-box .list1 li{
	flex-basis: calc(100%/3 - 12px);
	background-color: #fff;
	padding: 5px 0;
}
.mv .mv-box .list2 {
	font-size: 0.75rem;
	font-weight: 700;
	color: #fff;
}
.mv .mv-box .list2 li{
	flex-basis: calc(100%/2 - 10px);
	background-color: #369688;
}
.mv .mv-box .list2 li span{
	font-size: 2rem;
}
.mv .mv-box .note{
	font-size: 0.625rem;
	text-align: right;
}
@media (max-width:991.98px){
	.mv .mv-box {
		height: 355px;
		padding: 50px 40px;
	}
	.mv .mv-box .ttl{
		font-size: 4.5vw;
	}
	.mv .mv-box .subttl{
		font-size: 3vw;
	}
	.mv .mv-box .list-area{
		width: 100%;
	}
}
@media (max-width:767.98px){
	.mv{
		height: 900px;
	}
	.mv .mv-box{
		height: 555px;
    	width: 92%;
    	padding: 40px 25px;
	}

	.mv .mv-box .ttl{
		font-size: 1.875rem;
		line-height: 1.5;
		margin-bottom: 15px;
	}
	.mv .mv-box .subttl{
		font-size: 1.25rem;
		line-height: 1.75;
		margin-bottom: 3px;
	}

	.mv .mv-box .list1{
		flex-wrap: wrap;
	}
	.mv .mv-box .list1 li{
		flex-basis: 100%;
		margin-bottom: 20px;
	}
	.mv .mv-box .list1 li:last-child{
		margin-bottom: 0;
	}
	.mv .mv-box .list2 li{
		flex-basis: calc(100%/2 - 8px);
		margin-bottom: 5px;
		padding: 12px 0;
		line-height: 1.5;
	}
}
.mv-box-2 {
    background: linear-gradient(45deg, #eedd0f, #44bbaa);
    display: inline-block;
    width: max-content;
    outline: 1px solid #fff;
    outline-offset: -10px;
    position: relative;
    padding: 1rem;
    margin-top: 2rem;
}
.mv-box-2 .ttl-text {
    color: #fff;
    font-weight: 700;
    padding-inline:5vw;
    font-size: 1.657rem;
}
@media (max-width: 991.98px) {
    .mv-box-2 .ttl-text {
        padding-inline: 0vw;
    }
}
@media (max-width: 767.98px) {
    .mv-box-2 {
        margin-top: 0rem;
        width: auto;
    }
    .mv-box-2 .ttl-text {
        font-size: 1.125rem;
        padding-inline: 3vw;
    }
}
.offer-mark {
    position: absolute;
    top: -50px;
    right: 0px;
}
.offer-mark svg {
    width: 100px;
    height: 100px;
}
@media (max-width: 767.98px) {
    .offer-mark {
        margin-inline: calc(50% - 50vw);
    }
    .offer-mark svg {
        width: 80px;
        height: 80px;
    }
}


/* 特徴 */
.feature{
	position: relative;
	background-color: #eef4f4;
	padding: 27rem 0 5rem;
}
.solution{
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateY(-10%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
	background: #fff;
	border: 2px solid #eef4f4;
	width: 1000px;
	padding: 30px 60px;
}
.solution::after{
	content: '';
	position: absolute;
	width: 0;
    height: 0;
    bottom: -190px;
	left: 50%;
	transform: translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);    margin: auto;
    box-sizing: border-box;
    border: 130px solid transparent;
    border-top: 60px solid #d0d0d0;
}
.solution .ttl{
	position: absolute;
	top: -6%;
	left: 50%;
	transform: translateY(-10%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
	display: inline-block;
	color: #fff;
	font-weight: 700;
	padding: 5px 90px;
	font-size: 1.25rem;
	letter-spacing: 1.5px;
	background-color: #369688;
}
.solution .d-flex{
	margin: 30px 0 20px;
}
.solution .d-flex dl{
	flex-basis: calc(100%/4 - 60px);
}
.solution .d-flex dl dd{
	text-align: center;
}
@media (max-width:991.98px){
	.solution{
		width: 92%;
		padding: 10px 20px;
	}
	.solution .d-flex dl{
		margin-top: 20px;
	}
	.solution .d-flex dl dt{
		font-size: 0.9375rem;
	}
	.solution .ttl{
		width: 80%;
		top: -4%;
		padding: 5px 0;
	}
}
@media (max-width:767.98px){
	.solution .d-flex{
		flex-wrap: wrap;
	}
	.feature{
		padding-top: 35rem;
	}
	.solution::after{
		bottom: -150px;
		border: 110px solid transparent;
    	border-top: 40px solid #d0d0d0;
	}
	.solution .d-flex dl{
		flex-basis: calc(100%/2 - 5px);
	}
	.solution .d-flex dl dd{
	}
	.solution .d-flex dl dd img{
		width: 80%;
	}
}

.feature-area{
	margin: 0 auto;
}
.point{
	width: 100%;
}
.point .point-item{
	margin: 0 auto;
	padding: 0;
	justify-content: space-between;
}
.point .point-item li{
	flex-basis: calc(100%/3 - 1.75vw);
	list-style-type: none;
	background: #fff;
	padding: 40px 25px 25px;
	position: relative;
}
.point .point-item li h3{
	font-size: 1.375rem;
	line-height: 1.7;
	font-weight: 700;
}
.point .point-item .detail{
	padding: 0;
}
.point .point-item .detail p{
	margin: 0;
}
.point .point-item .detail li:nth-child(1){
	padding: 5px 0;
}
.point .point-item .detail li:nth-child(2){
	padding: 5px 0;
	height: 100px;
}
.point .point-item .detail li:nth-child(3){
	padding: 5px 0 0;
}
.point .point-item .item-tag{
	font-size: 1.125rem;
	position: absolute;
	top: -5%;
	left: 50%;
    transform: translateX(-50%);
	padding: 0 20px;
}
@media (max-width:991.98px){
	.point .point-item li h3{
		font-size: 1.25rem;
	}
	.point > .point-item > li > .detail > li > p{
		font-size: 0.875rem;
	}
}
@media (max-width:767.98px){
	.feature-area p{
		font-size: 0.875rem;
	}
	.point .point-item{
		justify-content: center;
		flex-wrap: wrap;
	}
	.point > .point-item > li{
		flex-basis: 92%;
		margin-bottom: 40px;
	}
	.point .point-item .detail li:nth-child(2){
		padding: 15px 0;
		height: 120px;
	}
}


/* ピックアップ */
.pickup{
	padding: 5rem 0;
}
.pickup .card-img-top img{
	height: 160px;
}


/* 活用例 */
.case{
	padding: 5rem 0;
	position: relative;
	z-index: 0;
}
.case .inner{
	max-width: 1200px;
}
.case::before{
	content: '';
	position: absolute;
	top: 0;
	background: url("/img/top/case-bg.png") center  90% / 100% no-repeat;
	mix-blend-mode: multiply;
    height: 100%;
    width: 100%;
	z-index: -1;
}
.case-item {
	margin: 0 auto;
	padding: 0;
	justify-content: space-between;
	position: relative;
}
.item-area > .case-item > li{
	flex-basis: calc(100%/2 - 50px);
	list-style-type: none;
	background: #fff;
	padding: 20px;
	margin-bottom: 40px;
	position: relative;
}
.item-area .case-item li h3{
	font-size: 1.25rem;
	line-height: 2rem;
	margin: 0;
	font-weight: 700;
}
.item-area .case-item li .detail{
	align-items: center;
	display: flex;
    padding-left: 33px;
	height: 100%;
}
.item-area .case-item li .detail li:nth-child(1){
	flex-basis: 70%;
	list-style-type: none;
	padding-left: 20px;
}
.item-area .case-item li .detail li:nth-child(2){
	flex-basis: 30%;
	list-style-type: none;
}
.item-area .case-item li .detail li:nth-child(2){
	text-align: center;
}

.item-area .case-item li .item-tag{
	font-size: 1.125rem;
	position: absolute;
	top: 40%;
	left: 0;
    transform: translateX(-50%);
	padding: 0 20px;
}
@media (max-width:1399.98px){
	.case .inner{
		width: 85vw;
	}
	.case::before{
		background-size: cover;
	}
}

@media (max-width:991.98px){
	.item-area .case-item{
		justify-content: center;
	}
	.item-area > .case-item > li{
		flex-basis: 92%;
		padding: 17px;
	}
	.item-area .case-item li .item-tag{
		top: -11%;
		left: 50%;
	}
}
@media (max-width:767.98px){
	.item-area > .case-item > li{
		flex-basis: 100%;
	}
	.item-area .case-item li .detail{
		margin-top: 10px;
		padding: 0;
	}
	.item-area .case-item li .detail li:nth-child(1){
		padding: 0;
	}
	.item-area .case-item li .detail li:nth-child(2) img{
		width: 80%;
	}
}
@media (max-width:575.98px){
	.case p{
		font-size: 0.875rem;
	}
	.item-area .case-item li h3{
		font-size: 0.9375rem;
	}
}


/* ご利用の流れ */
.usage{
	padding: 5rem 0;
}
.usage .inner{
	max-width: 1200px;
}
@media (max-width:575.98px){
	.usage .inner{
		width: 92%;
	}
}


/* よくあるご質問 */
.faq{
	background-color: #eef4f4;
	padding: 5rem 0;
}
.faq .inner{
	max-width: 1000px;
}
.faq dl{
	margin: 0;
}
.faq dl dt{
    font-size: 1.125rem;
    cursor: pointer;
    position: relative;
	background-color: #fff;
    border-bottom: 1px #eef4f4 solid;
}
.faq dl dt a{
	display: block;
	padding: 20px 40px 20px 70px;
}
.faq dl dt:last-child{
    border-bottom: none;
}
.faq dl dt:hover{
	background-color: #44BBAA;
}
.faq dl dt a:hover{
	color: #fff;
	text-decoration: none;
	opacity: 1;
}
.faq dl dt a::before {
    content: url("/img/common/q.svg");
	position: absolute;
	left: 2%;
	top: 25%;
	height: 36px;
	width: 36px;
}
.faq dl dt a[aria-expanded=false]::after {
    content: "";
    position: absolute;
    right: 3%;
    top: 40%;
    transition: all 0.2s ease-in-out;
    display: block;
    width: 16px;
    height: 16px;
    border-top: solid 3px #d0d0d0;
    border-right: solid 3px #d0d0d0;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}
.faq dl dd{
	margin: 0;
    font-size: 0.9375rem;
	background-color: #fff;
    border-bottom: 1px #eef4f4 solid;
}
.faq dl dt a[aria-expanded=true]{
	color: #fff;
	background-color: #44BBAA;
}
.faq dl dt a[aria-expanded=true]::after{
    content: "";
    position: absolute;
    right: 3%;
    top: 40%;
    transition: all 0.2s ease-in-out;
    display: block;
    width: 16px;
    height: 16px;
    border-top: solid 3px #d0d0d0;
    border-right: solid 3px #d0d0d0;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
@media (max-width:991.98px){
	.faq .inner{
		width: 92%;
	}
}
@media (max-width:575.98px){
	.faq dl dt a{
		font-size: 1rem;
		padding: 20px 50px 20px 65px;
	}
	.faq dl dt a[aria-expanded=false]::after,
	.faq dl dt a[aria-expanded=true]::after{
    	right: 5.5%;
	}
	.faq dl dt a::before {
		left: 4.5%;
		top: 35%;
	}
}


/* スクロール */
.scroll-arrow{
    width: 90px;
    position: absolute;
    top: -50px;
    right: 0;
	z-index: 1;
}
.scroll-arrow p {
    font-size: 0.8125rem;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}
.scroll-arrow .arrow {
    width: 1px;
    height: 100px;
    margin: 0 auto;
    position: relative;

}
.scroll-arrow .arrow::before {
    content: '';
    width: 1px;
    height: 100px;
    background-color: #424242;
    position: absolute;
    top: 0;
    left: 0;
    animation: arrowlong 2s ease infinite;

}
@keyframes arrowlong{
    0%{height:0;opacity:0}
    20%{height:0;opacity:1}
    80%{height:105%;opacity:1}
    100%{height:105%;opacity:0}
}


