
<meta charset="utf-8">

p {font-size: 18px !important;}

@media screen and (max-width: 768px) {
    p {font-size: 16px !important;}
}




/*공통*/
.overview { max-width:890px}
.sub-title { padding: 150px 0 100px;text-align: center;}
.sub-title h2 { font-size: 54px; font-weight: 700;color: #000; line-height: 1.2; max-width: 700px; line-height: 1.4;}
.sub-title p { font-size: 18px; color: #555;padding: 0px 0 50px 0; line-height: 1.65;}
.sub-title.left { text-align: left;}
.sub-title.left strong {color: #0460d9; font-size: 18px; padding-bottom: 20px;display: block}

.sub-content-title {padding: 100px 0 50px;}
.sub-content-title h3 {font-size: 38px;color: #222;font-weight: 700;}
.sub-content-title h3::after {content: ""; width: 7px; height: 7px; background: #0460d9;border-radius: 50%;display: inline-block;margin-left: 10px;}

.dot-title { display: block;  position: relative; margin-top: 30px;  padding-left: 20px; font-size: 16px; font-weight: 500; line-height: 22px; color: #000 }
.dot-title::before {content: "";  display: inline-block;  position: absolute; top: 5px; left: 0; width: 10px; height: 10px;  background-image: url("../img/sub/icon_hexa_blue.svg"); background-size: auto; background-position: center;  background-repeat: no-repeat}
.dot-title--nomb { margin-top: 0}
.dot-title--bottom { margin-top: 0;  margin-bottom: 30px}
.sub_title { text-align: left;  padding: 0px 20px 50px 20px; max-width: 1600px; word-break: keep-all; margin:100px auto}
.sub_title h2 {font-size: 40px; color: #000; max-width: 600px; line-height: 1.4; letter-spacing: -1px;}

/* main common */
.max-inner{max-width:1600px; width:100%; padding: 0 20px; margin:0 auto;}
.sec-title p.sub-tit{font-size:18px; color:#0460d9; font-weight:600; margin-bottom:20px;}
.max-inner .top-desc { font-size: 24px; font-weight: 700; max-width: 830px; word-break: keep-all; padding: 28px 0; line-height: 1.4;}


.download-button { margin: 50px 0 0; }
.download-button a { display: inline-block; padding: 20px 50px; background: #0460d9; color: #fff; }
.download-button a img { margin-left: 20px; }

@media screen and (max-width:576px) {
     .sub_title{margin:50px 0 50px}
	 .sub_title h2 { font-size:25px; line-height: 1.3}
}


/*탭*/
.tl_tab { padding-bottom: 30px; } 
.tl_tab ul { display: flex; flex-wrap: wrap; justify-content: center; padding: 0; margin: 0 auto; max-width: 450px;  /* 최대 너비 증가 */ list-style-type: none; gap: 20px;  /* 버튼 사이의 간격 */ } 
.tl_tab.ts2 ul li { width: calc(50% - 10px);  /* 50%에서 간격의 절반만큼 뺌 */ } 
.tl_tab.ts2 ul li a { display: flex; justify-content: center; align-items: center; height: 55px; font-size: 15px; color: #222; text-decoration: none; border: 1px solid #ddd; border-radius: 27.5px;  /* 타원형을 위해 height의 절반으로 설정 */ transition: all 0.3s ease; padding: 0 20px;  /* 좌우 패딩 추가 */ white-space: nowrap;  /* 텍스트가 한 줄로 유지되도록 */ overflow: hidden;  /* 넘치는 텍스트 숨김 */ text-overflow: ellipsis;  /* 넘치는 텍스트를 ...으로 표시 */ } 
.tl_tab.ts2 ul li a.on { background-color: #3181cb; color: #fff; } 
@media screen and (max-width: 576px) { 
    .tl_tab ul { max-width: 100%; gap: 10px;  /* 모바일에서는 간격을 좁힘 */ } 
    .tl_tab.ts2 ul li { width: calc(40% - 5px);  /* 모바일에서 간격 조정 */ } 
    .tl_tab.ts2 ul li a { padding: 0 10px;  /* 모바일에서는 패딩을 줄임 */ } 
} 
/*탭*/






/*인사말*/
.ceo_message { position: relative; }
.ceo_message .sticky-container { position: sticky; top: 0;  overflow: hidden; }
.ceo_message .image { width: 100%; height: 350px; overflow: hidden; position: relative; transition: height 0.8s cubic-bezier(0.25, 0.1, 0.25, 1); }
.ceo_message .image img { width: 1400px; height: 350px; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); transition: all 0.8s cubic-bezier(0.25, 0.1, 0.25, 1); object-fit: cover; }
.ceo_message .text-content { background-color: white; padding: 100px 0 0 0; position: relative; z-index: 1; transition: transform 0.8s cubic-bezier(0.25, 0.1, 0.25, 1); transform: translateY(100%); }
.ceo_message .row { display: flex; flex-wrap: wrap; max-width: 1200px; margin: 0 auto; }
.ceo_message .box-tit { flex: 1 1 100%; margin-bottom: 30px; }
.ceo_message .box-con { flex: 1 1 100%; }
.ceo_message .tit-h4 { font-size: 48px; font-weight: bold; line-height: 1.2; }
.ceo_message .top-copy { font-size: 48px; font-weight: 800; line-height: 1.2; margin-bottom: 20px; max-width: 700px; word-break: keep-all; }
.ceo_message .top-desc { font-size: 24px; font-weight: 600; color:#555; line-height: 1.4; margin-bottom: 30px; max-width: 700px; word-break: keep-all; }
.ceo_message .ceo-msg p { font-size: 18px; line-height: 1.6; margin-bottom: 20px; color:#666; }
.ceo_message .ceo-msg p strong { display: block; font-size: 24px; font-weight: 700; color: #111; margin: 20px 0 10px 0; }
.ceo_message .ceo-name { font-weight: 700; font-size: 18px; margin-top: 30px; }

@media (min-width: 768px) { 
    .ceo_message .box-tit { flex: 0 0 30%; } 
    .ceo_message .box-con { flex: 0 0 70%; } 
}
@media (max-width: 576px) { 
    .ceo_message .tit-h4 { font-size: 36px; }
    .ceo_message .top-copy { font-size: 28px; }
    .ceo_message .top-desc { font-size: 20px; } 
    .ceo_message .image img { width: 100%; height: 100%; }
}

/*인사말*/




.company_info { width: 100%; padding-top: 100px; }
.company_info .img_page { width: 100%; height: 550px; background-image: url(../img/company_info_bg_company.jpg); background-position: center; background-repeat: no-repeat; }
.company_info .txt_page { max-width: 1200px; margin: 0 auto; padding: 20px; }
.company_info .txt_page h2 { font-size: 42px; line-height: 1; font-weight: 600; margin-bottom: 44px; padding-top: 100px; display: block; }
.company_info .txt_page p { font-size: 18px; word-break: keep-all; line-height: 1.8; color: #555; padding-bottom: 15px; }
.Ideology { width: 100%; padding: 50px 0; }
.Ideology .inner { max-width: 1240px; margin: auto; clear: both; }
.Ideology .inner h2 { font-size: 36px; font-weight: bold; color: #000; letter-spacing: 5px; text-align: center; padding: 95px 0 50px 0; }
.Ideology .inner .point { color: #06F; }
.Ideology .inner h2:after { content: " "; display: block; margin: 20px auto; width: 40px; height: 2px; background-color: #000; clear: both; }
.Ideology dl { float: left; width: 33.3333%; padding: 20px; border-right: 1px solid #ddd; }
.Ideology dl:last-child { border: 0; }
.Ideology dl .web_icon { padding: 0 0 20px 0; text-align: center; color: #ff4200; }
.Ideology dl dt { font-size: 20px; height: 60px; font-weight: bold; letter-spacing: 5px; text-align: center; }
.Ideology dd { line-height: 2.2; text-align: center; font-size: 18px; color: #555; }
.tl_title_box_wrap { width: 100%; height: auto; padding: 150px 20px; clear: both; background-image: url(../img/work_page_bg.jpg); background-position: center; background-repeat: no-repeat; background-size: cover; }
.tl_title_box_wrap ul { padding: 0; margin: 0 auto; list-style: none; display: flex; flex-wrap: wrap; justify-content: space-between; }
.tl_title_box_wrap li { position: relative; width: 23.5%; min-height: 400px; background-color: #fff; margin-bottom: 2%; cursor: pointer; -webkit-transition: all 0.4s; transition: all 0.4s; background-position: center; background-size: cover; background-repeat: no-repeat; }
.tl_title_box_wrap li .bg { background-color: #2c3856; color: #fff; opacity: 0; position: absolute; width: 100%; height: 100%; top: 0; left: 0; z-index: 1; }
.tl_title_box_wrap li:hover .bg { opacity: 1; -webkit-transition: all 0.2s ease-out; -moz-transition: all 0.2s ease-out; -ms-transition: all 0.2s ease-out; -o-transition: all 0.2s ease-out; transition: all 0.2s ease-out; }
.tl_title_box_wrap li:hover { -webkit-box-shadow: 4px 4px 9px 0 rgba(0, 0, 0, .15); -ms-box-shadow: 4px 4px 9px 0 rgba(0, 0, 0, .15); box-shadow: 4px 4px 9px 0 rgba(0, 0, 0, .15); -webkit-transform: translateY(-25px); transform: translateY(-25px); }
.tl_title_box_wrap li .txt_wrap { width: 100%; height: 100%; position: absolute; top: 0; left: 0; box-sizing: border-box; overflow: hidden; padding: 40px; color: #fff; -webkit-transition: all 0.2s ease-out; -moz-transition: all 0.2s ease-out; -ms-transition: all 0.2s ease-out; -o-transition: all 0.2s ease-out; transition: all 0.2s ease-out; opacity: 1; display: table; z-index: 2; }
.tl_title_box_wrap li:hover .txt_wrap { opacity: 1; color: #fff; }
.tl_title_box_wrap li:hover .txt_wrap .cell I { color: #FFF; }
.tl_title_box_wrap li:hover .txt_wrap .cell h2 { color: #FFF; }
.tl_title_box_wrap li:hover .txt_wrap .cell p { color: #fff; }
.tl_title_box_wrap li .txt_wrap .cell { text-align: center; width: 100%; display: table-cell; vertical-align: middle; }
.tl_title_box_wrap li .txt_wrap .cell i { font-size: 35px; padding-bottom: 20px; color: #1a1a1a; }
.tl_title_box_wrap li .txt_wrap .cell h2 { font-size: 24px; color: #1a1a1a; margin: 0; font-weight: bold; }
.tl_title_box_wrap li .txt_wrap .cell .lead { font-size: 18px; color: #555; padding-top: 50px; word-break: keep-all; line-height: 1.6; }

@media screen and  (max-width: 992px) { 
    .company_info .work_page ul li { width: 47%; margin-bottom: 20px; margin-right: 0; margin-left: 2%; }
    .company_info .work_page ul li:last-child { margin-right: 0; } 
    .company_info .work_page ul li:nth-child(2n+2) { margin-right: 0; } 
    .Ideology dl { width: 100%; padding: 30px 0; clear: both; }
    .tl_title_box_wrap li { width: 48%; margin-left: 2%; margin-bottom: 3%; } 
    .tl_title_box_wrap li:nth-child(2n+1) { margin-left: 0; } 
}

@media screen and (max-width: 768px) { 
    .company_info { padding-top: 0px; } 
    .company_info .img_page { background-size: cover; height: 300px; } 
    .Ideology dl { width: 100%; border-right: 0; border-bottom: 1px solid #ddd; } 
    .Ideology dd { font-size: 16px}
    .tl_title_box_wrap li { width: 100%; margin-left: 0; margin-bottom: 3%; } 
}

@media screen and (max-width: 576px) { 
   .Ideology .inner h2 { padding: 0px 0 50px 0; }
}




/*회사소개*/
.container { width: 100%; max-width: 1400px; margin: 0 auto; padding: 0 20px; box-sizing: border-box; }
.about .image { width: 100%; height: 400px; background-image: url('../img/sub/about_bg.jpg'); background-size: cover; background-position: center; background-attachment: fixed; }
.about-container { display: flex; margin: 100px 0;  max-width: 1600px; margin: 100px auto}
.about-container .left { width: 385px; padding-right: 40px; display: flex; flex-direction: column; justify-content: space-between; }
.about-container .right { width: calc(100% - 385px); }
.about-container .left h4 { font-size: 36px; margin: 0; }
.about-container .left .subtitle { font-size: 18px; margin: 0; }
.about-wrap h5 { font-size: 26px; margin-bottom: 20px; }
.about-wrap p { font-size: 18px; margin-bottom: 30px; color: #555; line-height: 1.65; font-weight: 400; word-break: keep-all; max-width: 1000px }
.info-list { margin: 0; padding: 0; }
.info-items { list-style: none; padding: 0; display: flex; flex-wrap: wrap; margin: 0 -20px; }
.info-items > li { width: calc(50% - 40px); margin:0 20px; }
.info-item { display: flex; align-items: flex-start; padding: 40px 0; border-bottom: 1px solid #ddd; }
.info-index { width: 85px; font-size: 18px; font-weight: 500; color: #0066e0; margin-top: 5px }
.info-details { flex: 1;  line-height: 1.65}
.info-title { font-size: 18px; font-weight: 500; margin-bottom: 5px; }
.info-text { font-size: 16px; font-weight: 300 }
.download-btn { display: inline-block; padding: 12px 24px; background-color: #0066e0; color: #fff; text-decoration: none; border-radius: 4px; margin-top: 20px; font-size: 18px; }

/* 태블릿 스타일 */
@media screen and (max-width: 1023px) {
    .about .image { height: 350px; background-attachment: scroll; }
    .about-container { margin: 80px 0; }
    .about-container .left { width: 30%; }
    .about-container .right { width: 70%; }
    .about-container .left h4 { font-size: 28px; }
    .about-container .left .subtitle { font-size: 16px; }
    .about-wrap { margin-top: 40px; }
    .about-wrap h5 { font-size: 22px; }
    .about-wrap p { font-size: 16px; margin-bottom: 20px; }
    .info-item { padding: 20px 0}
    .info-index { width: 60px; font-size: 16px; }
    .download-btn { font-size: 16px; padding: 10px 20px; }
}

/* 모바일 스타일 */
@media screen and (max-width: 767px) {
    .about .image { height: 300px; }
    .about-container { flex-direction: column; margin: 50px 0; padding: 0 20px }
    .about-container .left, .about-container .right { width: 100%; }
    .about-container .left { margin-bottom: 30px; }
    .about-container .left h4 { font-size: 24px; margin-bottom: 10px; }
    .about-wrap { margin-top: 30px; }
    .about-wrap h5 { font-size: 20px; margin-bottom: 15px; }
    .info-items { margin: 0; }
    .info-items > li { width: 100%; margin: 0; }
}
/*회사소개*/



/* ci ==================================================================================== */
.ci { padding-top: 100px; }
.ci_wrap { max-width: 1600px; margin: 0 auto; padding: 0 20px; }
.ci_section { padding-bottom: 150px; }
.ci_section .ci_box { display: flex; margin-bottom: 4rem; }
.ci_section .ci_box h3 { width: 27.5rem; font-size: 38px; font-weight: 700; letter-spacing: -0.02em; color: #000; line-height: 1.26; }
.ci_section .ci_box .ci_txt { width: calc(100% - 27.5rem); }
.ci_section .ci_box .ci_txt .txt01 { font-size: 18px; font-weight: 400;  color: #666; line-height: 1.76; }
.ci_section .ci_box .ci_txt .txt02 { font-size: 15px; font-weight: 400; color: rgba(0, 0, 0, 0.5); line-height: 1.4; padding-top: 1.3rem; }
.ci_section .ci_img { display: flex; align-items: center; justify-content: center; min-height: 25rem; padding: 0 15rem; border: 1px solid #ddd; border-radius: 20px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.ci_section .ci_img img { max-width: 100%; }
.ci_section.ci_color_seciton .ci_box h3 { font-size: 38px; }
.ci_section .ci_color_box { display: flex; margin: 0 -1rem; padding-top: 2rem; }
.ci_section .ci_color_box .ci_color { width: calc(50% - 2rem); margin: 0 1rem; border-radius: 20px; padding: 3rem; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
.ci_section .ci_color_box .ci_color.color_1 { background: #967146; }
.ci_section .ci_color_box .ci_color.color_2 { background: #BB995E; }
.ci_section .ci_color_box .ci_color strong { display: block; font-size: 24px; font-weight: 700; letter-spacing: -0.02em; color: #fff; }
.ci_section .ci_color_box .ci_color .color_txt { padding-top: 3rem; }
.ci_section .ci_color_box .ci_color .color_txt span { display: inline-block; font-size: 17px; font-weight: 400; letter-spacing: -0.02em; color: rgba(255, 255, 255, 0.7); margin-right: 2rem; }

@media all and (max-width: 1280px) {
    .ci_section .ci_box .ci_txt .txt01 > br { display: none; }
}

@media all and (max-width: 992px) { 
    .ci_section { padding-bottom: 100px; } 
    .ci_section .ci_box { display: block; } 
    .ci_section .ci_box h3 { width: 100%; } 
    .ci_section .ci_box .ci_txt { width: 100%; padding-top: 1.5rem; } 
    .ci_section .ci_img { min-height: 18rem; padding: 0 5rem; }
    .ci_section .ci_color_box { padding-top: 0; display: block; margin: 0; } 
    .ci_section .ci_color_box .ci_color { width: 100%; margin: 0; margin-bottom: 2rem; }
}

@media all and (max-width: 768px) { 
    .ci_section .ci_color_box .ci_color .color_txt span { width: 100%; margin-right: 0; margin-bottom: 1rem; } 
    .ci_section .ci_color_box .ci_color .color_txt span:last-of-type { margin-bottom: 0rem; } 
}



/*연혁1*/
.history_area {position: relative;width: 100%;padding-top: 100px;}
.history_area .history_point {position: absolute;left: 50%;top: 0;margin-left: -5px;bottom: 20px;width:8px;background-color: #f6f6f6;overflow: hidden;}
.history_area dl {width: 50%;padding-right: 94px;padding-left: 20px;box-sizing:border-box;}
.history_area div:nth-child(odd) dl {padding-right: 20px;padding-left: 94px;}
.history_area dt {margin-bottom: 20px;font-size: 46px;line-height:1.3;color: #555;font-weight: bold;}
.history_area dd strong {display: block;padding-bottom: 12px;font-size: 20px;line-height: 1.6;color: #1a1a1a;font-weight: 500;}
.history_area dd p {display: block; font-size: 18px; color: #555; line-height: 1.75}
.history_area dd .img_box {display: block;margin-top: 39px;}
.history_area .right {text-align: right;}
.history_area .left {text-align: left;}
.history_area .fr {float: right;}
.history_area .img_box img { max-width: 100%}

@media screen and (max-width: 992px) {
	.history_area .history_point {left: 10px;margin-left: 0;}
	.history_area dl {float: none !important;width: 100%;padding-right: 20px;padding-left: 50px;text-align: left;}
	.history_area div:nth-child(odd) dl {/* padding-right: 0; */padding-left: 50px;}
	.history_area div + div {margin-top: 40px;}
	.history_area div:nth-child(2) {margin-top: 0;}
	.history_area dt {margin-bottom: 20px;font-size:30px;}
	.history_area dd p br {display: none;}
	.history_area dd .img_box {margin-top: 20px;}	
}
/*연혁1*/


/*연혁2*/
.timeline { position: relative; } 
.timeline-nav { display: flex; justify-content: space-between; margin-bottom: 40px; position: relative; flex-wrap: wrap; } 
.timeline-nav::before { content: ''; position: absolute; top: 15px; left: 0; width: 100%; height: 1px; background: #0096e0; } 
.timeline-nav button { background: none; border: none; cursor: pointer; font-size: 20px; position: relative; padding-top: 40px; margin-bottom: 10px; width: 200px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } 
.timeline-nav button::before { content: ''; position: absolute; top: 10px; left: 50%; transform: translateX(-50%); width: 10px; height: 10px; background: #0096e0; border-radius: 50%; } 
.timeline-nav button.active::after { display: block; content: ""; width: 29px; height: 29px; background: #fff; border: 11px solid #0096e0; position: absolute; top: 0; left: 50%; border-radius: 50%; transform: translateX(-50%) scale(1); transition: 0.5s; box-sizing: border-box; } 
.timeline-content { display: flex; flex-direction: row; } 
.timeline-left { width: 60%; padding-right: 40px; margin-top: 50px } 
.timeline-right { width: 40%; position: relative; } 
.timeline-year { font-size: 5em; color: #0096e0; font-weight: bold; margin-bottom: 20px; letter-spacing: -2px } 
.timeline-image { width: 100%; height: 300px; background-size: cover; background-position: center; } 
.timeline-item-wrapper { display: flex; padding-top: 140px; font-size: 18px; position: relative; } 
.timeline-year-column { flex-shrink: 0; width: 80px; color: #0096e0; } 
.timeline-year-line { width: 1px; background: #0096e0; position: absolute; top: 140px; bottom: 0; left: 90px; } 
.timeline-year-line::before { content: ''; position: absolute; top: 5px; left: -4px; width: 10px; height: 10px; background: #0096e0; border-radius: 50%; } 
.timeline-items { margin-left: 40px; flex-grow: 1; line-height: 1.6 } 
.timeline-item { display: flex; align-items: flex-start; margin-bottom: 26px; } 
.timeline-year-column > div, .timeline-item .description { min-height: 30px; display: flex; align-items: flex-start; color: #555; } 
.timeline-year-column > div { justify-content: flex-end; color: #0096e0; padding-right: 20px; padding-top: 5px; padding-bottom: 35px; font-weight: bold; } 
.timeline-item .description { padding-top: 5px; } 
.timeline-content-wrapper { display: none; } 
.timeline-content-wrapper.active { display: block; } 

@media (max-width: 1024px) { 
    .timeline-nav button { font-size: 18px; } 
    .timeline-year { font-size: 4em; } 
    .timeline-image { height: 250px; } 
    .timeline-item-wrapper { padding-top: 40px; font-size: 17px } 
    .timeline-year-line { top: 40px; } 
} 

@media (max-width: 768px) { 
    .timeline-content { flex-direction: column; } 
    .timeline-left { width: 100%; padding-right: 0; margin-bottom: 20px; } 
    .timeline-right { width: 100%; } 
    .timeline-year { font-size: 3em; } 
    .timeline-image { height: 200px; } 
    .timeline-item-wrapper { padding-top: 20px; font-size: 16px } 
    .timeline-year-column { width: 60px; } 
    .timeline-year-line { left: 70px; top: 20px; } 
    .timeline-items { margin-left: 30px; line-height: 1.0; } 
    .timeline-item .description { line-height: 1.2 } 
    .timeline-year-column > div { padding-bottom: 38px } 
} 

@media (max-width: 450px) { 
    .timeline-item-wrapper { align-items: flex-start; } 
    .timeline-year-column > div { padding-bottom: 0; height: auto; } 
    .timeline-item { flex-direction: column; margin-bottom: 20px; } 
    .timeline-item .description { margin-top: 5px; } 
}

/*연혁2*/






/*조직도*/
.sub_organization { width: 100%; padding-top: 100px}
.sub_organization h4{position:relative;margin:0 auto;width:280px;height:280px;border:25px solid #0074ff;background:#fff;font-size:28px;text-align:center;display:flex;justify-content:center;align-items:center;flex-direction:column;font-weight:700;border-radius:400px;color:#222;line-height:1.3}
.sub_organization h4:before{content:'';position:absolute;left:50%;transform:translateX(-50%);bottom:-76px;width:1px;height:55px;background:#ddd;z-index:-1}
.sub_organization h4 span { font-size: 18px; color: #555;  font-weight: 400;}
.sub_organization .dep {  position: relative; padding: 100px 0;display: flex; justify-content: space-between; align-items: center;}
.sub_organization .dep:before {  content: ''; position: absolute; top: 50px; left: 50%;  transform: translate(-50%, -50%);  width: 80%; height: 1px;  background: #ddd; z-index: -1;}
.sub_organization .dep dl dt { background: #222; color: #fff; font-weight: 600;}
.sub_organization .dep dl > * {  padding: 22px; text-align: center;font-size: 20px;}
.sub_organization .dep dl dd {  border: 1px solid #222; color: #222;}
.sub_organization .dep dl > * { padding: 22px; text-align: center; font-size: 20px;}
.sub_organization .dep dl {position: relative; width: 20%;}
.sub_organization .dep dl:before{content:'';position:absolute;top:-50px;left:50%;width:1px;height:100%;background:#eee;z-index:-1}
.sub_organization .dep2{display:flex;justify-content:space-between;align-items:stretch}
.sub_organization .dep2>dl{position:relative;width:20%}
.sub_organization .dep2>dl:before{content:'';position:absolute;left:50%;top:-100px;transform:translateX(-50%);width:1px;height:200px;background:#eee;z-index:-1}
.sub_organization .dep2 dl dt{background:#ddd;color:#555;font-weight:600}
.sub_organization .dep2 dl>*{padding:22px;font-size:18px;text-align:center}
.sub_organization .dep2 dl dd{border:1px solid #ddd;background:#fff}
.sub_organization .dep2 dl dd ul {  font-size: inherit;}
.sub_organization .dep2 dl dd ul li { line-height: 2.2; font-size: inherit;}

@media screen and (max-width: 992px) {
    .sub_organization .dep { font-size: 1.4rem;}
    .sub_organization .dep dl dt { font-size:18px;}
    .sub_organization .dep dl dd { font-size:16px;}
    .sub_organization .dep2 dl dd ul li { font-size:16px;}
    .sub_organization .dep2 dl > * { font-size: 16px; line-height: 1.3;}
    .sub_organization h4 { width: 200px;  height: 200px;  font-size: 2rem;border: 10px solid #0074ff; }
    .sub_organization h4 span { font-size: 1.0rem;}
}


@media screen and (max-width: 768px) {
    .sub_organization .dep { padding: 40px 0;}
    .sub_organization .dep, .sub_organization .dep2 {flex-wrap: wrap;}
    .sub_organization .dep2 dl dd ul li { line-height: 2.4;}
    .sub_organization h4 { width: 160px;height: 160px; font-size: 1.8rem;}
    .sub_organization h4:before, .sub_organization .dep:before, .sub_organization .dep dl:before, .sub_organization .dep2 > dl:before { display: none;}
    .sub_organization .dep dl, .sub_organization .dep2 dl {  margin: 5px 0;width: 49%; }
    .sub_organization .dep2 dl > * { padding: 12px;}
    .sub_organization .dep dl > * { padding: 15px 0;}
    .sub_organization .dep dl > * { font-size: 1.4rem;}
}

/*조직도*/




/* 폼메일 */
.formmail { width: 100%; padding-top: 100px}
.formmail input { height: 50px; line-height: 40px; background: #fff;border: 1px solid #ccc;font-size: 14px;box-sizing: border-box;transition: all 1s;}
.formmail h2 { width: 200px; float: left; font-size: 18px; font-weight: 500;color: #555; padding: 5px 10px 5px 0;}
.formmail .clearfix {  padding:30px 0}
.formmail .left { width:17%; float:left}
.formmail .left h2 { font-size:20px; font-weight:bold; color:#000;float:none}
.formmail .left p { font-size:18px; color:#555}
.formmail .right { width:73%; margin-bottom:50px; float:left; text-align:left}
.formmail p {font-size: 16px; color: #555;}
.formmail textarea { width: 900px; height: 130px; line-height: 1.5; padding: 5px;border: 1px solid #bbb; box-sizing: border-box;resize: none;}
.formmail label { font-size:18px; color:#555}
.formmail .radio { width: 20px;height: 20px; border: 1px solid #ddd; background-color: #fff; margin:0 3px; color:#555}
.formmail .btn_submit{ width: 180px; height: 55px;line-height: 55px; border: 0; color: #fff;font-size: 18px; text-align: center; background: #3a8afd;}
.formmail .form-radio {margin-right: 10px; line-height: 28px;}
.formmail #email_list {width: 200px; height: 50px; line-height: 40px;}
.formmail .checkbox { padding: 10px;line-height: 0; margin-top: 9px; width: 20px; height: 20px;}
.formmail #confirm {margin:3px; width: 20px; height: 20px;}
.formmail .send_submit { width: 180px;  height: 55px;line-height: 55px;  border: 1px solid #ddd; color: #000; font-size: 18px; font-weight: 600; text-align: center; margin-top: 20px; position: relative; overflow: hidden; background-color: #fff; transition: color 0.4s ease; cursor: pointer;}

.formmail .send_submit::before { content: '';  position: absolute;top: 0; left: -100%; width: 100%; height: 100%; background-color: #000; transition: left 0.4s ease; z-index: 0;}
.formmail .send_submit:hover::before { left: 0;}
.formmail .send_submit:hover {color: #fff;}
.formmail .send_submit span { position: relative; z-index: 1;}
.formmail #file1 {width: 400px;}

@media screen and (max-width: 576px)  {
    .formmail { padding-top: 0}
    .formmail h2 { width:100%;}
    .formmail .left { width:100%; padding-bottom: 20px}
    .formmail .right { width:100%;}
    .formmail label {font-size: 16px;}
    .formmail .company .text,
    .formmail #file1 { width:100%;}
    .formmail #email1,
    .formmail #email2 { width:45%;}
    .formmail .textarea { width:100%;}
    .formmail .frm_input { width: 100%;}
}


/* location 오시는 길 */

.content_area.location { max-width: 1600px; margin: 0 auto; padding: 60px 20px; width: 100%; box-sizing: border-box; }
.location .maparea { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: stretch; margin-bottom: 100px; padding-bottom: 100px; border-bottom: 1px solid #ccc; gap: 0px; }
.location .maparea:last-child { margin-bottom: 0; border-bottom: 0; }
.location .maparea .map-area { width: calc(55% - 0px); height: 562px; overflow: hidden; }
.location .maparea .loca_info_box { width: calc(45% - 0px); padding: 40px; box-sizing: border-box; border-top: 1px solid #967146; border-bottom: 1px solid #967146; display: flex; flex-direction: column; justify-content: center; height: 491px; }
.location .maparea h3 { color: #171717; font-size: 36px; font-weight: 800; letter-spacing: -0.36px; margin-top: 0; }
.location .maparea .loca_address { color: #171717; font-size: 19px; letter-spacing: -0.2px; margin-top: 32px; font-weight: 500; }
.location .maparea .loca_contact { color: #646464; font-size: 17px; letter-spacing: -0.16px; margin-top: 15px; line-height: 1.6; }
.location .maparea .loca_contact a { text-decoration: none; color: inherit; transition: color 0.3s; }
.location .maparea .loca_contact a:hover { color: #000; font-weight: 600; }
.location .maparea .loca_guide { margin-top: 48px; }
.location .maparea .loca_guide dl { display: flex; align-items: flex-start; }
.location .maparea .loca_guide dl + dl { margin-top: 20px; }
.location .maparea .loca_guide dt { width: 100px; min-width: 100px; text-align: center; margin-right: 20px; border-radius: 110px; color: #fff; font-size: 16px; font-weight: 500; line-height: 40px; height: 40px; letter-spacing: -0.16px; }
.location .maparea .loca_guide dd { width: 100%; color: #646464; font-size: 17px; line-height: 1.6; letter-spacing: -0.18px; margin-top: 5px; }
.location .maparea .loca_guide .loca_sub1 { background-color: #3cb44a; }
.location .maparea .loca_guide .loca_bus1 { background-color: #386de8; }
.location .maparea .loca_guide .loca_sub2 { background-color: #3cb44a; }
.location .maparea .loca_guide .loca_bus2 { background-color: #87c700; }

@media screen and (max-width: 1200px) {
  .location .maparea { flex-direction: column; gap: 30px; }
  .location .maparea .map-area { width: 100%; height: 450px; }
  .location .maparea .loca_info_box { width: 100%; padding: 40px 0; border-left: 0; border-right: 0; }
}

@media screen and (max-width: 768px) {
  .content_area.location { padding: 40px 20px; }
  .location .maparea { margin-bottom: 50px; padding-bottom: 50px; }
  .location .maparea .map-area { height: 350px; }
  .location .maparea h3 { font-size: 24px; letter-spacing: -0.24px; }
  .location .maparea .loca_address { font-size: 16px; margin-top: 20px; }
  .location .maparea .loca_guide { margin-top: 30px; }
  .location .maparea .loca_guide dt { width: 80px; min-width: 80px; font-size: 14px; line-height: 32px; height: 32px; margin-right: 12px; }
  .location .maparea .loca_guide dd { font-size: 15px; }
}

/*오시는 길*/




/* 기업 자문 */
.corp-adv-wrapper { width: 100%; max-width: 1600px; margin: 0 auto; padding: 0 20px; font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, Roboto, sans-serif; color: #333333; line-height: 1.6; background-color: #fff; box-sizing: border-box; }
.corp-adv-wrapper *, .corp-adv-wrapper *::before, .corp-adv-wrapper *::after { box-sizing: border-box; }
.corp-adv-wrapper ul { list-style: none; padding: 0; margin: 0; }
.corp-adv-wrapper a { text-decoration: none; }
.corp-adv-wrapper h2, .corp-adv-wrapper h3, .corp-adv-wrapper h4, .corp-adv-wrapper p { margin: 0; }
.corp-adv-section { padding: 100px 0; }
.corp-adv-foundation { border-bottom: 1px solid #eee; }
.corp-adv-foundation-layout { display: flex; gap: 40px; align-items: stretch; }
.corp-adv-foundation-img { flex: 0 0 35%; position: relative; border-radius: 16px; overflow: hidden; min-height: 450px; }
.corp-adv-foundation-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.corp-adv-foundation-img:hover img { transform: scale(1.05); }
.corp-adv-img-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 40px 30px; background: linear-gradient(to top, rgba(10,35,66,0.95), transparent); color: #fff; }
.corp-adv-img-overlay h2 { font-size: 32px; margin-bottom: 15px; line-height: 1.2; color: #fff; }
.corp-adv-img-overlay p { font-size: 18px; opacity: 0.9; color: #fff; }
.corp-adv-grid-basic { flex: 1; display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.corp-adv-card-basic { background: #F4F5F7; padding: 35px; border-radius: 16px; transition: all 0.3s ease; border: 1px solid transparent; }
.corp-adv-card-basic:hover { background: #fff; box-shadow: 0 4px 20px rgba(0,0,0,0.08); border-color: #C5A47E; transform: translateY(-5px); }
.corp-adv-card-basic .icon { font-size: 32px; display: block; margin-bottom: 20px; }
.corp-adv-card-basic h3 { font-size: 22px; margin-bottom: 15px; padding-top: 15px; color: #0A2342; font-weight: 700; }
.corp-adv-card-basic ul li { font-size: 18px; color: #666; margin-bottom: 10px; position: relative; padding-left: 15px; }
.corp-adv-card-basic ul li::before { content: "•"; position: absolute; left: 0; color: #C5A47E; font-weight: bold; }

.corp-adv-advisory { background-color: #fff; text-align: center; }
.corp-adv-header { margin-bottom: 60px; }
.corp-adv-header h2 { font-size: 36px; color: #0A2342; margin-bottom: 15px; font-weight: 700; }
.corp-adv-header p { font-size: 18px; color: #666; }
.corp-adv-grid-advisory { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.corp-adv-card-advisory { background: #fff; border: 1px solid #eee; padding: 50px 30px; border-radius: 12px; text-align: left; transition: all 0.3s ease; position: relative; overflow: hidden; border-top: 5px solid #0A2342; }
.corp-adv-card-advisory.highlight { border-top: 5px solid #C5A47E; box-shadow: 0 10px 30px rgba(0,0,0,0.05); }
.corp-adv-card-advisory:hover { box-shadow: 0 15px 40px rgba(0,0,0,0.12); transform: translateY(-8px); }
.card-header-badge { font-size: 15px; font-weight: 800; color: #C5A47E; text-transform: uppercase; margin-bottom: 15px; letter-spacing: 1.5px; }
.corp-adv-card-advisory h3 { font-size: 26px; margin-bottom: 20px; color: #0A2342; }
.corp-adv-card-advisory p { font-size: 18px; color: #666; line-height: 1.7; word-break: keep-all; }

.corp-adv-relations { position: relative; background: linear-gradient(135deg, #051020 0%, #0A2342 100%); color: #fff; border-radius: 24px; margin-bottom: 100px; overflow: hidden; box-shadow: 0 20px 60px rgba(10,35,66,0.3); }
.corp-adv-bg-deco { position: absolute; border-radius: 50%; filter: blur(90px); z-index: 0; opacity: 0.3; }
.corp-adv-bg-deco.circle-1 { width: 500px; height: 500px; background: #C5A47E; top: -150px; right: -150px; }
.corp-adv-bg-deco.circle-2 { width: 400px; height: 400px; background: #4a90e2; bottom: -100px; left: -100px; }
.corp-adv-relations-content { position: relative; z-index: 1; padding: 100px 60px; }

.corp-adv-header.relations-mode { text-align: center; margin-bottom: 70px; }
.corp-adv-header.relations-mode h2 { color: #fff; font-size: 40px; text-shadow: 0 2px 10px rgba(0,0,0,0.5); }
.corp-adv-header.relations-mode p { color: rgba(255,255,255,0.7); line-height: 1.65; }
.sub-badge { display: inline-block; padding: 6px 16px; border: 1px solid rgba(197,164,126,0.5); color: #C5A47E; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 2px; border-radius: 50px; margin-bottom: 20px; background: rgba(0,0,0,0.3); }

.corp-adv-grid-premium { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.corp-adv-card-premium { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.1); backdrop-filter: blur(12px); border-radius: 16px; padding: 1px; transition: all 0.4s ease; height: 100%; }
.card-inner { background: rgba(10,35,66,0.4); border-radius: 15px; padding: 40px 24px; height: 100%; display: flex; flex-direction: column; align-items: center; text-align: center; }
.icon-box { font-size: 40px; margin-bottom: 24px; width: 90px; height: 90px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.05); border-radius: 50%; border: 1px solid rgba(255,255,255,0.1); transition: all 0.4s ease; color: #fff; }
.corp-adv-card-premium h4 { font-size: 20px; color: #fff; margin-bottom: 16px; font-weight: 600; }
.corp-adv-card-premium .desc { font-size: 17px; color: rgba(255,255,255,0.6); line-height: 1.6; margin-bottom: 30px; flex-grow: 1; word-break: keep-all; }
.read-more { font-size: 14px; font-weight: 600; color: #C5A47E; opacity: 0; transform: translateY(10px); transition: all 0.4s ease; }

.corp-adv-card-premium:hover { transform: translateY(-10px); border-color: #C5A47E; box-shadow: 0 15px 40px rgba(0,0,0,0.4); }
.corp-adv-card-premium:hover .icon-box { background: #C5A47E; color: #0A2342; box-shadow: 0 0 25px rgba(197,164,126,0.6); transform: scale(1.1); }
.corp-adv-card-premium:hover h4 { color: #C5A47E; }
.corp-adv-card-premium:hover .read-more { opacity: 1; transform: translateY(0); }

@media (max-width: 1200px) {
    .corp-adv-grid-premium { grid-template-columns: repeat(2, 1fr); }
    .corp-adv-grid-advisory { gap: 20px; }
}
@media (max-width: 1024px) {
    .corp-adv-foundation-layout { flex-direction: column; }
    .corp-adv-foundation-img { min-height: 350px; flex: none; }
    .corp-adv-grid-advisory { grid-template-columns: repeat(2, 1fr); }
    .corp-adv-grid-advisory .corp-adv-card-advisory:last-child { grid-column: span 2; }
    .corp-adv-bg-deco { display: none; }
}
@media (max-width: 768px) {
    .corp-adv-wrapper { padding: 0 15px; }
    .corp-adv-section { padding: 60px 0; }
    .corp-adv-grid-basic, .corp-adv-grid-advisory, .corp-adv-grid-premium { grid-template-columns: 1fr; }
    .corp-adv-grid-advisory .corp-adv-card-advisory:last-child { grid-column: auto; }
    .corp-adv-relations-content { padding: 60px 20px; }
    .corp-adv-header h2, .corp-adv-header.relations-mode h2 { font-size: 28px; }
    .corp-adv-img-overlay h2 { font-size: 26px; }
}
/* 기업 자문 */






/* 노동사건 */
.labor-section { width: 100%; padding: 120px 20px; display: flex; justify-content: center; }
.labor-container { width: 100%; max-width: 1600px; }
.labor-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; align-items: stretch; }
.labor-card { background: #fff;border: 0; border-top: 1px solid #ddd; border-radius: 16px; transition: all 0.3s ease;display: flex; flex-direction: column; overflow: hidden; position: relative; padding: 0;}
.labor-card:hover { transform: translateY(-10px); box-shadow: 0 20px 40px rgba(150, 113, 70, 0.25); }
.labor-card-image { width: 100%; height: 220px; overflow: hidden; background-color: #e9ecef; }
.labor-card-image img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
.labor-card:hover .labor-card-image img { transform: scale(1.07); }
.labor-card-content { padding: 30px; display: flex; flex-direction: column; flex-grow: 1; border: 1px solid #ddd;border-radius: 0 0 15px 15px; }
.labor-card-label { font-size: 13px; font-weight: 800; letter-spacing: 1px; color: #967146; margin-bottom: 16px; opacity: 0.8; text-transform: uppercase; }
.labor-card h3 { font-size: 22px; font-weight: 700; line-height: 1.35; color: #1a1a1a; margin-bottom: 16px; word-break: keep-all; }
.labor-card-desc { font-size: 18px; line-height: 1.6; color: #666; margin-bottom: 40px; word-break: keep-all; }
.labor-arrow { margin-top: auto; align-self: flex-end; font-size: 26px; color: #d1d5db; transition: 0.3s; display: inline-block; }
.labor-card:hover .labor-arrow { color: #967146; transform: translateX(8px); }

/* === 반응형 === */
@media (max-width: 1200px) {
  .labor-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .labor-card-image { height: 200px; }
}

@media (max-width: 768px) {
  .labor-section { padding: 60px 16px; }
  .labor-grid { grid-template-columns: 1fr; gap: 30px; }
  .labor-card h3 { font-size: 20px; }
  .labor-card-image { height: 180px; }
  .labor-card:hover { transform: none; }
}
/* 노동사건 */





/* --- Government Grant Section Styles --- */

.gov-grant-section { width: 100%; background-color: #F9FAFB; padding: 100px 0; box-sizing: border-box; }
.gov-grant-wrapper { width: 100%; max-width: 1600px; margin: 0 auto; padding: 0 20px; font-family: 'Pretendard', sans-serif; }

/* Header */
.gov-grant-header { text-align: center; margin-bottom: 60px; }
.gov-grant-badge { display: inline-block; padding: 6px 14px; background-color: #EBF0F5; color: #0A2342; font-size: 13px; font-weight: 700; border-radius: 20px; margin-bottom: 20px; text-transform: uppercase; letter-spacing: 1px; }
.gov-grant-header h2 { font-size: 40px; color: #0A2342; margin: 0 0 20px 0; font-weight: 700; }
.gov-grant-header p { font-size: 18px; color: #666; line-height: 1.6; margin: 0; }

/* Grid Layout */
.gov-grant-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 60px; }

/* Cards */
.gov-grant-card { background: #fff; border-radius: 16px; padding: 40px 30px; border: 1px solid #ddd; transition: all 0.3s ease; display: flex; flex-direction: column; align-items: flex-start; }
.gov-grant-card:hover { transform: translateY(-10px); box-shadow: 0 15px 30px rgba(0,0,0,0.1); border-color: #C5A47E; }
.icon-circle { width: 60px; height: 60px; background-color: #F4F5F7; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 28px; margin-bottom: 24px; transition: background 0.3s; }
.gov-grant-card:hover .icon-circle { background-color: #0A2342; color: #fff; }
.gov-grant-card h3 { font-size: 22px; color: #0A2342; margin: 0 0 10px 0; font-weight: 700; }
.gov-grant-card .summary { font-size: 17px; color: #888; margin: 0 0 24px 0; line-height: 1.5; min-height: 45px; }

/* List inside Card */
.grant-list { width: 100%; padding: 0; margin: 0; list-style: none; border-top: 1px solid #eee; padding-top: 20px; }
.grant-list li { font-size: 15px; color: #555; margin-bottom: 12px; padding-left: 20px; position: relative; }
.grant-list li::before { content: "✔"; position: absolute; left: 0; color: #C5A47E; font-size: 12px; top: 3px; }

/* Bottom Banner */
.gov-grant-banner { background-color: #967146; border-radius: 20px; padding: 50px 60px; display: flex; justify-content: space-between; align-items: center; color: #fff; box-shadow: 0 20px 40px rgba(10, 35, 66, 0.2); }
.banner-content h3 { font-size: 28px; margin: 0 0 15px 0; font-weight: 700; color: #fff; }
.banner-content p { font-size: 17px; opacity: 0.8; line-height: 1.6; margin: 0; }
.banner-steps { display: flex; align-items: center; gap: 20px; }
.step-item { text-align: center; }
.step-num { display: block; font-size: 18px; color: #C5A47E; font-weight: 800; margin-bottom: 5px; }
.step-text { font-size: 17px; font-weight: 600; }
.step-arrow { color: rgba(255,255,255,0.3); font-size: 20px; }

/* Responsive Design */
@media (max-width: 1200px) { 
  .gov-grant-grid { grid-template-columns: repeat(2, 1fr); }
  .gov-grant-banner { flex-direction: column; text-align: center; gap: 40px; }
}

@media (max-width: 768px) { 
  .gov-grant-section { padding: 60px 0; }
  .gov-grant-grid { grid-template-columns: 1fr; }
  .gov-grant-header h2 { font-size: 28px; }
  .banner-steps { flex-direction: column; gap: 15px; }
  .step-arrow { transform: rotate(90deg); }
  .gov-grant-banner { padding: 40px 20px; }
}




/* --- 사업주 지원금 컨설팅 (Business Grant Consulting) Styles --- */

/* Reset & Container */
.biz-grant-section { width: 100%; padding: 100px 0; background-color: #fff; font-family: 'Pretendard', sans-serif; color: #333; box-sizing: border-box; }
.biz-grant-section * { box-sizing: border-box; }
.biz-grant-container { max-width: 1600px; margin: 0 auto; padding: 0 20px; }

/* 1. Intro Layout */
.biz-grant-intro-wrap { display: flex; justify-content: space-between; align-items: center; gap: 60px; margin-bottom: 80px; }
.biz-grant-intro-txt { flex: 1; }
.biz-grant-badge { display: inline-block; font-size: 13px; font-weight: 700; color: #C5A47E; border: 1px solid #C5A47E; padding: 6px 14px; border-radius: 50px; margin-bottom: 20px; text-transform: uppercase; letter-spacing: 1px; }
.biz-grant-intro-txt h2 { font-size: 38px; font-weight: 700; line-height: 1.3; color: #0A2342; margin-bottom: 24px; margin-top: 0; }
.biz-main-desc { font-size: 18px; font-weight: 600; color: #222; line-height: 1.6; margin-bottom: 20px; }
.biz-sub-desc { font-size: 17px; color: #666; line-height: 1.7; }
.biz-grant-intro-img { flex: 1; height: 480px; border-radius: 24px; overflow: hidden; box-shadow: 20px 20px 0px #F4F5F7; }
.biz-grant-intro-img img { width: 100%; height: 100%; object-fit: cover; }

/* 2. Photo Grid Cards */
.biz-grant-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 80px; }
.biz-grant-card { background: #fff; border: 1px solid #eee; border-radius: 16px; overflow: hidden; transition: all 0.3s ease; display: flex; flex-direction: column; }
.biz-grant-card:hover { transform: translateY(-10px); box-shadow: 0 15px 30px rgba(0,0,0,0.1); border-color: #C5A47E; }

/* Card Image Area */
.biz-card-img { width: 100%; height: 240px; position: relative; overflow: hidden; }
.biz-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.biz-grant-card:hover .biz-card-img img { transform: scale(1.1); }

/* Number Badge */
.biz-card-num { position: absolute; top: 20px; left: 20px; width: 44px; height: 44px; background: rgba(10, 35, 66, 0.95); color: #C5A47E; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 16px; border-radius: 50%; }

/* Card Text Area */
.biz-card-body { padding: 30px; flex-grow: 1; display: flex; flex-direction: column; }
.biz-card-body h3 { font-size: 21px; font-weight: 700; color: #0A2342; margin: 0 0 12px 0; }
.biz-card-body .summary { font-size: 18px; color: #666; line-height: 1.5; margin-bottom: 20px;  overflow: hidden; }

/* Checklist */
.biz-check-list { list-style: none; padding: 0; margin: auto 0 0 0; border-top: 1px solid #f0f0f0; padding-top: 15px; }
.biz-check-list li { font-size: 15px; color: #555; margin-bottom: 8px; position: relative; padding-left: 20px; }
.biz-check-list li::before { content: "✔"; position: absolute; left: 0; top: 1px; color: #C5A47E; font-size: 12px; }

/* 3. Bottom Banner */
.biz-grant-banner { background: #0A2342; border-radius: 20px; padding: 50px 60px; display: flex; justify-content: space-between; align-items: center; color: #fff; position: relative; overflow: hidden; box-shadow: 0 20px 40px rgba(10, 35, 66, 0.2); }
.biz-grant-banner::after { content: ''; position: absolute; right: -40px; bottom: -60px; width: 250px; height: 250px; background: rgba(197, 164, 126, 0.1); border-radius: 50%; pointer-events: none; }
.biz-banner-txt h3 { font-size: 28px; margin: 0 0 10px 0; }
.biz-banner-txt .highlight { color: #C5A47E; }
.biz-banner-txt p { font-size: 18px; opacity: 0.8; margin: 0; }
.biz-consult-btn { display: inline-block; padding: 16px 36px; background: #C5A47E; color: #fff; font-weight: 700; border-radius: 4px; text-decoration: none; transition: background 0.3s; z-index: 1; font-size: 16px; }
.biz-consult-btn:hover { background: #b08d65; }

/* --- Responsive Media Queries --- */
@media (max-width: 1200px) {
    .biz-grant-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 1024px) {
    .biz-grant-intro-wrap { flex-direction: column; gap: 40px; }
    .biz-grant-intro-img { width: 100%; height: 350px; box-shadow: none; }
    .biz-grant-banner { flex-direction: column; text-align: center; gap: 30px; padding: 40px 20px; }
}

@media (max-width: 768px) {
    .biz-grant-intro-txt h2 { font-size: 30px; }
    .pc-only { display: none; }
    .biz-grant-grid { grid-template-columns: 1fr; }
}



/* 급여아웃소싱 • 4대보험 */
.outsourcing-section { width: 100%; padding: 100px 20px; display: flex; flex-direction: column; align-items: center; }
.container { width: 100%; max-width: 1600px; }

.intro-box { display: flex; background-color: #ffffff; border-radius: 24px; overflow: hidden; margin-bottom: 90px; }
.intro-text { flex: 1; padding: 70px 60px; display: flex; flex-direction: column; justify-content: center; border: 1px solid #ddd; border-radius: 30px 0 0 30px;}
.intro-badge { display: inline-block; background-color: #967146; color: #fff; font-weight: 700; padding: 8px 18px; border-radius: 6px; font-size: 13px; letter-spacing: 1px; margin-bottom: 24px; width: fit-content; text-transform: uppercase; }
.intro-text h2 { font-size: 38px; font-weight: 800; color: #0f172a; margin-bottom: 24px; line-height: 1.35; }
.intro-text p { font-size: 18px; color: #64748b; word-break: keep-all;  line-height: 1.65; }
.highlight { color: #967146; font-weight: 700; }
.intro-image { flex: 1; background-image: url('https://images.unsplash.com/photo-1664575602554-2087b04935a5?q=80&w=2670&auto=format&fit=crop'); background-size: cover; background-position: center; min-height: 420px; }

.section-title-area { text-align: center; margin-bottom: 60px; position: relative; }
.sub-title { display: block; font-size: 14px; color: #967146; font-weight: 700; letter-spacing: 2px; margin-bottom: 10px; text-transform: uppercase; }
.main-title { font-size: 36px; font-weight: 800; color: #0f172a; position: relative; display: inline-block; padding-bottom: 20px; }
.main-title::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 60px; height: 4px; background-color: #967146; border-radius: 2px; }

.grid-3-col { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; width: 100%; }
.service-card { background: #fff; border-radius: 20px; overflow: hidden;  border: 1px solid #e2e8f0; display: flex; flex-direction: column; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); position: relative; }
.service-card:hover { transform: translateY(-8px); box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); border-color: #967146; }
.card-img-wrap { height: 220px; overflow: hidden; background-color: #f1f5f9; }
.card-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.service-card:hover .card-img-wrap img { transform: scale(1.05); }
.card-body { padding: 32px; flex-grow: 1; }
.card-num { font-size: 14px; font-weight: 900; color: #cbd5e1; margin-bottom: 8px; display: block; }
.service-card:hover .card-num { color: #967146; }
.card-body h4 { font-size: 24px; font-weight: 700; margin-bottom: 24px; color: #1e293b; word-break: keep-all; }
.check-list li { position: relative; padding-left: 28px; margin-bottom: 12px; font-size: 16px; color: #475569; line-height: 1.5; word-break: keep-all; }
.check-list li::before { content: '✔'; position: absolute; left: 0; top: 2px; width: 18px; height: 18px; background-color: #ffd8ab; color: #ab7f4c; border-radius: 50%; font-size: 10px; display: flex; align-items: center; justify-content: center; font-weight: bold; }


@media (max-width: 1200px) {
  .grid-3-col { grid-template-columns: repeat(2, 1fr); }
  .intro-text h2 { font-size: 30px; }
}

@media (max-width: 768px) {
  .intro-box { flex-direction: column-reverse; margin-bottom: 60px; }
  .intro-image { min-height: 240px; }
  .intro-text { padding: 40px 24px; }
  .grid-3-col { grid-template-columns: 1fr; }
  .main-title { font-size: 28px; }
}

/* 급여아웃소싱 • 4대보험 */





/* 강의및교육 */
.edu-section { width: 90%; max-width: 1600px; margin: 100px auto; }
.course-list { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.course-item { background: #ffffff; border-radius: 12px; overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease; display: flex; flex-direction: column; }
.course-item:hover { transform: translateY(-10px); box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1); }
.course-visual { width: 100%; height: 240px; overflow: hidden; }
.course-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.course-item:hover .course-visual img { transform: scale(1.05); }
.course-detail { padding: 30px 25px; flex-grow: 1; display: flex; flex-direction: column; border: 1px solid #ddd; border-radius: 0 0 15px 15px;}
.course-badge { display: inline-block; font-size: 14px; font-weight: 700; color: #fff; background-color: #c5a065; padding: 4px 12px; border-radius: 20px; margin-bottom: 15px; width: fit-content; }
.course-title { font-size: 22px; font-weight: 700; color: #102a43; margin-bottom: 12px; word-break: keep-all; line-height: 1.4;}
.course-topic { font-size: 18px; color: #444; margin-bottom: 8px; font-weight: 600; }
.course-desc { font-size: 15px; color: #888; font-weight: 400; margin-top: auto; word-break: keep-all; line-height: 1.65; }


@media screen and (max-width: 1200px) {
    .course-list { grid-template-columns: repeat(2, 1fr); }
}


@media screen and (max-width: 768px) {
    .course-list { grid-template-columns: repeat(1, 1fr); gap: 20px; }
    .course-visual { height: 200px; }
}
 /* 강의및교육 */





.sanjae-header { background-color:#2c3e50; color:white; padding:80px 20px; text-align:center; position:relative; overflow:hidden; margin-bottom:80px; }
.sanjae-header h1 { font-size:3rem; font-weight:800; margin-bottom:15px; letter-spacing:-1px; position:relative; z-index:2; }
.sanjae-header p { font-size:1.2rem; opacity:0.8; max-width:600px; margin:0 auto; font-weight:300; position:relative; z-index:2; }
.sanjae-header::before { content:''; position:absolute; top:-50%; left:-10%; width:500px; height:500px; background:rgba(255,255,255,0.05); border-radius:50%; }
.sanjae-container { max-width:1600px; margin:0 auto; padding:0 20px 100px; }
.sanjae-card { display:flex; align-items:center; background:transparent; margin-bottom:100px; position:relative; }
.sanjae-card:nth-child(even) { flex-direction:row-reverse; }
.sanjae-visual { flex:1; height:400px; position:relative; overflow:hidden; border-radius:4px; z-index:2; }
.sanjae-visual img { width:100%; height:100%; object-fit:cover; filter:grayscale(100%); transition:all 0.4s cubic-bezier(0.165,0.84,0.44,1); }
.sanjae-card:hover .sanjae-visual img { filter:grayscale(0%); transform:scale(1.05); }
.sanjae-info { flex:1; padding:40px; background:#ffffff; position:relative; z-index:2; min-height:300px; display:flex; flex-direction:column; justify-content:center; margin-left:0px; }
.sanjae-card:nth-child(even) .sanjae-info { margin-left:0; margin-right:0px; }
.sanjae-index { position:absolute; top:-60px; font-size:8rem; font-weight:900; color:rgba(0,0,0,0.03); line-height:1; font-family:'Segoe UI', sans-serif; z-index:1; transition:all 0.4s cubic-bezier(0.165,0.84,0.44,1); }
.sanjae-card:nth-child(odd) .sanjae-index { right:20px; }
.sanjae-card:nth-child(even) .sanjae-index { left:20px; }
.sanjae-card:hover .sanjae-index { color:rgba(230,126,34,0.1); transform:translateY(-10px); }
.sanjae-category { color:#c5a065; font-size:0.9rem; font-weight:600; text-transform:uppercase; letter-spacing:2px; margin-bottom:10px; display:block; }
.sanjae-title { font-size:2rem; font-weight:700; color:#2c3e50; margin-bottom:20px; line-height:1.65; }
.sanjae-desc { color:#666; font-size:18px; margin-bottom:20px; word-break:keep-all; line-height:1.65; }
.sanjae-point { background:rgba(197,160,101,1); font-weight:600; }
ul.sanjae-list { list-style:none; border-top:1px solid #eee; padding-top:15px; margin-top:20px; }
ul.sanjae-list li { font-size:16px; color:#666; margin-bottom:5px; padding-left:15px; position:relative; }
ul.sanjae-list li::before { content:''; position:absolute; left:0; top:10px; width:6px; height:6px; background:#e67e22; border-radius:50%; }

@media (max-width:900px) { 
    .sanjae-card, .sanjae-card:nth-child(even) { flex-direction:column; margin-bottom:60px; } 
    .sanjae-visual { width:100%; height:250px; } 
    .sanjae-info, .sanjae-card:nth-child(even) .sanjae-info { width:90%; margin:-40px auto 0; padding:30px; } 
    .sanjae-index { top:-20px; font-size:5rem; } 
    .sanjae-title { font-size:1.6rem; } 
    .sanjae-header h1 { font-size:2rem; } 
}






.container { width: 90%; max-width: 1600px; margin: 80px auto; }
.header-title { text-align: center; font-size: 2.5rem; font-weight: 700; margin-bottom: 60px; color: #111; letter-spacing: -0.02em; }
.grid-wrapper { display: grid; grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); gap: 32px; }
.card { background: #fff; border-radius: 20px; overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease; display: flex; flex-direction: column; }
.card:hover { transform: translateY(-10px); box-shadow: 0 20px 40px rgba(0,0,0,0.12); }
.card-image { width: 100%; height: 240px; background-color: #e9ecef; position: relative; }
.card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.card:hover .card-image img { transform: scale(1.05); }
.card-content { padding: 32px; flex-grow: 1; }
.card-number { font-size: 0.9rem; color: #967146; font-weight: 700; margin-bottom: 8px; display: block; text-transform: uppercase; }
.card-title { font-size: 1.5rem; font-weight: 700; margin-bottom: 16px; color: #1f2937; letter-spacing: -0.03em; }
.card-desc { font-size: 18px; color: #6b7280; word-break: keep-all; text-align: justify; }
@media (max-width: 1024px) { 
    .grid-wrapper { grid-template-columns: repeat(2, 1fr); } 
}
@media (max-width: 768px) { 
    .container { width: 95%; margin: 40px auto; }
    .grid-wrapper { grid-template-columns: 1fr; } 
    .header-title { font-size: 1.8rem; } 
    .card-image { height: 200px; } 
}




.split-layout-wrapper { width: 100%; max-width: 1600px; margin:0 auto 150px auto; background-color: #fff; display: flex; box-shadow: 0 10px 30px rgba(0,0,0,0.1); overflow: hidden; min-height: 600px; }
.text-section { flex: 4; background-color: #0a192f; color: #fff; padding: 60px 80px; display: flex; flex-direction: column; justify-content: center; position: relative; }
.deco-line { width: 60px; height: 4px; background-color: #eeba30; margin-bottom: 30px; }
.title-area h1 { font-size: 3.2rem; font-weight: 900; line-height: 1.2; margin-bottom: 40px; letter-spacing: -0.02em; }
.content-area { font-size: 1.15rem; font-weight: 300; line-height: 1.8; color: #e0e6ed; word-break: keep-all; }
.highlight-box { display: inline-block; margin: 20px 0; padding: 15px 25px; border: 1px solid #eeba30; background: rgba(238,186,48,0.1); color: #eeba30; font-weight: 700; font-size: 1.4rem; }
.highlight-box strong { color: #fff; font-weight: 900; }
.image-section { flex: 6; position: relative; overflow: hidden; }
.image-section img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.split-layout-wrapper:hover .image-section img { transform: scale(1.03); }
@media (max-width: 1024px) { 
    .split-layout-wrapper { flex-direction: column-reverse; height: auto; min-height: auto; } 
    .image-section { height: 300px; flex: none; } 
    .text-section { padding: 40px 30px; flex: none; } 
    .title-area h1 { font-size: 2.2rem; margin-bottom: 25px; } 
    .highlight-box { display: block; text-align: center; font-size: 1.2rem; } 
}



