/* 서브 스타일 시작 */
	/* 서브 공통 */
	/* 공통 스타일 */

	body {
		overflow-x: hidden;
		font-family: 'Pretendard', 'Suit', sans-serif;
	}
	.content-wrap {
		font-family: 'Pretendard', 'Suit', sans-serif;
		width: 100%;
		padding: 130px 0 80px; 
	}

	.section-container {
		max-width: 1400px;
		margin: 0 auto;
	}


	.section-title {
		font-size: 48px;
		font-weight: 700;
		color: #222;
		margin-bottom: 20px;
	}

	.section-title .highlight {
		color: var(--color-theme);
	}

	/* 섹션 서브타이틀 — 회사소개 .intro-heading 과 동일 타이포 스케일 */
	.section-subtitle {
		font-size: 54px;
		font-weight: 700;
		color: #222;
		word-break: keep-all;
		margin: 0;
	}

	.content-text,
	.section-content {
		font-size: 20px;
		line-height: 1.8;
		color: #555;
		word-break: keep-all;
	}

	/* area-header 공통 본문 텍스트 */
	.area-header-text {
		font-size: 20px;
		line-height: 1.5;
		color: #444;
		word-break: keep-all;
		margin-bottom: 10px;
	}

	.area-header-text:last-child {
		margin-bottom: 0;
	}

	/* area 하위 페이지 — 섹션 블록 제목·본문 (.section-title / .content-text 클래스 사용) */
	.content-wrap.area-common .section-header-title .section-title {
		margin-bottom: 0;
	}

	.content-wrap.area-common .section-header-content .content-text {
		margin-bottom: 0;
	}

	/* area 페이지 공통 헤더 박스 */
	.content-wrap.area-common .area-header {
		width: 100%;
		margin-bottom: 100px;
		position: relative;
	}

	.content-wrap.area-common .area-header-content {
		width: 100%;
		padding: 40px 30px;
		background: #f8f9fa;
		border-radius: 10px;
	}

	/* .content-wrap h2 { width: fit-content; margin: 0 auto 50px; padding-left: 50px; 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; } */

	.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; }

	/* 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, 186, 255, 0.3);		/* 라인 배경색 */

		--border: 1px solid rgba(10, 186, 255, 0.5);	/* 기본 테두리 설정 */
		--border-radius: 8px;					/* 칸 가장자리 굴림 */

		--depth01-bgcolor: #0ABAFF;			/* 1뎁스 배경색 */
		--depth01-txtcolor: #fff;				/* 1뎁스 글씨색 */

		--depth02-bgcolor: rgba(10, 186, 255, 0.25);	/* 2뎁스 배경색 */
		--depth02-txtcolor: #333;				/* 2뎁스 글씨색 */

		--depth03-bgcolor: #0A8FD6;			/* 3뎁스 배경색 */
		--depth03-txtcolor: #fff;				/* 3뎁스 글씨색 */

		--depth04-bgcolor: #FD8208;			/* 4뎁스 배경색 */
		--depth04-txtcolor: #fff;				/* 4뎁스 글씨색 */

		--depth05-bgcolor: #FD8208;			/* 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; } /* 특수 배열 칸 숨기기 처리 */


	/* 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("/board/images/mapboard_tel.svg") no-repeat 0 50%; background-size: 18px auto; }
	.location .item .txt-box .info-box p.mail { background: url("/board/images/mapboard_mail.svg") no-repeat 0 50%; background-size: 18px auto; }
	.location .item .txt-box .info-box p.location { background: url("/board/images/mapboard_location.svg") no-repeat 0 50%; background-size: 18px auto; }
	.location .item .txt-box .info-box p.traffic { background: url("/board/images/mapboard_traffic.svg") 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); }


	/* 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 { display: flex; flex-direction: column; width: calc(100% - 15px); height: 250px; padding: 30px; background: var(--color-lightblack); border: 1px solid transparent; transition: all 0.2s ease-in-out; }
	.center-business-intro .content-box .content:hover { background: var(--color-theme); border-radius: 0 50px 0 0; }
	.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; }

	.gpi-note {
		font-size: 20px;
		line-height: 1.8;
		color: #666;
		margin-top: 28px;
		padding: 20px;
		background: #f8f9fa;
		border-radius: 8px;
	}

	.gpi-note a {
		color: var(--color-theme);
		font-weight: 600;
		text-decoration: none;
	}

	.gpi-note a:hover {
		text-decoration: underline;
	}

/* ============================================
   반응형 디자인
   ============================================ */

/* 태블릿 가로 및 작은 데스크톱 (1024px ~ 1439px) */
@media screen and (max-width: 1439px) {
	.content-wrap {
		padding: 100px 0 60px;
	}
	
	.section-container {
		max-width: 1200px;
		padding: 0 30px;
	}
	
	.section-title {
		font-size: 42px;
		margin-bottom: 50px;
	}
	
	.section-subtitle {
		font-size: 42px;
	}


	.area-header-text {
		font-size: 18px;
	}
	
	.introduce .inner {
		max-width: calc(100% - 60px);
	}
	
	.introduce .inner .content-box {
		padding-bottom: 70px;
	}
	
	.introduce .inner .content-box .img-box {
		padding: 0 30px;
	}
	
	.introduce .inner .content-box .txt-box h1 {
		font-size: 38px;
	}
	
	.introduce .inner .content-box .txt-box h3 {
		font-size: 20px;
	}
	
	.introduce .inner .content-box .txt-box h4 {
		font-size: 18px;
	}
	
	.history ul li h3 {
		font-size: 26px;
	}
	
	.center-business-intro .content-box {
		gap: 25px;
		margin-bottom: 80px;
	}
	
	.center-business-intro .content-box .content {
		height: 220px;
		padding: 25px;
	}
	
	.center-business-intro .content-box .content h3 {
		font-size: 22px;
	}
	
	.center-business-intro .content-box .content:hover h3 {
		font-size: 24px;
	}
}

@media screen and (max-width: 1024px) {
	.content-wrap.area-common .area-header {
		margin-bottom: 60px;
	}

	.content-wrap.area-common .area-header-content {
		padding: 30px 25px;
	}
	 .gpi-note {
		font-size: 17px;
	}
}

@media screen and (max-width: 768px) {
	.content-wrap.area-common .area-header {
		margin-bottom: 40px;
	}

	.content-wrap.area-common .area-header-content {
		padding: 25px 20px;
	}
	
	.gpi-note {
		font-size: 16px;
	}

}

@media screen and (max-width: 768px) {
	.area-header-text {
		font-size: 16px;
		line-height: 1.6;
	}

}

/* 태블릿 세로 (768px ~ 1023px) */
@media screen and (max-width: 1023px) {
	.content-wrap {
		padding: 80px 0 50px;
	}
	
	.section-container {
		max-width: 100%;
		padding: 0 25px;
	}
	
	.section-title {
		font-size: 36px;
	}
	
	.section-subtitle {
		font-size: 36px;
	}
	
	
	.introduce .inner {
		max-width: calc(100% - 50px);
	}
	
	.introduce .inner .content-box {
		flex-direction: column;
		padding-bottom: 50px;
	}
	
	.introduce .inner .content-box .img-box {
		width: 100%;
		padding: 0 20px 30px;
	}
	
	.introduce .inner .content-box .txt-box {
		width: 100%;
	}
	
	.introduce .inner .content-box .txt-box h1 {
		font-size: 32px;
	}
	
	.introduce .inner .content-box .txt-box h3 {
		font-size: 18px;
	}
	
	.introduce .inner .content-box .txt-box h4 {
		font-size: 16px;
	}
	
	.history ul::before {
		left: 30px;
		transform: translateX(0);
	}
	
	.history ul li {
		padding-left: calc(30px + 20px);
	}
	
	.history ul li:nth-child(odd) {
		align-items: flex-start;
		padding-left: calc(30px + 20px);
		padding-right: 0;
	}
	
	.history ul li h3::after {
		left: -25px;
	}
	
	.history ul li:nth-child(odd) h3::after {
		left: -25px;
		right: auto;
	}
	
	.history ul li p {
		font-size: 15px;
	}
	
	.history ul li:nth-child(odd) p {
		flex-direction: row;
		padding-left: 10px;
		padding-right: 0;
		text-align: left;
	}
	
	.history ul li:nth-child(odd) p::after {
		left: 0;
		right: auto;
	}
	
	.location .item {
		gap: 0;
	}
	
	.location .item .txt-box {
		padding: 30px 20px;
	}
	
	.location .item .txt-box h4 {
		font-size: 12px;
	}
	
	.location .item .txt-box h3 {
		margin-bottom: 30px;
		font-size: 18px;
	}
	
	.location .item .txt-box .info-box p {
		font-size: 14px;
	}
	
	.location .item .map-box {
		height: 350px;
	}
	
	.center-business-intro .content-box {
		flex-direction: column;
		gap: 20px;
		margin-bottom: 60px;
	}
	
	.center-business-intro .content-box .content {
		width: 100%;
		height: auto;
		min-height: 200px;
	}
	
	.center-business-intro .content-box.triple .content {
		width: 100%;
	}
}

/* 모바일 (480px ~ 767px) */
@media screen and (max-width: 768px) {
	.mo {
		display: block;
	}
	
	.pc {
		display: none;
	}
	
	html, body {
		font-size: 14px;
	}
	
	.content-wrap {
		padding: 60px 0 40px;
	}
	
	.section-container {
		padding: 0 20px;
	}
	
	
	.section-title {
		font-size: 32px;
	}
	
	.section-subtitle {
		font-size: 28px;
	}
	
	.content-text {
		font-size: 18px;
		line-height: 1.7;
	}
	
	.introduce .inner {
		max-width: calc(100% - 40px);
	}
	
	.introduce .inner .content-box {
		padding-bottom: 40px;
	}
	
	.introduce .inner .content-box .img-box {
		padding: 0 10px 20px;
	}
	
	.introduce .inner .content-box .txt-box h1 {
		font-size: 26px;
	}
	
	.introduce .inner .content-box .txt-box h3 {
		font-size: 16px;
	}
	
	.introduce .inner .content-box .txt-box h4 {
		font-size: 15px;
	}
	
	.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 h3 {
		font-size: 24px;
	}
	
	.history ul li h3::after {
		width: 7px;
		height: 7px;
		left: -18px;
	}
	
	.history ul li:nth-child(odd) h3::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;
	}
	
	.location .item .txt-box {
		padding: 25px 15px;
	}
	
	.location .item .txt-box h4 {
		font-size: 10px;
	}
	
	.location .item .txt-box h3 {
		margin-bottom: 20px;
		font-size: 16px;
	}
	
	.location .item .txt-box .info-box p {
		font-size: 13px;
		padding-left: 28px;
	}
	
	.location .item .map-box {
		height: 275px;
	}
	
	.center-business-intro .content-box {
		margin-bottom: 50px;
	}
	
	.center-business-intro .content-box .content {
		min-height: 180px;
		padding: 20px;
	}
	
	.center-business-intro .content-box .content h4 {
		font-size: 13px;
	}
	
	.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: 16px;
	}
}

/* 작은 모바일 (~479px) */
@media screen and (max-width: 479px) {
	
	.section-container {
		padding: 0 16px;
	}
	
	.section-title {
		font-size: 30px;
		margin-bottom: 30px;
	}
	
	.section-subtitle {
		font-size: 28px;
	}
	
	.content-text {
		font-size: 16px;
		line-height: 1.7;
	}
	
	.introduce .inner {
		max-width: calc(100% - 32px);
	}
	
	.introduce .inner .content-box {
		padding-bottom: 30px;
	}
	
	.introduce .inner .content-box .img-box {
		padding: 0 5px 15px;
	}
	
	.introduce .inner .content-box .txt-box h1 {
		font-size: 22px;
	}
	
	.introduce .inner .content-box .txt-box h3 {
		font-size: 15px;
	}
	
	.introduce .inner .content-box .txt-box h4 {
		font-size: 14px;
	}
	
	.history ul li h3 {
		font-size: 20px;
	}
	
	.history ul li p {
		font-size: 13px;
	}
	
	.location .item .txt-box {
		padding: 20px 12px;
	}
	
	.location .item .txt-box h4 {
		font-size: 9px;
	}
	
	.location .item .txt-box h3 {
		font-size: 14px;
		margin-bottom: 15px;
	}
	
	.location .item .txt-box .info-box p {
		font-size: 12px;
		padding-left: 24px;
	}
	
	.location .item .map-box {
		height: 250px;
	}
	
	.center-business-intro .content-box .content {
		min-height: 160px;
		padding: 18px;
	}
	
	.center-business-intro .content-box .content h4 {
		font-size: 12px;
	}
	
	.center-business-intro .content-box .content h3 {
		font-size: 18px;
	}
	
	.center-business-intro .content-box .content:hover h3 {
		font-size: 20px;
	}
	
	.center-business-intro .content-box .content p {
		font-size: 14px;
	}
}