@charset "utf-8";
/* CSS Document */
.bg-gray {
	position: relative;
}
.top .bg-gray::after {
	content: '';
	display: block;
	width: 200%;
	height: 2px;
	background: url(/parts/img/line_horizontal.png) repeat-x;
	background-size: 6px 2px;
	position: absolute;
	top: 110px;
	right: -100%;
	z-index: -1;
}
.title-wrap {
	position: relative;
}
.title-wrap::after {
	content: '';
	display: block;
	width: 168px;
	height: 82px;
	background: #f8f8f8 url(/parts/img/spoon_icon.png) no-repeat;
	position: absolute;
	right: -110px;
	top: -13px;
}
.main {
	padding-bottom: 70px;
}

/* ---------------------------------------
	index
--------------------------------------- */
#service .bg-gray {
	margin-bottom: 65px;
}
.service-list {
	margin-top: 40px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 1.6em;
    font-family: "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
	li {
		background: #fff;
		a {
			display: grid;
			grid-template-rows: subgrid;
			grid-row: span 2;
			box-sizing: border-box;
			height: 100%;
			padding: 2.4em;
			background: #fff;
			text-align: center;
			transition: .3s box-shadow;
			@media (hover:hover) {
				&:hover {
					box-shadow: 0 0 1.6em rgba(0,0,0,0.1);
					h4, .hl-service-list__item {					
						> span {
							color: #ca3738;
							background-image: url(/parts/img/arrow_red.png);
						}
					}	
				}
			}
		}
		img {
			width: 132px;
			margin: 0 auto;
			vertical-align: bottom;
		}
		figcaption {
			text-align: left;
			p {
				line-height: 1.5;
				*+& {
					margin-top: 1em;
				}
			}
			@media (min-width: 601px) {
				margin-top: 2em;				
			}
		}
		h4, .hl-service-list__item {
			text-align: center;
			font-size: 18px;
			font-weight: bold;
			line-height: 1.4;
			> span {
				display: inline-block;
				padding: 3px 26px 3px 0;
				background: url(/parts/img/arrow_black.png) right center /6px 10px no-repeat;
				text-align: left;
			}		
		}	
	}	
}

.service-list.other-service li img {
	width: 190px;
}


/* ---------------------------------------
	ページ制作共通
--------------------------------------- */
.troubles {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.troubles li {
	box-sizing: border-box;
	width: calc((100% - 30px) / 2);
	margin-bottom: 10px;
	padding: 2px 0 10px 45px;
	border-bottom: 1px dotted #ccc;
	position: relative;
}
.troubles li + li {
}
.troubles li span {
	display: inline-block;
	width: 24px;
	height: 24px;
	border: 1px solid #f1bd40;
	background: #fff;
	border-radius: 5px;
	position: absolute;
	top: 0;
	left: 0;
}
.troubles li span::before {
	content: '';
	display: block;
	box-sizing: border-box;
	width: 13px;
	height: 8px;
	border-left: 2px solid #f1bd40;
	border-bottom: 2px solid #f1bd40;
	position: absolute;
	top: 5px;
	left: 6px;
	margin: auto;
	transform: rotate(-35deg);
}

/* サービスの流れ */
.box-service{
	background: #fff;
	border-radius: 5px;
	/* margin: 90px 0 !important; */
}
.box-service h3{
	background: #fef2d5;
	border-radius: 5px 5px 0 0;
	padding: 15px 0 15px 80px;
	font-size: 20px;
}
.box-service h3 span{
	position: relative;
	font-weight: bold;
}
.box-service h3 span:before{
	content: '';
	display: block;
	background: url(../img/ic_flow_top.png) 0 0 no-repeat;
	width: 48px;
	height: 72px;
	position: absolute;
	left: -65px;
	bottom:-8px;
}
.service-flow{
	padding: 45px 0 40px;
	background: url(../img/bg_flow.png) 50px 0 repeat-y;
}
.service-flow > li {
	padding: 0 20px 0 90px;
	position: relative;
}
.service-flow > li:before{
	content:'';
	display: block;
	width: 15px;
	height: 15px;
	background: #fff;
	border: 1px solid #252525;
	position: absolute;
	border-radius: 50%;
	left: 42px;
	top:5px;
	z-index: 10;
}
.service-flow > li + li {
	margin-top: 40px;
}
.service-flow > li h4 {
	font-size: 18px;
	font-weight:bold;
	position: relative;
}
.service-flow > li h4 .num {
	color: #f1bd40;
	padding-right:5px;
	display: inline-block
}
.service-flow > li p {
	margin: 0;
}

.full-list li a span {
	color: #f1bd40;
	margin-right: 10px;
}

figure {
	text-align: center;
	*+& {
		margin-top: 2.4em;
	}
}
.top figure {
	margin-top: 0;
}
figure img {
	width: auto;
	max-width: 100%;
}
.-lpbtobbnr {
    display: block;
    position: relative;
    margin-top: 30px;
	transition-duration: 0.3s;
}
.-lpbtobbnr:hover {
	opacity: 0.7;
}
.-lpbtobbnr img {
	max-width: 100%;
}
@media screen and (max-width: 767px) {
	.main h1.-spsmaller {
		font-size: 23px;
	}
	.box-service{
		background: #fff;
		border-radius: 5px;
		/* margin: 70px 0 !important; */
		margin-top: 70px!important;
	}
	.box-service h3{
		padding: 10px 0;
		font-size: 18px;
		text-align: center;
		font-weight: normal;
	}
	.box-service h3 span{
		position: relative;
		font-weight: bold;
		display: block;
	}
	.box-service h3 span:before{
		content: '';
		display: block;
		background: url(../img/ic_flow_top_sp.png) 0 0 no-repeat;
		background-size: 31px 68px;
		width: 31px;
		height: 68px;
		position: absolute;
		left: 11px;
		bottom:-8px;
	}
	.service-flow{
		padding: 35px 0;
		background: url(../img/bg_flow.png) 25px 0 repeat-y;
	}
	.service-flow > li {
		padding: 0 15px 0 50px;
		position: relative;
	}
	.service-flow > li:before{
		content:'';
		display: block;
		width: 15px;
		height: 15px;
		background: #fff;
		border: 1px solid #252525;
		position: absolute;
		border-radius: 50%;
		left: 18px;
		top:5px;
		z-index: 10;
	}
	.service-flow > li + li {
		margin-top: 30px;
	}
	.service-flow > li h4 {
		font-size: 16px;
	}
	.service-flow > li h4 .num {
		color: #f1bd40;
		padding-right:5px;
		display: inline-block
	}
	.service-flow > li p {
		margin: 0;
	}


	.full-list li a span {
		color: #f1bd40;
		margin-right: 10px;
	}
}


/*
.points-list li {
	display: inline-block;
	margin: 0 10px 15px 0;
}
.points-list li a {
	display: block;
	padding: 10px 20px 10px 50px;
	background: #f9f0d9;
	border-radius: 30px;
	line-height: 1.4;
	position: relative;
}
.points-list li a:hover {
	color: #fff;
	background: #f1bd40;
}
.points-list li a span {
	display: block;
	height: 20px;
	position: absolute;
	top: 0;
	left: 20px;
	bottom: 0;
	margin: auto;
}
*/
.points-detail {
	margin-top: 40px;
}
.points-detail > li {
	padding: 24px 30px 30px;
	border: 2px solid #f1bd40;
}
.points-detail > li + li {
	margin-top: 30px;
}
.points-detail > li h4 {
	margin-bottom: 20px;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.4;
}
.points-detail > li h4 .num {
	margin-right: 10px;
	font-size: 26px;
	color: #f1bd40;
	opacity: 0.8;
	font-style: italic;
}
.points-detail > li p {
	margin-bottom: 0;
}
.points-detail > li p + p {
	margin-top: 10px;
}
.features {
	display: flex;
	margin-top: 30px;
	justify-content: space-between;
	flex-wrap: wrap;
}
.features li {
	margin-bottom: 20px;
	box-sizing: border-box;
	width: calc((100% - 20px) / 2);
	padding: 20px 20px 24px;
	border-radius: 5px;
	background: #fff;
}
.features li:nth-last-child(-n + 2) {
	margin-bottom: 0;
}
.features li h5 {
	margin-bottom: 16px;
	padding-bottom: 10px;
	border-bottom: 1px dotted #d8d8d8;
	font-weight: bold;
	color: #f1bd40;
}
.features li p {
	line-height: 1.6;
}
a.btn-black-area{
	margin-top: 30px;
	display: block;
	height: 50px;
	box-sizing: border-box;
	background: #282828;
	color: #fff;
	text-align: center;
	line-height: 50px;
}
a.btn-black-area span {
	padding-right: 26px;
	background: url(/parts/img/arrow_white.png) center right /6px 10px no-repeat;
}
a.btn-black-area:hover {
	background: #fff;
	border: 1px solid #ca3738;
	color: #ca3738;
}
a.btn-black-area:hover span {
	background-image: url(/parts/img/arrow_red.png);
}
a.bnr-area{
    margin-top:60px;
    display: block;
}
a.bnr-area img{
    width:100%;
}
a.bnr-area:hover img{
    opacity: 0.5 ;
    transition: 0.3s ease;
}
/* ---------------------------------------
	トータルWebマーケティング
--------------------------------------- */
.e-circle-wrap {
	margin-top: 20px;
	background: #fff;
	border-radius: 5px;
	text-align: center;
}
.e-circle {
	display: inline-block;
	width: 360px;
	height: 380px;
	position: relative;
	vertical-align: bottom;
}
.e-circle::after {
	content: '';
	display: block;
	width: 240px;
	height: 240px;
	border-radius: 50%;
	border: 3px dotted #e0e0e0;
	position: absolute;
	top: 36px;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
.e-circle li {
	width: 150px;
	height: 150px;
	border-radius: 50%;
	background: #fff;
	position: absolute;
	text-align: center;
	/* color: #fff; */
	z-index: 10;
	border: 1px solid;
}
.e-circle li div {
	margin-top: 24px;
	line-height: 1.4;
	font-weight: bold;
}
.e-circle li figure {
	margin-top: 0;
	margin-bottom: 6px;
}
.e-circle li figure img {
	width: auto;
}
.e-circle li span {
	display: block;
	font-weight: normal;
	font-size: 12px;
}
.e-circle li:nth-child(1) {
	top: 30px;
	left: 0;
	right: 0;
	margin: auto;
	color: #f1bd40;
}
.e-circle li:nth-child(2) {
	left: 12px;
	bottom: 50px;
	/* background: #ca3738; */
	color: #ca3738;
}
.e-circle li:nth-child(3) {
	right: 12px;
	bottom: 50px;
	/* background: #387cad; */
	color: #387cad;
}
.compare {
	margin-top: 20px;
	display: flex;
	justify-content: space-between;
}
.compare li {
	box-sizing: border-box;
	width: calc((100% - 20px) / 2);
	padding: 20px;
	background: #fff;
	border-radius: 5px;
	text-align: center;
}
.compare li figure {
	margin-top: 0;
	position: relative;
}
.compare li figure span {
	display: block;
	position: absolute;
	left: 0;
	margin: auto;
}
.compare li figure span.not {
	width: 24px;
	height: 4px;
	background: #ca3738;
	transform: rotate(45deg);
	top: 6px;
}
.compare li figure span.not::before {
	content: '';
	display: block;
	width: 4px;
	height: 24px;
	background: #ca3738;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
.compare li figure span.ok {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	box-sizing: border-box;
	border: 4px solid #ca3738;
	bottom: auto;
	top: -5px;
}
.compare li figure img {
	display: block;
	width: auto;
	max-width: 100%;
	margin: 0 auto;
}
.compare li figure figcaption {
	padding-top: 20px;
	border-top: 1px solid #ddd;
	margin-top: 20px;
	font-weight: bold;
	line-height: 1.4;
}
.compare li figure figcaption p {
	display: inline-block;
	margin-bottom: 0;
	padding-left: 30px;
	position: relative;
}

/* ---------------------------------------
	コンテンツマーケティング
--------------------------------------- */
.make-fun {
	margin-top: 20px;
	display: flex;
	justify-content: space-between;
}
.make-fun li {
	box-sizing: border-box;
	width: calc((100% - (20px * 4)) / 5);
	padding: 8px 8px 20px;
	background: #fff;
	position: relative;
}
.make-fun li::after {
	content: '';
	display: block;
	width: 20px;
	height: 20px;
	background: #fff;
	transform: rotate(45deg);
	position: absolute;
	top: 0;
	right: -10px;
	bottom: 0;
	margin: auto;
}
.make-fun li:last-child::after {
	display: none;
}
.make-fun figure {
	margin-top: 0;
	text-align: center;
}
.make-fun figure img {
	width: auto;
	max-width: 100%;
	vertical-align: bottom;
}
.make-fun figcaption {
	font-size: 12px;
	text-align: center;
}
.task-list {
	margin: 30px 0;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.task-list li {
	padding: 8px 16px;
	border-radius: 30px;
	background: #fff;
	border: 2px dotted #ddd;
	font-size: 14px;
	line-height: 1.6;
	box-sizing: border-box;
	width: calc(50% - 5px);
	margin-bottom: 10px;
	display: flex;
	align-items: center;
}
.task-list li span {
	padding-left: 30px;
	position: relative;
}
.task-list li span::before {
	content: '';
	display: block;
	box-sizing: border-box;
	width: 13px;
	height: 8px;
	border-left: 2px solid #f1bd40;
	border-bottom: 2px solid #f1bd40;
	position: absolute;
	top: 3px;
	left: 5px;
	margin: auto;
	transform: rotate(-35deg);
}

/* ---------------------------------------
	コーポレートサイト制作
--------------------------------------- */
.corp-howto {
	margin-top: 30px;
	padding: 20px 20px 20px 40px;
	background: #fff;
	border-radius: 5px;
	list-style: disc;
	text-align: 1.6;
}
.corp-howto li + li {
	margin-top: 5px;
}

/* ---------------------------------------
	btob
--------------------------------------- */
.btob #point1 {
	overflow: hidden;
}
.btob-flow {
	margin: 30px 0;
	padding: 20px;
	display: flex;
	justify-content: space-between;
	position: relative;
}
.btob-flow li {
	box-sizing: border-box;
	width: calc((100% - (30px * 2)) / 3);
	padding: 25px 30px;
	border-radius: 5px;
	background: #fff;
	text-align: center;
	position: relative;
}
.btob-flow li::after {
	content: '';
	display: block;
	width: 20px;
	height: 20px;
	background: #fff;
	transform: rotate(45deg);
	position: absolute;
	top: 0;
	right: -10px;
	bottom: 0;
	margin: auto;
}
.btob-flow li:last-child::after {
	display: none;
}
.btob-flow li h5 {
	margin-bottom: 25px;
	padding-bottom: 15px;
	border-bottom: 1px dotted #d8d8d8;
	font-size: 16px;
	font-weight: bold;
	color: #f1bd40;
}
.btob-flow::before {
	content: '';
	display: block;
	box-sizing: border-box;
	width: calc((((100% - (30px * 2)) / 3) * 2) + 45px);
	height: 100%;
	border: 2px dotted #349440;
	border-radius: 5px;
	position: absolute;
	top: 0;
	left: 0;
}
.btob-flow::after {
	content: 'Webサイトが営業ツールとして特に力を発揮するプロセス';
	display: block;
	width: calc((((100% - (30px * 2)) / 3) * 2) + 45px);
	font-size: 16px;
	text-align: center;
	white-space: pre;
	line-height: 1.4;
	color: #349440;
	font-weight: bold;
	position: absolute;
	left: 0;
	bottom: -35px;
}
.conversion-list-wrap {
	margin-top: 30px;
}
.conversion-list {
	display: flex;
	justify-content: space-between;
}
.conversion-list li {
	box-sizing: border-box;
	width: calc((100% - (10px * 4)) / 5);
	padding: 12px 10px;
	border-radius: 25px;
	background: #fff;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1.4;
}
.conversion-list li:last-child {
	background: #e7f5e8;
}
.difficulty {
	margin-top: 20px;
	border-top: 2px dotted #ccc;
	padding-top: 15px;
	width: calc((((100% - (10px * 4)) / 5) * 4) + (10px * 3));
	display: flex;
	justify-content: space-between;
	position: relative;
}
.difficulty::before {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 6px 10.4px 6px 0;
	border-color: transparent #ccc transparent transparent;
	position: absolute;
	left: -2px;
	top: -7px;
}
.difficulty::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 6px 0 6px 10.4px;
	border-color: transparent transparent transparent #ccc;
	position: absolute;
	right: -2px;
	top: -7px;
}
.difficulty li:nth-child(1) {
	text-align: left;
}
.difficulty li:nth-child(2) {
	text-align: center;
	color: #349440;
	font-weight: bold;
}
.difficulty li:nth-child(2) br {
	display: none;
}
.difficulty li:nth-child(3) {
	text-align: right;
}

/* ---------------------------------------
	採用サイト制作
--------------------------------------- */
.recruit-flow {
	display: flex;
	margin-top: 30px;
	justify-content: space-between;
	flex-wrap: wrap;
}
.recruit-flow > li {
	box-sizing: border-box;
	width: calc((100% - (30px * 2)) / 3);
	padding: 25px 30px;
	border-radius: 5px;
	background: #fff;
	position: relative;
}
.recruit-flow > li::after {
	content: '';
	display: block;
	width: 20px;
	height: 20px;
	background: #fff;
	transform: rotate(45deg);
	position: absolute;
	top: 0;
	right: -10px;
	bottom: 0;
	margin: auto;
}
.recruit-flow > li:last-child::after {
	display: none;
}
.recruit-flow > li h5 {
	margin-bottom: 25px;
	padding: 0 0 15px 18px;
	border-bottom: 1px dotted #d8d8d8;
	font-size: 16px;
	font-weight: bold;
	color: #f1bd40;
	line-height: 1.4;
	position: relative;
}
.recruit-flow > li h5 span {
	position: absolute;
	left: 0;
	top: 0;
}
.recruit-flow > li ul {
	padding-left: 18px;
	line-height: 1.6;
	list-style: disc;
}
.recruit-flow > li ul li + li {
	margin-top: 5px;
}
.recruit .points-detail > li > figure {
	margin-top: 20px;
	padding: 50px 30px;
	border-radius: 5px;
	background: #fff;
	text-align: center;
}
.recruit .points-detail > li > figure img {
	width: auto;
	max-width: 100%;
	vertical-align: bottom;
}
.recruit figure {
	padding: 1em .8em 1em;
	border-radius: 5px;
	background: #fff;
	@media (max-width:600px) {
		padding: .5em;
		font-size: 12px;
	}
}

/* ---------------------------------------
	ランディングページ制作
--------------------------------------- */
.lp .txt-harf li h4 {
	color: #f1bd40;
}
.lp-effect {
	margin-top: 20px;
	display: flex;
	justify-content: space-between;
}
.lp-effect li {
	box-sizing: border-box;
	width: calc((100% - (20px * 2)) / 3);
	padding: 20px 8px 20px;
	background: #fff;
	position: relative;
}
.lp-effect li::after {
	content: '';
	display: block;
	width: 20px;
	height: 20px;
	background: #fff;
	transform: rotate(45deg);
	position: absolute;
	top: 0;
	right: -10px;
	bottom: 0;
	margin: auto;
}
.lp-effect li:last-child::after {
	display: none;
}
.lp-effect li figure {
	margin-top: 0;
	text-align: center;
	position: relative;
	z-index: 10;
}
.lp-effect li figure img {
	width: 120px;
	max-width: 100%;
}
.lp-effect li figure figcaption {
	font-size: 12px;
	line-height: 1.4;
}

/* ---------------------------------------
	10 for 1
--------------------------------------- */
.tenforone-flow {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
	padding: 40px 30px;
	border-radius: 5px;
	background: #fff;
	text-align: center;
}
.tenforone-flow li figure {
	margin-top: 0;
}
.tenforone-flow li:nth-child(1) {
	width: 58%;
	position: relative;
}
.tenforone-flow li:nth-child(2) {
	width: 32%;
}
.tenforone-flow li:nth-child(1)::before,
.tenforone-flow li:nth-child(1)::after {
	content: '';
	display: block;
	background: #387cad;
	position: absolute;
	margin: auto;
}
.tenforone-flow li:nth-child(1)::before {
	content: 'for';
	width: 60px;
	height: 50px;
	right: -60px;
	top: 50px;
	color: #fff;
	font-size: 20px;
	font-weight: bold;
	line-height: 50px;
}
.tenforone-flow li:nth-child(1)::after {
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 40px 0 40px 30px;
	border-color: #fff #fff #fff #387cad;
	right: -80px;
	top: 35px;
}
.tenforone-flow li figure img {
	width: auto;
}
.tenforone-flow li figure figcaption {
	margin-top: 10px;
	line-height: 1.6;
}
.tenforone-flow li figure figcaption b {
	font-size: 18px;
	font-weight: bold;
	color: #387cad;
}
.tenforone-flow li figure figcaption strong {
	font-size: 18px;
	font-weight: bold;
	color: #349440;
}
.flow li p {
	margin-top: 24px;
}
.example_10for1 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.example_10for1 li {
	width: calc((100% - 20px) / 2);
	box-sizing: border-box;
	margin-bottom: 20px;
}
.example_10for1 li figure {
	margin-top: 0;
}
.example_10for1 li figure img {
	width: 100%;
}
.example_10for1 li figure figcaption span {
	display: inline-block;
	padding-right: 32px;
	background: url(/parts/img/target_blank_black.png) right center /12px 12px no-repeat;
}

/* ---------------------------------------
	buycott
--------------------------------------- */
.buycott .main .to-buycott {
	margin-top: 100px;
	padding: 30px;
	border: 2px solid #282828;
	border-radius: 5px;
	background: #fff;
}
.to-buycott h3.title-ico {
	margin-top: 0;
}
.to-buycott .btn-black {
	margin-top: 20px;
	display: block;
	height: 50px;
	box-sizing: border-box;
	background: #282828;
	color: #fff;
	text-align: center;
	line-height: 50px;
}
.to-buycott .btn-black span {
	padding-right: 26px;
	background: url(/parts/img/arrow_white.png) center right /6px 10px no-repeat;
}
.to-buycott .btn-black:hover {
	background: #fff;
	border: 1px solid #ca3738;
	color: #ca3738
}
.to-buycott .btn-black:hover span {
	background-image: url(/parts/img/arrow_red.png);
}
.effect-copy{
	font-size: 40px;
	margin-bottom:5px;
	letter-spacing: .05em;
	font-weight: bold;
	line-height: 1;
}
.effect-copy span{
	font-size: 16px;
	margin-left:.5em;
	font-style: normal
}
.style-figure01{
	text-align: center;
	padding: 20px;
	background: #fff;
	margin-top:30px;
	border-radius:5px;
}
.style-figure01 img{
	width: auto;
	display: block;
	margin: 0 auto;
}
.buycott-data {
	margin-top: 30px;
	padding: 30px;
	border-radius: 5px;
	background: #fff;
	display: flex;
	justify-content: space-between;
}
.buycott-data > div:nth-child(1) {
	width: 300px;
	text-align: center;
}
.buycott-data > div:nth-child(2) {
	width: calc(100% - 300px - 30px);
}
.buycott-data img {
	width: 100%;
	box-shadow: 0 0 10px rgba(0,0,0,.08);
	vertical-align: bottom;
}
.buycott-data p span {
	display: block;
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 15px;

}
.buycott-data p span::before {
	content: '●';
}
.buycott-data .btn-black {
	margin-top: 20px;
	display: block;
	height: 50px;
	box-sizing: border-box;
	background: #282828;
	color: #fff;
	text-align: center;
	line-height: 50px;
}
.buycott-data .btn-black span {
	padding-right: 32px;
	background: url(/parts/img/target_blank.png) center right /12px 12px no-repeat;
}
.buycott-data .btn-black:hover {
	background: #fff;
	border: 1px solid #ca3738;
	color: #ca3738;
}
.buycott-data .btn-black:hover span {
	background-image: url(/parts/img/target_blank_red.png);
}

.main p strong{
	font-weight: bold;
	border-bottom: 2px dotted #e59019;
	padding-bottom:1px;
}
.main p+p{
	margin-top:2em;
}
.main .effect-copy+p{
	margin-top:0;
}

/* ---------------------------------------
	だれでもCMS
--------------------------------------- */
.invest-points > li {
	padding: 20px 20px 24px;
	background: #fff;
	border-radius: 5px;
}
.invest-points > li + li {
	margin-top: 20px;
}
.invest-points > li h4 {
	margin-bottom: 24px;
	padding: 0 0 16px 64px;
	border-bottom: 1px dotted #d8d8d8;
	font-size: 16px;
	font-weight: bold;
	line-height: 1.6;
	position: relative;
}
.invest-points > li h4 .num {
	position: absolute;
	top: 0;
	left: 0;
	color: #f1bd40;
}
.invest-points > li p + p {
	margin-top: 10px;
}
.cms #point2 h4 {
	margin-top: 40px;
	font-size: 16px;
	font-weight: bold;
	letter-spacing: .2em;
}
.cms #point2 h4 span {
	margin-left: 10px;
	font-weight: normal;
	font-size: 14px;
	color: #282828;
	letter-spacing: 0;
}
.func-list {
	margin-top: 20px;
	display: flex;
	justify-content: space-between;
}
.func-list li {
	box-sizing: border-box;
	width: calc((100% - (15px * 5)) / 6);
	padding: 20px 10px;
	border-radius: 5px;
	background: #f1bd40;
	text-align: center;
	display: flex;
	align-items: center;
	color: #fff;
	font-weight: bold;
	line-height: 1.6;
}
.func-list.custom li {
	background: #fff;
	border: 1px solid #f1bd40;
	color: #f1bd40;
}
.func-list li span {
	width: 100%;
}
.safety-points {
	margin-top: 20px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.safety-points li {
	box-sizing: border-box;
	width: calc((100% - 30px) / 2);
	margin-bottom: 10px;
	padding: 2px 0 10px 45px;
	border-bottom: 1px dotted #ccc;
	position: relative;
}
.safety-points li span {
	display: inline-block;
	width: 24px;
	height: 24px;
	border: 1px solid #f1bd40;
	background: #fff;
	border-radius: 5px;
	position: absolute;
	top: 0;
	left: 0;
}
.safety-points li span::before {
	content: '';
	display: block;
	box-sizing: border-box;
	width: 13px;
	height: 8px;
	border-left: 2px solid #f1bd40;
	border-bottom: 2px solid #f1bd40;
	position: absolute;
	top: 5px;
	left: 6px;
	margin: auto;
	transform: rotate(-35deg);
}
.cms-table {
	width: 100%;
}
.cms-table th,
.cms-table td {
	padding: 15px 0;
	border-bottom: 1px dotted #d8d8d8;
	vertical-align: middle;
}
.cms-table th {
	width: 180px;
	color: #349440;
	font-size: 16px;
	text-align: left;
	position: relative;
}
.cms-table th::after {
	content: '';
	display: block;
	box-sizing: border-box;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	border: 2px solid #c93738;
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	margin: auto;
}
.cms-table td {
}
.cms-table p{
	text-align: right;
	margin-top:2rem;
}
.cms-example {
	margin-top: 30px;
	padding: 20px 20px 20px 40px;
	background: #fff;
	border-radius: 5px;
	list-style: disc;
	text-align: 1.6;
}
.cms-example li + li {
	margin-top: 5px;
}
.cms .btn-black {
	margin-top: 30px;
	display: block;
	height: 50px;
	box-sizing: border-box;
	background: #282828;
	color: #fff;
	text-align: center;
	line-height: 50px;
}
.cms .btn-black span {
	padding-right: 26px;
	background: url(/parts/img/arrow_white.png) center right /6px 10px no-repeat;
}
.cms .btn-black:hover {
	background: #fff;
	border: 1px solid #ca3738;
	color: #ca3738;
}
.cms .btn-black:hover span {
	background-image: url(/parts/img/arrow_red.png);
}

@media screen and (max-width: 1080px) {
	.title-wrap::after {
		right: -4%;
	}

	/* ---------------------------------------
		ページ制作共通
	--------------------------------------- */
/*	.service-flow > li h4 {
		width: 125px;
		padding-left: 46px;
		font-size: 14px;
	}
	.service-flow > li p {
		width: calc(100% - 110px);
		margin: 0 0 0 10px;
	} */

	/* ---------------------------------------
		btob
	--------------------------------------- */
	.btob-flow {
		margin-bottom: 50px;
	}
	.btob-flow::after {
		content: 'Webサイトが営業ツールとして\A特に力を発揮するプロセス';
		bottom: -60px;
	}

	/* ---------------------------------------
		buycott
	--------------------------------------- */
	.tenforone-flow li:nth-child(1)::before {
		width: 40px;
		height: 40px;
		line-height: 40px;
		z-index: 2;
		right: -6.2vw;
	}
	.tenforone-flow li:nth-child(1)::after {
		border-width: 35px 0 35px 30px;
		right: -9vw;
	}
	.tenforone-flow li figure img {
		height: 15vw;
	}
	.buycott-data {
		display: block;
		padding: 30px;
	}
	.buycott-data > div:nth-child(1) {
		width: 100%;
	}
	.buycott-data > div:nth-child(2) {
		width: 100%;
		margin-top: 20px;
	}
	.buycott-data img {
		width: auto;
		max-width: 100%;
	}
	.buycott-data p span {
		margin-bottom: 5px;
	}
	
	/* ---------------------------------------
		誰でもCMS
	--------------------------------------- */
	.func-list {
		flex-wrap: wrap;
	}
	.func-list li {
		width: calc((100% - (20px * 2)) / 3);
		margin-bottom: 20px;
	}
}

@media screen and (max-width: 767px) {
	.chusho aside .side-nav {
		margin-top: calc(20vw + 46px)!important;
	}
	.title-wrap::after {
		display: none;
	}
	#service .bg-gray {
		margin-bottom: 80px;
	}
	.main {
		padding-bottom: 60px;
	}
	/* ---------------------------------------
		index
	--------------------------------------- */

	/* ---------------------------------------
		ページ制作共通
	--------------------------------------- */
	.troubles {
		display: block;
	}
	.troubles li {
		width: auto;
		padding: 5px 0 10px 40px;
		line-height: 1.6;
	}
	.troubles li + li {
		margin-top: 10px;
	}
	/* .service-flow {
		margin-top: 30px;
	}
	.service-flow > li {
		display: block;
		padding: 15px 15px 20px;
	}
	.service-flow > li + li {
		margin-top: 30px;
	}
	.service-flow > li::before {
		left: 60px;
	}
	.service-flow > li h4 {
		width: auto;
		padding-left: 36px;
		margin-bottom: 10px;
	}
	.service-flow > li h4 .num {
		width: 40px;
		height: 60px;
		padding: 35px 0 0 13px;
		left: -10px;
		top: -35px;
	}
	.service-flow > li p {
		width: auto;
		margin-left: 0;
		line-height: 1.6;
	} */
	.points-list li a {
		padding: 8px 12px 8px 42px;
	}
	.points-list li a span {
		left: 15px;
	}
	.points-detail > li {
		padding: 20px 15px 20px;
	}
	.points-detail > li h4 {
		margin-bottom: 10px;
		position: relative;
		padding-left: 40px;
		font-size: 16px;
	}
	.points-detail > li h4 .num {
		height: 20px;
		margin-right: 0;
		font-size: 20px;
		line-height: 1;
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		margin: auto;
	}

	/* ---------------------------------------
		トータルWebマーケティング
	--------------------------------------- */
	.compare {
		display: block;
	}
	.compare li {
		width: auto;
	}
	.compare li + li {
		margin-top: 20px;
	}
	.compare li figure figcaption {
		font-size: 12px;
		top: 5px;
	}
	
	/* ---------------------------------------
		コーポレートサイト制作
	--------------------------------------- */
	.task-list li {
		padding: 8px 10px;
	}
	.task-list li span {
		padding-left: 25px;
	}
	.task-list li span::before {
		width: 11px;
		height: 7px;
		top: 5px;
	}
	
	/* ---------------------------------------
		コンテンツマーケティング
	--------------------------------------- */
	.make-fun {
		justify-content: center;
		flex-wrap: wrap;
	}
	.make-fun li {
		width: 100%;
		padding: 10px;
	}
	.make-fun li + li {
		margin-top: 15px;
	}
	.make-fun li::after {
		right: auto;
		left: 20px;
		bottom: -7px;
		top: auto;
	}
	.make-fun figure {
		display: flex;
		align-items: center;
	}
	.make-fun figure img {
		width: 40px;
		height: 40px;
		margin-right: 10px;
	}
	.make-fun figure figcaption br {
		display: none;
	}

	/* ---------------------------------------
		btob
	--------------------------------------- */
	.btob-flow {
		display: block;
		margin: 70px 0 0;
	}
	.btob-flow > li {
		width: 100%;
		padding: 15px 15px 20px;
	}
	.btob-flow > li::after {
		top: auto;
		left: 0;
		bottom: -10px;
		right: 0;
	}
	.btob-flow > li + li {
		margin-top: 30px;
	}
	.btob-flow > li:last-child {
		margin-top: 40px;
	}
	.btob-flow li > h5 {
		margin-bottom: 10px;
		padding-bottom: 10px;
	}
	.btob-flow > li p {
		margin-bottom: 0;
		font-size: 12px;
	}
	.btob-flow::before {
		width: 100%;
		height: 370px;
		top: -20px;
	}
	.btob-flow::after {
		width: 60%;
		top: -40px;
		left: 0;
		height: 40px;
		right: 0;
		margin: auto;
		bottom: auto;
		background: #f8f8f8;
	}
	.conversion-list-wrap {
		position: relative;
	}
	.conversion-list {
		display: block;
	}
	.conversion-list li {
		width: 160px;
		padding: 0;
		height: 46px;
		line-height: 46px;
	}
	.conversion-list li + li {
		margin-top: 20px;
	}
	.difficulty {
		box-sizing: border-box;
		display: block;
		margin-top: 0;
		border-top: none;
		border-left: 2px dotted #ccc;
		padding: 0 0 0 20px;
		position: absolute;
		right: 0;
		top: 0;
		width: calc(100% - 180px);
		height: 244px;
	}
	.difficulty::before {
		border-width: 0 6px 10.4px 6px;
		border-color: transparent transparent #ccc transparent;
		top: -2px;
		left: -7px;
	}
	.difficulty::after {
		border-width: 10.4px 6px 0 6px;
		border-color: #ccc transparent transparent transparent;
		left: -7px;
		bottom: -2px;
		top: auto;
		right: auto;
	}
	.difficulty li {
		position: absolute;
		left: 20px;
		margin: auto;
	}
	.difficulty li:nth-child(1) {
		top: 0;
	}
	.difficulty li:nth-child(2) {
		height: 25px;
		top: 0;
		bottom: 0;
		text-align: left;
		line-height: 1.4;
	}
	.difficulty li:nth-child(3) {
		bottom: 0;
	}

	/* ---------------------------------------
		採用サイト制作
	--------------------------------------- */
	.recruit-flow {
		display: block;
		margin-top: 20px;
	}
	.recruit-flow > li {
		width: 100%;
		padding: 20px 20px 30px;
	}
	.recruit-flow > li::after {
		top: auto;
		left: 40px;
		bottom: -10px;
		right: auto;
	}
	.recruit-flow > li + li {
		margin-top: 20px;
	}
	.recruit .points-detail > li > figure {
		padding: 30px 15px;
	}

	/* ---------------------------------------
		ランディングページ制作
	--------------------------------------- */
	.lp-effect li {
		/* width: calc((100% - (8px * 2)) / 3); */
	}
	.features {
		display: block;
		margin-top: 20px;
	}
	.features li {
		width: 100%;
		margin-bottom: auto;
	}
	.features li + li {
		margin-top: 20px;
	}

	/* ---------------------------------------
		buycott
	--------------------------------------- */
	.effect-copy {
		font-size: 24px;
	}
	.effect-copy span {
		font-size: 14px;
	}
	.buycott .main .to-buycott {
		padding: 20px;
	}
	.to-buycott .btn-black {
		height: auto;
		padding: 12px 20px;
		line-height: 1.4;
	}
	.to-buycott .btn-black span {
		display: block;
	}
	.buycott-data {
		padding: 20px;
	}

	/* ---------------------------------------
		10 for 1
	--------------------------------------- */
	.tenforone-flow {
		display: block;
	}
	.tenforone-flow li:nth-child(1),
	.tenforone-flow li:nth-child(2) {
		width: 100%;
	}
	.tenforone-flow li:nth-child(2) {
		margin-top: 90px;
	}
	.tenforone-flow li:nth-child(1)::before,
	.tenforone-flow li:nth-child(1)::after {
		top: auto;
		left: 0;
		right: 0;
	}
	.tenforone-flow li:nth-child(1)::before {
		width: 50px;
		bottom: -50px;
		line-height: 50px;
	}
	.tenforone-flow li:nth-child(1)::after {
		border-width: 30px 40px 0 40px;
		border-color: #387cad #fff #fff #fff;
		bottom: -70px;
	}
	.tenforone-flow li figure img {
		height: auto;
		max-width: 100%;
	}
	.example_10for1 {
		display: block;
	}
	.example_10for1 li {
		width: 100%;
	}
	.example_10for1 li + li {
		margin-top: 20px;
	}

	/* ---------------------------------------
		だれでもCMS
	--------------------------------------- */
	.func-list li {
		font-size: 12px;
		width: calc((100% - (10px * 2)) / 3);
		margin-bottom: 10px;
	}
	.safety-points {
		display: block;
	}
	.safety-points li {
		width: auto;
		padding: 5px 0 10px 40px;
		line-height: 1.6;
	}
	.invest-points > li h4 {
		margin-bottom: 16px;
	}
}

@media screen and (max-width: 600px) {
	.chusho aside .side-nav {
		margin-top: calc(23vw + 46px)!important;
	}
	/* ---------------------------------------
		index
	--------------------------------------- */
	.service-list {
		gap: .5em
	}
	.service-list li a {
		padding: 1.3em 1em;
		figure {
			display: grid;
			grid-template-columns: 20% 1fr;
			align-items: center;
			gap: 1em;
		}
		figcaption {
			p {
				margin: .5em 0 0;
				font-size: 13px;
			}
		}
	}
	.service-list li img {
		width: 96%;
	}
	.service-list li h4,
	.service-list li .hl-service-list__item {
		font-size: 15px;
		text-align: left;
	}
	.service-list.other-service li img {
		width: 90%;
	}
	.main h1.rikumae_tit{
		font-size: 23px;
	}
}
@media screen and (max-width: 480px) {
	.chusho aside .side-nav {
		margin-top: calc(24vw + 46px)!important;
	}
	/* ---------------------------------------
		トータルWebマーケティング
	--------------------------------------- */
	.e-circle-wrap {
		padding: 20px 0 10px;
	}
	.e-circle {
		width: 240px;
		height: 240px;
	}
	.e-circle::after {
		width: 180px;
		height: 180px;
	}
	.e-circle li {
		width: 120px;
		height: 120px;
	}
	.e-circle li:nth-child(1) {
		top: 0;
	}
	.e-circle li:nth-child(2) {
		left: -5px;
		bottom: 10px;
	}
	.e-circle li:nth-child(3) {
		right: -5px;
		bottom: 10px;
	}
	.e-circle li div {
		margin-top: 14px;
	}
	.e-circle li figure {
		height: 50px;
	}
	.e-circle li figure img {
		width: auto;
		height: 100%;
	}

	/* ---------------------------------------
		btob
	--------------------------------------- */
	.btob-flow::after {
		width: 80%;
	}
	.difficulty li:nth-child(2) br {
		display: inherit;
	}
}
@media screen and (max-width: 400px) {
	.chusho aside .side-nav {
		margin-top: calc(28vw + 46px)!important;
	}
}
.chusho .main section img {
	max-width: 100%;
	height: auto;
}
.chusho .main section {
	position: relative;
	z-index: 3;
	margin-top: 80px;
}
.chusho .main section:first-child {
	margin-top: 0;
}
@media screen and (max-width: 767px) {
	.chusho .main section {
		margin-top: 40px;
	}
}
.main.-pb0 {
	padding-bottom: 0;
	padding-top: 0;
    font-size: 1.2em;
	    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
    font-weight: 500;
}
.main.-pb0 .main {
	width: 100%;
}

.main.-pb0 .main figure {
	margin-top: 20px;
}
.main.-pb0 .main img {
	max-width: 100%;
	height: auto;
}
.main.-undercv {
	position: relative;
}

.cv-cont {
	position: relative;
	z-index: 3;
}
.cv-cont h2 {
	font-size: 32px;
	text-align: center;
	margin-bottom: 36px;
	color: #3c3c3c;
	line-height: 1.2;
	font-weight: 600;
}
.cv-cont h2 span {
	display: inline-block;
	position: relative;
}
.cv-cont h2 span:before {
	content: '';
	display: block;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	top: -10px;
	margin: auto;
	right: 0;
	left: 0;
	background: #e48c10;
	position: absolute;
}
.cv-cont_inner {
	width: 100%;
	margin: auto;
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.cv-cont_flex {
	display: flex;
	justify-content: space-between;
	width: 100%;
	flex-wrap: wrap;
	margin: auto;
}
.cv-cont_item {
	width: 405px;
	background: #f5f5f5;
	padding: 15px 40px;
	box-sizing: border-box;
	border-radius: 5px;
	margin: 0 auto 10px auto;
}
.cv-cont_item.-bgwhiteitem {
	background: #fff;
}
.cv-cont_item p{
	text-align: center;
	font-size: 18px;
	position: relative;
	padding: 0 12px;
	margin-bottom: 5px;
	font-weight: normal;
	line-height: 1.4;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
	font-weight: 600;
}
.cv-cont_item p span {
	background: linear-gradient(transparent 63%, #f9dc76 63%);
	line-height: 1;
	display: inline-block;
}
.cv-cont_item p:before,.cv-cont_item p:after {
	content: '';
	display: block;
	width: 1px;
	height: 25px;
	transform: rotate(-30deg);
	bottom: 0;
	left: 0;
	background: #333;
	position: absolute;
}
.cv-cont_item p:after {
	right: 0!important;
	left: auto;
	
	transform: rotate(30deg);
}
a.cv-cont_btn {
	border-radius: 60px;
	background: #f0b425;
	color: #fff;
	border: 6px solid #fff3d5;
	display: flex;
	font-size: 20px;
	justify-content: center;
	align-items: center;
	line-height: 1;
	padding: 0 50px;
	height: 48px;
	position: relative;
	font-weight: 600;
	text-align: center;
	max-width: 188px;
	margin: auto;
}
.cv-cont_btn:after {
	    display: block;
    content: '';
    background: url(/parts/img/arrow_white.png) no-repeat;
    width: 9px;
    height: 18px;
    background-size: contain;
    position: absolute;
    right: 20px;
    top: 19px;
}
.cv-cont_btn.-yellow:before {
	    display: block;
    content: '';
    background: url(/parts/img/ico_balloon_white.png) no-repeat;
    width: 22px;
    height: 23px;
    background-size: contain;
    position: absolute;
    left: 15px;
    top: 12px;
}
.cv-cont_btn.-black {
	background: #ca3738;
	border: 6px solid #ffebeb;
}
.cv-cont_btn.-black:before {
	    display: block;
    content: '';
    background: url(/parts/img/ico_foot_contact_white.png) no-repeat;
    width: 24px;
    height: 23px;
    background-size: contain;
    position: absolute;
    left: 15px;
    top: 12px;
}
.cv-cont_btn:hover {
	background: #434343!important;
	border: 6px solid #ededed!important;
}
.cv-cont > p {
	text-align: center;
	margin-top: 10px;
	font-weight: 600;
}
.cv-cont > p a {
	pointer-events: none;
	font-weight: 600;
	display: inline-block;
	margin: 0 5px;
}
@media screen and (max-width: 992px) {
	.mv-cv {
		position: absolute;
		width: 100%;
		top: auto;
		z-index: 100;
		bottom: 300px;
	}
	.mv-cv_inner {
		max-width: 1080px;
		width: 90%;
		margin: auto;
		border-radius: 10px;
		padding: 20px 30px;
	}
	.mv-cv_inner {
		max-width: 100%;
		flex-wrap: wrap;
	}
	.mv-cv_item {
		width: 305px;
		margin: auto;
	}
}
@media screen and (max-width: 770px) {
	a.cv-cont_btn {
		white-space: nowrap;
		font-size: 18px;
	}
	.cv-cont_item p {
		font-size: 17px;
		white-space: nowrap;
	}
	.mv-cv_item {
		width: 100%;
		margin: 0 auto 15px auto;
	}
	.mv-cv_item + .mv-cv_item {
		margin-top: 15px;
	}
	.cv-cont > p a {
		pointer-events: auto;
	}
	.cv-cont h2 {
		font-size: 20px;
	}
}
@media screen and (max-width: 767px) {
	.head-img.sp.-btobmv{
		left: 0!important;
		right: auto;
	}
}


@media screen and (max-width: 480px) {
	.cv-cont_item {
		width: 100%;
		padding: 15px 30px;
		box-sizing: border-box;
	}
}




.-bgwhite {
	position: relative;
}
.-bgwhite section,.-bgwhite figure {
	position: relative;
	z-index: 1;
}
.-bgwhite:before {
	content: '';
	display: block;
	position: absolute;
	background: #fff;
	top: 0;
	left: -100vw;
	width: 220vw;
	height: 100%;
}
.main.-bgwhite.-underline {
	padding-top: 80px;
	position: relative;
	z-index: 0;
}
.-underline {
	position: relative;
	z-index: 3;
}
.-underline:after {
	content: '';
	display: block;
	position: absolute;
	background: #e8e8e8;
	bottom: -0;
    left: -100vw;
    width: 200vw;
	height: 1px;
}
@media screen and (max-width: 770px) {
	.-bgwhite {
		padding-top: 40px!important;
	}
	.main.-bgwhite.-underline {
		padding: 60px 0 40px 0!important;
	}
}


.head-img_btob img{
	width: 100%;
}
.btob-cont_subtit {
	@media (min-width:993px) {
		margin-top: 4em;		
	}
	display: flex;
	justify-content: space-between;
}
.btob-cont_subtit a{
	width: 290px;
    box-sizing: border-box;
    height: 50px;
    margin: 0;
    max-width: 100%;
    font-size: 18px;
	border: none!important;
}
.btob-cont_subtit a:hover {
	border: none!important;
}
.btob-cont_subtit p{
    width: calc(100% - 290px);
	font-size: 15px;
}
@media screen and (max-width: 992px) {
	.btob-cont_subtit {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.btob-cont_subtit a{
		width:100%;
	}
	.btob-cont_subtit p{
		width: 100%;
		font-size: 14px;
		margin-bottom: 20px;
	}
}
@media screen and (max-width: 770px) {
	
	.btob-cont_subtit {
		margin-top: calc(30vw + 20px);
	}
}
@media screen and (max-width: 600px) {

	.btob-cont_subtit {
		margin-top:calc(33vw + 20px);
	}
}
@media screen and (max-width: 460px) {

	.btob-cont_subtit {
		margin-top: calc(40vw + 20px);
	}
}


.chusho .main h2.title-line:first-child {
	margin-top: 0;
}
.title-yellow {
	padding-left: 54px;
}

.title-yellow:first-child{
	margin-top: 0;
}
.title-yellow { 
	font-size: 20px;
	border-bottom: solid 2px #e48c10;
	font-weight: bold;
	margin-bottom: 25px;
	padding: 5px 0 11px 60px!important;
	position: relative;
	margin-top: 80px;
	line-height: 1.4;
	color: #e48c10;
}
.title-yellow.num:before{
	counter-increment: num;
	content: "0" counter(num);
	color: #f1bd40;
	display: inline-block;
	padding: 0px 7px;
	width: 40px;
	position: absolute;
	top: 0;
	left: 0;
	font-size: 30px;
}
@media screen and (max-width: 992px) {

}


.btob-cont_reason {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.btob-cont_reason div{
	display: flex;
	align-items: center;
	box-sizing: border-box;
	padding: 20px 30px;
	width: calc((100% - (15px * 1)) / 2);
	margin-bottom: 15px;
	background: #fff;
	justify-content: space-between;
	min-height: 210px;
}
.btob-cont_reason figure img {
	
	width: 106px;
	height: 106px;
}
.btob-cont_reason figure {
	width: 106px;
	text-align: center;
    margin-top: 0;
    line-height: 1.2;
}
.btob-cont_reason p {
	width: calc(100% - 128px);
	line-height: 1.6;
	font-size: 14px;
	margin: 0!important;
}
.btob-cont_reason p span {
	font-weight: 600;
}
.btob-cont_reason figure span{
	display: inline-block;
	font-size: 20px;
	color: #e48c10;
	margin-top: 12px;
	font-weight: 700;
		
}
@media screen and (max-width: 992px) {
	.btob-cont_reason div {
		width: 100%;
		padding: 15px;
	}
}



.btob-cont_work {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1em;
	margin-top: 20px;
	@media (max-width:600px) {
		gap: .5em;
		grid-template-columns: repeat(2, 1fr);
	}
}
.btob-cont_work > div a {
	display: block;
	text-align: center;
}
.btob-cont_work figure {
	margin-top: 0;
	transition-duration: 0.3s;
}
.btob-cont_work > div a:hover figure{
	opacity: 0.6;
}
.btob-cont_work figure img {
	width: 100%;
}
.btob-cont_work span {
	display: inline-block;
	padding: 0px 26px 0px 0;
    line-height: 1.3;
	background: url(/parts/img/arrow_black.png) right center /6px 10px no-repeat;
	text-align: left;
    width: 90%;
    box-sizing: border-box;
}
.btob-cont_work > div a:hover span {
	color: #ca3738;
	background-image: url(/parts/img/arrow_red.png);
}
.btob-cont_work > div a:hover .span {
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
	transition: 0.5s ease;
}
.btob-cont_workbtn {
	margin-top: 30px;
}
.btob-cont_workbtn a{
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 50px;
	background: #282828;
	color: #fff;
	box-sizing: border-box;
    padding: 10px 20px;
}
.btob-cont_workbtn span {
	display: inline-block;
	padding-right: 40px;
	position: relative;
    background: url(/parts/img/arrow_white.png) right center /6px 10px no-repeat;
}
.btob-cont_workbtn a:hover{
	background: #ca3738;
}
@media screen and (max-width: 992px) {
	.btob-cont_work > div {
		margin-bottom: 0;
	}
	.btob-cont_work span {
		    padding: 0px 26px 0 0;
    font-size: 12px;
	}
}













.chusho .main ul.full-list,.main ul.full-list.-arrowdown{
	padding: 0;
	background: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.chusho .main ul.full-list li,.main ul.full-list.-arrowdown li{
	display: block;
	background: #f8f8f8;
	border-bottom: none;
	position: relative;
	border-radius: 5px;
	margin-bottom: 5px;
	width: 49.5%;
}
.main ul.full-list.-arrowdown li.-w100 {
	width: 100%;
}
.main ul.full-list.-arrowdown.-column03 li {
	width: calc((100% - (18px * 2)) / 3);
}
.chusho .main ul.full-list li.-white,.main ul.full-list.-arrowdown li {
	background: #fff;
}
.chusho .main ul.full-list li a,.main ul.full-list.-arrowdown li a{
	display: block;
	padding: 15px 40px 15px 50px;
	font-size: 16px;
	position: relative;
}
.chusho .main ul.full-list li a span,.main ul.full-list.-arrowdown li a span {
	height: 28px;
	position: absolute;
	top: 0;
	left: 15px;
	bottom: 0;
	margin: auto;
}
.chusho .main ul.full-list li:last-child,.main ul.full-list.-arrowdown li:last-child{
	border: none;
}
.chusho .main ul.full-list li a:after,.main ul.full-list.-arrowdown li a:after{
	content: '';
	background: url(/parts/img/arrow_list_red.png) no-repeat;
	width: 14px;
	height: 12px;
	background-size: 100%;
	display: block;
	position: absolute;
	right: 15px;
	top: 0;
	bottom: 0;
	margin: auto;
	transform: rotate(90deg);
}
.chusho .main ul.full-list li a:hover,.main ul.full-list.-arrowdown li a:hover{
	color: #ca3738;
}
.chusho .main ul.full-list li a:hover:after,.main ul.full-list.-arrowdown li a:hover:after{
	background: url(/parts/img/arrow_list_black.png) no-repeat;
	width: 14px;
	height: 12px;
	background-size: 100%;
}
@media screen and (max-width: 770px) {
	.chusho .main ul.full-list li,.main ul.full-list.-arrowdown lis {
		width: 100%;
	}
}



.txt_figure {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-direction: row-reverse;
}
.txt_figure figure {
	margin-top: 0!important;
}
.txt_figure figure img{
	width: 360px;
}
.txt_figure p {
	width: calc(100% - 384px);
	margin-top: 0!important;
}
@media screen and (max-width: 992px) {
	.txt_figure {
		flex-wrap: wrap;
		flex-direction: column;
	}
	.txt_figure figure{
		width: 100%;
		margin-bottom: 20px;
	}
	.txt_figure figure img{
		max-width: 100%;
		margin: auto;
		display: block;
	}
	.txt_figure p {
		width: 100%;
	}
}

.c-blk-btn {
	/* background: #ddd; */
	padding: 1em 0;
	margin-top: 2em!important;
	.-push {
		font-size: 1.3em;
		text-align: center;
		font-weight: bold;
		color: #ca3738;
		@media (max-width: 767px) {
			font-size: 1em;			
		}
		span {
			display: inline-flex;
			gap: .25em;
			&::before {
				content: '＼';
			}
			&::after {
				content: '／';
			}
		}
	}
	.-btn {
		margin-top: .25em;
	}
}
a.cv-cont_btn {
	&.-red {
		background: #ca3738;
		border: 2px solid #ef8a8a;
		padding: 1em 4em;
		height: auto;
		font-size: 16px;
		max-width: 360px;
		box-shadow: 0 0 8px rgba(255,200,200,.2);
		&:hover {
			border: 2px solid #434343!important;
		}
		&::after {
			top: 50%;
			translate: 0 -50%;
		}

	}
}

.-marker {
	background:linear-gradient(transparent 60%, #f1bd40 60%, #f1bd40 89%, transparent 90%);	
}

.c-table_contents {
	border: 1px solid #ccc ;
	padding: 2em;
}
.hl-table_contents {
	font-weight: bold;
	margin-bottom: 1em;
}
.c-list-table_contents {
	a {
		display: flex;
		gap: .64em;
		span:first-of-type {
			color:#f0b425;
			font-weight: bold;
		}
		span:nth-of-type(2) {
			text-decoration: underline;
		}
	}
	*+li {
		margin-top: .4em;
	}
}

.c-grid {
	display: grid;
	&.-zeroclick {
		width: 80%;
		margin: 2em auto 0;
		grid-template-columns: repeat(2, 1fr);
		gap: 3em;
		figure {
			border-radius: 8px;
			background: #fff;
			border: 2px solid #282828;
			margin: 0;
			figcaption {
				background: #282828;
				color: #fff;
				padding: .5em;
			}
			.c-img {
				padding: 2em 0;
				img {
					width: 90%;
					max-width: 200px;
					height: auto;
					display: block;
					margin: 0 auto;
				}
			}
		}
		@media(max-width:767px) {
			width: 90%;
			gap: 2em;
		}
	}
}

.recruit-flow.-llmo {
	margin: 2em auto; 
	display: grid; 
	grid-template-columns: 1fr 1fr; 
	gap: 40px;
	> li {
		width: auto;
		box-shadow: 0 0 12px rgba(0,0,0,.1);
	}
	@media(max-width:767px) {
		grid-template-columns: auto;
		gap: 10px;
	}
}

.hl-llmo-sub {
	margin-bottom: 1em;
	font-weight: bold;
	color: #ca3738;
	font-size: 17px;
	text-decoration: underline;
}

.c-list-eeat {
	display: grid;
	gap: .6em;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 2em;
	div {
		padding: 1.2em;
		background: #fff;
		border-radius: 2px;
		box-shadow: 0 0 1px rgba(0,0,0,.6);
	}
}

.-yellow {
	color: #e48c10;
}
.-red {
	color: #ca3738;
}


.c-list-cicle {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1em 5em;
	margin: 1em auto 3em;
	position: relative;
	@media(max-width:767px) {
		display: block;
		width: 92%;
		margin-left: 0;
	}
	> div {
		position: relative;
		@media(max-width:767px) {
			display: grid;
			grid-template-columns: 32vw 1fr;
			gap: .8em;
			align-items: center;
			*+& {
				margin-top: 5em;
			}
		}	
		&:not(:last-of-type) {
			&::after {
				content: '';
				display: block;
				width: 2em;
				aspect-ratio: 1/.8;
				background: #000;
				clip-path: polygon(0 0, 100% 0, 50% 100%);
				position: absolute;
				right: -3.5em;
				rotate: -90deg;
				top: 24%;
				opacity: .4;
				@media(max-width:767px) {
					rotate: 0deg;
					right: 0;
					left: 50%;
					translate: -50% 0;
					top: calc(100% + 2em);
				}
			}
		}
	}
	.c-pdca {
		grid-column: 1/4;
		display: flex;
		align-items: center;
		justify-content: space-between;
		position: relative;
		&::before,
		&::after {
			content: '●';
			font-size: 1.5em;
			color: #349440;
		}
		> span {
			&::before {
				content: '';
				display: block;
				width: 96%;
				position: absolute;
				height: 1px;
				background: #349440;
				left: 50%;
				top: 47%;
				translate: -50% -50%;
				z-index: 0;
			}
			span {
				background: #fafafa;
				position: relative;
				z-index: 2;
				padding: 0 1em;
				font-weight: bold;
				font-size: 17px;
				color: #349440;
			}
		}
		@media(max-width:767px) {
			position: absolute;
			right: -3em;
			translate: 0 -50%;
			top: 50%;
			writing-mode: vertical-rl;
			height: 100%;
			width: auto;
			> span {
				&::before {
					content: '';
					display: block;
					width: 1px;
					position: absolute;
					height: 96%;
					background: #349440;
					left: 50%;
					top: 50%;
					translate: -50% -50%;
					z-index: 0;
				}
				span {
					background: #fafafa;
					position: relative;
					z-index: 2;
					padding: 1em 0;
					font-weight: bold;
					font-size: 13px;
					color: #349440;
				}
			}	
		}
	}
}

.c-suggestion {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 5em;
	margin-top: 2em!important;
	padding: 0 3em;
	@media(max-width:767px) {		
		gap: 2em;
		padding: 0 0;
	}	
}
.c-suggestion__item {
	background: #fff;
	border-radius: 5px;
	padding: 1em 2em 1.5em;
	border: 2px solid #e48c10;
	position: relative;
	&:not(:last-of-type) {
		&::after {
			content: '';
			display: block;
			width: 4em;
			aspect-ratio: 1/1;
			background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2236%22%20height%3D%2236%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23e48c10%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22ai%20ai-Cross%22%3E%3Cpath%20d%3D%22M20%2020L4%204m16%200L4%2020%22%2F%3E%3C%2Fsvg%3E')50% 50% no-repeat;
			background-size: contain;
			position: absolute;
			top: 50%;
			left: calc(100% + 3%);
			translate: 0 -50%;
		}
	}
	.hl-suggestion {
		font-size: 20px;
		text-align: center;
		margin-bottom: 1em;
		font-weight: bold;
		color: #e48c10;
	}
	@media(max-width:767px) {		
		padding: 1em 1em 1.5em;
		&:not(:last-of-type) {
			&::after {
				width: 2em;
				position: absolute;
				left: calc(100% + 1%);
			}
		}
		.hl-suggestion {
			font-size: 16px;
		}
	}
}

.c-phase-box {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	aspect-ratio: 1/1;
	background: #368d3e;
	color: #fff;
	padding: 1em;
	border-radius: 50%;
	h4 {
		font-size: 19px;
		font-weight: bold;
		margin-top: .8em;
	}
	p {
		text-align: center;
		line-height: 1.4;
		margin-top: .5em;
		text-decoration: underline;
	}
	@media(max-width:767px) {
		max-width: 32vw;
		margin: 0;
		padding: 0;
		flex: 1;
		h4 {
			font-size: 15px;
		}
		p {
			font-size: 11px;
		}
	}	
}

.c-list-text {
	margin-top: 2em;
	font-size: 13.5px;
	line-height: 1.3;
	li {
		display: flex;
		gap: .5em;
		align-items: flex-start;
		&::before {
			content: '';
			display: block;
			width: .3em;
			aspect-ratio: 1/1;
			background: #000;
			position: relative;
			top: .3em;
			border-radius: 50%;
		}
		span {
			flex: 1;
		}
		*+& {
			margin-top: .8em;
		}
		@media(max-width:767px) {
			*+& {
				margin-top: .4em;
			}
		}		
	}
	@media(max-width:767px) {
		font-size: 12px;
		margin-top: 1em;
	}		
}