@charset "UTF-8";

/* --service common-- */
@media all {
	.service-flow-box {
		display: flex;
		color: #3B4C85;
	}


	.service-flow-box .service-list {
		counter-reset: num;
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		align-content: space-between;
		justify-content: space-between;
		width: 100%;
		height: 80%;
	}

	.service-flow-box .service-item {
		counter-increment: num;
		display: flex;
		align-items: center;
	}

	.service-flow-box .service-item a {
		position: relative;
		display: block;
		font-weight: bold;
		line-height: 1.4;
	}

	.service-flow-box .service-item a::before {
		content: counter(num, decimal-leading-zero);
		position: absolute;
		top: calc(50% - .875em);
		left: 0;
		display: flex;
		justify-content: center;
		align-items: center;
		width: 1.75em;
		height: 1.75em;
		background: #fff;
		border: 2px solid #3B4C85;
		border-radius: 50%;
		font-size: 25px;
		line-height: 1;
		transition: .3s;
	}
	body.cg .service-flow-box .service-item.cg a::before,
	body.vr .service-flow-box .service-item.vr a::before,
	body.presen .service-flow-box .service-item.presen a::before,
	body.design .service-flow-box .service-item.design a::before,
	body.education .service-flow-box .service-item.education a::before,
	body.contractor .service-flow-box .service-item.contractor a::before,
	.service-flow-box .service-item a:hover::before {
		background-color: #3B4C85;
		color: #fff;
	}
	.service-flow-box .service-item a::after {
		content: '▶︎';
		position: absolute;
		top: calc(50% - .4em);
		left: -1.125em;
		width: 1em;
		height: 1em;
		display: flex;
		align-items: center;
		line-height: 1;
		opacity: 0;
		transition: opacity .3s;
	}
	
	body.cg .service-flow-box .service-item.cg a::after,
	body.vr .service-flow-box .service-item.vr a::after,
	body.presen .service-flow-box .service-item.presen a::after,
	body.design .service-flow-box .service-item.design a::after,
	body.education .service-flow-box .service-item.education a::after,
	body.contractor .service-flow-box .service-item.contractor a::after,
	.service-flow-box .service-item a:hover::after {
		opacity: 1;
	}

	.service-flow-box .service-item a > span {
		display: block;
	}
	.service-flow-box .service-item a > span::after {
		content: attr(data-en);
		display: block;
		font-weight: normal;
	}
	.service-flow-box .service-item a small {
		font-size: 77.8%;
	}
	.flow-circle {
		position: relative;
		display: flex;
		align-items: center;
		justify-content: center;
		background: center / contain no-repeat url(../img/service/common/flow-circle.svg);
		text-align: center;
	}
	.flow-circle::before {
		content: '';
		position: absolute;
		z-index: -1;
	}
	.flow-circle-text {
		padding-top: .25em;
	}
	.flow-circle-text::after {
		content: attr(data-en);
		display: block;
	}

}

/* --service common-- sp & tab */
@media (max-width: 1024px) {
	.service-flow-box {
		flex-direction: column;
	}
}

/* --service common-- sp */
@media only screen and (max-width: 767px) {
	.service-flow-box {
		margin-top: 8vw;
		align-items: center;
	}
	.service-flow-box .service-list-box {
		position: relative;
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		padding: 25vw var(--sp-vw-14px) 10vw;
		width: 87.5vw;
		height: 149.0625vw;
		background: center / contain no-repeat url(../img/service/common/list-box-sp.svg);
	}
	.service-flow-box .service-list-box::after {
		content: '';
		position: absolute;
		top: calc(100% - 2px);
		left: 0;
		width: 99.75%;
		height: 45.9375vw;
		background: center / contain no-repeat url(../img/service/common/flow-arrow-sp.svg);
	}
	.service-flow-box .service-list {
		margin: 0 auto;
		width: 85%;
		height: 73%;
	}
	.service-flow-box .service-list-lead,
	.service-flow-box .service-item a > span,
	.service-flow-box .service-item a::before {
		font-size: var(--sp-vw-14px);
	}
	.service-flow-box .service-item a::after {
		top: calc(50% - .35em);
		left: -1.25em;
		font-size: var(--sp-vw-12px);
	}
	.service-flow-box .service-item a > span {
		margin-left: 2.75em;
	}
	.service-flow-box .service-item a > span::after {
		font-size: var(--sp-vw-10px);
	}
	.flow-circle {
		width: 33.75vw;
		height: 33.75vw;
		background-image: url(../img/service/common/flow-circle-sp.svg);
	}
	.flow-circle.designer {
		margin-top: 4vw;
	}
	.flow-circle.client {
		margin-top: 8vw;
	}
	.flow-circle-text {
		font-size: var(--sp-vw-14px);
		font-weight: bold;
		line-height: 1.3;
	}
	.flow-circle-text::after {
		font-size: var(--sp-vw-12px);
		font-weight: normal;
	}
	.section-header-ttl {
		font-size: var(--sp-vw-22px);
	}
	.section-header-lead {
		margin: var(--sp-vw-28px) auto 0;
		padding: 0 1.5em;
		font-size: var(--sp-vw-14px);
	}
}
/* --service common-- tab & pc */
@media print,
(min-width: 768px) {
	.service-flow-box {
		align-items: center;
		margin: 110px auto 0;
	}

	.service-flow-box .service-list-box {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		align-items: center;
		background: center / contain no-repeat url(../img/service/common/list-box.svg);
		padding: 80px 50px 60px;
		width: 550px;
		height: 495px;
	}

	.service-flow-box .service-list-lead {
		margin: 0 auto;
		width: 400px;
		line-height: 2;
	}

	.service-flow-box .service-list {
		height: 245px;
	}

	.service-flow-box .service-item {
		height: 62px;
		font-size: 18px;
	}
	.service-flow-box .service-item small {
		font-size: 14px;
	}

	.service-flow-box .service-item a > span {
		display: block;
		margin-left: 65px;
	}
	.service-flow-box .service-item a > span::after {
		font-size: 12px;
	}

	.flow-circle {
		width: 170px;
		height: 170px;
	}
	.flow-circle-text {
		font-size: 24px;
		font-weight: bold;
		line-height: 1.4;
	}
	.flow-circle-text::after {
		font-size: 12px;
		font-weight: normal;
	}

	.flow-circle.designer::before {
		width: 62px;
		height: 62px;
		background: center / contain no-repeat url(../img/service/common/flow-line.svg);
	}
	.flow-circle.flow-circle.client::before {
		width: 53px;
		height: 53px;
		background: center / contain no-repeat url(../img/service/common/flow-arrow.svg);
	}

	.main-section:first-of-type {
		margin-top: 50px;
	}
	.section-header-ttl {
		font-size: 34px;
	}
	.section-header-lead {
		margin: 80px auto 0;
		width: 605px;
	}
}
/* --service common-- pc */
@media (min-width: 1025px) {
	.service-flow-box {
		width: 1000px;
	}
	.flow-circle.designer {
		margin-left: 60px;
	}
	.flow-circle.designer::before {
		top: calc(50% - 31px);
		left: -61px;
	}
	.flow-circle.client {
		margin-left: 50px;
	}
	.flow-circle.flow-circle.client::before {
		top: calc(50% - 26.5px);
		left: -53px;
	}
}
/* --service common-- tab */
@media print,
(min-width: 768px) and (max-width: 1024px) {
	.flow-circle.designer {
		margin-top: 60px;
	}
	.flow-circle.designer::before {
		top: -61px;
		left: calc(50% - 31px);
		transform: rotate(90deg);
	}
	.flow-circle.client {
		margin-top: 50px;
	}
	.flow-circle.flow-circle.client::before {
		top: -53px;
		left: calc(50% - 26.5px);
		transform: rotate(90deg);
	}
}