@charset "utf-8";

/*    scene-area　→　サービス
-------------------------------------------------------------- */
.scene-area{
    padding: 100px 0;
    background-color: #EFF3F9;
	position: relative;
}
.scene-area::before {
    content: "";
    display: inline-block;
    background: url(../img/bg-decoration.png) no-repeat right 50px top 250px / cover;
    width: 1600px;
    height: 650px;
    position: absolute;
    left: 0;
    bottom: 0;
	z-index: 0;
}
.scene-area::after {
	/*
    content: "";
    display: inline-block;
    background: url(../img/bg-decoration-02.png) center/cover,no-repeat;
    width: 272px;
    height: 107px;
    position: absolute;
    left: 30px;
    bottom: -35px;
	*/
	content: "";
    display: inline-block;
    background: url(../img/bg-decoration-01.png) center/cover,no-repeat;
    width: 111px;
    height: 172px;
    position: absolute;
    left: 30px;
    bottom: -35px;
}

.scene-area .case-box{
	position: relative;
}
/*
.scene-area .case-box::after{
	content: "";
    display: inline-block;
    background: url(../img/bg-decoration-01.png) center/cover,no-repeat;
    width: 111px;
    height: 172px;
    position: absolute;
    left: 0;
    top: 70px;
}
*/

.scene-area .case-box.factory .txt-box{
	position: relative;
	z-index: 2;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.scene-area .case-box.factory .txt-box .sec-img {
	width: 200px;
}
.scene-area .case-box.factory .txt-box .sec-img img {
	width: 100%;
}

.scene-area .case-box.factory .txt-box .in {
	width: calc(100% - 260px);
}

.scene-area .case-box.factory .txt-box .sec-copy {
    font-size: 2.0rem;
    font-weight: 500;
    color: #00A1E0;
}

.scene-area .case-box.factory .txt-box .sec-catch {
    font-size: 4.4rem;
    font-weight: bold;
    margin: 10px 0 0;
    line-height: 1.4;
}

.scene-area .case-box.factory .txt-box .txt {
	margin: 20px 0 0;
	line-height: 2;
}


@media screen and (max-width: 768px){
    .scene-area{
        padding: 40px 20px 50px;
    }
	
	
	.scene-area::after {
		background-size: contain;
		background-repeat: no-repeat;
		width: 180px;
		height: 100px;
		left: auto;
		right: -10px;
		bottom: auto;
		top: 0;
		background-image: url(../img/bg-decoration-02.png);
	}
	
	.scene-area .case-box.factory .txt-box{
		display: block;
		width: auto;
	}

	.scene-area .case-box.factory .txt-box .sec-img {
		width: auto;
	}
	.scene-area .case-box.factory .txt-box .sec-img img {
		width: 120px;
	}

	.scene-area .case-box.factory .txt-box .in {
		width: auto;
	}

	.scene-area .case-box.factory .txt-box .sec-copy {
		font-size: 1.8rem;
		display: none;
	}
	.scene-area .case-box.factory .txt-box .sec-catch {
		font-size: 2.6rem;
		margin: 15px 0 0;
	}
	
	.scene-area .case-box.factory .txt-box .txt {
		margin: 15px 0 0;
	}

}

/*    wear-area
-------------------------------------------------------------- */
.wear-area{
    padding: 80px 0 120px;
	background: linear-gradient(90deg,#E3E8ED 0%, #E3E8ED 60%, var(--blue) 60%, var(--blue) 100%);
}
.wear-area .section-title {
    position: relative;
    font: 500 5.8rem / 1.4 'Lato', sans-serif;
    letter-spacing: .05em;
}

.wear-area .ja {
    padding: 0px 0 0 25px;
    display: block;
    font: 500 1.8rem / 1.2 'Noto Sans JP', serif;
	position: relative;
}

.wear-area .ja::before {
    content: "";
    display: inline-block;
    background: url(../img/icon-section-title.svg) center/cover,no-repeat;
    width: 15px;
    height: 6px;
    position: absolute;
    left: 0;
    top: 10px;
}

.wear-area .flow-list .flow-item{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 0 50px;
	/*
    box-shadow: 0 3px 20px 5px rgba(0,0,0,.1);
	*/
	position: relative;
	background-color: #fff;
	/*
	border: solid 2px var(--blue);
	*/
}
.wear-area .flow-list .flow-item:last-of-type{
    margin: 0;
}

.wear-area .flow-list .flow-item::before{
    background-image: url(../img/bm-point-bg.svg);
    width: 72px;
    height: 72px;
    background-size: cover;
    bottom: 50%;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    left: -35px;
    font-size: 1.5rem;
    letter-spacing: 0.05em;
    font-weight: bold;
    font-family: var(--lato);
    position: absolute;
    content: "";
    text-align: center;
    line-height: 37px;
    z-index: 1;
}

.wear-area .flow-list .flow-item::after{
    content: "";
    width: 37px;
    height: 37px;
    background-size: cover;
    bottom: 50%;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    left: -18px;
    line-height: 92px;
    font-size: 2.4rem;
    text-align: center;
    font-weight: bold;
    font-family: var(--lato);
    position: absolute;
    z-index: 1;
}
.wear-area .flow-list .flow-item:nth-child(1)::after{
    background-image: url(../img/icon-crm.svg);
}
.wear-area .flow-list .flow-item:nth-child(2)::after{
    background-image: url(../img/icon-e-commerce.svg);
}
.wear-area .flow-list .flow-item:nth-child(3)::after{
    background-image: url(../img/icon-ipaas.svg);
}
.wear-area .flow-list .flow-item:nth-child(4)::after{
    background-image: url(../img/icon-bi.svg);
}
.wear-area .flow-list .flow-item:nth-child(5)::after{
    background-image: url(../img/icon-marketing.svg);
}
.wear-area .flow-list .flow-item:nth-child(6)::after{
    background-image: url(../img/icon-solutions.svg);
}

.wear-area .flow-list{
    margin: 70px 0 0;
}
.wear-area .flow-list .flow-item .img-box{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 410px;
}
.wear-area .flow-list .flow-item .img-box .img{
	width: 100%;
}
.wear-area .flow-list .flow-item .img-box img{
	width: 100%;
    height: 100%;
    object-fit: cover;
}

.wear-area .flow-list .flow-item .txt-box{
    width: calc(100% - 490px);
    padding: 40px 60px 40px 0;
}

.wear-area .flow-list .flow-item .txt-box .service-name {
	font: 500 3.4rem / 1.2 'Lato', sans-serif;
    margin: 0px 0 30px 0;
    padding: 0;
    position: relative;
}

.wear-area .flow-list .flow-item .txt-box .service-name::before {
    content: "";
    display: inline-block;
    background: url(../img/icon-section-title-01.svg) center/cover,no-repeat;
    width: 18px;
    height: 7px;
    position: absolute;
    left: -35px;
    top: 20px;
}

.wear-area .flow-list .flow-item .txt-box .service-name .service-name-jp{
	font: 500 1.8rem / 1.2 'Noto Sans JP', sans-serif;
    padding: 4px 0 0;
    color: #00A1E0;
	color: var(--blue);
	display: block;
}

.wear-area .flow-list .flow-item .txt-box .flow-ttl{
    font-size: 1.5rem;
    font-weight: 500;
	display: block;	
	background: #EFF3F9;
	padding: 5px 20px 7px;
	/*
	background: url(../img/copy-bg.png) no-repeat left bottom;
	padding: 0 0 20px;
	*/
	/*
	background: #EFF3F9;
	*/
	/*
    border-bottom: 1px solid #ddd;
    padding: 0 0 3px 5px;
	line-height: 2;
	position: relative;
	*/
}
/*
.wear-area .flow-list .flow-item .txt-box .flow-ttl::after {
  position: absolute;
  left:  0;
  display: block;
  content: " ";
  padding: 0 0 3px;
  width: 23%;
  border-bottom: 1px solid #0E6EB8;
}
*/

/*
.wear-area .flow-list .flow-item .txt-box .child-list .child-item{
    position: relative;
    padding: 0 0 0 20px;
    line-height: 1.6;
    margin: 0px 0 10px;
}
.wear-area .flow-list .flow-item .txt-box .child-list .child-item span{
    font-weight: bold;
}
.wear-area .flow-list .flow-item .txt-box .child-list .child-item:last-of-type{
    margin: 0;
}
.wear-area .flow-list .flow-item .txt-box .child-list .child-item::before{
    position: absolute;
    left: -3px;
    top: 0;
    content: '・';
    color: var(--blue);
}
*/


.wear-area .child-list{
}
.wear-area .child-list li{
	line-height: 1.7;
	margin: 0;
	padding: 15px 0 15px 20px;
	position: relative;
	border-bottom: 1px #ccc dashed;
	font-size: 1.6rem;
	font-family: "Lato", 'Noto Sans JP',YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
.wear-area .child-list li:first-child{
	margin: 0;
}
.wear-area .child-list li::before{
	position: absolute;
	left: 0;
	top: 30px;
	/*
	top: 26px;
	width: 6px;
	height: 6px;
	border-radius: 50px;
	*/
	width: 10px;
	height: 1px;
    content: "";
    background: var(--blue);
	background: url(../img/decoration.png) no-repeat left top / 100% 1px;
}
.wear-area .child-list li span{
	font-weight: bold;
	font-size: 1.8rem;
}
.wear-area .child-list li span::after{
    content: "：";
	display: inline-block;
}


@media screen and (max-width: 768px){
    .wear-area{
        padding: 40px 20px 50px;
		background: linear-gradient(90deg,#E3E8ED 0%, #E3E8ED 75%, var(--blue) 75%, var(--blue) 100%);
    }
	
	
	.wear-area .section-title {
		font-size: 4.0rem;
		letter-spacing: .03em;
		font-weight: 700;
	}
	
	.wear-area .ja {
		padding: 0px 0 0 22px;
		font-size: 1.7rem;
	}
	.wear-area .ja::before {
	}
	.wear-area .flow-list {
		margin: 40px 0 0;
	}
	
    .wear-area .flow-list .flow-item{
        display: block;
        margin: 0 0 30px;
    }
	
	.wear-area .flow-list .flow-item::before{
		width: 60px;
		height: 60px;
		bottom: auto;
		top: 100px;
		line-height: 0;
		
        right: 0;
        left: 0;
        margin: 0 auto;
		/*
		background: rgba( 30, 50, 104, .8);
		border-radius: 50%;
		*/
		display: none;
	}

	.wear-area .flow-list .flow-item::after{
		width: 30px;
		height: 30px;
		
		top: 100px;
        right: 0;
        left: 0;
        margin: 0 auto;
		
		display: none;
	}

	
    .wear-area .flow-list .flow-item:last-of-type{
        margin: 0;
    }
	/*
    .wear-area .flow-list .flow-item::before{
        top: 0px;
        right: 0;
        left: 0;
        margin: 0 auto;
    }
    .wear-area .flow-list .flow-item::after{
        top: 0px;
        right: 0;
        left: 0;
        margin: 0 auto;
    }
	*/
    .wear-area .flow-list .flow-item .img-box{
        width: 100%;
		display: block;
    }
	.wear-area .flow-list .flow-item .img-box .img{
        width: 100%;
		height: 200px;
		overflow: hidden;
	}
    .wear-area .flow-list .flow-item .img-box img{
        width: 100%;
		height: 100%;
		object-fit: cover;
    }
	
    .wear-area .flow-list .flow-item .txt-box{
        /* width: calc(100% - 140px); */
        width: 100%;
        padding: 30px 30px 20px;
    }
	
	.wear-area .flow-list .flow-item .txt-box .service-name,
	.wear-area .flow-list .marketing.flow-item .txt-box .service-name{
		font: 700 2.6rem / 1.2 'Lato', sans-serif;
		margin: 0px 0 30px 0;
	}
	.wear-area .flow-list .flow-item .txt-box .service-name::before {
		left: -25px;
		top: 13px;
	}
	.wear-area .flow-list .flow-item .txt-box .service-name .service-name-jp {
	    font: 500 1.8rem / 1.4 'Noto Sans JP', sans-serif;
		padding: 3px 0 0;
	}
	
    .wear-area .flow-list .flow-item .txt-box .flow-ttl{
        font-size: 1.5rem;
        line-height: 1.5;
		padding: 5px 10px;
    }
	
	
	.wear-area .child-list li{
		line-height: 1.6;
	}
	.wear-area .child-list li:last-child{
		border-bottom: none;
	}
	.wear-area .child-list li span{
		display: block;
	}
	.wear-area .child-list li span::after{
		display: none;
	}

}

/*スクロール*/
.copy-area{
	padding: 30px 0 40px;
}

.copy-area .scroll {
    transition: all .3s;
    opacity: 1;
    animation: scrolltxt 10s linear infinite;
    position: relative;
    /*bottom: -250px;*/
    left: 20%;
    display: flex;
    transform: translate(-50%, 0%);
    white-space: nowrap;
}

.copy-area .scroll.copy {
    transition: all .3s;
    opacity: 1;
    animation: scrolltxt1 10s linear infinite;
    position: relative;
    right: 0%;
    display: flex;
    transform: translate(-50%, 0%);
    white-space: nowrap;
}

.copy-area .scroll .scroll-copy {
    font-family: 'Lato', sans-serif,"Josefin Sans", sans-serif;
    font-size: 10.0rem;
    font-weight: 900;
    color: #657684;
    white-space: nowrap;
    text-align: center;
    display: inline-block;
    line-height: 1.4;
    padding: 0 0 0 30px;
}

.copy-area .scroll .scroll-txt {
    font-family: 'Lato', sans-serif,"Josefin Sans", sans-serif;
    font-size: 10.0rem;
    font-weight: 900;
    color: transparent;
    -webkit-text-stroke: 1px #657684;
    white-space: nowrap;
    text-align: center;
    display: inline-block;
    line-height: 1;
    padding: 0 0 0 30px;
}

@media screen and (max-width: 768px){
	
	.copy-area{
		padding: 20px 0 30px;
	}

	.copy-area .scroll {
		animation: scrolltxt 2s linear infinite;
	}
	.copy-area .scroll.copy {
		animation: scrolltxt1 3s linear infinite;
	}

	
	.copy-area .scroll .scroll-copy {
		font-size: 5.0rem;
	}

	.copy-area .scroll .scroll-txt {
		font-size: 5.0rem;
	}

	}

	@keyframes scrolltxt{
	0% {
		transform: translate(-40%, 0%);
	}

	100% {
		transform: translate(-60%, 0%);
	}
	}

	@keyframes scrolltxt1{
	0% {
		transform: translate(-60%, 0%);
	}

	100% {
		transform: translate(-40%, 0%);
	}
	
}