@charset "utf-8";
.org-container { border: 1px solid #e5e5e5; border-radius: 8px; background-color: #ffffff; padding: 40px; display: flex; justify-content: center; overflow-x: auto; }
.tree { min-width: 800px; --row2-gap-offset: 62.5px; --box1-shift-left: 15px; }
@media (max-width: 1400px) {
  .org-container { display: block; }
  .tree { display: table; margin: 0 auto; }
}
.tree ul { display: flex; justify-content: center; position: relative; padding-top: 0; margin: 30px 0 0 0; list-style: none; padding-left: 0; }
.tree li { position: relative; padding: 30px 7.5px 0 7.5px; text-align: center; }
.tree > li { padding-top: 0; }
.tree li::before { content: ""; position: absolute; top: 0; left: 50%; width: 0; height: 30px; border-left: 1px solid #ccc; transform: translateX(-50%); }
.tree li::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 0; border-top: 1px solid #ccc; }
.tree li:first-child::after { left: 50%; width: 50%; }
.tree li:last-child::after { right: 50%; width: 50%; left: auto; }
.tree li:only-child::after { display: none; }
.tree > li::before { display: none; }
.tree .node + ul::before { content: ""; position: absolute; top: -30px; left: 50%; width: 0; height: 30px; border-left: 1px solid #ccc; transform: translateX(-50%); }
.tree > li > ul { margin-top: 60px; }
.tree > li > ul > li { padding: 60px var(--row2-gap-offset) 0; }
.tree > li > ul > li:first-child { padding: 60px calc(var(--row2-gap-offset) + var(--box1-shift-left)) 0 calc(var(--row2-gap-offset) - var(--box1-shift-left)); }
.tree > li > ul > li:first-child::before { left: calc(50% - var(--box1-shift-left)); }
.tree > li > ul > li:first-child::after { left: calc(50% - var(--box1-shift-left)); width: calc(50% + var(--box1-shift-left)); }
.tree > li > .node + ul::before { top: -60px; height: 60px; }
.tree > li > ul > li::before { height: 60px; }
.node { display: inline-flex; justify-content: center; align-items: center; border-radius: 4px; box-sizing: border-box; font-weight: 700; line-height: 100%; letter-spacing: -1%; text-align: center; vertical-align: middle; }
.node.root { background-color: #24355b; color: #fff; font-size: 22px; width: 250px; height: 70px; border-radius: 6px; }
.node.center-type1 { background-color: #44c1c4; color: #fff; font-size: 20px; width: 220px; height: 55px; }
.node.center-type2 { background-color: #00a3e9; color: #fff; font-size: 20px; width: 220px; height: 55px; }
.node.team { background-color: #fff; font-size: 16px; width: 220px; height: 45px; }
.node.team-type1 { color: #44c1c4; border: 1px solid #44c1c4; }
.node.team-type2 { color: #00a3e9; border: 1px solid #00a3e9; }
.team-fax { color: #666; font-weight: 600; font-size: 18px; margin-left: 10px; line-height: normal; letter-spacing: -2%; display: inline-block; vertical-align: baseline; }
.card-list { display: grid; column-gap: 16px; row-gap: 20px; margin-bottom: 20px; }
.card-list.top-card { grid-template-columns: calc((100% - (16px * 2)) / 3); }
.card-list.three-cols { grid-template-columns: repeat(3, 1fr); }
.card { background-color: #f7f9fa; border-radius: 5px; padding: 30px; min-height: 281px; }
.card-name { color: #111; display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; font-weight: 700; font-size: 26px; line-height: 100%; letter-spacing: -2%; vertical-align: middle; }
.card-role { color: #00a3e9; font-weight: 600; font-size: 14px; line-height: 100%; letter-spacing: 1%; vertical-align: middle; }
.card-contact { display: flex; align-items: center; gap: 15px; padding-bottom: 14px; margin-bottom: 34px; border-bottom: 1px solid #d7e1f2; flex-wrap: wrap; }
.contact-item { display: flex; align-items: center; gap: 6px; color: #666; font-weight: 600; font-size: 13px; line-height: 140%; letter-spacing: -2%; }
.contact-item::before { content: ""; display: inline-block; background-repeat: no-repeat; background-position: center; background-size: contain; }
.contact-email::before { width: 20px; height: 20px; background-image: url("../img/content/ico-mail.png"); }
.contact-phone::before { width: 20px; height: 20px; background-image: url("../img/content/ico-phone.png"); }
.card-tasks { list-style: none; }
.card-tasks li { position: relative; padding-left: 12px; color: #333; margin-bottom: 12px; word-break: keep-all; font-weight: 500; font-size: 15px; line-height: 100%; letter-spacing: -2%; vertical-align: middle; }
.card-tasks li:last-child { margin-bottom: 0; }
.card-tasks > li::before { content: "·"; position: absolute; left: 0; top: -5px; color: #44c1c4; font-weight: 800; font-size: 18px; }
.m-line { display: none; }
.card-tasks ul.ul-type02 { list-style-type: "- "; padding-left: 12px; margin-top: 12px; }
.card-tasks ul.ul-type02 li { padding-left: 0; margin-bottom: 8px; }
.card-tasks ul.ul-type02 li:last-child { margin-bottom: 0; }
@media (max-width: 1200px) {
  .org-container { padding: 40px 15px; display: block; overflow-x: hidden; }
  .card-list.top-card { grid-template-columns: calc(50% - 10px); }
  .card-list.three-cols { grid-template-columns: repeat(2, 1fr); }
  .card { padding: 25px; }
  .tree { min-width: 0; }
  .card-tasks li::before { top: -2px; }
  .tree li::before, .tree li::after, .tree li:first-child::after, .tree li:last-child::after, .tree li:only-child::after, .tree > li::before, .tree .node + ul::before, .tree > li > ul > li:first-child::before, .tree > li > ul > li:first-child::after, .tree > li > .node + ul::before, .tree > li > ul > li::before { display: none !important; content: none !important; }
  .tree { display: block; min-width: 0; width: 100%; --m-gap: 12px; --m-indent: 24px; --m-mid: 24px; --m-stroke: 1px; }
  .tree ul, .tree > li > ul { display: block; margin: 0; padding: 0; }
  .tree li, .tree > li > ul > li, .tree > li > ul > li:first-child, .tree > li > ul > li > ul > li { display: block; position: relative; padding: 0; margin: 0 0 var(--m-gap) 0; width: 100%; text-align: left; }
  .tree ul, .tree > li > ul, .tree > li > ul > li > ul { display: block; margin-top: 0; padding-top: var(--m-gap); margin-bottom: 0; margin-left: var(--m-indent); padding-left: var(--m-indent); border-left: none; }
  .tree > li { margin-top: 0; padding-top: 0; margin-left: 0; padding-left: 0; border-left: none; }
  .tree ul > li .m-line, .tree > li > ul > li .m-line, .tree > li > ul > li > ul > li .m-line { display: block !important; position: absolute; top: calc(var(--m-gap) * -1); left: calc((var(--m-indent) + var(--m-stroke)) * -1); width: calc(var(--m-indent) + var(--m-stroke)); height: calc(100% + var(--m-gap)); border-left: var(--m-stroke) solid #ccc; border-top: none; border-right: none; border-bottom: none; background: transparent; z-index: 1; }
  .tree ul > li:last-child .m-line, .tree > li > ul > li:last-child .m-line, .tree > li > ul > li > ul > li:last-child .m-line { height: calc(var(--m-gap) + var(--m-mid)); }
  .tree ul > li .m-line::before, .tree > li > ul > li .m-line::before, .tree > li > ul > li > ul > li .m-line::before { display: block !important; content: "" !important; position: absolute; top: calc(var(--m-gap) + var(--m-mid) - var(--m-stroke)); left: 0; width: calc(var(--m-indent) + var(--m-stroke)); height: var(--m-stroke); background-color: #ccc; }
  .tree .node, .tree .node.root { width: 100%; height: auto; min-height: 50px; padding: 12px 20px; justify-content: flex-start; text-align: left; white-space: normal; }
}
@media (max-width: 768px) {
  .card-list.top-card, .card-list.three-cols { grid-template-columns: 1fr; }
  .h4-tit01 { font-size: 24px; }
}
/* 기술사업화센터 제거 후 선 연결 */
.direct-group {
	padding-top: 60px;
}
.direct-group::before {
	height: 60px !important;
}
.direct-group > ul {
    margin: 0 !important;
    padding-top: 0 !important;
}
.direct-group > ul::before {
	content: "";
	position: absolute;
	top: -30px;
	left: 50%;
	width: 0;
	height: 30px;
	border-left: 1px solid #ccc;
	transform: translateX(-50%);
}
@media (max-width: 1200px) {


	.direct-group{padding-top: 0;}
	.tree > li > ul{position: relative;}
	.tree > li > ul:after{content:'';width: 1px;position: absolute;left: -1px;top: 0;bottom: 95px;background: #ccc;}
	.tree > li > ul br{display: none;}

	.direct-group > ul {
		margin-left: var(--m-indent);
		padding-left: var(--m-indent);
		padding-top: var(--m-gap);
	}
	.direct-group > ul::before {
		display: none;
	}
}