/* 서브 스타일 시작 */
	/* 서브 공통 */
	.content-wrap { width: 100%; padding: 130px 0 130px; }
	.content-wrap .inner { display: flex; flex-direction: column; align-items: center; width: 95%; max-width: 1200px; margin: 0 auto; padding: 0; }

	.content-wrap h2 { width: fit-content; margin: 0 auto 50px; padding-left: 40px; font-size: 32px; font-weight: 600; color: var(--color-lightblack); text-align: center; position: relative; }
	.content-wrap h2::before { content: ""; display: block; width: 15px; height: 15px; background: var(--color-theme); position: absolute; top: 5px; left: 0; }
	.content-wrap h2::after { content: ""; display: block; width: 15px; height: 15px; background: var(--color-lightgray); position: absolute; top: 20px; left: 15px; }

	@media screen and (max-width: 768px) {
		.content-wrap { padding: 100px 0 100px; }
		.content-wrap h2 { font-size: 28px; }
		.content-wrap .inner { max-width: 100%; width: 100%; padding: 0 20px; margin: 0 auto; }
	}

	@media screen and (max-width: 480px) {
		.content-wrap { padding: 80px 0 80px; }
		.content-wrap h2 { font-size: 24px;}
	}

	.introduce .inner { max-width: calc(100% - 100px); }
	.introduce .inner .content-box { display: flex; padding-bottom: 90px; position: relative; }
	.introduce .inner .content-box::before { content: ""; display: block; width: 100%; height: 68%; background: var(--color-lighttheme); position: absolute; bottom: 0; left: 0; z-index: -1; }
	.introduce .inner .content-box .img-box { width: 50%; padding: 0 50px; }
	.introduce .inner .content-box .txt-box { display: flex; flex-direction: column; justify-content: space-between; width: 50%; }
	.introduce .inner .content-box .txt-box > div { display: flex; flex-direction: column; gap: 20px; }
	.introduce .inner .content-box .txt-box h1 { width: 100%; max-width: 640px; font-size: 44px; font-weight: 800; color: var(--color-lightblack); }
	.introduce .inner .content-box .txt-box h1 span { color: var(--color-theme); }
	.introduce .inner .content-box .txt-box h3 { width: 100%; max-width: 640px; font-size: 22px; font-weight: 600; color: var(--color-lightblack); line-height: 1.5em; }
	.introduce .inner .content-box .txt-box h4 { width: 100%; max-width: 640px; font-size: 20px; font-weight: 500; color: var(--color-lightblack); line-height: 1.5em; }
	.introduce .inner .content-box .txt-box h4 strong { color: var(--color-theme); }
	.introduce .inner .content-box .txt-box p { width: 100%; max-width: 640px; color: var(--color-lightblack); line-height: 1.5em; }

	@media screen and (max-width: 768px) {
		.introduce .inner { max-width: 100%; }
		.introduce .inner .content-box { flex-direction: column; }
		.introduce .inner .content-box::before { height: 41%; }
		.introduce .inner .content-box .img-box { width: 100%; padding: 0px; margin-bottom: 20px; } 
		.introduce .inner .content-box .txt-box { width: 100%; padding: 0px 20px; margin-bottom: 20px; }
		.introduce .inner .content-box .txt-box h1 { font-size: 36px; }
		.introduce .inner .content-box .txt-box h3 { font-size: 20px; }
		.introduce .inner .content-box .txt-box h4 { font-size: 18px; }
	}

	@media screen and (max-width: 480px) {
		.introduce .inner .content-box::before { height: 50%; }
		.introduce .inner .content-box .img-box, 
		.introduce .inner .content-box .txt-box { padding: 0px; }
		.introduce .inner .content-box .txt-box h1 { font-size: 30px; }
		.introduce .inner .content-box .txt-box h3 { font-size: 18px; }
		.introduce .inner .content-box .txt-box h4 { font-size: 16px; }
	}

	/* Company > History */
	.history ul { display: flex; flex-direction: column; width: 100%; position: relative; }
	.history ul::before { content: ""; width: 2px; height: calc(100%); background: var(--color-theme); background: linear-gradient(0deg, #333 0%, var(--color-theme) 100%); border-radius: 999px; position: absolute; left: 50%; top: 20px; transform: translateX(-50%); }

	.history ul li { display: flex; flex-direction: column; margin-bottom: 32px; padding-left: calc(50% + 50px); }
	.history ul li:last-child { margin-bottom: 0; }
	.history ul li:nth-child(odd) { align-items: flex-end; padding-left: 0; padding-right: calc(50% + 50px); }

	.history ul li h3 { margin-bottom: 12px; font-size: 28px; font-weight: 900; color: var(--color-theme); line-height: 1.5em; position: relative; }
	.history ul li h3::after{ content: ""; width: 10px; height: 10px; background: var(--color-theme); border-radius: 999px; position: absolute; left: -55px; top: 50%; transform: translateY(-50%); }
	.history ul li:nth-child(odd) h3::after{ left: auto; right: -55px; }

	.history ul li p { display: flex; width: 100%; margin-bottom: 8px; padding-left: 10px; font-size: 16px; color: #555; line-height: 1.5em; position: relative; }
	.history ul li p::after { content: ""; display: block; width: 3px; height: 3px; background: var(--color-theme); border-radius: 999px; position: absolute; left: 0; top: 10px; }
	.history ul li:nth-child(odd) p { display: flex; flex-direction: row-reverse; padding-left: 0; padding-right: 10px; text-align: right; }
	.history ul li:nth-child(odd) p::after { left: auto; right: 0; top: 10px; }
	.history ul li p .tit { width: 40px; height: 100%; font-weight: 600; color: #333; }
	.history ul li p .cont { width: calc(100% - 40px); height: 100%; }


	/* Company > Organization */
	:root {
		--width: 220px;						/* 칸 가로 길이 */
		--line-horizon: 100px;					/* 칸 사이 가로 간격 */
		--line-vertical: 40px;					/* 행 사이 세로 간격 */
		--line-half-vertical: 21px;				/* 행 사이 세로 간격의 절반 기입 */

		--line-bgcolor: rgba(10, 164, 181, 0.3);		/* 라인 배경색 */

		--border: 1px solid rgba(10, 164, 181, 0.5);	/* 기본 테두리 설정 */
		--border-radius: 8px;					/* 칸 가장자리 굴림 */

		--depth01-bgcolor: rgba(10, 164, 181, 1);			/* 1뎁스 배경색 */
		--depth01-txtcolor: #fff;				/* 1뎁스 글씨색 */

		--depth02-bgcolor: rgba(10, 164, 181, 0.25);	/* 2뎁스 배경색 */
		--depth02-txtcolor: #333;				/* 2뎁스 글씨색 */

		--depth03-bgcolor: #719397;			/* 3뎁스 배경색 */
		--depth03-txtcolor: #fff;				/* 3뎁스 글씨색 */

		--depth04-bgcolor: #3974ed;			/* 4뎁스 배경색 */
		--depth04-txtcolor: #fff;				/* 4뎁스 글씨색 */

		--depth05-bgcolor: #3974ed;			/* 5뎁스 배경색 */
		--depth05-txtcolor: #fff;				/* 5뎁스 글씨색 */
	}

	.organization .organ-wrap { display: flex; flex-direction: column; gap: var(--line-vertical); width: 100%; margin: 0 auto; }
	.organization .organ-wrap ul { display: flex; justify-content: center; align-items: center; gap: var(--line-horizon); position: relative; }
	.organization .organ-wrap ul li { display: flex; justify-content: center; align-items: center; width: var(--width); padding: 10px 20px; border: var(--border); border-radius: var(--border-radius); font-size: 18px; color: #555; line-height: 1.5em; text-align: center; position: relative; }

	/* 칸 오른쪽 가로선 - li에 적용 */
	.organization .organ-wrap .line-h::before { content: ""; display: block; width: var(--line-horizon); height: 1px; background: var(--line-bgcolor); position: absolute; left: 100%; top: 50%; }
	/* 칸 상단 세로선 - li에 적용 */
	.organization .organ-wrap .line-top-v::before { content: ""; display: block; width: 1px; height: var(--line-half-vertical); background: var(--line-bgcolor); position: absolute; left: 50%; bottom: 100%; }
	/* 칸 하단 세로선 - li에 적용 */
	.organization .organ-wrap .line-bottom-v::before { content: ""; display: block; width: 1px; height: var(--line-half-vertical); background: var(--line-bgcolor); position: absolute; left: 50%; top: 100%; }
	/* 중앙 상단 가로선 - ul에 적용 */
	.organization .organ-wrap .line-top-h::before { content: ""; display: block; width: calc(var(--width) + var(--line-horizon)); height: 1px; background: var(--line-bgcolor); position: absolute; left: 50%; bottom: calc(100% + var(--line-half-vertical) - 2px); transform: translateX(-50%); }
	/* 중앙 하단 세로선 - ul에 적용 */
	.organization .organ-wrap .line-v::before { content: ""; display: block; width: 1px; height: var(--line-vertical); background: var(--line-bgcolor); position: absolute; left: 36.7%; top: 100%; }
	.organization .organ-wrap .line-v2::after { content: ""; display: block; width: 1px; height: var(--line-vertical); background: var(--line-bgcolor); position: absolute; left: 63.3%; top: 100%; }

	.organization .organ-wrap .depth00 { background: var(--depth05-bgcolor); padding:20px; border: none; font-weight: 500; color: var(--depth05-txtcolor); }
	.organization .organ-wrap .depth01 { background: var(--depth01-bgcolor); border: none; font-weight: 500; color: var(--depth01-txtcolor); }
	.organization .organ-wrap .depth02 { background: var(--depth02-bgcolor); border: none; color: var(--depth02-txtcolor); }
	.organization .organ-wrap .depth03 { background: var(--depth03-bgcolor); border: none; color: var(--depth03-txtcolor); }

	.organization .organ-wrap ul li.hidden { visibility: hidden; } /* 특수 배열 칸 숨기기 처리 */

	@media screen and (max-width: 768px) {
		.organization .organ-wrap ul li { width: calc(var(--width) - 40px); font-size: 16px; }
		.organization .organ-wrap .line-top-h::before { width: calc(var(--width) + var(--line-horizon) - 40px); }
	}

	@media screen and (max-width: 480px) {
		.organization .organ-wrap ul { flex-direction: column; gap: var(--line-vertical); }
		.organization .organ-wrap ul li { width: 100%; padding: 10px; font-size: 14px; }
		.organization .organ-wrap .line-h::before, 
		.organization .organ-wrap .line-top-h::before, 
		.organization .organ-wrap .line-v::before, 
		.organization .organ-wrap .line-v2::after { display: none; }
	}


	/* Company > Location */
	.location { width: 100%; display: flex; flex-direction: column; gap: 50px; }
	.location .item { display: flex; flex-direction: column; gap: 20px; width: 100%; }
	.location .item .txt-box { padding: 48px; background: var(--color-lightengray); }
	.location .item .txt-box h4 { font-size: 14px; color: var(--color-theme); }
	.location .item .txt-box h3 { margin-bottom: 50px; font-size: 20px; font-weight: 600; color: var(--color-theme); }
	.location .item .txt-box .info-box { display: flex; flex-direction: column; gap: 14px; }
	.location .item .txt-box .info-box p { padding-left: 32px; font-weight: 500; color: var(--color-lightblack); }
	.location .item .txt-box .info-box p.tel { background: url("/ggedc/board/images/mapboard_tel.png") no-repeat 0 50%; background-size: 18px auto; }
	.location .item .txt-box .info-box p.mail { background: url("/ggedc/board/images/mapboard_mail.png") no-repeat 0 50%; background-size: 18px auto; }
	.location .item .txt-box .info-box p.location { background: url("/ggedc/board/images/mapboard_location.png") no-repeat 0 50%; background-size: 18px auto; }
	.location .item .txt-box .info-box p.traffic { background: url("/ggedc/board/images/mapboard_traffic.png") no-repeat 0 50%; background-size: 18px auto; }
	.location .item .map-box { width: 100%; height: 500px; background: var(--color-lightengray); }
	.location .item .map-box .root_daum_roughmap.root_daum_roughmap_landing { width: 100% !important; height: 100% !important; }
	.location .item .map-box .root_daum_roughmap.root_daum_roughmap_landing .wrap_map { width: 100% !important; height: 100% !important; }
	.location .item .map-box .root_daum_roughmap.root_daum_roughmap_landing .wrap_map .map_border { border: none !important; background: none !important; }
	.location .line { width: 100%; height: 1px; margin: 50px auto; background: var(--color-lightgray); }

	@media screen and (max-width: 1279px) {
		.location .item .txt-box { padding: 30px 20px !important; }
	}

	/* Center */
	.center-business-intro .inner { max-width: 1440px; }
	.center-business-intro .content-box { display: flex; gap: 30px; width: 100%; margin-bottom: 100px; }
	.center-business-intro .content-box .content { position: relative; display: flex; flex-direction: column; width: calc(100% - 15px); height: 250px; padding: 30px; border: 1px solid transparent; transition: all 0.2s ease-in-out; }
	.center-business-intro .content-box .content::before {content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 250px;background: url("../images/main/business01.png") no-repeat center center; background-size: cover; filter: brightness(0.4); z-index: -1; }
	.center-business-intro .content-box .content:hover { background: var(--color-theme); border-radius: 0 50px 0 0; transition: all 0.5s ease-in-out; }
	.center-business-intro .content-box .content:hover::before  { opacity: 0; transition: all 0.5s ease-in-out; }
	.center-business-intro .content-box.triple .content { width: calc((100%/3) - 20px); }
	.center-business-intro .content-box .content h4 { margin-bottom: 10px; font-size: 15px; font-weight: 800; color: var(--color-white); letter-spacing: 2px; text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); }
	.center-business-intro .content-box .content:hover h4 { text-shadow: none; transition: all 0.5s ease-in-out; }
	.center-business-intro .content-box .content h3 { margin-bottom: 20px; font-size: 24px; font-weight: 700; color: var(--color-white); text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); }
	.center-business-intro .content-box .content:hover h3 { font-size: 26px; text-shadow: none; transition: all 0.5s ease-in-out; }
	.center-business-intro .content-box .content p { padding-left: 10px; font-size: 18px; color: var(--color-white); line-height: 1.5em; position: relative; top: 18px; opacity: 0; }
	.center-business-intro .content-box .content p::before { content: ""; display: block; width: 3px; height: 3px; background: var(--color-white); position: absolute; top: 50%; left: 0; transform: translateY(-50%); }
	.center-business-intro .content-box .content:hover p.line01 { top: 0; opacity: 1; transition: all 0.5s ease-in-out 0.5s; }
	.center-business-intro .content-box .content:hover p.line02 { top: 0; opacity: 1; transition: all 0.5s ease-in-out 0.7s; }

	.center-business-intro .content-box .content-02::before { 
		background: url("../images/sub/center/sub_business1-2.png") no-repeat center center; 
	}
	.center-business-intro .content-box .content-03::before { 
		background: url("../images/main/business02.png") no-repeat center center; 
	}
	.center-business-intro .content-box .content-04::before { 
		background: url("../images/sub/center/sub_business2-2.png") no-repeat center center; 
	}
	.center-business-intro .content-box .content-05::before { 
		background: url("../images/main/business03.png") no-repeat center center; 
	}
	.center-business-intro .content-box .content-06::before { 
		background: url("../images/sub/center/sub_business3-2.png") no-repeat center center; 
	}
	.center-business-intro .content-box .content-07::before { 
		background: url("../images/main/business04.png") no-repeat center center; 
	}
	.center-business-intro .content-box .content-08::before { 
		background: url("../images/sub/center/sub_business4-2.png") no-repeat center center; 
	}
	.center-business-intro .content-box .content-09::before { 
		background: url("../images/sub/center/sub_business4-3.png") no-repeat center center; 
	}

	
	@media screen and (max-width: 768px) {
		.center-business-intro .content-box { flex-direction: column; gap: 20px; }
		.center-business-intro .content-box .content { width: 100%; height: 200px; border-radius: 0 50px 0 0; }
		.center-business-intro .content-box .content::before { height: 200px; border-radius: 0 50px 0 0; }
		.center-business-intro .content-box.triple .content { width: 100%; }
		.center-business-intro .content-box .content h3 { font-size: 22px; }
		.center-business-intro .content-box .content p { font-size: 16px; opacity: 1; }
		.center-business-intro .content-box .content:hover {   pointer-events: none; }
		.center-business-intro .content-box .content:hover h3 { font-size: 22px; }
		.center-business-intro .content-box .content:hover p.line01 { top: 18px; opacity: 1; }
		.center-business-intro .content-box .content:hover p.line02 { top: 18px; opacity: 1; }
	}

	@media screen and (max-width: 480px) {
		.center-business-intro .content-box { gap: 15px; }
		.center-business-intro .content-box .content h3 { font-size: 20px; }
		.center-business-intro .content-box .content:hover h3 { font-size: 22px; }
		.center-business-intro .content-box .content p { font-size: 14px; }
	}

	@media screen and (max-width: 1279px) {

	.location .item { gap: 0; }
	.location .item .txt-box { padding: 30px 10px; }
	.location .item .txt-box h4 { font-size: 10px; }
	.location .item .txt-box h3 { margin-bottom: 20px; }
	.location .item .map-box { width: 100%; height: 275px; }
	}

	@media screen and (max-width: 768px) {
		.mo { display: block; }
		.pc { display: none; }
	
	html, body { font-size: 14px; }
	
	.history ul::before { width: 1px; height: calc(100% - 280px); left: 0; top: 20px; transform: translateX(0); }
	.history ul li { padding: 0 0 0 15px; }
	.history ul li:nth-child(odd){ align-items: flex-start; padding: 0 0 0 15px; }

	.history ul li h2 { font-size: 24px; }
	.history ul li h2::after{ width: 7px; height: 7px; left: -18px; }
	.history ul li:nth-child(odd) h2::after{ left: -18px; right: auto; }

	.history ul li p { font-size: 14px; }
	.history ul li:nth-child(odd) p { flex-direction: row; align-items: flex-start; padding: 0 0 0 10px; text-align: left; }
	.history ul li:nth-child(odd) p::after { left: 0; right: auto; }

/*
	.organization .organ-wrap ul { width: 100%; }
	.organization .organ-wrap ul li { width: calc(100%/3); padding: 10px; font-size: 14px; }

	.organization .organ-wrap .line-top-h::before { width: calc((100%/3) + var(--line-horizon));}
	.organization .organ-wrap .line-v.line-v2::before { height: 37px; top: calc(100% - 21px); }
*/
	}