/**************************/
/* edgeendo css template */
/*sapphire flowchart*/
/*500183960 & 500183970*/
/*************************/

.flow_wrapper_sp {
	width: 100%;
}

.flow_wrapper_sp .grid_sp {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 36px 5px auto;
	grid-template-columns: 36px auto;
	-ms-grid-rows: 60px 20px auto 20px 36px;
	grid-template-rows: 60px auto 36px;
	grid-gap: 20px 5px;
}

.group1_head_sp {
	-ms-grid-column: 1;
	grid-column: 1 / 2;
	-ms-grid-row: 1;
	grid-row: 1 / 2;
	background: #666666;
	font-size: 1.5em;
	color: #ffffff;
	font-weight: bold;
	padding: 10px 5px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.group2_head_sp {
	-ms-grid-column: 1;
	grid-column: 1 / 2;
	-ms-grid-row: 2;
	-ms-grid-row-span: 1;
	grid-row: 2 / 3;
	background: #9c577b;
	font-size: 1.5em;
	color: #ffffff;
	font-weight: bold;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
}

.group2_head_sp p {
	padding-top: 10px;
}

.group3_head_sp {
	-ms-grid-column: 1;
	-ms-grid-column-span: 2;
	grid-column: 1 / 3;
	-ms-grid-row: 5;
	grid-row: 3 / 4;
	background: #9c577b;
	font-size: 1.5em;
	color: #ffffff;
	font-weight: bold;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.group3_head_sp p {
	letter-spacing: 0.3em;
	padding-left: 1em;
}

.group1_body_sp {
	-ms-grid-column: 3;
	grid-column: 2 / 3;
	-ms-grid-row: 1;
	grid-row: 1 / 2;

}

.group2_body_sp {
	-ms-grid-column: 3;
	grid-column: 2 / 3;
	-ms-grid-row: 3;
	grid-row: 2 / 3;

}

.group1_head_sp p,
.group2_head_sp p {
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-o-writing-mode: vertical-rl;
}

.group1_body_sp div ul,
.group2_body_sp div ul {
	list-style: none;
}

/*ハンドファイル#10*/
.group1_body_sp .flow {
	position: relative;
}

.group1_body_sp .flow::before {
	content: '';
	width: 6px;
	height: 10px;
	background-color: #666666;
	position: absolute;
	top: 100%;
	left: calc(50% - 3px);
}

.group1_body_sp .flow::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #666666 transparent transparent transparent;
	position: absolute;
	top: calc(100% + 10px);
	left: calc(50% - 10px);
}

.group1_body_sp .flow ul.box li {
	width: 100%;
	height: 60px;
	background: #ffffff;
	border: solid 1px #666666;
	box-sizing: border-box;
	padding: 5px;
	display: flex;
	flex-direction: column;
	justify-content: space-around;
	align-items: center;
}

.group1_body_sp .flow ul.box li img {
	display: inline-block;
	width: 100%;
	max-width: 150px !important;
	max-height: 24px;
}

.group1_body_sp .flow ul.box li p {
	color: #666666;
	font-size: 1em;
	font-weight: bold;
}

.group2_body_sp {
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
}

.group2_body_sp .flow1 {
	width: 100%;
	position: relative;
}

.group2_body_sp .flow1::before {
	content: '';
	width: 6px;
	height: calc(15px + 42px);
	background-color: #0058a8;
	position: absolute;
	top: calc(100% - 15px);
	left: calc(50% - 3px);
}

.group2_body_sp .flow1 ul.box {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	margin-bottom: 15px;
}

.group2_body_sp .flow1 ul.box li {
	width: 50%;
	height: 190px;
	background: #ffffff;
	border: solid 1px #9c577b;
	box-sizing: border-box;
	padding: 10px 5px 5px;
	display: flex;
	flex-direction: column;
	justify-content: space-around;
	align-items: center;
}

.group2_body_sp .flow1 ul.box li:first-child {
	border-right: dotted 1px #9c577b;
	box-sizing: border-box;
	position: relative;
}

.group2_body_sp .flow1 ul.box li:last-child {
	border-left: none;
}

.group2_body_sp .flow1 ul.box li img {
	display: inline-block;
	width: 100%;
	max-width: 75px !important;
	max-height: 126px !important;
}

.group2_body_sp .flow1 ul.box li p {
	color: #666666;
	font-size: 1em;
	font-weight: bold;
}

.group2_body_sp .flow1 ul.box li span.or {
	background: #9c577b;
	color: #ffffff;
	border-radius: 3px;
	font-weight: bold;
	width: 2em;
	padding: 2px 0;
	text-align: center;
	position: absolute;
	left: calc(100% - 1em);
	bottom: 50%;
}

.group2_body_sp .flow1 ul.box li a {
	font-size: 1em;
	color: #009633;
	text-decoration: underline;
}

.group2_body_sp .flow2 {
	width: 100%;
	position: relative;
	background: #c5e5f9;
	border-radius: 6px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 10px;
	margin-bottom: 10px;
}

.group2_body_sp .flow2::before {
	content: '';
	width: calc(100% - 33.3%);
	height: 6px;
	background-color: #0058a8;
	position: absolute;
	top: calc(100% + 6px);
	left: auto;
}

.group2_body_sp .flow2 p {
	font-size: 1.4em;
	color: #666666;
	font-weight: bold;
}

.group2_body_sp .arrow_box3 {
	width: 100%;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
}

.group2_body_sp .arrow_box3 .arrow_l,
.group2_body_sp .arrow_box3 .arrow_c,
.group2_body_sp .arrow_box3 .arrow_r {
	width: 100%;
	height: 20px;
	margin-right: 5px;
	position: relative;
}

.group2_body_sp .arrow_box3 .arrow_r {
	margin-right: 0;
}

.group2_body_sp .arrow_box3 .arrow_l::before,
.group2_body_sp .arrow_box3 .arrow_c::before,
.group2_body_sp .arrow_box3 .arrow_r::before {
	content: '';
	width: 6px;
	height: 14px;
	background-color: #0058a8;
	position: absolute;
	top: -4px;
	left: calc(50% - 3px);
}

.group2_body_sp .arrow_box3 .arrow_l::after,
.group2_body_sp .arrow_box3 .arrow_c::after,
.group2_body_sp .arrow_box3 .arrow_r::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #0058a8 transparent transparent transparent;
	position: absolute;
	top: 10px;
	left: calc(50% - 10px);
}

.group2_body_sp .flow3 {
	width: 100%;
	position: relative;
	margin-bottom: 20px;
}

.group2_body_sp .flow3 ul.box {
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
}

.group2_body_sp .flow3 ul.box li {
	width: 100%;
	height: auto;
	min-height: 120px;
	position: relative;
	background: #c5e5f9;
	border-radius: 6px;
	padding: 5px;
	margin-right: 5px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: space-around;
	align-items: center;
}

.group2_body_sp .flow3 ul.box li::before {
	content: '';
	width: 6px;
	height: 10px;
	background-color: #0058a8;
	position: absolute;
	top: 100%;
	left: calc(50% - 3px);
}

.group2_body_sp .flow3 ul.box li::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #0058a8 transparent transparent transparent;
	position: absolute;
	top: calc(100% + 10px);
	left: calc(50% - 10px);
}

.group2_body_sp .flow3 ul.box li:last-child {
	margin-right: 0px;
}

.group2_body_sp .flow3 ul.box li p {
	display: inline-block;
	width: 100%;
	font-size: 15px;
	color: #666666;
	font-weight: bold;
	position: relative;
	text-align: center;
}

.group2_body_sp .flow3 ul.box li p.arrow3::before {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 9px 9px 0 9px;
	border-color: #0058a8 transparent transparent transparent;
	position: absolute;
	top: 100%;
	left: calc(50% - 9px);
}

.group2_body_sp .flow3 ul.box li p span {
	font-size: 12px;
	line-height: 1.2;
	text-align: center;
}

.group2_body_sp .flow4 {
	width: 100%;
	position: relative;
	margin-bottom: 30px;
}

.group2_body_sp .flow4::before {
	content: '';
	width: calc(100% - 33.3%);
	height: 6px;
	background-color: #0058a8;
	position: absolute;
	top: calc(100% + 9px);
	left: calc(33.3% / 2);
}

.group2_body_sp .flow4 ul.box {
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
}

.group2_body_sp .flow4 ul.box li {
	width: 100%;
	height: auto;
	max-height: 270px;
	position: relative;
	background: #ffffff;
	border: solid 1px #0058a8;
	box-sizing: border-box;
	padding: 10px 5px;
	margin-right: 5px;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
}

.group2_body_sp .flow4 ul.box li::before {
	content: '';
	width: 6px;
	height: 16px;
	background-color: #0058a8;
	position: absolute;
	top: 100%;
	left: calc(50% - 3px);
}

.group2_body_sp .flow4 ul.box li:nth-child(2)::before {
	height: 30px;
}

.group2_body_sp .flow4 ul.box li:last-child {
	margin-right: 0px;
}

.group2_body_sp .flow4 ul.box li p {
	display: inline-block;
	font-size: 1em;
	color: #0058a8;
	font-weight: bold;
	line-height: 1.2;
	text-align: center;
}

.group2_body_sp .flow4 ul.box li p span {
	display: inline-block;
	color: #666666;
	text-align: center;

}

.group2_body_sp .flow4 ul.box li a img {
	display: block;
	width: 100%;
	max-width: 50px !important;
	max-height: 135px !important;
	margin-bottom: 5px;
}

.group2_body_sp .flow4 ul.box li a span {
	display: block;
	font-size: 0.9em;
	color: #009633;
	text-decoration: underline;
}

.group2_body_sp .flow5 {
	width: 100%;
	position: relative;
	background: #c5e5f9;
	border-radius: 6px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 10px;
	margin-bottom: 10px;
}

.group2_body_sp .flow5::before {
	content: '';
	width: 6px;
	height: 15px;
	background-color: #0058a8;
	position: absolute;
	top: 100%;
	left: calc(50% - 3px);
}

.group2_body_sp .flow5::after {
	content: '';
	width: calc(100% - 50%);
	height: 6px;
	background-color: #0058a8;
	position: absolute;
	top: calc(100% + 10px);
	left: auto;
}

.group2_body_sp .flow5 p {
	font-size: 18px;
	color: #666666;
	font-weight: bold;
}

.group2_body_sp .arrow_box2 {
	width: 100%;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: row;
}

.group2_body_sp .arrow_box2 .arrow_left,
.group2_body_sp .arrow_box2 .arrow_right {
	width: 50%;
	height: 20px;
	position: relative;
}

.group2_body_sp .arrow_box2 .arrow_left {
	margin-right: 5px;
}

.group2_body_sp .arrow_box2 .arrow_left::before,
.group2_body_sp .arrow_box2 .arrow_right::before {
	content: '';
	width: 6px;
	height: 10px;
	background-color: #0058a8;
	position: absolute;
	top: 0;
	left: calc(50% - 3px);
}

.group2_body_sp .arrow_box2 .arrow_left::after,
.group2_body_sp .arrow_box2 .arrow_right::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #0058a8 transparent transparent transparent;
	position: absolute;
	top: 10px;
	left: calc(50% - 10px);
}

.group2_body_sp .flow6 {
	width: 100%;
}

.group2_body_sp .flow6 ul.box {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
}

.group2_body_sp .flow6 ul.box li {
	width: 50%;
	max-height: 220px;
	position: relative;
	background: #c5e5f9;
	border-radius: 6px;
	padding: 5px;
	margin-right: 5px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: space-around;
	align-items: center;
}

.group2_body_sp .flow6 ul.box li::before {
	content: '';
	width: 6px;
	height: 10px;
	background-color: #0058a8;
	position: absolute;
	top: 100%;
	left: calc(50% - 3px);
}

.group2_body_sp .flow6 ul.box li::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #0058a8 transparent transparent transparent;
	position: absolute;
	top: calc(100% + 10px);
	left: calc(50% - 10px);
}

.group2_body_sp .flow6 ul.box li:last-child {
	margin-right: 0px;
}

.group2_body_sp .flow6 ul.box li div.arrow {
	width: 100%;
	position: relative;
}

.group2_body_sp .flow6 ul.box li p {
	display: inline-block;
	width: 100%;
	font-size: 1.5em;
	color: #666666;
	font-weight: bold;
	position: relative;
	text-align: center;
}

.group2_body_sp .flow6 ul.box li p.arrow6::before {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 9px 9px 0 9px;
	border-color: #0058a8 transparent transparent transparent;
	position: absolute;
	top: calc(100% + -4px);
	left: calc(50% - 9px);
}

.group2_body_sp .flow6 ul.box li p span {
	font-size: 86%;
	line-height: 1.1;
}

.group2_body_sp .flow6 ul.box li p span.mark {
	display: block;
	font-size: 50%;
	font-weight: normal;
	text-align: center;
}