
/* contents common title
------------------------------------------------------------*/

section.work_story_section {
	margin: 4rem 0;
}

div.work_story_intro_area {
	padding: 6rem 0;
}
div.work_story_intro_area_02 {
	padding: 0 0 6rem;
}

h2.work_story_intro_h2 {
	font-family: "Noto Sans Japanese", sans-serif;
	font-size: 2.7rem;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.8rem;
	color: #333;
	line-height: 190%;
}


div.work_story_intro_left {
	width: 55%;
	text-align: right;
}
div.work_story_intro_right {
	position: relative;
	width: 45%;
}


div.work_story_intro_left > img {
	display: in-lineblock;
	width: 61.4%;
	margin-right: 5%;
}

div.work_story_intro_pos {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

div.work_story_intro_right p {
	margin: 0;
	font-size: 1.4rem;
	font-weight: 600;
	color: #333;
	line-height: 300%;
}


/* step
--------------------------------------------------*/

div.work_story_step_left {
	width: 62%;
	margin-right: 3%;
}
div.work_story_step_right {
	width: 35%;
}

div.work_story_step_left_box {
	box-sizing: border-box;
}

div.work_story_step_left_box:last-child {
}
div.work_story_step_left_box:last-child div.step_number_box {
	display: none;
}



div.work_story_step_left_box:last-child div.step_box_3 {
	margin: 15rem 0 7rem;
}

div.work_story_step_left_box:last-child div.step_timeline_box_2 {
	margin: 15rem 0;
}

div.work_story_step_left_box:last-child div.step_timeline_box_1 {
	position: absolute;
	top: 0px;
	left: 25px;
	width: 50%;
	height: 100%;
	border-left: dashed 3px #d1d2d2;
}
div.work_story_step_left_box:last-child div.step_timeline_box_1:before {
	content: "";
	position: absolute;
	z-index: 99;
	top: 0;
	right: 19px;
	display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #d1d2d2;
}
div.work_story_step_left_box:last-child div.step_timeline_box_1:after {
	content: "";
	position: absolute;
	z-index: 99;
	bottom: 0;
	right: 19px;
	display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #d1d2d2;
}

div.step_box_1 {
	width: 50px;
}
div.step_box_2 {
	position: relative;
	width: 50px;
}
div.step_box_3 {
	position: relative;
	width: calc(100% - 100px);
}

div.step_box_3_outer {
	padding: 4px;
	background: #006a8f;
	background: -moz-linear-gradient(left, rgba(0, 104, 143, 1) 0%, rgba(0, 135, 143, 1) 100%);
	background: -webkit-linear-gradient(left, rgba(0, 104, 143, 1) 0%, rgba(0, 135, 143, 1) 100%);
	background: linear-gradient(to right, rgba(0, 104, 143, 1) 0%, rgba(0, 135, 143, 1) 100%);
}

div.step_box_3_inner {
	width: 100%;
  padding: 2.7rem 2rem;
	background-color: #FFF;
}
h3.step_title {
	margin: 0 0 1rem 0;
	font-size: 1.8rem;
	font-weight: 600;
	color: #28809e;
}
p.step_str {
	margin: 0;
	font-size: 1.3rem;
	font-weight: 500;
	line-height: 180%;
}

div.step_img_box {
	position: absolute;
	top: -20px;
	right: 20px;
	width: 60px;
	height: 60px;
	padding: 10px;
	background-color: #fff;
}
div.step_img_box > img {
	width: 100%;
}

div.next_icon {
	position: relative;
	width: 100%;
	height: 35px;
	text-align: center;
}

div.next_icon .glyphicon {
	color: #aaa;
    font-style: normal;
		font-size: 2rem;
    font-weight: 400;
		margin-top: 7px;
}

div.step_number_box {
	position: relative;
	z-index: 100;
	width: 50px;
	height: 50px;
	background: #006a8f;
	background: -moz-linear-gradient(left, rgba(0, 104, 143, 1) 0%, rgba(0, 135, 143, 1) 100%);
	background: -webkit-linear-gradient(left, rgba(0, 104, 143, 1) 0%, rgba(0, 135, 143, 1) 100%);
	background: linear-gradient(to right, rgba(0, 104, 143, 1) 0%, rgba(0, 135, 143, 1) 100%);
	color: #FFF;
}
div.step_number_box:after {
	content: "";
	position: absolute;
	z-index: 99;
	top: 21px;
	right: -8px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 10px;
	border-color: transparent transparent transparent #00878f;
}

div.step_number_pos {
	font-family: 'Roboto', sans-serif;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
}


div.step_number_box span {
	display: block;
	width: 100%;
	text-align: center;
	letter-spacing: 0.1rem;
	line-height: 100%;
}
span.step_number_num {
	font-size: 2rem;
}
span.step_number_step {
	font-size: 1.2rem;
}


div.step_timeline_box_1 {
	position: relative;
	top: 0;
	left: 25px;
	width: 50%;
	height: 100%;
	border-left: solid 3px #d1d2d2;
}


div.step_timeline_box_1_1 {
	position: relative;
	top: 25px;
	left: 25px;
	width: 50%;
	height: calc(100% - 25px);
	border-left: solid 3px #d1d2d2;
}

div.step_timeline_box_2 {
	position: absolute;
	top: 25px;
	left: 25px;
	width: 50%;
	height: calc(100% - 25px);
	border-top: solid 3px #28809e;
}

div.step_circle_1 {
	position: absolute;
	top: -11px;
	left: -10px;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: #006a8f;
}
div.step_circle_2 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: #FFF;
}
div.step_circle_3 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #006a8f;
}


div.work_story_step_right {
	position: relative;
}

div.work_story_step_right_box {
	position: relative;
	/* padding: 1rem; */
}
div.work_story_step_right_box:first-child {
	padding: 0;
}

/* div.story_step_right_box_1 {
	margin-bottom: 4rem;
}
div.story_step_right_box_2 {
	margin-bottom: 4rem;
}
div.story_step_right_box_3 {
	margin-bottom: 4rem;
}
div.story_step_right_box_4 {
	margin-bottom: 4rem;
} */
div.story_step_right_box_last {
	position: absolute;
	/* bottom: 8rem; */
}

div.work_story_step_right_box p {
	margin: 0;
	line-height: 190%;
	font-size: 1.3rem;
	font-weight: 500;
	text-align: justify;
}

div.step_right_box_str_1 {
	position: relative;
	padding: 2rem 2.5rem 2.1rem;
	background-color: #c7eaf0;
}
div.step_right_box_str_2 {
	position: relative;
	top: -25px;
	padding: 2rem 2.5rem 2.1rem;
	background-color: #e0f399;
}
div.step_right_box_str_3 {
	position: relative;
	top: -50px;
	padding: 2rem 2.5rem 2.1rem;
	background-color: #f7d596;
}
div.step_right_box_str_4 {
	position: relative;
	top: -75px;
	padding: 2rem 2.5rem 2.1rem;
	background-color: #ffd2d2;
}

img.step_right_box_img {
	width: 100%;
}

div.step_right_box_img_1 {
	position: relative;
	top: -25px;
}

div.step_right_box_img_2 {
	position: relative;
	top: -50px;
}

div.step_right_box_img_3 {
	position: relative;
	top: -75px;
}

div.step_right_box_img_4 {
	position: relative;
	top: -95px;
}



/*

light-blue		c7eaf0
light-green		e0f399
light-orange	f7d596
light-pink		ffd2d2

*/



@media screen and (max-width: 960px) {

	/* h2.work_story_intro_h2 {
		display: none;
	} */
	h3.step_title {
	    font-size: 2rem;
	}
	p.step_str {
    font-size: 1.8rem;
}
	div.work_story_intro_left {
		width: 100%;
		text-align: center;
	}
	div.work_story_intro_right {
		width: 90%;
		margin: 0 auto;
		padding: 2rem 0 0;
	}
	div.work_story_intro_pos {
		position: relative;
		top: initial;
		transform: initial;
	}

	div.work_story_intro_right p {
		font-size: 1.8rem;
		letter-spacing: -0.1em;
	}


br{
		display: none;
	}

	div.work_story_step_left {
		width: 100%;
    margin-right: 0;
	}
	div.work_story_step_right {
		width: 100%;
		margin-top: 20%;
	}


	div.step_number_box {
		box-sizing: border-box;
		height: calc(100% - 35px);
	}

	div.step_box_2 {
		display: none;
	}
	div.step_box_3 {
		width: calc(100% - 50px);
	}

	div.next_icon > span {
		position: absolute;
		left: 40%;
	}

	div.work_story_step_left_box:nth-child(10) div.step_number_box {
		display: block;
		height: 100%;
	}

	div.work_story_step_left_box:last-child {
		position: relative;
		margin-top: 80px;
	}

	div.work_story_step_left_box:last-child:before {
		content: "";
		position: absolute;
		top: -80px;
		left: 50%;
		width: 50%;
		height: 80px;
		border-left: dashed 2px #d1d2d2;

	}

	div.work_story_step_left_box:last-child div.step_number_box {
		display: block;
		height: calc(100% - 35px);
	}

	div.work_story_step_left_box:last-child div.step_box_3 {
		margin: 0;
	}

	div.work_story_step_left_box:last-child div.step_timeline_box_2 {
		margin: 0;
	}
	div.work_story_step_right_box p {
		font-size: 1.8rem;
	}

	div.story_step_right_box_1 {
		margin-bottom: initial;
	}
	div.story_step_right_box_2 {
		margin-bottom: initial;
	}
	div.story_step_right_box_3 {
		margin-bottom: initial;
	}
	div.story_step_right_box_4 {
		margin-bottom: initial;
	}
	div.story_step_right_box_last {
		position: relative;
		bottom: initial;
		margin-bottom: 20%;
	}

	div.step_number_box:after {
		top: 50%;
	}


}
