/**************************/
/* edgeendo css template */
/*glidepath & fire flowchart*/
/*500183980 & 500180210*/
/*************************/

.flow_wrapper {
	margin-bottom: 20px;
	width: 100%;
}

/*チャート大枠グリッドCSS*************************************/	
.flow_wrapper .grid {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: 60px 25px 110px 25px 630px 25px 35px;
	grid-template-columns: 60px 110px 630px 35px;
	-ms-grid-rows: 36px 10px 400px;
	grid-template-rows: 36px 400px;
	grid-gap: 10px 25px;
}
/*ヘッダ*/
.flow_wrapper .group1_head {
	grid-row: 1 / 2;
	grid-column: 1 / 2;
	-ms-grid-row: 1;
	-ms-grid-column: 1;
}
.flow_wrapper .group2_head {
	grid-row: 1 / 2;
	grid-column: 2 / 3;
	-ms-grid-row: 1;
	-ms-grid-column: 3;
}
.flow_wrapper .group3_head {
	grid-row: 1 / 2;
	grid-column: 3 / 4;
	-ms-grid-row: 1;
	-ms-grid-column: 5;
}
.flow_wrapper .group4_head {
	grid-row: 1 / 3;
	grid-column: 4 / 5;
	-ms-grid-row: 1;
	-ms-grid-column: 7;
	-ms-grid-row-span: 3;
}
/*ボディ*/
.flow_wrapper .group1_body {
	grid-row: 2 / 3;
	grid-column: 1 / 2;
	-ms-grid-row: 3;
	-ms-grid-column: 1;
}
.flow_wrapper .group2_body {
	grid-row: 2 / 3;
	grid-column: 2 / 3;
	-ms-grid-row: 3;
	-ms-grid-column: 3;
}
.flow_wrapper .group3_body {
	grid-row: 2 / 3;
	grid-column: 3 / 4;
	-ms-grid-row: 3;
	-ms-grid-column: 5;
}
/*チャート大枠グリッドCSS*************************************/	

.flow_wrapper .group1_head,
.flow_wrapper .group2_head,
.flow_wrapper .group3_head,
.flow_wrapper .group4_head {
	color: #ffffff;
	font-weight: bold;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
}
.flow_wrapper .group1_head,
.flow_wrapper .group2_head{
	background: #666666;
}
.flow_wrapper .group3_head,
.flow_wrapper .group4_head{
	background: #9c577b;
}
.flow_wrapper .group1_head p{
	font-size: 18px;
}
.flow_wrapper .group2_head p{
	font-size: 11px;
}
.flow_wrapper .group3_head p,
.flow_wrapper .group4_head p{
	font-size: 20px;
	letter-spacing: 0.3em;
}
.flow_wrapper .group4_head p {
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-o-writing-mode: vertical-rl;
}

/**共通**************************************/

.flow_wrapper .group1_body div ul.box,
.flow_wrapper .group2_body div ul.box,
.flow_wrapper .group3_body div ul.box{
	list-style: none;
}

/**穿通group1_body flow0**************************************/

.flow_wrapper .group1_body .flow0 {
	position: relative;
}
.flow_wrapper .group1_body .flow0 ul.box li {
	width: 60px;
	height: 400px;
	background: #ffffff;
	border: solid 3px #666666;
	box-sizing: border-box;
	padding: 5px;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	text-align: center;

}
.flow_wrapper .group1_body .flow0 ul.box li p {
	color: #666666;
	font-size: 10px;
	font-weight: bold;
	line-height: 1.2;
}
.flow_wrapper .group1_body .flow0 ul.box li img {
	width: 30px;
	height: auto;
}
/*矢印*/
.flow_wrapper .group1_body .flow0::before {
	content: '';
	width: 14px;
	height: 6px;
	background-color: #666666;
	position: absolute;
	top: calc(50% - 3px);
	left: 100%;
}
.flow_wrapper .group1_body .flow0::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #666666;
	position: absolute;
	top: calc(50% - 11px);
	left: calc(100% + 14px);
}
/**グライドパス形成group2_body flow1**************************************/

.flow_wrapper .group2_body {
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
}
.flow_wrapper .group2_body .flow1 ul.box li {
	width: 110px;
	height: 200px;
	background: #ffffff;
	border: solid 3px #0058a8;
	box-sizing: border-box;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    text-align: center;
}
.flow_wrapper .group2_body .flow1 ul.box li:first-child {
	border-bottom: dotted 3px #666666;
	padding: 5px 5px 20px;
	position: relative;
}
.flow_wrapper .group2_body .flow1 ul.box li:first-child img {
    width: 28px;
    height: auto;
}
.flow_wrapper .group2_body .flow1 ul.box li:last-child {
	border-top: none;
	padding: 15px 5px 5px;
	background: #fff999;
}
.flow_wrapper .group2_body .flow1 ul.box li:last-child img {
    width: 60px;
	height: auto;
}
.flow_wrapper .group2_body .flow1 ul.box li p {
	color: #666666;
	font-size: 11px;
	font-weight: bold;
	line-height: 1.2;
}
.flow_wrapper .group2_body .flow1 ul.box li span.or {
	background: #666666;
	color: #ffffff;
	border-radius: 3px;
	font-weight: bold;
	width: 3em;
	padding: 2px 0;
	text-align: center;
	position: absolute;
    left: calc((100% - 3em)/2);
	bottom: -10px;
}
.flow_wrapper .group2_body .flow1 ul.box li a {
	font-size: 11px;
	color: #009633;
	text-decoration: underline;
}

/**根管形成 group3_body flow2~6**************************************/

.flow_wrapper .group3_body {
	display: flex;
	flex-wrap: nowrap;
	justify-content: flex-start;
	align-items: center;
}
/*3-2*/
.flow_wrapper .group3_body .flow2 ul.box li {
	width: 100px;
	height: 400px;
	position: relative;
	background: #ffffff;
	border: solid 3px #0058a8;
	box-sizing: border-box;
	padding: 50px 5px 50px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: space-around;
	align-items: center;
	text-align: center;
	margin-right: 25px;
}
.flow_wrapper .group3_body .flow2 ul.box li::before {
	content: '';
    width: 545px;
    height: 6px;
    background-color: #0058a8;
    position: absolute;
    top: 0;
    left: 100%;
}
.flow_wrapper .group3_body .flow2 ul.box li::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #0058a8;
	position: absolute;
	top: -8px;
    left: calc(100% + 545px);
}
.flow_wrapper .group3_body .flow2 ul.box li img {
	width: 60px;
    height: auto;
}
.flow_wrapper .group3_body .flow2 ul.box li p {
	font-size: 12px;
	color: #0058a8;
	font-weight: bold;
	line-height: 1.2;
}
.flow_wrapper .group3_body .flow2 ul.box li p span {
	font-size: 12px;
	color: #666666;
	display: block;
}
.flow_wrapper .group3_body .flow2 ul.box li a span {
	font-size: 11px;
	color: #009633;
	text-decoration: underline;
}

/*3-3*/
.flow_wrapper .group3_body .flow3 ul.box li {
	width: 110px;
	height: 100px;
	position: relative;
	background: #c5e5f9;
	border-radius: 6px;
	display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
	margin-bottom: 30px;
	margin-right: 20px;
}
.flow_wrapper .group3_body .flow3 ul.box li::before {
	content: '';
    width: 13px;
    height: 6px;
    background-color: #0058a8;
    position: absolute;
    top: calc(50% - 3px);
    left: -26px;
}
.flow_wrapper .group3_body .flow3 ul.box li::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #0058a8;
	position: absolute;
	top: calc(50% - 11px);
    left: -13px;
}
.flow_wrapper .group3_body .flow3 ul.box li p {
	font-size: 15px;
	color: #666666;
	font-weight: bold;
}
.flow_wrapper .group3_body .flow3 ul.box li div.arrow {
	content: '';
	width: 20px;
	height: 6px;
	background-color: #0058a8;
	position: absolute;
	top: calc(50% - 3px);
	left: 100%;
}
.flow_wrapper .group3_body .flow3 ul.box li:last-child {
	margin-bottom: 0px;
}



/*3-4*/
.flow_wrapper .group3_body .flow4{
	align-self: center;
}
.flow_wrapper .group3_body .flow4 ul.box li {
	width: 108px;
	height: 180px;
	position: relative;
	background: #ffffff;
	border: solid 3px #0058a8;
	box-sizing: border-box;
	padding: 5px 3px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	text-align: center;
	margin-bottom: 10px;
	margin-right: 25px;
}
.flow_wrapper .group3_body .flow4 ul.box li::before {
	content: '';
    width: 13px;
    height: 6px;
    background-color: #0058a8;
    position: absolute;
    top: calc(50% - 3px);
    left: calc(100% + 3px);
}
.flow_wrapper .group3_body .flow4 ul.box li::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #0058a8;
	position: absolute;
	top: calc(50% - 11px);
    left: calc(100% + 15px);
}

/*追加直線*/
.flow_wrapper .group3_body .flow4 ul.box li div.arrow {
	content: '';
	width: 282px;
	height: 6px;
	background-color: #0058a8;
	position: absolute;
	top: 0;
	left: 100%;
}
.flow_wrapper .group3_body .flow4 ul.box li div.arrow:after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #0058a8;
	position: absolute;
	top: calc(50% - 11px);
    left: 100%;
}

.flow_wrapper .group3_body .flow4 ul.box li:last-child {
	margin-bottom: 0px;
}
.flow_wrapper .group3_body .flow4 ul.box li img {
	width: 40px;
    height: auto;
}
.flow_wrapper .group3_body .flow4 ul.box li p {
	font-size: 10px;
	color: #0058a8;
	font-weight: bold;
	line-height: 1.2;
}
.flow_wrapper .group3_body .flow4 ul.box li p span {
	font-size: 12px;
	color: #666666;
	display: block;
}

.flow_wrapper .group3_body .flow4 ul.box li a span {
	font-size: 11px;
	color: #009633;
	text-decoration: underline;
}

.flow_wrapper .group3_body .flow4 ul.box li a span {
	font-size: 11px;
	color: #009633;
	text-decoration: underline;
}


/*3-5*/
.flow_wrapper .group3_body .flow5{
	align-self: flex-end;
}
.flow_wrapper .group3_body .flow5 ul.box li {
	width: 108px;
	height: 180px;
	position: relative;
	padding: 5px 3px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	text-align: center;
	margin-bottom: 75px;
	margin-right: 25px;
}
.flow_wrapper .group3_body .flow5 ul.box li:first-child::before {
	content: '';
    width: 149px;
    height: 6px;
    background-color: #0058a8;
    position: absolute;
    top: calc(50% - 3px);
    left: 100%;
}
.flow_wrapper .group3_body .flow5 ul.box li:first-child::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #0058a8;
	position: absolute;
	top: calc(50% - 11px);
    left:calc(100% + 149px);
}
.flow_wrapper .group3_body .flow5 ul.box li:last-child::before {
	content: '';
    width: 13px;
    height: 6px;
    background-color: #0058a8;
    position: absolute;
    top: calc(50% - 3px);
    left: 100%;
}
.flow_wrapper .group3_body .flow5 ul.box li:last-child::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #0058a8;
	position: absolute;
	top: calc(50% - 11px);
    left:calc(100% + 13px);
}

.flow_wrapper .group3_body .flow5 ul.box li:first-child {
	background: #ffffff;
	border: solid 3px #0058a8;
	box-sizing: border-box;

}
.flow_wrapper .group3_body .flow5 ul.box li:first-child p {
	font-size: 10px;
	color: #0058a8;
	font-weight: bold;
	line-height: 1.2;
}
.flow_wrapper .group3_body .flow5 ul.box li:first-child p span {
	font-size: 12px;
	color: #666666;
	display: block;
}
.flow_wrapper .group3_body .flow5 ul.box li:first-child img {
	width: 40px;
    height: auto;

}
.flow_wrapper .group3_body .flow5 ul.box li:first-child a span {
	font-size: 11px;
	color: #009633;
	text-decoration: underline;
}
.flow_wrapper .group3_body .flow5 ul.box li:last-child {
	height: 130px;
	background: #c5e5f9;
	border-radius: 6px;
	display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
	margin-bottom: 0;
}
.flow_wrapper .group3_body .flow5 ul.box li:last-child p {
	font-size: 15px;
	color: #666666;
	font-weight: bold;
}

/*3-6*/
.flow_wrapper .group3_body .flow6{
	align-self: flex-end;
}
.flow_wrapper .group3_body .flow6 ul.box li {
	width: 108px;
	height: 180px;
	position: relative;
	background: #ffffff;
	border: solid 3px #0058a8;
	box-sizing: border-box;
	padding: 5px 3px;
	display: flex;
	flex-wrap: nowrap;
	flex-direction: column;
	justify-content: space-between;
	align-items: center;
	text-align: center;
	margin-right: 25px;
}
.flow_wrapper .group3_body .flow6 ul.box li::before {
	content: '';
    width: 16px;
    height: 6px;
    background-color: #0058a8;
    position: absolute;
    top: calc(70% - 3px);
    left: 100%;
}
.flow_wrapper .group3_body .flow6 ul.box li::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 11px 0 11px 12px;
	border-color: transparent transparent transparent #0058a8;
	position: absolute;
	top: calc(70% - 11px);
    left: calc(100% + 16px);
}
.flow_wrapper .group3_body .flow6 ul.box li img {
	width: 40px;
	height: auto;
}
.flow_wrapper .group3_body .flow6 ul.box li p {
	font-size: 10px;
	color: #0058a8;
	font-weight: bold;
	line-height: 1.2;
}
.flow_wrapper .group3_body .flow6 ul.box li p span {
	font-size: 12px;
	color: #666666;
	display: block;
}
.flow_wrapper .group3_body .flow6 ul.box li a span {
	font-size: 11px;
	color: #009633;
	text-decoration: underline;
}

	