/* Container */
.org-chart {
	margin: 0 auto;
	position: relative;
}

/* Parent node */
.parent-node {
	font-size:16px;
}

/* Children wrapper */
.children-wrapper {
	position: relative;
	margin-top:60px;
	margin-bottom: 60px;
}

/* Vertical line connecting parent to children */
.vertical-line {
	position: absolute;
	top: 0;
	left: 25px;
	width: 4px;
	background-color: #d32f2f;
	border-radius: 3px;
	height: 100%;
	z-index: 5;
	box-shadow: 0 0 6px rgba(211,47,47,0.4);
}

/* Grid layout for children */
.children-grid {
	display: grid;
	/*grid-template-columns: repeat(2, 1fr);*/
	gap: 20px 20px;
	position:relative;
	top:45px;
	max-width:1170px;
	margin:0 auto;
	
	grid-template-columns: repeat(5, 1fr);
}
.children-grid2 {
	display: grid;
	/*grid-template-columns: repeat(8, 1fr);*/
	grid-template-columns: repeat(6, 1fr);
	gap: 20px 20px;
	margin-top:120px;
	position:relative;
	top:25px;
}
.children-grid3 {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px 20px;
	position:relative;
	top:-5px;
	max-width:1170px;
	margin:120px auto 0;
}
.child-node {
	font-weight:700;
	font-size:13px;
}
.child-node > div {
	height:45px;
}
.child-node > .corporate_logo {
	height:45px;
}
.child-node span {
	font-weight:400;
	display:block;
	margin-bottom:2px;
}
.child-node img {
	max-width:none;
}

#vertical_line {
	width:1px;
	height:5%;
	background:#555;
	position:absolute;
	top:5%;
	left:0;
	right:0;
	margin:0 auto;
}
.horizontal_line1_maxwidth1170{
    max-width: 1170px;
    margin: 0 auto;
    height: 100%;
    position: absolute;
    top: 9.99%;
    left: 0;
    right: 0;
    width: 100%;
}
#horizontal_line {
	width: 61.5%;
	height: 1px;
	background: #555;
	position: absolute;
	top: 9.99%;
	left: 17.5%;
	
	width: 100%;
    max-width: calc(100% - ((100% - 80px) / 5));
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}
#vertical_line2 {
	width: 1px;
	height: 7%;
	background: #555;
	position: absolute;
	top: 10%;
	left: 17.5%;
	
	top: 0;
	left: calc((20% / 2) - 8px);
}
#vertical_line3 {
	width: 1px;
	height: 7%;
	background: #555;
	position: absolute;
	top: 10%;
	left: 30.3%;
	
	top: 0;
	left: calc(40% - (20% / 2) - 4px);
}
#vertical_line4 {
	width: 1px;
	height: 7%;
	background: #555;
	position: absolute;
	top: 10%;
	left: 43.2%;
	
	top: 0;
	left: 0;
    right: 0;
    margin: 0 auto;
}
#vertical_line5 {
	width: 1px;
	height: 7%;
	background: #555;
	position: absolute;
	top: 10%;
	left: 59.5%;
	
	top: 0;
	left: calc(80% - (20% / 2) - -4px);
}
#vertical_line6 {
	width: 1px;
	height: 7%;
	background: #555;
	position: absolute;
	top: 10%;
	left: 79%;
	
	top: 0;
	left: calc(100% - (20% / 2) - -8px);
}

#vertical_line20{
    width: 1px;
	background: #555;
	position: absolute;
	top: 0%;
	left: calc(49% - (20% / 2) - -1px);
    height: 33%;
}
#vertical_line21{
    width: 1px;
	background: #555;
	position: absolute;
	top: 0%;
	left: calc(70% - (20% / 2) - -10.2px);
	height: 33%;
}

#horizontal_line2 {
	width:88%;
	width:84.5%;
	height:1px;
	background:#555;
	position:absolute;
	top:43%;
	left:0;
	right:0;
	margin:0 auto;
}
#vertical_line7 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 6%;
	left: 7.66%;
}
#vertical_line8 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 18%;
	left: 24.5%;
}
#vertical_line9 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 30.6%;
	left: 41.6%;
}
#vertical_line10 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 43.3%;
	left: 58.4%;
}
#vertical_line11 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 56%;
	left: 75.2%;
}
#vertical_line12 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 68.6%;
	left: 92.2%;
}

#vertical_line18 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 81.2%;
}

#vertical_line19 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 43%;
	left: 94%;
}

.horizontal_line3_maxwidth1170{
    max-width: 1170px;
    margin: 0 auto;
    height: 100%;
    position: absolute;
    top: 74.1%;
    left: 0;
    right: 0;
    width: 100%;
}
#horizontal_line3 {
	width:59%;
	height:1px;
	background:#555;
	position:absolute;
	top:74%;
	left:0;
	right:0;
	margin:0 auto;
	
	width: 100%;
	max-width: calc(100% - ((100% - 64px) / 4));
	top: 0;
}
#vertical_line13 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 74%;
  	left: 20.5%;
  	
  	top: 0;
  	left: calc((25% / 2) - 9px);
}
#vertical_line14 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 74%;
  	left: 40.2%;
  	
  	top: 0;
  	left: calc(50% - (25% / 2) - 4.5px);
}
#vertical_line15 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 74%;
	left: 59.5%;
	
	top: 0;
	left: calc(75% - (25% / 2) - -1px)
}
#vertical_line16 {
	width: 1px;
	height: 6%;
	background: #555;
	position: absolute;
	top: 74%;
	left: 79.49%;
	
	top: 0;
	left: calc(100% - (25% / 2) - -7px)
}
#vertical_line17 {
	width: 1px;
	height: 64%;
	background: #555;
	position: absolute;
	top: 10%;
	left:49.98%;
	
	top: 43%;
	height: 31.2%;
}

#corporate_grid1 {
	display:grid;
	grid-template-columns: repeat(3,1fr);
	column-gap:20px;
	row-gap:20px;
	align-items:center;
}

#corporate_grid2 {
	display:grid;
	grid-template-columns: repeat(2,1fr);
	column-gap:20px;
	row-gap:20px;
	align-items:center;
}

#listing {
	background:#f5f4ed;
	padding:60px 0;
}
#listing a {
	color:#ec1f28;
}

@media (max-width: 1440px) {
/*	#horizontal_line {
		width: 65%;
		left: 15.5%;
	}

	#vertical_line2 {
		left: 15.5%;
	}

	#vertical_line3 {
		left: 29%;
	}

	#vertical_line4 {
		left: 42.8%;
	}

	#vertical_line5 {
		left: 60%;
	}

	#vertical_line6 {
		left: 80.5%;
	}*/

	/*#horizontal_line3 {
		width: 62.5%;
	}

	#vertical_line13 {
		left: 18.8%;
	}

	#vertical_line14 {
		left: 39.5%;
	}

	#vertical_line15 {
		left: 60%;
	}

	#vertical_line16 {
		left: 81.2%;
	}*/
}

@media (max-width: 1280px) {
	/*#horizontal_line {
		width: 73.5%;
		left: 11%;
	}

	#vertical_line2 {
		left: 11%;
	}

	#vertical_line3 {
		left: 26.5%;
	}

	#vertical_line4 {
		left: 41.8%;
	}

	#vertical_line5 {
		left: 61.5%;
	}

	#vertical_line6 {
		left: 84.5%;
	}*/

	/*#horizontal_line3 {
		width: 70.5%;
	}

	#vertical_line13 {
		left: 14.8%;
	}

	#vertical_line14 {
		left: 38%;
	}

	#vertical_line15 {
		left: 61.5%;
	}

	#vertical_line16 {
		left: 85.2%;
	}*/
}

@media (max-width: 1200px) {
	.child-node, .child-node span {
		font-size:12px;
	}

	.child-node img {
		max-width: 100px;
	}
}

@media (max-width: 991px) {
    .children-wrapper{margin-top: 35px;}
	.children-grid, .children-grid2, .children-grid3 {
		grid-template-columns: 1fr;
		margin:0;
	}
	.children-grid2 {
		margin-top:46px;
	}
	.children-grid3 {
		margin-top:50px;
	}

	#mobile_vertical1 {
		width: 1px;
		height: 3%;
		background: #555;
		position: absolute;
		top: 2%;
		left: 0.5px;
		right: 0;
		margin: 0 auto;
	}

	#mobile_horizontal1 {
		width: 25%;
        height: 1px;
        background: #555;
        position: absolute;
        top: 4.9%;
        left: 24.95%;
	}

	#mobile_vertical2 {
		width: 1px;
		height: 92.5%;
		background: #555;
		position: absolute;
		top: 5%;
		left: 25%;
        height: calc(100% - 8.1%);
        left: 24.95%;
	}

	#mobile_horizontal2 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 8.5%;
		top: calc(((92.5% / 16) / 2) + 7%);
		left: 25%;
	}

	#mobile_horizontal3 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 14%;
		top: calc(((92.5% / 16) / 2) + 14%);
		left: 25%;
	}

	#mobile_horizontal4 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 20%;
		top: calc(((92.5% / 16) / 2) + 20.1%);
		left: 25%;
	}

	#mobile_horizontal5 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 25.5%;
		top: calc(((92.5% / 16) / 2) + 26.5%);
		left: 25%;
	}

	#mobile_horizontal6 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 31%;
		top: calc(((92.5% / 16) / 2) + 33%);
		left: 25%;
	}

	#mobile_horizontal7 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 37%;
		top: calc(((92.5% / 16) / 2) + 39.8%);
		left: 25%;
	}

	#mobile_horizontal8 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 42.8%;
		top: calc(((92.5% / 16) / 2) + 46%);
		left: 25%;
	}

	#mobile_horizontal9 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 47.6%;
		top: calc(((92.5% / 16) / 2) + 51%);
		left: 25%;
	}

	#mobile_horizontal10 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 53%;
		top: calc(((92.5% / 16) / 2) + 57%);
		left: 25%;
	}

	#mobile_horizontal11 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 59%;
		top: calc(((92.5% / 16) / 2) + 63.2%);
		left: 25%;
	}

	#mobile_horizontal12 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 65%;
		top: calc(((92.5% / 16) / 2) + 69.5%);
		left: 25%;
	}

	#mobile_horizontal13 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 70.2%;
		top: calc(((92.5% / 16) / 2) + 75.5%);
		left: 25%;
	}

	#mobile_horizontal14 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 76%;
		top: calc(((92.5% / 16) / 2) + 81%);
		left: 25%;
	}

	#mobile_horizontal15 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 81.5%;
		top: calc(((92.5% / 16) / 2) + 87.5%);
		left: 25%;
	}

	#mobile_horizontal16 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 86.5%;
		top: calc(((92.5% / 16) / 2) + 94%);
		left: 25%;
	}

	#mobile_horizontal17 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 92%;
		top: calc(((92.5% / 16) / 2) + 112%);
		left: 25%;
		display: none;
	}

	#mobile_horizontal18 {
		width: 7%;
		height: 1px;
		background: #555;
		position: absolute;
		top: 97.5%;
		top: calc(((92.5% / 16) / 2) + 119%);
		left: 25%;
		display: none;
	}

	#corporate_grid1, #corporate_grid2, #corporate_grid3 {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	/* .org-chart {
		max-width: 95%;
	}

	.parent-node {
		font-size: 1.1rem;
		padding: 10px 18px;
		max-width: 100%;
	}

	.children-wrapper {
		padding-left: 35px;
	}

	.vertical-line {
		left: 17px;
		width: 3px;
	} */

	/* .children-grid {
		grid-template-columns: 1fr;
		gap: 16px 0;
	}

	.child-node {
		font-size: 0.95rem;
		padding: 12px 15px;
		min-height: auto;
	}

	/* Horizontal line points left only at right */
	.child-node::before {
		left: 15px;
		width: 15px;
		height: 2.5px;
		background-color: #d32f2f;
	} */
}

@media (max-width: 480px) {
	.child-node::before {
		display: none;
	}

	.children-wrapper {
		padding-left: 20px;
	}

	.vertical-line {
		left: 10px;
	}

	#mobile_horizontal1 {
		width: 40%;
		left: 10%;
	}

	#mobile_vertical2 {
		left: 10%;
	}

	#mobile_horizontal16,#mobile_horizontal15,#mobile_horizontal14,#mobile_horizontal13,#mobile_horizontal12,#mobile_horizontal11,#mobile_horizontal10,#mobile_horizontal9,#mobile_horizontal8,#mobile_horizontal7,#mobile_horizontal6,#mobile_horizontal5,#mobile_horizontal4,#mobile_horizontal3,#mobile_horizontal2,#mobile_horizontal17,#mobile_horizontal18 {
		left:10%;
		width: 15%;
	}
}