@charset "UTF-8";

*, *:before, *:after { -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; }
.all_wrap{overflow: hidden;position: relative;}

.jarallax {position: relative;z-index: 0;height: 100%;}
.jarallax > .jarallax-img {position: absolute;  object-fit: cover;  top: 0;  left: 0;  width: 100%;  height: 100%;  z-index: -1;}
.main_admin{display: none;}
@media all and (max-width:1024px) {
	.main_admin{position: fixed; z-index: 11; top:75px; right: 10px; display: block;}
	.main_admin a{font-size: 14px; background: #fff; border-radius: 5px; margin-bottom: 5px; width: 80px; height: 30px; display: inline-block; text-align: center; line-height: 30px; font-weight: 500;}
}
/* 공통 */
.width{width: 92% !important; max-width: 1400px; margin: 0 auto; position: relative;}
.common{padding: 90px 0px;}
:root{
--color: #0e3092;

--fs40: 4.0rem;
--fs32: 3.2rem;
--fs28: 2.8rem;
--fs26: 2.6rem;
--fs24: 2.4rem;
--fs22: 2.2rem;
--fs20: 2.0rem;
--fs18: 1.8rem;
--fs14: 1.4rem;
}
.board_title{margin-bottom: 50px; text-align: center; }
.board_title h2{font-size: var(--fs32); font-weight: 500; position: relative; display: inline-block; padding: 0px 150px; }
.sub_title h2{font-size: var(--fs32); font-weight: 500; position: relative; display: inline-block; }
.board_title h2::after{content: '';position: absolute; width: 110px; height: 1px; background: #ccc; right: 0; top: 50%; transform: translateY(-50%)}
.board_title h2::before{content: '';position: absolute; width: 110px; height: 1px; background: #ccc; left: 0; top: 50%; transform: translateY(-50%)}
.board_title p{margin-top: 25px; font-size: var(--fs18); line-height: 135%;}
.board_title h3{margin-top: 25px; font-size: var(--fs24); line-height: 135%; font-weight: 400; color: var(--color);}
.board_title h4{margin-top: 15px; font-size: var(--fs18); line-height: 135%; }
.center{text-align: center;}
.left{text-align: left;}
.su400{font-family: 'SUIT-Regular' !important;}
.su500{font-family: 'SUIT-Medium' !important;}
.su600{font-family: 'SUIT-SemiBold' !important;}
.su800{font-family: 'SUIT-ExtraBold' !important;}
.su900{font-family: 'SUIT-Heavy' !important;}
@media all and (max-width: 1024px) {
.common{padding: 60px 0px;}
.board_title{margin-bottom: 60px;}
.board_title h2{padding: 0px 15%;}
.board_title h2::after{width: 20px;}
.board_title h2::before{width: 20px;}
}

#header{width: 100%;position: fixed;top: 0;z-index: 999; transition: 0.3s all; box-shadow: 0px 1px 3px rgba(0,0,0,0.1); background: #fff;}
#header .header_width{width: 96%; margin: 0 auto;}
#header .head_login_wrap{display: flex; align-items: center;}
#header .head_login{display: flex;justify-content: flex-end;padding: 7px 10px; border: 1px solid #ddd; border-radius: 30px; margin-right: 25px;}
#header .head_login li{margin:0px 5px;}
#header .head_login a{font-size: 1.4rem; color: #1a1a1a; white-space: nowrap; font-weight: 400;}
#header .head_login i{font-size: 20px;}
#header .head_menu .logo img{width: 140px;}
#header.scroll{top:-36px;}
#header .head_menu{position: relative;display: flex;justify-content: space-between;align-items: center;width: 100%; height: 90px;}
#header .head_menu .main_menu { width: 70%; display: flex; justify-content: center; align-items: center; text-align: center; height: 100%; z-index: 9;}
#header .head_menu .main_menu .dept1 { width: 18%; position: relative; padding: 15px 0px;}
#header .head_menu .main_menu .dept1 > a { font-size: 1.9rem; font-weight: 400; color: #1a1a1a;}
#header .head_menu .main_menu .dept1 > a.active { color: #1a1a1a; font-weight: bold; }
#header .head_menu .main_menu .dept1 > a.menuon { color: #1a1a1a; font-weight: bold; }
#header .head_menu .sub_menu { position: absolute; top: 100%; left: 50%; transform: translateX(-50%); width: 100%; padding-top: 20px; display: none; padding-bottom: 30px;}
#header .head_menu .main_menu .dept2 { padding: 12px 0px; background: #fff;}
#header .head_menu .main_menu .dept2:nth-child(1){border-top: 4px solid #E60012;}
#header .head_menu .main_menu .dept2 a { font-size: 1.8rem; display: block; font-weight: 400; color: #555;}
#header .main_menu .dept2>a:hover,
#header .main_menu .dept2>a:active,
#header .main_menu .dept2>a.menuon,
#header .main_menu .dept2>a:focus { color: #1a1a1a;font-weight: bold;}
#header .menu_bg {background: rgba(0,0,0,0.05);width: 100%;height: 0;left: 0;z-index: 1;position: absolute; }


/* 모바일 */
.mobile_head {width: 100%; height: 60px; display: flex; justify-content: space-between; align-items: center; padding: 0px 15px; display: none; position: fixed; background: #fff; z-index: 99; box-shadow: 0px 1px 3px rgba(0,0,0,0.1);}
.mobile_head .mobile_logo { width: 80px; }
.mobile_head .mobile_logo img { width: 100%; }
#mobile_menu {  display: none; position: fixed; top: 0; right: -100%; width: 100%; background: #fff; z-index: 1000; height: 100vh; overflow-y: scroll; -ms-overflow-style: none; scrollbar-width: none;}
#mobile_menu::-webkit-scrollbar{display: none;}
#mobile_menu .mob_logo { width: 100%; padding: 0px 20px; height: 60px; background: #fff; border-bottom: 1px solid #eee; display: flex; justify-content: space-between; align-items: center;}
#mobile_menu .mob_logo a { width: 100px; }
#mobile_menu .mob_logo a img { width: 100%; }
#mobile_menu .mobile_close { font-size: 30px; cursor: pointer; color: #1a1a1a;}
#mobile_menu .mob_menu .top_menu {display: flex;justify-content: space-between; align-items: center; padding: 20px 20px;font-size: 18px;  border-bottom: 1px solid #eee; color: #1a1a1a;}
.mobile_open{font-size: 24px; color: #1a1a1a;}
#mobile_menu .mob_menu .top_menu.on { color: #1a1a1a; font-weight: bold; background: none;}
#mobile_menu .mob_menu .sub_menu { padding: 15px 20px; border-bottom: 1px solid #ccc; background: #fff; visibility: visible; }
#mobile_menu .mob_menu .sub_menu a {display: block; color: #333 ;font-size: 17px; padding: 10px; background: #fff; font-weight: 400;}
#mobile_menu .mob_menu_btn{display: flex; padding: 10px 0px; margin: 0px 20px; justify-content: space-between;}
#mobile_menu .mob_menu_btn li{width: 49%;}
#mobile_menu .mob_menu_btn a{font-size: 17px;  background: #ddd;display: flex; height: 50px; justify-content: center; align-items: center;}
#mobile_menu .mob_menu_btn a i{font-size: 16px; margin-right: 5px;}
.mob_bg {  display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100vh; background: rgba(0, 0, 0, 0.5); z-index: 99;}

@media screen and ( max-width: 1400px ){
#pcmenu .topmenu { font-size: 16px; }
#pcmenu .submenu a { font-size: 14px; }
}
@media screen and ( max-width: 1024px ){
#header { display: none; }
.mobile_head{display: flex;}
}

/* 메인 풀 페이지 */

/* 슬라이드 백그라운드 */
#section0 .slide1{background: url('../img/visual01.png') no-repeat;background-position: center;background-size: cover; }
#section0 .slide3{background: url('../img/visual03.png') no-repeat;background-position: center;background-size: cover; }


#section1 {background: url('../img/back01.png') no-repeat;background-position: center;background-size: cover; padding: 60px 0px;}
#section2 {background: url('../img/back02.png') no-repeat;background-position: center;background-size: cover; padding: 60px 0px;}
#section3 {background: url('../img/back03.png') no-repeat;background-position: center;background-size: cover; padding: 60px 0px;}

/* 모바일용 백그라운드 입니다. 필요하신경우 주석을 풀고 파일명에 맞게 이미지를 ftp 업로드 해주세요. */
/* @media all and (max-width:768px) {
	#section0 .slide1{background: url('../img/mvisual01.png') no-repeat;background-position: center;background-size: cover; }
	#section0 .slide3{background: url('../img/mvisual03.png') no-repeat;background-position: center;background-size: cover; }

	#section1 {background: url('../img/mback01.png') no-repeat;background-position: center;background-size: cover; }
	#section2 {background: url('../img/mback02.png') no-repeat;background-position: center;background-size: cover;}
	#section3 {background: url('../img/mback03.png') no-repeat;background-position: center;background-size: cover;}
} */

#section0  .swiper_visual{height: 100%;}
#section0 .swiper-pagination{bottom: 40px;}
#section0 .swiper-pagination-bullet{opacity: 1; background: #eee;}
#section0 .swiper-pagination-bullet-active{ background: #fff; width: 25px; border-radius: 10px;}
.main_text {display: flex;justify-content: flex-end; align-items: center; height: 100%;}
.main_text h2 {color: #fff;font-family: 'Montaga', serif;font-size: var(--fs40);background: url('../img/visual_bg.png') no-repeat;padding: 130px 30px;width: 695px;height: 437px;position: relative; }
.main_text h2 span {position: absolute;opacity: 0.7; font-size: var(--fs40);}
.main_text h2 span.mtext_left {left: -40px;top: 110px; }
.main_text h2 span.mtext_right {right: 68px; }

#fp-nav ul li a span, .fp-slidesNav ul li a span {background: #fff; }
#fp-nav ul li .fp-tooltip {opacity: 1;overflow: initial; font-family: 'Pretendard'; font-size: var(--fs14);}
#fp-nav ul li, .fp-slidesNav ul li {margin: 30px 5px; }

.main_title p{color: #fff; font-size: var(--fs22);  font-weight: 500; font-family: 'Montaga', serif; letter-spacing: 0.1em; margin-bottom: 5px;}
.main_title h2{color: #fff; font-size: var(--fs32); margin-bottom: 70px; font-weight: 500; }
@media all and (max-width: 1024px){
	.main_text h2{width: 100%; height: auto; background: none;}
	.main_text h2 span.mtext_left{left: -4px;}
	.main_text h2 span.mtext_right{right: initial;}
}
@media all and (max-width: 768px){
	.main_text h2{padding: 15px 0px 0px 25px; font-size: var(--fs28); letter-spacing: -0.04em;}
	.main_text h2 span.mtext_left{top: 0;}
}


/* 솔루션 */
#section1 .main_title{text-align: center;}
.solution_wrap{display: flex; gap: 15px 1.7%;}
.solution_wrap .solu_box{padding: 40px 30px; background: #fff; width: 32%;display: flex; flex-direction: column; justify-content: space-between;}
.solution_wrap .solu_box h3{font-size: var(--fs26); font-weight: bold; padding-top: 25px; border-top: 3px solid #000;}
.solution_wrap .solu_box h4{font-size: var(--fs18); font-weight: 300; margin-top: 30px; line-height: 130%; margin-bottom: 40px;}
.solution_wrap .solu_box p span{font-weight: bold; font-size: var(--fs18); word-break: keep-all; display: inline-block; margin-right: 15px; line-height: 170%;}
.solution_wrap .solu_box a{margin-top: 40px; display: inline-block; width: 160px; height: 50px; border: 2px solid #000; font-size: var(--fs18); font-weight: 500; display: flex; align-items: center; justify-content: center;}
.solution_wrap .solu_box a span{font-size:var(--fs22); margin-left: 15px;}
.solution_wrap .solu_box:hover{background: var(--color); color: #fff;}
.solution_wrap .solu_box:hover h3{border-top: 3px solid #fff;}
.solution_wrap .solu_box:hover a{border: 2px solid #fff; background: #fff; color: var(--color);}
@media all and (max-width: 1024px){
	.main_title h2{margin-bottom: 60px;}
	.solution_wrap .solu_box{padding: 25px 15px;}
	.solution_wrap .solu_box h3{padding-top: 15px;}
	.solution_wrap .solu_box h4{margin-top: 15px; margin-bottom: 15px;}
	.solution_wrap .solu_box a{margin-top: 25px; height: 40px;}
}
@media all and (max-width: 850px){
	.solution_wrap{flex-wrap: wrap; gap: 15px 2%;}
	.solution_wrap .solu_box{width: 49%;}
}
@media all and (max-width: 650px){
	.solution_wrap .solu_box{width: 100%; padding: 20px;}
	.solution_wrap .solu_box h3{font-size: 2.2rem;}
	.solution_wrap .solu_box h4{font-size: 1.6rem;}
	.solution_wrap .solu_box p span{font-size: 1.6rem;}
	.solution_wrap .solu_box a{margin-top: 15px; font-size: 1.6rem; width: 140px;}
	.solution_wrap .solu_box a span{font-size: 2.0rem; margin-left: 10px;}
}

/* 메인오시는 길 */
#section2 .main_title{text-align: center;}
#section2 .map_wrap{height: 40vh;}
#section2 .map_company{background:  var(--color); padding: 40px 30px; color: #fff;}
#section2 .map_company h2{border-bottom: 1px solid #fff;}
@media all and (max-width: 850px){
	.map_wrap iframe{width: 100% !important;}
}

/* 뉴스레터 */
#section3 .main_title{text-align: center;}
@media all and (max-width: 850px){
	.pic_lt ul{flex-wrap: wrap; gap: 15px 1.5%;}
	.pic_lt ul li{width: 49%; padding: 12px !important;}
	.pic_lt .lt_wrap .lt_text_top .lt_text_con a:first-child{letter-spacing: -0.04em;}
	.pic_lt .lt_wrap .lt_text_top .lt_text_con a:last-child{letter-spacing: -0.04em;}
}
@media all and (max-width: 650px){
	.pic_lt ul li{width: 100%;}
}

/* 하단 */
#ft{background: #222;padding: 40px 0px; width: 100%;}
.foot_logo{display: block; text-align: center;margin-bottom: 20px; padding-bottom: 30px; border-bottom: 1px solid #8e8e8e;}
.foot_info span{font-size: 1.4rem; color: #ddd; margin: 0px 10px; line-height: 170%;}
.foot_info a{font-size: 1.4rem; color: #ddd; margin: 0px 10px; line-height: 170%;}
#ft .copyright{margin-top: 30px; color: #ccc;}
#ft .copyright span{font-size: 1.4rem;}
#ft .foot_service{margin-top: 20px;}
#ft .foot_service a {font-size: 1.4rem; color: #9e9e9e;}
#ft .foot_service a:first-child{margin-right: 10px;}
@media all and (max-width: 768px) {
.foot_info{display: flex; flex-direction: column;}
.foot_info span{margin: 0px; line-height: 140%;}
}

/* sub_visual */
.sub_visual{width: 100%;height: 320px;background-repeat: no-repeat !important;background-size: cover !important;background-position: center center !important; display: flex; align-items: center; justify-content: center; overflow: hidden; padding: 90px 80px 0;}
.sub_visual .sub_top_text{text-align: center; color: #fff;}
.sub_visual .sub_top_text h3{font-size: 44px; font-weight: 800; letter-spacing: -1.5px; margin: 0;}
.sub_visual .sub_top_text p{font-size: var(--fs22);font-weight: 600;}
@media all and (max-width: 1024px) {
.sub_visual{height: 320px; padding: 60px 30px 0;}
.sub_visual .sub_top_text h3{font-size: 32px;}
}

/* lnb */
.lnb_wrap{position: relative;}
.lnb{background: #f9f9f9; border-bottom: 1px solid #ddd;}
.lnb .lnb_map{height: 60px; display: flex; align-items: center; border-left: 1px solid #f1f1f1;}
.lnb .lnb_map .home{width: 60px; height: 100%;background: #f9f9f9;display: flex;justify-content: center;align-items: center;}
.lnb .lnb_map .home a{color: #333;}
.lnb .lnb_map .home i{font-size: 20px;}
.lnb .lnb_map > li{width: 250px; height: 100%;border-right: 1px solid #f1f1f1; padding: 0px 15px;position: relative;}
.lnb .lnb_map li.dep a{width: 100%; height: 100%;display: flex;align-items: center; font-size: 14px;}
.lnb .lnb_map li.dep a span{width: 100%;display: flex; justify-content: space-between;align-items: center; font-size: 1.7rem; color: #333;}
.lnb .lnb_map li.dep a span i{font-size: 24px;}
.lnb .lnb_map li.dep ul{display: none;position: absolute;left: 0; top: 61px;width: 100%;z-index: 10;}
.lnb .lnb_map li.dep ul li{width: 100%; background: #f9f9f9; border-bottom: 1px solid #fff;}
.lnb .lnb_map li.dep ul li a{padding: 15px 15px;font-size: 1.6rem;}
.lnb .lnb_map li.dep ul li a:hover{background: ; color: var(--color);transition: 0.3s all; font-weight: bold;}
.lnb .lnb_map li.dep ul li:hover{border-bottom: 1px solid var(--color)}
.lnb .lnb_map li.dep ul li a.on{background: #f1f1f1;}

@media screen and (max-width:1400px) {
.lnb .lnb_map{width: 100% !important;}
}
@media screen and (max-width:900px){
.lnb .lnb_map{height: 55px;}
.lnb .lnb_map .home i{font-size: 16px;}
.lnb .lnb_map li.dep ul{top: 56px;}
}
@media screen and (max-width:600px){
.lnb .lnb_map{height: 50px;}
.lnb .lnb_map .home{width: 12%;}
.lnb .lnb_map li{width: 44%;}
.lnb .lnb_map li:last-child{width: 44%;}
.lnb .lnb_map li.dep ul{top: 51px;}
.lnb .lnb_map li.dep a{font-size: 12.5px;}
.lnb .lnb_map li.dep ul li a{font-size: 12.5px;}
}

/* 인사말 */

.greeting_wrap{display: flex; align-items: flex-start; justify-content: space-between;}
.greeting_wrap .greeting_text{width: 52%;}
.greeting_wrap .greeting_text h2{color: var(--color); font-weight: 600; font-size: var(--fs28); margin-bottom: 40px;}
.greeting_wrap .greeting_text p{font-size: var(--fs20); color: #333; line-height: 130%;}
.greeting_wrap .greeting_text p:last-child{margin-top: 20px;}
.greeting_wrap .greeting_img{width: 42%;}
.greeting_wrap .greeting_img img{width: 100%;}

.greeting_info{margin-top: 100px; border-top: 3px solid var(--color); display: flex; flex-wrap: wrap;}
.greeting_info li{width: 50%; display: flex; min-height: 60px; border-bottom: 1px solid #ddd;}
.greeting_info li:last-child{width: 100%;}
.greeting_info li p{min-width: 180px; background: #f6f6f6; display: flex; align-items: center; justify-content: center; font-size: var(--fs18); font-weight: 500;}
.greeting_info li span{width: 100%; padding-left: 15px; display: flex; align-items: center; font-size: var(--fs18); color: #333;}
@media screen and (max-width:1024px) {
.greeting_wrap .greeting_text h2{margin-bottom: 20px; font-size: var(--fs24);}
}
@media screen and (max-width:950px) {
.greeting_wrap{flex-direction: column;}
.greeting_wrap .greeting_text{width: 100%; margin-bottom: 50px;}
.greeting_wrap .greeting_text p:last-child{margin-top: 15px;}
.greeting_wrap .greeting_img{width: 100%;}
}
@media screen and (max-width:768px) {
.greeting_info{margin-top: 60px;}
.greeting_info li p{min-width: 140px;}
.greeting_info li{width: 100%;}
}


/* 연혁 */

.history_circle{width: 120px; height: 120px; background: #222;border-radius: 50%;color: #fff; display: flex; align-items: center; justify-content: center; margin: 0 auto; margin-bottom: 80px;}
.history_circle p{text-align: center; font-size: 1.8rem;}
.history_wrap{position: relative;}
.history_wrap .history_line{position: absolute; width: 1px; height: 100%; background: #ccc; left: 0; right: 0; margin: 0 auto;}
.history_left{ width: 50%; text-align: right; position: relative; padding-right: 50px; margin-bottom: 40px;}
.history_left img{ width: 100%; margin-top: 20px;}
.history_left h2{font-size: var(--fs22); margin-bottom: 15px; font-weight: 500;}
.history_left p{ font-size: var(--fs18); line-height: 130%;}
.history_right{width: 50%; margin: 0 0 0 auto; position: relative; padding-left: 50px; margin-bottom: 40px;}
.history_right img{ width: 100%; margin-top: 20px;}
.history_right h2{font-size: var(--fs22); margin-bottom: 15px; font-weight: 500;}
.history_right p{ font-size: var(--fs18); line-height: 130%;}
.history_left::after{content: ''; position: absolute; width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 4px solid #364F6B; right: -8px; top: 0;}
.history_right::after{content: ''; position: absolute; width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 4px solid #364F6B; left: -8px; top: 0;}
@media screen and (max-width:950px) {
	.history_circle{margin-bottom: 60px;}
}
@media screen and (max-width:850px) {
	.history_wrap .history_line{display: none;}
	.history_left{width: 100%; padding-left: 30px; padding-right: 0px;text-align: left;}
	.history_right{width: 100%; padding-left: 30px; padding-right: 0px;}
	.history_left::after{right: initial; left: -8px;}
	.history_box{padding-bottom: 30px; border-bottom: 1px dotted #ccc; margin-bottom: 30px;}
	.history_box:last-child{border-bottom: 0px;}
	.history_box::after{left: 0px; }
}


/* 구성원소개 */

.people_box{display: flex; padding: 50px 30px 50px 30px; justify-content: space-between; align-items: center;}
.people_box:nth-of-type(2n){background: #f6f6f6;}
.people_box .people_img{width: 32%; padding: 10px; border:  1px solid #ccc; background: #fff;}
.people_box .people_img img{width: 100%; background: #ccc;}
.people_box .people_text{width: 65%; padding-left: 3%;}
.people_box .people_text h2{font-size: var(--fs26); font-weight:
600; padding-bottom: 15px; margin-bottom: 17px; border-bottom: 2px solid #ddd;}
.people_box .people_text h2 span{font-size: var(--fs22);}
.people_box .people_text h3{font-size: var(--fs20); font-weight: 500; margin-bottom: 15px;}
.people_box .people_history{display: flex; justify-content: space-between;}
.people_box .people_history ul{width: 49.5%;}
.people_box .people_history ul li{display: flex; line-height: 130%; margin-bottom: 10px; color: #333; font-weight: 400;}
.people_box .people_history ul li span{margin-right: 7px;}
@media screen and (max-width:1024px){
	.people_box .people_text{width: 60%;}
	.people_box .people_img{width: 45%;}
}
@media screen and (max-width:850px){
	.people_box{padding: 20px; flex-direction: column; margin-bottom: 50px;}
	.people_box:last-child{margin-bottom: 0px;}
	.people_box .people_img{width: 100%; margin-bottom: 30px;}
	.people_box .people_text{padding-left: 0px; width: 100%;}
}
@media screen and (max-width:768px){
	.people_box .people_history{flex-direction: column; height: 250px; overflow-y: scroll;}
	.people_box .people_history ul{width: 100%;}
}

/* 오시는 길 */

.map_wrap{width: 100%; position: relative;}
.root_daum_roughmap{width: 100% !important; height: 100%;}
.root_daum_roughmap .wrap_controllers{display: none;}
.map_wrap .map_company{position: absolute; z-index: 3; right: 0; bottom: -70px; background: #253d5b; padding: 30px 40px;}
.map_wrap .map_company h2{padding-bottom: 20px; border-bottom: 1px solid #ccc;}
.map_wrap .map_company h2 img{width: 170px; }
.map_wrap .map_company ul{display: flex; margin-top: 20px;}
.map_wrap .map_company ul li{display: flex; align-items: center; font-size: var(--fs20); color: #fff;}
.map_wrap .map_company ul li:first-child{margin-right: 50px;}
.map_wrap .map_company ul li i{font-size: 2.4rem; margin-right: +6px;}
/* 맵버튼 */
.map_btn{margin-top: 160px; text-align: center; display: flex; justify-content: center;}
.map_btn a{display: flex; align-items: center; justify-content: center; width: 250px; height: 55px; font-size: var(--fs20); font-weight: 500; color: #fff;}
.map_btn a > i{font-size: 30px; margin-right: 10px;}
.map_btn a:first-child{border: 1px solid #00c63b; background:#00c63b; margin-right: 15px;}
.map_btn a:last-child{border: 1px solid #f9e200; background: #f9e200; color: #3d1d1c;}
/* 교통 */
.visit_wrap{margin-top: 100px;}
.visit_wrap .visit_box{display: flex;justify-content: space-between; align-items: flex-start; padding-bottom: 40px; border-bottom: 1px solid #ccc; margin-bottom: 40px;}
.visit_wrap .visit_box:last-of-type{margin-bottom: 0px; padding-bottom: 0px; border-bottom: 0px;}
.visit_wrap .visit_box h3{display: flex; align-items: center; font-size: var(--fs26); width: 30%;}
.visit_wrap .visit_box h3 i{width: 40px; height: 40px; border-radius: 7px; background: var(--color); color: #fff; text-align: center; line-height: 40px; position: relative; z-index: 2; margin-right: 15px; font-weight: 100;}
.visit_wrap .visit_box ul{width: 70%;}
.visit_wrap .visit_box ul li{font-size: 1.8rem; line-height: 130%; margin-top: 20px;}
.visit_wrap .visit_box ul li:first-of-type{margin-top: 0px;}
.visit_wrap .visit_box ul li span{display: inline-block; width: 60px; height: 30px; line-height: 30px;text-align: center; background:#525e75; color: #fff; border-radius: 3px; margin-right: 10px; font-size: 14px;}
.visit_wrap .visit_box ul li span.bus1{background: #BDD2B6;}
.visit_wrap .visit_box ul li span.bus2{background: #A2B29F;}
.visit_wrap .visit_box ul li span.bus3{background: #798777;}
.visit_wrap .visit_box ul li span.way1{background: #FFD36E;}
.visit_wrap .visit_box ul li span.way2{background: #4C657E;}
.visit_wrap .visit_box ul li span.way3{background: #F29696;}
.visit_wrap .visit_box ul li span.way4{background: #B7C4CF;}

@media all and (max-width: 850px) {
.map_wrap .map_company{position: relative; bottom: initial;}
.map_btn{margin-top: 10px;}
.visit_wrap .visit_box{flex-direction: column;}
.visit_wrap .visit_box h3{width: 100%; margin-bottom: 20px;}
.visit_wrap .visit_box ul li{margin-top: 12px;}
.visit_wrap .visit_box ul{width: 100%; padding-left: 55px;}
}
@media all and (max-width: 768px) {
.map_wrap .map_company ul{flex-direction: column;}
.map_wrap .map_company ul li:first-child{margin-right: 0px; margin-bottom: 20px;}
.map_btn a{width: 50%;}
.map_btn a:first-child{margin-right: 10px;}
}

/* 제도/절차01 */

#process1{background: #f8fbff;}
#process1 .process_wrap {display: flex; justify-content: space-around;}
#process1 .box{width: 23%; background: #fff; padding: 40px 0px; text-align: center;}
#process1 .box h2{ font-size: 40px; width: 110px; height: 110px; border-radius: 50%; background:  #f6f6f6; line-height: 110px; margin: 0 auto; color: #333;}
#process1 .box p{font-size: var(--fs22); font-weight: 600; margin-top: 30px; padding-bottom: 15px; margin-bottom: 17px; position: relative; text-align: center;}
#process1 .box p::after{content: ''; width: 40px; height: 2px; background: #ccc; position: absolute; bottom: 0; left: 0; right: 0; margin: 0 auto;}
#process1 .box span{font-size: var(--fs18); color: #333; text-align: center; line-height: 120%; padding: 0px 10px; display: inline-block;}
#service{padding-top: 90px;}
#service .service_box_wrap{display: flex; flex-wrap: wrap; gap: 30px 2%;}
#service .box{width: 49%; border: 1px solid #ddd;}
#service .box h3{padding: 12px 3px; background: #253d5b;; text-align: center; font-weight: 600; font-size: var(--fs22); color: #fff;}
#service .box .text{padding: 20px 25px;}
#service .box .text p{font-size: var(--fs18); line-height: 135%; display: flex; margin-bottom: 15px;}
#service .box .text p:last-child{margin-bottom: 0px;}
#service .box .text p span{margin-right: 7px;}
@media all and (max-width: 1024px) {
	#process1 .box{padding: 20px 5px;}
	#service{padding-top: 60px;}
}
@media all and (max-width: 900px){
	#process1 .process_wrap{flex-wrap: wrap; gap: 15px 2%;}
	#process1 .box{width: 49%;}
}
@media all and (max-width: 768px){
	#service .box{width: 100%;}
	#process1 .box h2{width: 90px; height: 90px; line-height: 90px;}
	.board_title p br{display: none;}
	.board_title h4 br{display: none;}
	.board_title h3{margin-top: 10px; font-size: 2.1rem;}
	#process1 .box p{margin-top: 15px; margin-bottom: 8px; padding-bottom: 8px;}
	#process1 .box span{padding: 0px; font-size: 1.6rem;}
	#service .box .text{padding: 20px 10px;}
	#service .box .text p{letter-spacing: -0.04em;}
}

/* 제도/절차02 */
#process2{background: #f8f8f8;}
#process2 .sub_title{margin-bottom: 50px;}
#process2 .process_wrap{display: flex; flex-wrap: wrap; gap: 20px 3%;}
#process2 .box{display: flex; width: 48.5%; border-radius: 5px; overflow: hidden; background: #fff; box-shadow: 0px 0px 3px rgba(0,0,0,0.2);}
#process2 .box h2{font-size: var(--fs26); font-weight: bold; color: #fff; min-width: 70px; background: #253d5b; display: flex; align-items: center; justify-content: center;}
#process2 .box .text{padding: 12px 15px; width: 100%;}
#process2 .box .text p{font-size: var(--fs20); font-weight: 500; margin-bottom: 7px;}
#process2 .box .text span{color: #333; display: block; line-height: 130%;}
@media all and (max-width: 768px){
	#process2 .sub_title{margin-bottom: 35px;}
	#process2 .box{width: 100%;}
	#process2 .box .text span{letter-spacing: -0.04em;}
}

/* 제도/절차03 */
#process3{background: #f9f9f9;}
#process3 .business_box{display: flex; justify-content: space-between; margin-bottom: 80px;}
#process3 .business_box:last-child{margin-bottom: 0px;}
#process3 .business_box .business_title{width: 26%;}
#process3 .business_box .business_title h3{font-size: var(--fs24); display: flex; align-items: center; font-weight: 500;}
#process3 .business_box .business_title h3 span{font-size: 15px; color: #364F6B; margin-right: 15px;}
#process3 .business_box .business_text{width: 74%;}
#process3 .business_box .business_text p{font-size: var(--fs18); color: #333; line-height: 130%; margin-bottom: 20px;}
#process3 .business_box .business_text p:last-child{margin-bottom: 0px;}
.service_area01 .service_wrap{margin-top: 50px; display: flex; flex-wrap: wrap;  gap: 60px 2%;}
.service_area01 h2{font-size: var(--fs28); font-weight: 500;}
.service_area01 .service_box{width: 32%; box-shadow: 0px 1px 4px rgba(0,0,0,0.2); position: relative; background: #fff;}
.service_area01 .service_box .service_img{position: relative;}
.service_area01 .service_box .service_img img{width: 100%;}
.service_area01 .service_box .service_title{background: #fff; position: absolute; width: 80%; margin: 0 auto; padding: 20px 0 0 0; text-align: center; bottom: 0px; left: 0; right: 0;}
.service_area01 .service_box .service_title span{ font-family: 'Montaga', serif; color:#253d5b; font-size: 1.6rem; font-weight: 500; margin-bottom: 5px; display: inline-block;}
.service_area01 .service_box .service_title h2{font-size: var(--fs22); position: relative; padding-bottom: 20px; font-weight: 500;}
.service_area01 .service_box .service_title h2::after{content: ""; position: absolute; width: 30px; height: 2px; background: #666; bottom: -3px; left: 0; right: 0; margin: 0 auto;}
.service_area01 .service_box .service_text{padding: 30px 20px 25px 20px;}
.service_area01 .service_box .service_text p{display: flex; font-size: var(--fs18); line-height: 130%; margin-bottom: 15px;}
.service_area01 .service_box .service_text p:last-child{margin-bottom: 0px;}
.service_area01 .service_box .service_text span{margin-right: 10px;}

@media all and (max-width: 1024px) {
.service_area01 .service_box{width: 49%;}
.service_area01 .service_wrap{margin-top: 60px;}
}
@media all and (max-width: 650px) {
.service_area01 .service_box{width: 100%;}
.service_area01 .service_box .service_text{padding: 30px 20px 40px 20px;}
}

@media all and (max-width: 768px) {
#process3 .business_box{margin-bottom: 50px; flex-direction: column;}
.business_area03 .business_box .business_title{width: 100%; margin-bottom: 20px;}
#process3 .business_box .business_text{width: 100%; padding-left: 25px;}
}


/* 사건 page01 */
/* 원하는 조각들을 복사해서 붙여 넣은 후 #labor1~3 으로 변경해주세요. */
#labor1 .board_title{margin-bottom: 80px; }
/* 회색테두리 */
#labor1 .labor_top{margin: 0 auto; border: 20px solid #f6f6f6; padding: 4% 8%; position: relative; max-width: 1000px; }
#labor1 .labor_top h2{position: absolute; top: -25px; left: 0; right: 0; margin: 0 auto; padding: 0px 30px; background: #fff; width: 80%; text-align: center; font-size: var(--fs24); font-weight: 500;}
#labor1 .labor_top h2 b{color: var(--color)}
#labor1 .labor_top h3{font-size: var(--fs18); line-height: 130%; text-align: center; margin-bottom: 20px; color: #333;}
#labor1 .labor_top h3:last-child{margin-bottom: 0px;}
/* 백그라운드가 있는 텍스트 */
#labor1 .labor_bg{background: url('../img/labor1.png')no-repeat; background-position: center; background-size: cover; margin-top: 80px; padding: 15px;}
#labor1 .labor_bg .text{padding: 6% 7%; border: 1px solid rgba(255,255,255,0.4);}
#labor1 .labor_bg p{font-size: var(--fs18); color: #fff; text-align: center; line-height: 130%; margin-bottom: 20px;}
#labor1 .labor_bg p:last-child{margin-bottom: 0px;}
#labor1 .labor_text{margin-top: 80px;}
#labor1 .labor_text > h2{font-size: var(--fs28); font-weight: 500; margin-bottom: 10px;}
#labor1 .labor_text > h2 span{font-size: 24px; color: #568AE5;}
#labor1 .labor_text > h3{font-size: var(--fs20);  line-height: 130%;}
/* 사건과정 부분 */
#labor1 .labor_table{display: flex; border-radius: 5px; overflow: hidden; border: 1px solid #ccc; margin-top: 40px; margin-bottom: 20px;}
#labor1 .labor_table .box{width: 50%; text-align: center;}
#labor1 .labor_table .box{border-right: 1px solid #ccc;}
#labor1 .labor_table .box:last-child{border-right: 0px;}
#labor1 .labor_table .box h4{padding: 14px 2px; background:#253d5b ; color: #fff; font-weight: 700; font-size: var(--fs18);}
#labor1 .labor_table .box h5{padding: 14px 2px; border-bottom: 1px solid #ccc; font-weight: 400; font-size: var(--fs18);}
#labor1 .labor_table .box h5:last-child{border-bottom: 0px;}
#labor1 .labor_text p{color: #de1111; line-height: 130%; font-size: var(--fs18);}
@media all and (max-width: 1024px){
	#labor1 .labor_bg{margin-top: 60px;}
}
@media all and (max-width: 768px){
	#labor1 .labor_top h2{font-size: 2.2rem; top: -20px;}
	#labor1 .labor_top{border: 10px solid #f6f6f6; padding: 30px 20px;}
	#labor1 .labor_bg .text{padding: 20px 15px;}
	#labor1 .labor_table{flex-direction: column; border: none; gap: 20px 0px;}
	#labor1 .labor_table .box{width: 100%; border: 1px solid #ccc; overflow: hidden; border-radius: 5px;}
	#labor1 .labor_table .box:last-child{border-right: 1px solid #ccc;}
}


/* 사건 page02 */
#labor2 .board_title{margin-bottom: 80px; }
/* 회색테두리 */
#labor2 .labor_top{margin: 0 auto; border: 20px solid #f6f6f6; padding: 4% 8%; position: relative; max-width: 1000px; }
#labor2 .labor_top h2{position: absolute; top: -25px; left: 0; right: 0; margin: 0 auto; padding: 0px 30px; background: #fff; width: 80%; text-align: center; font-size: var(--fs24); font-weight: 500;}
#labor2 .labor_top h2 b{color: var(--color)}
#labor2 .labor_top h3{font-size: var(--fs18); line-height: 130%; text-align: center; margin-bottom: 20px; color: #333;}
#labor2 .labor_top h3:last-child{margin-bottom: 0px;}
/* 백그라운드가 있는 텍스트 */
#labor2 .labor_bg{background: url('../img/labor1.png')no-repeat; background-position: center; background-size: cover; margin-top: 80px; padding: 15px;}
#labor2 .labor_bg .text{padding: 6% 7%; border: 1px solid rgba(255,255,255,0.4);}
#labor2 .labor_bg p{font-size: var(--fs18); color: #fff; text-align: center; line-height: 130%; margin-bottom: 20px;}
#labor2 .labor_bg p:last-child{margin-bottom: 0px;}
#labor2 .labor_text{margin-top: 80px;}
#labor2 .labor_text > h2{font-size: var(--fs28); font-weight: 500; margin-bottom: 10px;}
#labor2 .labor_text > h2 span{font-size: 24px; color: #568AE5;}
#labor2 .labor_text > h3{font-size: var(--fs20);  line-height: 130%;}
/* 사건과정 부분 */
#labor2 .labor_table{display: flex; gap: 30px 2.5%; overflow: hidden; margin-top: 40px; margin-bottom: 20px;}
#labor2 .labor_table .box{width: 32%; text-align: center; border-radius: 5px; overflow: hidden; border: 1px solid #ccc;}
#labor2 .labor_table .box{border-right: 1px solid #ccc;}
#labor2 .labor_table .box h4{padding: 14px 2px; background:#253d5b ; color: #fff; font-weight: 700; font-size: var(--fs18);}
#labor2 .labor_table .box h5{padding: 14px 2px; border-bottom: 1px solid #ccc; font-weight: 400; font-size: var(--fs18);}
#labor2 .labor_table .box h5:last-child{border-bottom: 0px;}
#labor2 .labor_text p{color: #de1111; line-height: 130%; font-size: var(--fs18);}
@media all and (max-width: 1024px){
	#labor2 .labor_bg{margin-top: 60px;}
}
@media all and (max-width: 850px){
	#labor2 .labor_table{flex-direction: column;}
	#labor2 .labor_table .box{width: 100%;}
}
@media all and (max-width: 768px){
	#labor2 .labor_top h2{font-size: 2.2rem; top: -20px;}
	#labor2 .labor_top{border: 10px solid #f6f6f6; padding: 30px 20px;}
	#labor2 .labor_bg .text{padding: 20px 15px;}
}


/* 사건 page03 */
#labor3{padding-top: 90px;}
#labor3 .board_title{margin-bottom: 80px; }
/* 회색테두리 */
#labor3 .labor_wrap{display: flex; justify-content: space-between; align-items: center; margin-bottom: 80px;}
#labor3 .labor_top{width: 50%;border: 20px solid #f6f6f6; padding: 4% 8%; position: relative; }
/* 회색 테투리 옆 사진 */
#labor3 .labor_ect{width: 46%; border-radius: 5px; overflow: hidden;}
#labor3 .labor_ect img{width: 100%;}
#labor3 .labor_top h2{position: absolute; top: -25px; left: 0; right: 0; margin: 0 auto; padding: 0px 30px; background: #fff; width: 80%; text-align: center; font-size: var(--fs24); font-weight: 500;}
#labor3 .labor_top h2 b{color: var(--color)}
#labor3 .labor_top h3{font-size: var(--fs18); line-height: 130%; text-align: center; margin-bottom: 20px; color: #333;}
#labor3 .labor_top h3:last-child{margin-bottom: 0px;}
/* 백그라운드가 있는 텍스트 */
#labor3 .labor_bg{background: url('../img/labor1.png')no-repeat; background-position: center; background-size: cover;  padding: 15px;}
#labor3 .labor_bg .text{padding: 6% 7%; border: 1px solid rgba(255,255,255,0.4);}
#labor3 .labor_bg p{font-size: var(--fs18); color: #fff; text-align: center; line-height: 130%; margin-bottom: 20px;}
#labor3 .labor_bg p:last-child{margin-bottom: 0px;}
/* 사건 아이콘 박스 */
#labor3 .labor3_ver{background: #f6f6f6;}
#labor3 .labor3_ver .width > h2{text-align: center; font-size: var(--fs28); font-weight: 500; margin-bottom: 50px;}
#labor3 .labor3_ver .width > p{color: #de1111; line-height: 130%; font-size: var(--fs18);}
#labor3 .labor3_ver .box_wrap{display: flex; flex-wrap: wrap; justify-content: center; gap: 40px 3%; margin-bottom: 30px;}
#labor3 .labor3_ver .box{background: #fff; width: 20%; border-radius: 5px; border: 1px solid #eee; text-align: center; padding: 30px 3px 45px 3px;}
#labor3 .labor3_ver .box span i{color: #253d5b; font-size: 5.0rem; }
#labor3 .labor3_ver .box p{margin-top: 20px; font-size: var(--fs20); font-weight: 400;}
@media all and (max-width: 1024px){
	#labor3 .labor_top{border: 10px solid #f6f6f6; padding: 30px 20px;}
	#labor3 .labor_top h2{font-size: 2.2rem; top: -20px; }
}
@media all and (max-width: 850px){
	#labor3 .labor_wrap{flex-direction: column-reverse;}
	#labor3 .labor_ect{width: 100%; margin-bottom: 50px;}
	#labor3 .labor_top{width: 100%;}
	#labor3 .labor3_ver .box_wrap{justify-content: flex-start; gap:25px 3%;}
	#labor3 .labor3_ver .box{width: 31.3%;}
}
@media all and (max-width: 768px){
	#labor3 .labor_bg .text{padding: 20px 15px;}
	#labor3 .labor_bg .text{width: 100% !important;}
}
@media all and (max-width: 650px){
	#labor3 .labor3_ver .box{width: 48.5%;}
}



/* 페이지 네비, 게시판 등 */
#bo_gall .is_notice{border-radius: 30px;}
.quick_banner{z-index: 99; right: 20px; bottom: 20px; position: fixed;animation: quickBounce .8s infinite alternate; display: none;}
#top_btn{width: 45px; height: 45px;border: none; background: #fff; border-radius: 50%;box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); transition: 0.3s all;}
#top_btn span{font-size: 14px; font-weight: bold;}
#top_btn:hover{background: #eee; color: #000;}
.in_top{width: 45px; height: 45px;border: none; background: #fff; border-radius: 50%;box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); transition: 0.3s all; display: block; text-align: center; line-height: 45px; font-size: 14px; font-weight: bold; text-transform: uppercase;}
.in_top:hover{background: #eee; color: #000;}

.floating_menu { width: 45px; height: 45px; border-radius: 50%; background: var(--color); position: fixed; bottom: 72px; z-index: 99; }
.floating_menu.in_float{position: initial;}
.floating_menu input { position: absolute; width: 45px; height: 45px; margin: 0; opacity: 0; cursor: pointer; }
.floating_menu input:checked ~ .floating_plus { transform: rotate(135deg); }
.floating_menu input:checked ~ .floating_nav li:nth-child(1) { transform: translatey(-52px); opacity: 1; }
.floating_menu input:checked ~ .floating_nav li:nth-child(2) { transform: translatey(-104px); opacity: 1; }
.floating_menu input:checked ~ .floating_nav li:nth-child(3) { transform: translatey(-156px); opacity: 1; }
.floating_menu input:checked ~ .floating_nav li:nth-child(4) { transform: translatey(-208px); opacity: 1; }
.floating_menu input ~ .floating_plus { transform: rotate(0); }
.floating_menu > .floating_plus { display: flex; justify-content: center; align-items: center; width: 45px; height: 45px; font-size: 20px; color: #FFFFFF; background:var(--color); border-radius: 50%; transform: rotate(0); transition: all 0.5s ease; pointer-events: none; box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); }
.floating_menu > .floating_plus i { line-height: normal !important; }
.floating_menu > .floating_nav { display: flex; justify-content: center; align-items: center; padding: 0; margin: 0; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: -1; }
.floating_nav li { display: flex; justify-content: center; align-items: center; width: 45px; height: 45px; border-radius: 50%; background: #fff; cursor: pointer; position: absolute; transition: all 0.5s ease; box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.2); opacity: 0; }
.floating_menu > .floating_nav li a i { font-size: 20px; color: #222; }
.floating_menu > .floating_nav li a i.xi-kakaotalk { font-size: 28px; margin-top: 3px; }
/* 사이드 배너 */
.banner_wrap{position: fixed; right: 20px; top: 50%; transform: translateY(-50%); z-index: 99; display: flex; flex-direction: column; align-items: center; width: 170px;}
.banner_wrap .side_cta{display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; width: 100%; padding: 24px 0; background: #2a2a2a; border-radius: 16px 16px 0 0; color: #fff; font-size: 15px; font-weight: 600; text-decoration: none; letter-spacing: -0.3px; line-height: 100%; transition: 0.3s;}
.banner_wrap .side_cta:hover{opacity: 0.9;}
.banner_wrap .side_cta i{font-size: 28px;}
.banner_wrap ul{list-style: none; padding: 0; margin: 0; width: 100%; background: #fff; border-radius: 0 0 16px 16px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,0.1);}
.banner_wrap ul li{border-top: 1px solid #f0f0f0;}
.banner_wrap ul li a{display: flex; align-items: center; justify-content: center; gap: 8px; padding: 22px 15px; color: #333; font-size: 14px; font-weight: 500; text-decoration: none; transition: 0.3s; line-height: 100%; letter-spacing: -0.3px;}
.banner_wrap ul li a img{width: 18px;}
.banner_wrap ul li a:hover{background: #f8f8f8; color: var(--color);}
.banner_wrap .side_toggle{width: 48px; height: 48px; border-radius: 50%; background: #fff; border: 1px solid #ddd; cursor: pointer; margin-top: 12px; display: flex; align-items: center; justify-content: center; box-shadow: 0 2px 10px rgba(0,0,0,0.12); position: relative; z-index: 10;}
.banner_wrap .side_toggle:hover{border-color: #999; background: #f5f5f5;}
.banner_wrap .side_toggle img{width: 14px;}
.banner_wrap .side_toggle .side_open{display: none;}
/* 닫힌 상태 */
.banner_wrap.closed .side_cta{border-radius: 16px;}
.banner_wrap.closed ul{display: none;}
.banner_wrap.closed .side_toggle .side_close{display: none;}
.banner_wrap.closed .side_toggle .side_open{display: block;}

/* 퀵메뉴 바운스 효과 */
/* @keyframes quickBounce {from {transform: translateY(0px);}to {transform: translateY(-15px);  }}
@keyframes quickBounce2 {0%,80%,100% {-webkit-transform: scale(0);	transform: scale(0);}
40% {-webkit-transform: scale(1.0);	transform: scale(1.0);}} */

.pg_wrap{margin-top: 60px; display: flex; justify-content: center; width: 100%;}
.pg_wrap .pg{display: flex;}
.pg_page{width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; margin: 0 2px; background-color: none; border: 1px solid #ccc;}
.pg_current{border: 1px solid #8e8e8e; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; margin: 0 2px; background: none;}

@media all and (max-width: 1400px) {
:root{
	--fs40: 3.4rem;
	--fs32: 2.8rem;
	--fs26: 2.3rem;
}
}
/* 갤러리 */
@media all and (max-width: 1024px) {
html{font-size: 55% !important;}
.gall_row .col-gn-4{width: 33.33333%;}
.gall_row .col-gn-5{width: 25%;}
}

@media all and (max-width: 850px) {
.gall_row .col-gn-4, .gall_row .col-gn-3, .gall_row .col-gn-5{width: 50%;}
#bo_cate li{width: 25%; margin-bottom: 10px;}
#bo_cate ul{flex-wrap: wrap;}
}

@media all and (max-width: 600px) {
.gall_row .col-gn-4, .gall_row .col-gn-3, .gall_row .col-gn-5, .gall_row .col-gn-2{width: 100%;}
}


/* 공통 반응형 */
@media all and (max-width: 1200px){}
@media all and (max-width: 1024px){
	.main_title h2{font-size: var(--fs28);}
}
@media all and (max-width: 900px){}
@media all and (max-width: 768px){
	.banner_wrap{display: none;}
}
@media all and (max-width: 650px){}

/*  */


/* ============================================
   HUMAN C&C MAIN PAGE LAYOUT
   ============================================ */

/* ----- HERO ----- */
.main-wrap .hero {
  position: relative;
  height: 100vh;
  background: linear-gradient(rgba(10,10,10,0.5), rgba(10,10,10,0.85)),
              url('https://images.unsplash.com/photo-1454165804606-c3d57bc86b40?w=1800&q=80') center/cover no-repeat;
  display: flex;
  align-items: center;
  padding: 0 80px;
  color: #fff;
  overflow: hidden;
}
.main-wrap .hero-bgtext {
  position: absolute;
  right: -40px;
  bottom: -60px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 240px;
  font-weight: 900;
  line-height: 0.75;
  color: rgba(255,255,255,0.04);
  pointer-events: none;
  letter-spacing: -8px;
}
.main-wrap .hero-content {
  position: relative;
  z-index: 2;
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  text-align: center;
}
.main-wrap .hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 18px;
  background: rgba(230,0,18,0.12);
  border: 1px solid rgba(230,0,18,0.5);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  margin-bottom: 28px;
  letter-spacing: 2px;
  color: #ff7a7a;
}
.main-wrap .hero-tag i { font-size: 6px; color: #E60012; }
.main-wrap .hero-title {
  font-size: 56px;
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: -2px;
  margin: 0 auto 22px;
  color: #fff;
  max-width: 720px;
}
.main-wrap .hero-title .accent {
  color: #E60012;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  font-family: inherit;
  display: inline;
}
.main-wrap .hero-desc {
  font-size: 17px;
  opacity: 0.85;
  max-width: 540px;
  margin: 0 auto 36px;
  line-height: 1.75;
  font-weight: 300;
}
.main-wrap .hero-btns { display: flex; gap: 12px; justify-content: center; }
.main-wrap .hero-scroll {
  position: absolute;
  left: 50%;
  bottom: 30px;
  transform: translateX(-50%);
  font-size: 10px;
  letter-spacing: 4px;
  opacity: 0.7;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 3;
  color: #fff;
}
.main-wrap .hero-scroll .dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #E60012;
  animation: scrollDot 1.6s infinite;
}

/* ----- ABOUT ----- */
.main-wrap .about {
  padding: 110px 80px;
  position: relative;
  background: #fff;
}
.main-wrap .about .bg-text { right: -30px; top: 60px; }
.main-wrap .about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: center;
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
}
.main-wrap .about-imgwrap { position: relative; }
.main-wrap .about-imgbox {
  aspect-ratio: 4/5;
  border-radius: 4px;
  overflow: hidden;
}
.main-wrap .about-imgbox img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.2s;
}
.main-wrap .about-imgwrap:hover .about-imgbox img { transform: scale(1.05); }
.main-wrap .about-imgtag {
  position: absolute;
  left: -10px;
  top: 30px;
  background: #E60012;
  color: #fff;
  padding: 8px 16px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  z-index: 2;
}
.main-wrap .about-floatcard {
  position: absolute;
  right: -30px;
  bottom: 40px;
  background: #1a1a1a;
  color: #fff;
  padding: 26px 32px;
  border-radius: 4px;
}
.main-wrap .about-floatcard .num {
  font-size: 60px;
  line-height: 1;
  letter-spacing: -1.5px;
}
.main-wrap .about-floatcard .num span { color: #E60012; }
.main-wrap .about-floatcard .lab-text {
  font-size: 12px;
  letter-spacing: 1.5px;
  opacity: 0.7;
  margin-top: 6px;
}
.main-wrap .about-content { padding: 10px 0; }
.main-wrap .about-content h2 {
  font-size: 38px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.3;
  margin-bottom: 22px;
}
.main-wrap .about-content p {
  color: #555;
  line-height: 1.95;
  margin-bottom: 40px;
  font-size: 15px;
  font-weight: 300;
}
.main-wrap .about-content .quote-line {
  width: 32px;
  height: 3px;
  background: #E60012;
  margin-bottom: 16px;
}
.main-wrap .strengths {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid #eee;
}
.main-wrap .strength {
  padding: 44px 28px;
  border-right: 1px solid #eee;
  position: relative;
  transition: all .25s;
  text-align: center;
}
.main-wrap .strength:last-child { border-right: none; }
.main-wrap .strength::before {
  content: '';
  position: absolute;
  left: 50%; top: -1px;
  width: 0; height: 2px;
  background: #E60012;
  transition: width .35s;
  transform: translateX(-50%);
}
.main-wrap .strength:hover::before { width: 70%; }
.main-wrap .strength .idx {
  font-size: 16px;
  color: #999;
  letter-spacing: 1.5px;
  margin-bottom: 18px;
}
.main-wrap .strength i {
  color: #1a1a1a;
  font-size: 34px;
  margin-bottom: 20px;
  display: block;
}
.main-wrap .strength h4 {
  font-size: 19px;
  font-weight: 700;
  margin-bottom: 10px;
}
.main-wrap .strength p {
  font-size: 14px;
  color: #777;
  line-height: 1.7;
  margin: 0;
  font-weight: 400;
}

/* ----- BUSINESS ----- */
.main-wrap .business {
  background: #f5f5f5;
  padding: 110px 80px;
  position: relative;
  overflow: hidden;
}
.main-wrap .business .bg-text { left: -30px; top: 60px; }
.main-wrap .business-head {
  margin-bottom: 50px;
  position: relative;
  z-index: 2;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
.main-wrap .business-head h2 {
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -1.5px;
  line-height: 1.2;
}
.main-wrap .business-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
}
.main-wrap .biz-card {
  position: relative;
  height: 380px;
  border-radius: 4px;
  overflow: hidden;
  cursor: pointer;
  transition: transform .4s;
}
.main-wrap .biz-img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform .8s;
}
.main-wrap .biz-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.92) 5%, rgba(0,0,0,0.45) 55%, rgba(0,0,0,0.15) 100%);
  transition: background .3s;
}
.main-wrap .biz-body {
  position: absolute; inset: 0;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: #fff;
  z-index: 2;
}
.main-wrap .biz-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.main-wrap .biz-top .idx {
  font-size: 18px;
  opacity: 0.7;
  letter-spacing: 1px;
}
.main-wrap .biz-top i { font-size: 22px; opacity: 0.9; }
.main-wrap .biz-bottom h3 {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 8px;
  letter-spacing: -0.5px;
  color: #fff;
}
.main-wrap .biz-bottom p {
  font-size: 13px;
  opacity: 0.85;
  line-height: 1.7;
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s, opacity .3s, margin .3s;
  opacity: 0;
  margin-bottom: 0;
  color: #fff;
}
.main-wrap .biz-more {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1.5px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.3);
  margin-top: 14px;
  color: #fff;
}
.main-wrap .biz-more i { font-size: 11px; transition: transform .25s; }
.main-wrap .biz-card:hover { transform: translateY(-6px); }
.main-wrap .biz-card:hover .biz-img { transform: scale(1.08); }
.main-wrap .biz-card:hover .biz-overlay {
  background: linear-gradient(to top, rgba(230,0,18,0.85) 0%, rgba(0,0,0,0.5) 80%);
}
.main-wrap .biz-card:hover .biz-bottom p {
  max-height: 100px;
  opacity: 1;
  margin-bottom: 4px;
}
.main-wrap .biz-card:hover .biz-more i { transform: translateX(4px); }

/* ----- STATS (PARALLAX) ----- */
.main-wrap .stats {
  background: linear-gradient(rgba(10,10,10,0.85), rgba(10,10,10,0.92)),
              url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=1800&q=80') center/cover;
  background-attachment: fixed;
  color: #fff;
  text-align: center;
  padding: 110px 80px;
  position: relative;
  overflow: hidden;
}
.main-wrap .stats-bgtext {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  font-size: 220px;
  font-weight: 700;
  line-height: 0.9;
  color: rgba(255,255,255,0.04);
  pointer-events: none;
  letter-spacing: 4px;
  white-space: nowrap;
  font-family: 'Bebas Neue', sans-serif;
}
.main-wrap .stats .label {
  justify-content: center;
  color: #ff5555;
  position: relative;
  z-index: 2;
}
.main-wrap .stats .label::before { background: #ff5555; }
.main-wrap .stats h2 {
  font-size: 36px;
  font-weight: 800;
  margin-bottom: 70px;
  letter-spacing: -1px;
  position: relative;
  z-index: 2;
  color: #fff;
}
.main-wrap .stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.main-wrap .stat-item {
  padding: 0 20px;
  border-right: 1px solid rgba(255,255,255,0.12);
}
.main-wrap .stat-item:last-child { border-right: none; }
.main-wrap .stat-num {
  font-size: 76px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -1.5px;
  line-height: 1;
  margin-bottom: 12px;
}
.main-wrap .stat-num span { color: #E60012; }
.main-wrap .stat-label {
  font-size: 13px;
  opacity: 0.7;
  letter-spacing: 1.5px;
}

/* ----- CLIENTS (SLIDER) ----- */
.main-wrap .clients {
  padding: 100px 80px;
  background: #fff;
  border-top: 1px solid #f0f0f0;
  position: relative;
  overflow: hidden;
}
.main-wrap .clients-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 44px;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
.main-wrap .clients-head h2 {
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -1.5px;
  line-height: 1.15;
}
.main-wrap .clients-head h2 small {
  font-size: 16px;
  color: #999;
  font-weight: 400;
  margin-left: 12px;
  letter-spacing: 0;
}
.main-wrap .clients-track-wrap {
  overflow: hidden;
  max-width: 1280px;
  margin: 0 auto;
}
.main-wrap .clients-track {
  display: flex;
  gap: 16px;
  transition: transform .55s cubic-bezier(.2, .7, .2, 1);
}
.main-wrap .client-logo {
  flex: 0 0 calc((100% - 80px) / 6);
  height: 100px;
  border: 1px solid #eee;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #999;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 1.5px;
  transition: all .25s;
}
.main-wrap .client-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 15px;
}

/* ----- RECRUIT (CTA BAND) ----- */
.main-wrap .recruit {
  padding: 100px 80px;
  background: linear-gradient(rgba(15,15,15,0.85), rgba(15,15,15,0.92)),
              url('https://images.unsplash.com/photo-1522071820081-009f0129c71c?w=1800&q=80') center/cover no-repeat;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.main-wrap .recruit .bg-text {
  right: -40px;
  bottom: -80px;
  font-size: 240px;
  color: rgba(255,255,255,0.04);
}
.main-wrap .recruit-glow {
  position: absolute;
  right: -150px;
  top: -150px;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(230,0,18,0.2), transparent 65%);
  pointer-events: none;
}
.main-wrap .recruit-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  position: relative;
  z-index: 1;
  max-width: 1280px;
  margin: 0 auto;
}
.main-wrap .recruit-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  font-weight: 700;
  color: #ff5555;
  letter-spacing: 2.5px;
  margin-bottom: 14px;
}
.main-wrap .recruit-label::before {
  content: '';
  display: block;
  width: 26px;
  height: 1px;
  background: #ff5555;
}
.main-wrap .recruit h3 {
  font-size: 40px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.2;
  margin-bottom: 12px;
  color: #fff;
}
.main-wrap .recruit p {
  opacity: 0.7;
  font-size: 15px;
  font-weight: 300;
  color: #fff;
}

/* ----- CONTACT ----- */
.main-wrap .contact {
  padding: 110px 80px;
  background: #fff;
  text-align: center;
}
.main-wrap .contact h2 {
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -1.5px;
  margin-bottom: 20px;
  line-height: 1.2;
}
.main-wrap .contact .label { justify-content: center; }
.main-wrap .contact-sub {
  color: #666;
  font-size: 16px;
  max-width: 600px;
  line-height: 1.85;
  margin: 0 auto 60px;
  font-weight: 300;
}
.main-wrap .contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 60px;
  border-top: 1px solid #eee;
  border-bottom: 1px solid #eee;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
}
.main-wrap .contact-item {
  padding: 50px 30px;
  text-align: center;
  transition: all .3s;
  border-right: 1px solid #eee;
  position: relative;
}
.main-wrap .contact-item:last-child { border-right: none; }
.main-wrap .contact-item::after {
  content: '';
  position: absolute;
  left: 0; bottom: -1px;
  width: 0; height: 2px;
  background: #E60012;
  transition: width .35s;
}
.main-wrap .contact-item:hover::after { width: 100%; }
.main-wrap .contact-item:hover { background: #fafafa; }
.main-wrap .contact-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: #1a1a1a;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin-bottom: 22px;
  transition: all .3s;
}
.main-wrap .contact-item:hover .contact-icon {
  background: #E60012;
  transform: rotate(-8deg) scale(1.05);
}
.main-wrap .contact-item h4 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 8px;
}
.main-wrap .contact-item p {
  color: #666;
  font-size: 14px;
  line-height: 1.8;
  font-weight: 400;
}

/* ----- RESPONSIVE ----- */
@media (max-width: 1100px) {
  .main-wrap .business-grid,
  .main-wrap .stats-grid,
  .main-wrap .clients-track { grid-template-columns: repeat(2, 1fr); }

  .main-wrap .about-grid,
  .main-wrap .recruit-inner {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: flex-start;
  }

  .main-wrap .contact-grid { grid-template-columns: 1fr; }

  .main-wrap .hero,
  .main-wrap .about,
  .main-wrap .business,
  .main-wrap .stats,
  .main-wrap .clients,
  .main-wrap .recruit,
  .main-wrap .contact { padding-left: 30px; padding-right: 30px; }

  .main-wrap .hero-title { font-size: 42px; }
  .main-wrap .about-content h2,
  .main-wrap .business-head h2,
  .main-wrap .clients-head h2,
  .main-wrap .contact h2,
  .main-wrap .recruit h3,
  .main-wrap .stats h2 { font-size: 30px; }

  .main-wrap .stat-num { font-size: 56px; }
  .main-wrap .client-logo { flex: 0 0 calc((100% - 16px) / 2); }
  .main-wrap .stat-item:nth-child(2n) { border-right: none; }

  .main-wrap .about-floatcard {
    right: 0;
    bottom: 0;
    padding: 20px 24px;
  }
  .main-wrap .about-floatcard .num { font-size: 44px; }
}

@media (max-width: 700px) {
  .main-wrap .hero { padding: 0 24px; height: 540px; }
  .main-wrap .hero-title { font-size: 32px; }
  .main-wrap .business-grid { grid-template-columns: 1fr; }
  .main-wrap .strengths { grid-template-columns: 1fr; }
  .main-wrap .strength {
    border-right: none;
    border-bottom: 1px solid #eee;
    padding: 22px 0;
  }
  .main-wrap .strength:last-child { border-bottom: none; }
  .main-wrap .stat-num { font-size: 44px; }
  .main-wrap .stat-item { padding: 0 12px; }
}


/* ============================================
   SUB PAGE COMMON
   ============================================ */
.main-wrap .sub-hero {
  position: relative;
  height: 320px;
  background: linear-gradient(rgba(20,20,20,0.7), rgba(20,20,20,0.85)),
              url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=1800&q=80') center/cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
  overflow: hidden;
  padding: 90px 80px 0;
}
.main-wrap .sub-hero-bgtext {
  position: absolute;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 200px;
  color: rgba(255,255,255,0.05);
  letter-spacing: -4px;
  pointer-events: none;
  bottom: -40px;
  left: 50%;
  transform: translateX(-50%);
  line-height: 0.8;
  white-space: nowrap;
  font-weight: 700;
}
.main-wrap .sub-hero-inner { position: relative; z-index: 2; }
.main-wrap .sub-hero h1 {
  font-size: 44px;
  font-weight: 800;
  letter-spacing: -1.5px;
  margin: 0;
  color: #fff;
}
.main-wrap .sub-hero .breadcrumb {
  font-size: 12px;
  letter-spacing: 2.5px;
  opacity: 0.85;
  font-weight: 500;
}
.main-wrap .sub-hero .breadcrumb span { color: #ff5555; margin: 0 10px; }

.main-wrap .sub-section {
  padding: 100px 80px;
  max-width: 1280px;
  margin: 0 auto;
}
.main-wrap .sub-section.bg-gray { max-width: 100%; background: #f7f7f7; }
.main-wrap .sub-section.bg-dark { max-width: 100%; background: #1a1a1a; color: #fff; }
.main-wrap .sub-section.bg-gray .sub-inner,
.main-wrap .sub-section.bg-dark .sub-inner { max-width: 1280px; margin: 0 auto; }

.main-wrap .section-head { text-align: center; margin-bottom: 56px; }
.main-wrap .section-head .label { justify-content: center; }
.main-wrap .section-head h2 {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.4;
  margin: 0;
}
.main-wrap .section-head h2 small {
  display: block;
  font-size: 14px;
  font-weight: 400;
  color: #888;
  margin-top: 14px;
  letter-spacing: 0.5px;
}

/* GREETING */
.main-wrap .greeting-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 70px;
  align-items: start;
}
.main-wrap .greeting-text h2 {
  font-size: 32px;
  line-height: 1.4;
  letter-spacing: -1px;
  margin: 0 0 28px;
  font-weight: 800;
}
.main-wrap .greeting-text h2 .accent {
  color: #E60012;
  font-size: inherit; font-weight: inherit; line-height: inherit;
}
.main-wrap .greeting-text p {
  color: #555;
  line-height: 1.95;
  margin: 0 0 16px;
  font-size: 15px;
  font-weight: 300;
}
.main-wrap .greeting-text .signature {
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid #eee;
  font-size: 14px;
  color: #888;
}
.main-wrap .greeting-text .signature strong {
  color: #1a1a1a;
  font-size: 18px;
  margin-left: 8px;
  font-weight: 800;
}
.main-wrap .company-info {
  background: #1a1a1a;
  color: #fff;
  padding: 48px 40px;
  border-radius: 4px;
  position: relative;
  overflow: hidden;
}
.main-wrap .company-info::before {
  content: 'INFO';
  position: absolute;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 140px;
  color: rgba(255,255,255,0.04);
  right: -20px;
  bottom: -50px;
  line-height: 0.8;
  pointer-events: none;
  font-weight: 700;
}
.main-wrap .company-info-head {
  margin-bottom: 28px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  position: relative;
  z-index: 1;
}
.main-wrap .company-info-head .num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 56px;
  color: #E60012;
  line-height: 1;
  font-weight: 700;
}
.main-wrap .company-info-head h3 {
  font-size: 22px;
  font-weight: 800;
  margin: 8px 0 0;
  color: #fff;
}
.main-wrap .company-info dl {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 14px 16px;
  margin: 0;
  position: relative;
  z-index: 1;
}
.main-wrap .company-info dt {
  color: #ff5555;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  padding-top: 2px;
}
.main-wrap .company-info dd {
  color: rgba(255,255,255,0.85);
  font-size: 14px;
  margin: 0;
  line-height: 1.65;
}

/* HISTORY TIMELINE */
.main-wrap .timeline { position: relative; }
.main-wrap .timeline::before {
  content: '';
  position: absolute;
  left: 195px;
  top: 0; bottom: 0;
  width: 1px;
  background: #e5e5e5;
}
.main-wrap .timeline-row {
  display: grid;
  grid-template-columns: 200px 50px 1fr;
  padding: 24px 0;
  align-items: start;
}
.main-wrap .timeline-row .year {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 32px;
  color: #1a1a1a;
  letter-spacing: 1px;
  font-weight: 700;
  line-height: 1;
}
.main-wrap .timeline-row .dot {
  position: relative;
  display: flex;
  justify-content: center;
}
.main-wrap .timeline-row .dot::before {
  content: '';
  width: 14px;
  height: 14px;
  background: #E60012;
  border-radius: 50%;
  border: 3px solid #fff;
  box-shadow: 0 0 0 1px #E60012;
  margin-top: 5px;
  z-index: 2;
}
.main-wrap .timeline-row ul {
  padding: 0; margin: 0; list-style: none;
}
.main-wrap .timeline-row ul li {
  font-size: 15px;
  color: #555;
  padding: 5px 0 5px 14px;
  position: relative;
  line-height: 1.7;
}
.main-wrap .timeline-row ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 14px;
  width: 5px; height: 5px;
  background: #ccc;
  border-radius: 50%;
}
.main-wrap .timeline-row ul li b {
  color: #1a1a1a;
  font-weight: 700;
}

/* ORGANIZATION */
.main-wrap .org-block { margin-bottom: 80px; }
.main-wrap .org-block:last-child { margin-bottom: 0; }
.main-wrap .org-title {
  text-align: center;
  font-size: 22px;
  font-weight: 800;
  margin: 0 0 50px;
  letter-spacing: -0.5px;
}
.main-wrap .org-title span {
  display: inline-block;
  padding: 6px 24px;
  background: #1a1a1a;
  color: #fff;
  border-radius: 100px;
  font-size: 14px;
  margin-right: 14px;
  letter-spacing: 1px;
}
.main-wrap .org-tree { text-align: center; }
.main-wrap .org-ceo {
  display: inline-block;
  background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%);
  color: #fff;
  padding: 26px 50px;
  border-radius: 6px;
  margin: 0 auto 56px;
  position: relative;
  box-shadow: 0 14px 36px rgba(0,0,0,0.18);
}
.main-wrap .org-ceo::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -56px;
  width: 1px;
  height: 56px;
  background: #ddd;
}
.main-wrap .org-ceo .role {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 14px;
  color: #ff5555;
  letter-spacing: 2.5px;
  margin-bottom: 8px;
}
.main-wrap .org-ceo .name {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.5px;
}
.main-wrap .org-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 56px;
  position: relative;
}
.main-wrap .org-row::before {
  content: '';
  position: absolute;
  top: -56px;
  left: 16.66%; right: 16.66%;
  height: 1px;
  background: #ddd;
}
.main-wrap .org-row.cols-2 {
  grid-template-columns: repeat(2, 1fr);
  padding: 0 16.66%;
  margin-bottom: 56px;
}
.main-wrap .org-row.cols-2::before {
  left: 50%;
  right: auto;
  width: 1px;
  height: 56px;
  top: -56px;
  background: #ddd;
  transform: translateX(-50%);
}
.main-wrap .org-row.cols-2::after {
  content: '';
  position: absolute;
  bottom: -56px;
  left: 50%;
  width: 1px;
  height: 56px;
  background: #ddd;
  transform: translateX(-50%);
}
.main-wrap .org-card {
  background: #fff;
  border: 1px solid #1a1a1a;
  padding: 22px 18px;
  border-radius: 4px;
  position: relative;
  text-align: center;
}
.main-wrap .org-card::before {
  content: '';
  position: absolute;
  top: -56px;
  left: 50%;
  width: 1px;
  height: 56px;
  background: #ddd;
}
.main-wrap .org-card .role {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 12px;
  color: #E60012;
  letter-spacing: 1.5px;
  margin-bottom: 6px;
}
.main-wrap .org-card .name {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.3px;
}
.main-wrap .org-teams {
  display: grid;
  gap: 18px;
  margin-top: 50px;
  position: relative;
}
.main-wrap .org-teams.cols-3 { grid-template-columns: repeat(3, 1fr); }
.main-wrap .org-teams.cols-2 { grid-template-columns: repeat(2, 1fr); }
.main-wrap .org-teams::before {
  content: '';
  position: absolute;
  top: -25px;
  left: 16.66%; right: 16.66%;
  height: 1px;
  background: #ddd;
}
.main-wrap .org-teams.cols-2::before { left: 25%; right: 25%; }
.main-wrap .org-team {
  background: #f5f5f5;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
}
.main-wrap .org-team::before {
  content: '';
  position: absolute;
  top: -25px;
  left: 50%;
  width: 1px;
  height: 25px;
  background: #ddd;
}
.main-wrap .org-team-head {
  background: #1a1a1a;
  color: #fff;
  padding: 14px;
  text-align: center;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: -0.3px;
}
.main-wrap .org-team-body { padding: 18px; }
.main-wrap .org-team-cat {
  font-size: 12px;
  font-weight: 700;
  color: #E60012;
  margin-bottom: 8px;
  padding: 3px 10px;
  background: rgba(230,0,18,0.08);
  border-radius: 3px;
  display: inline-block;
}
.main-wrap .org-team-list {
  font-size: 13px;
  color: #555;
  line-height: 1.7;
  padding: 0 0 12px;
  margin: 0;
  list-style: none;
}
.main-wrap .org-team-list:last-child { padding-bottom: 0; }
.main-wrap .org-team-list li { padding: 2px 0; }

/* PERFORMANCE GRID */
.main-wrap .perf-block { margin-bottom: 80px; }
.main-wrap .perf-block:last-child { margin-bottom: 0; }
.main-wrap .perf-block-head {
  display: flex;
  align-items: baseline;
  gap: 20px;
  margin-bottom: 32px;
  border-bottom: 2px solid #1a1a1a;
  padding-bottom: 16px;
}
.main-wrap .perf-block-head .num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 42px;
  color: #E60012;
  font-weight: 700;
  line-height: 1;
}
.main-wrap .perf-block-head h3 {
  font-size: 22px;
  font-weight: 800;
  margin: 0;
  letter-spacing: -0.5px;
}
.main-wrap .perf-block-head h3 small {
  font-size: 13px;
  color: #888;
  font-weight: 400;
  margin-left: 12px;
}
.main-wrap .perf-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.main-wrap .perf-card {
  background: #fff;
  border: 1px solid #eee;
  padding: 24px 22px;
  border-radius: 4px;
  transition: all .25s;
  position: relative;
}
.main-wrap .perf-card:hover {
  transform: translateY(-3px);
  border-color: #1a1a1a;
  box-shadow: 0 12px 30px rgba(0,0,0,0.08);
}
.main-wrap .perf-card:hover .perf-num { color: #E60012; }
.main-wrap .perf-card .perf-tag {
  display: inline-block;
  padding: 4px 10px;
  background: #1a1a1a;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  border-radius: 3px;
  margin-bottom: 12px;
}
.main-wrap .perf-card h4 {
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 10px;
  letter-spacing: -0.3px;
  line-height: 1.4;
}
.main-wrap .perf-card .perf-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 32px;
  color: #1a1a1a;
  font-weight: 700;
  margin-bottom: 14px;
  line-height: 1;
}
.main-wrap .perf-card .perf-num small {
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 14px;
  color: #888;
  font-weight: 400;
  margin-left: 4px;
}
.main-wrap .perf-card ul { margin: 0; padding: 0; list-style: none; }
.main-wrap .perf-card ul li {
  font-size: 14px;
  color: #666;
  padding: 4px 0 4px 18px;
  position: relative;
  line-height: 1.7;
}
.main-wrap .perf-card ul li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #999;
  font-weight: 700;
}

/* CERTIFICATE - 세로형 직사각형 (인증서 비율) */
.main-wrap .cert-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.main-wrap .cert-grid.cols-5 { grid-template-columns: repeat(5, 1fr); }
.main-wrap .cert-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 6px;
  display: block;
  overflow: hidden;
  transition: all .25s;
  padding: 0;
}
.main-wrap .cert-card:hover {
  border-color: #1a1a1a;
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,0.1);
}
.main-wrap .cert-img {
  width: 100%;
  aspect-ratio: 3 / 4;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}
.main-wrap .cert-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(26,26,26,0.5) 0%, rgba(26,26,26,0.85) 100%);
  transition: background .35s;
}
.main-wrap .cert-card:hover .cert-img::after {
  background: linear-gradient(135deg, rgba(230,0,18,0.5) 0%, rgba(230,0,18,0.85) 100%);
}
.main-wrap .cert-img i {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  color: #fff;
  font-size: 42px;
}
.main-wrap .cert-info {
  padding: 22px 22px 26px;
  text-align: center;
}
.main-wrap .cert-info h4 {
  font-size: 16px;
  font-weight: 800;
  margin: 0 0 12px;
  letter-spacing: -0.3px;
  line-height: 1.45;
  min-height: 46px;
}
.main-wrap .cert-info .meta {
  font-size: 13px;
  color: #888;
}
.main-wrap .cert-info .meta span {
  color: #1a1a1a;
  font-weight: 700;
  display: block;
  margin-bottom: 4px;
}

/* LOCATION */
.main-wrap .loc-grid {
  display: grid;
  grid-template-columns: 1fr 380px;
  border: 1px solid #eee;
  border-radius: 4px;
  overflow: hidden;
}
.main-wrap .loc-map { height: 480px; background: #f5f5f5; }
.main-wrap .loc-map iframe { width: 100%; height: 100%; border: 0; }
.main-wrap .loc-info { padding: 40px; background: #1a1a1a; color: #fff; }
.main-wrap .loc-info h3 {
  font-size: 26px;
  font-weight: 800;
  margin: 0 0 28px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  letter-spacing: -0.5px;
}
.main-wrap .loc-info dl {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 16px 12px;
  margin: 0;
}
.main-wrap .loc-info dt {
  color: #ff5555;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  padding-top: 2px;
}
.main-wrap .loc-info dd {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: rgba(255,255,255,0.85);
}
.main-wrap .loc-transit {
  margin-top: 60px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.main-wrap .loc-transit-card {
  padding: 28px 24px;
  border: 1px solid #eee;
  border-radius: 4px;
  text-align: center;
}
.main-wrap .loc-transit-card i {
  font-size: 28px;
  color: #E60012;
  margin-bottom: 14px;
}
.main-wrap .loc-transit-card h4 {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 10px;
}
.main-wrap .loc-transit-card p {
  font-size: 13px;
  color: #666;
  line-height: 1.7;
  margin: 0;
}

/* BUSINESS DETAIL PAGES */
.main-wrap .biz-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: center;
  margin-bottom: 80px;
}
.main-wrap .biz-intro-img {
  aspect-ratio: 4/3;
  border-radius: 4px;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}
.main-wrap .biz-intro-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 60%, rgba(230,0,18,0.15));
}
.main-wrap .biz-intro-text h2 {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.4;
  margin: 0 0 24px;
}
.main-wrap .biz-intro-text h2 .accent {
  color: #E60012;
  font-size: inherit; font-weight: inherit;
}
.main-wrap .biz-intro-text p {
  color: #555;
  line-height: 1.85;
  font-size: 17px;
  font-weight: 400;
  margin: 0 0 16px;
}
.main-wrap .biz-services {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 60px;
}
.main-wrap .biz-service {
  background: #fff;
  border: 1px solid #eee;
  padding: 32px 32px;
  border-radius: 12px;
  transition: all .25s;
}
.main-wrap .biz-service:hover {
  border-color: transparent;
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(0,0,0,0.10);
}
.main-wrap .biz-service-head {
  display: flex;
  align-items: center;
  gap: 22px;
  margin-bottom: 20px;
}
.main-wrap .biz-service-img {
  width: 90px; height: 90px;
  border-radius: 12px;
  background-size: cover;
  background-position: center;
  flex: none;
  position: relative;
  overflow: hidden;
  transition: transform .35s;
}
.main-wrap .biz-service-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 50%, rgba(230,0,18,0.25));
  opacity: 0;
  transition: opacity .3s;
}
.main-wrap .biz-service:hover .biz-service-img { transform: scale(1.05); }
.main-wrap .biz-service:hover .biz-service-img::after { opacity: 1; }
.main-wrap .biz-service h4 {
  font-size: 21px;
  font-weight: 800;
  margin: 0;
  letter-spacing: -0.5px;
  line-height: 1.35;
}
.main-wrap .biz-service p {
  color: #555;
  font-size: 15px;
  line-height: 1.8;
  margin: 0;
  font-weight: 400;
}
.main-wrap .biz-process {
  background: #f7f7f7;
  padding: 60px 50px;
  border-radius: 4px;
  margin-top: 60px;
}
.main-wrap .biz-process-head {
  text-align: center;
  margin-bottom: 40px;
}
.main-wrap .biz-process-head h3 {
  font-size: 26px;
  font-weight: 800;
  margin: 0 0 8px;
}
.main-wrap .biz-process-head p {
  color: #888;
  font-size: 14px;
  margin: 0;
}
.main-wrap .biz-process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.main-wrap .biz-process-step {
  text-align: center;
  padding: 0 16px;
  position: relative;
}
.main-wrap .biz-process-step:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 55px;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #ddd 50%, transparent 50%);
  background-size: 8px 1px;
  background-repeat: repeat-x;
  z-index: 0;
}
.main-wrap .biz-process-step .step-circle {
  width: 110px;
  height: 110px;
  border: 2px solid #E60012;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto 22px;
  background: #fff;
  transition: all .35s;
  position: relative;
  z-index: 1;
}
.main-wrap .biz-process-step:hover .step-circle {
  background: #E60012;
  transform: translateY(-6px);
  box-shadow: 0 14px 32px rgba(230, 0, 18, 0.25);
}
.main-wrap .biz-process-step .step-tag {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 12px;
  letter-spacing: 1.8px;
  color: #888;
  transition: color .35s;
  line-height: 1;
  margin-bottom: 6px;
}
.main-wrap .biz-process-step:hover .step-tag { color: rgba(255,255,255,0.85); }
.main-wrap .biz-process-step .step-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 38px;
  color: #E60012;
  font-weight: 700;
  line-height: 1;
  transition: color .35s;
}
.main-wrap .biz-process-step:hover .step-num { color: #fff; }
.main-wrap .biz-process-step h4 {
  font-size: 17px;
  font-weight: 800;
  margin: 0 0 10px;
  letter-spacing: -0.3px;
}
.main-wrap .biz-process-step p {
  font-size: 13px;
  color: #777;
  line-height: 1.7;
  margin: 0;
}

/* SUB PAGE RESPONSIVE */
@media (max-width: 1100px) {
  .main-wrap .sub-hero { padding: 60px 30px 0; }
  .main-wrap .sub-hero h1 { font-size: 32px; }
  .main-wrap .sub-hero-bgtext { font-size: 130px; }
  .main-wrap .sub-section { padding: 70px 30px; }
  .main-wrap .greeting-grid,
  .main-wrap .biz-intro,
  .main-wrap .loc-grid { grid-template-columns: 1fr; gap: 40px; }
  .main-wrap .loc-map { height: 350px; }
  .main-wrap .perf-grid,
  .main-wrap .cert-grid,
  .main-wrap .cert-grid.cols-5,
  .main-wrap .biz-services,
  .main-wrap .loc-transit { grid-template-columns: repeat(2, 1fr); }
  .main-wrap .org-row,
  .main-wrap .org-row.cols-2,
  .main-wrap .org-teams.cols-3,
  .main-wrap .org-teams.cols-2 { grid-template-columns: 1fr; padding: 0; }
  .main-wrap .org-row::before,
  .main-wrap .org-row.cols-2::before,
  .main-wrap .org-row.cols-2::after,
  .main-wrap .org-teams::before,
  .main-wrap .org-card::before,
  .main-wrap .org-team::before { display: none; }
  .main-wrap .timeline::before { left: 100px; }
  .main-wrap .timeline-row { grid-template-columns: 100px 30px 1fr; }
  .main-wrap .timeline-row .year { font-size: 24px; }
  .main-wrap .biz-process-grid { grid-template-columns: repeat(2, 1fr); gap: 30px 20px; }
  .main-wrap .biz-process-step:not(:last-child)::after { display: none; }
}
@media (max-width: 700px) {
  .main-wrap .perf-grid,
  .main-wrap .cert-grid,
  .main-wrap .cert-grid.cols-5,
  .main-wrap .biz-services,
  .main-wrap .loc-transit { grid-template-columns: 1fr; }
  .main-wrap .biz-process-grid { grid-template-columns: 1fr; }
}


/* ============================================
   PERFORMANCE PAGE — REDESIGN
   ============================================ */

/* 페이지 상단 하이라이트 통계 */
.main-wrap .perf-highlight {
  background: #fff;
  color: #1a1a1a;
  padding: 90px 80px;
  text-align: center;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid #f0f0f0;
}
.main-wrap .perf-highlight::before {
  content: 'PERFORMANCE';
  position: absolute;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 240px;
  color: rgba(0,0,0,0.025);
  letter-spacing: -4px;
  white-space: nowrap;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  font-weight: 700;
  line-height: 1;
}
.main-wrap .perf-highlight-inner {
  position: relative;
  z-index: 2;
  max-width: 1280px;
  margin: 0 auto;
}
.main-wrap .perf-highlight .label {
  justify-content: center;
}
.main-wrap .perf-highlight h2 {
  font-size: 34px;
  font-weight: 800;
  margin: 0 0 60px;
  letter-spacing: -1px;
  color: #1a1a1a;
}
.main-wrap .perf-highlight-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
}
.main-wrap .perf-highlight-stat {
  position: relative;
  border-right: 1px solid #eee;
  padding: 0 20px;
}
.main-wrap .perf-highlight-stat:last-child { border-right: none; }
.main-wrap .perf-highlight-stat .num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 64px;
  color: #1a1a1a;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -1.5px;
  margin-bottom: 12px;
}
.main-wrap .perf-highlight-stat .num span { color: #E60012; }
.main-wrap .perf-highlight-stat .lab {
  font-size: 12px;
  letter-spacing: 2px;
  color: #888;
  font-family: 'Bebas Neue', sans-serif;
  margin-bottom: 4px;
}
.main-wrap .perf-highlight-stat .desc {
  font-size: 13px;
  color: #888;
}

/* 새 perf-block (independent section) */
.main-wrap .perf-blk {
  padding: 110px 80px;
  position: relative;
  overflow: hidden;
  background: #fff;
}
.main-wrap .perf-blk.bg-gray { background: #f7f7f7; }
.main-wrap .perf-blk.bg-dark { background: #1a1a1a; color: #fff; }
.main-wrap .perf-blk-bgtext {
  position: absolute;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 220px;
  color: rgba(0,0,0,0.04);
  letter-spacing: -4px;
  white-space: nowrap;
  pointer-events: none;
  line-height: 1;
  font-weight: 700;
  right: -40px;
  top: 50px;
}
.main-wrap .perf-blk.bg-dark .perf-blk-bgtext { color: rgba(255,255,255,0.04); }
.main-wrap .perf-blk-inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.main-wrap .perf-blk-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 50px;
  padding-bottom: 24px;
  border-bottom: 2px solid currentColor;
  border-color: rgba(0,0,0,0.08);
}
.main-wrap .perf-blk.bg-dark .perf-blk-head { border-color: rgba(255,255,255,0.12); }
.main-wrap .perf-blk-head-l {
  display: flex;
  align-items: baseline;
  gap: 22px;
}
.main-wrap .perf-blk-head-l .num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 56px;
  color: #E60012;
  font-weight: 700;
  line-height: 1;
}
.main-wrap .perf-blk-head-l .titles .label {
  margin-bottom: 8px;
}
.main-wrap .perf-blk.bg-dark .perf-blk-head-l .titles .label { color: #ff5555; }
.main-wrap .perf-blk.bg-dark .perf-blk-head-l .titles .label::before { background: #ff5555; }
.main-wrap .perf-blk-head-l .titles h3 {
  font-size: 28px;
  font-weight: 800;
  margin: 0;
  letter-spacing: -0.5px;
  line-height: 1.2;
}
.main-wrap .perf-blk-head-l .titles h3 small {
  display: block;
  font-size: 13px;
  color: #888;
  font-weight: 400;
  margin-top: 8px;
  letter-spacing: 0;
}
.main-wrap .perf-blk.bg-dark .perf-blk-head-l .titles h3 { color: #fff; }
.main-wrap .perf-blk.bg-dark .perf-blk-head-l .titles h3 small { color: rgba(255,255,255,0.6); }
.main-wrap .perf-blk-head-r {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 14px;
  letter-spacing: 3px;
  color: #aaa;
}
.main-wrap .perf-blk.bg-dark .perf-blk-head-r { color: rgba(255,255,255,0.4); }

/* 다크 블록의 카드 */
.main-wrap .perf-blk.bg-dark .perf-card {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.1);
  color: #fff;
}
.main-wrap .perf-blk.bg-dark .perf-card:hover {
  background: rgba(255,255,255,0.08);
  border-color: #E60012;
  box-shadow: 0 12px 30px rgba(230, 0, 18, 0.15);
}
.main-wrap .perf-blk.bg-dark .perf-card h4 { color: #fff; }
.main-wrap .perf-blk.bg-dark .perf-card .perf-num { color: #fff; }
.main-wrap .perf-blk.bg-dark .perf-card:hover .perf-num { color: #ff5555; }
.main-wrap .perf-blk.bg-dark .perf-card ul li { color: rgba(255,255,255,0.75); }
.main-wrap .perf-blk.bg-dark .perf-card ul li::before { color: #ff5555; }
.main-wrap .perf-blk.bg-dark .perf-card .perf-num small { color: rgba(255,255,255,0.5); }
.main-wrap .perf-blk.bg-dark .perf-card .perf-tag {
  background: #E60012;
  color: #fff;
}

/* 매장 판매 - 5개 카드 가로 스크롤 (한 줄) */
.main-wrap .perf-store-cards {
  display: flex;
  gap: 18px;
  padding-bottom: 14px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.main-wrap .perf-store-cards::-webkit-scrollbar { height: 6px; }
.main-wrap .perf-store-cards::-webkit-scrollbar-track {
  background: rgba(255,255,255,0.05);
  border-radius: 4px;
}
.main-wrap .perf-store-cards::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.18);
  border-radius: 4px;
}
.main-wrap .perf-store-svc {
  flex: 1 1 0;
  min-width: 240px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  overflow: hidden;
  transition: all .25s;
  display: flex;
  flex-direction: column;
}
.main-wrap .perf-store-svc:hover {
  border-color: #E60012;
  background: rgba(255,255,255,0.07);
  transform: translateY(-3px);
}
.main-wrap .perf-store-svc-img {
  height: 170px;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}
.main-wrap .perf-store-svc-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15,15,15,0.2) 0%, rgba(15,15,15,0.85) 100%);
  transition: background .35s;
}
.main-wrap .perf-store-svc:hover .perf-store-svc-img::after {
  background: linear-gradient(180deg, rgba(230,0,18,0.2) 0%, rgba(230,0,18,0.7) 100%);
}
.main-wrap .perf-store-svc-img .step-num {
  position: absolute;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 56px;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  bottom: 20px;
  left: 24px;
  z-index: 2;
  letter-spacing: -1px;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.main-wrap .perf-store-svc-body {
  padding: 24px 26px 28px;
  flex: 1;
}
.main-wrap .perf-store-svc-body h4 {
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 12px;
  color: #fff;
  letter-spacing: -0.3px;
  line-height: 1.4;
}
.main-wrap .perf-store-svc-body p {
  font-size: 14.5px;
  color: rgba(255,255,255,0.7);
  line-height: 1.75;
  margin: 0;
}

/* 거래 브랜드 - 카드 그리드 아래 한 줄 */
.main-wrap .perf-brands-row {
  margin-top: 32px;
  padding: 24px 30px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
}
.main-wrap .perf-brands-row .lab {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 13px;
  letter-spacing: 2.5px;
  color: rgba(255,255,255,0.55);
  font-weight: 700;
  flex: none;
  white-space: nowrap;
}
.main-wrap .perf-brands-row .brand-list {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  flex: 1;
}
.main-wrap .perf-brands-row .brand-list span {
  padding: 10px 18px;
  background: rgba(255,255,255,0.08);
  border-radius: 4px;
  font-size: 14px;
  color: #fff;
  font-weight: 600;
  letter-spacing: -0.2px;
  transition: background .2s;
}
.main-wrap .perf-brands-row .brand-list span:hover {
  background: rgba(255,255,255,0.18);
}

/* responsive */
@media (max-width: 1100px) {
  .main-wrap .perf-highlight,
  .main-wrap .perf-blk { padding: 70px 30px; }
  .main-wrap .perf-highlight-stats { grid-template-columns: repeat(2, 1fr); gap: 30px 20px; }
  .main-wrap .perf-highlight-stat { border-right: none; padding: 0; }
  .main-wrap .perf-highlight-stat:nth-child(1),
  .main-wrap .perf-highlight-stat:nth-child(2) { border-bottom: 1px solid #eee; padding-bottom: 30px; }
  .main-wrap .perf-highlight-stat .num { font-size: 48px; }
  .main-wrap .perf-blk-head { flex-direction: column; align-items: flex-start; gap: 20px; }
  .main-wrap .perf-blk-bgtext { font-size: 130px; right: -20px; top: 30px; }
  .main-wrap .perf-store { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .main-wrap .perf-highlight-stats { grid-template-columns: 1fr; }
  .main-wrap .perf-highlight-stat:nth-child(3) { border-bottom: 1px solid #eee; padding-bottom: 30px; }
  .main-wrap .perf-brands-grid { grid-template-columns: 1fr; }
}


/* ============================================
   GREETING PAGE — REDESIGN
   ============================================ */

/* 메시지 인트로 (가운데) */
.main-wrap .greeting-intro {
  text-align: center;
  max-width: 820px;
  margin: 0 auto 56px;
}
.main-wrap .greeting-intro .label { justify-content: center; }
.main-wrap .greeting-intro h2 {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.4;
  margin: 0 0 18px;
  color: #1a1a1a;
}
.main-wrap .greeting-intro h2 .accent {
  color: #E60012;
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  line-height: inherit;
}
.main-wrap .greeting-intro .lead {
  font-size: 19px;
  color: #555;
  line-height: 1.7;
  margin: 0;
  font-weight: 400;
}

/* 큰 와이드 이미지 */
.main-wrap .greeting-image {
  width: 100%;
  aspect-ratio: 16 / 7;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  margin: 0 0 70px;
}

/* 인사말 본문 (가운데) */
.main-wrap .greeting-message {
  max-width: 820px;
  margin: 0 auto;
}
.main-wrap .greeting-message p {
  font-size: 16px;
  line-height: 1.95;
  color: #555;
  margin: 0 0 20px;
  font-weight: 400;
}
.main-wrap .greeting-message .signature {
  margin-top: 44px;
  padding-top: 26px;
  border-top: 1px solid #eee;
  font-size: 14px;
  color: #888;
  text-align: right;
}
.main-wrap .greeting-message .signature strong {
  color: #1a1a1a;
  font-size: 18px;
  margin-left: 10px;
  font-weight: 800;
}

/* 회사 개요 (이미지 배경 섹션) */
.main-wrap .company-overview-section {
  background: linear-gradient(rgba(20,20,20,0.55), rgba(20,20,20,0.7)),
              url('https://images.unsplash.com/photo-1556761175-b413da4baf72?w=1800&q=80') center/cover no-repeat;
  background-attachment: fixed;
  padding: 110px 80px;
  position: relative;
}
.main-wrap .company-overview-section .section-head h2 { color: #fff; }
.main-wrap .company-overview-section .section-head .label { color: #ff5555; }
.main-wrap .company-overview-section .section-head .label::before { background: #ff5555; }
.main-wrap .company-overview-inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.main-wrap .company-overview {
  background: #fff;
  border-radius: 8px;
  padding: 50px 60px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.25);
}
.main-wrap .company-overview dl {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px 60px;
  margin: 0;
}
.main-wrap .company-overview .field {
  border-bottom: 1px solid #eee;
  padding-bottom: 20px;
}
.main-wrap .company-overview .field.full { grid-column: span 2; }
.main-wrap .company-overview dt {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 12px;
  letter-spacing: 2px;
  color: #999;
  margin-bottom: 10px;
  font-weight: 700;
}
.main-wrap .company-overview dd {
  margin: 0;
  font-size: 17px;
  color: #1a1a1a;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.3px;
}
.main-wrap .company-overview dd.txt-small {
  font-size: 14px;
  font-weight: 400;
  color: #555;
  line-height: 1.7;
}

@media (max-width: 1100px) {
  .main-wrap .greeting-intro h2 { font-size: 26px; }
  .main-wrap .greeting-intro .lead { font-size: 16px; }
  .main-wrap .greeting-image { aspect-ratio: 16/10; margin-bottom: 40px; }
  .main-wrap .company-overview-section { padding: 70px 30px; }
  .main-wrap .company-overview { padding: 36px 28px; }
  .main-wrap .company-overview dl { grid-template-columns: 1fr; gap: 22px; }
  .main-wrap .company-overview .field.full { grid-column: span 1; }
}


/* ============================================
   HISTORY PAGE — REDESIGN (시대별 + 가운데 정렬)
   ============================================ */
.main-wrap .history-wrap {
  position: relative;
  text-align: center;
}
.main-wrap .history-wrap::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 1px;
  background: #e5e5e5;
  transform: translateX(-50%);
}
.main-wrap .history-section { margin-bottom: 100px; }
.main-wrap .history-section:last-child { margin-bottom: 0; }

/* 시대 헤더 (큰 영문) */
.main-wrap .era-divider {
  text-align: center;
  margin-bottom: 50px;
  position: relative;
  z-index: 2;
}
.main-wrap .era-divider .era-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 88px;
  font-weight: 700;
  letter-spacing: -3px;
  line-height: 1;
  color: #1a1a1a;
  display: inline-block;
  padding: 0 40px;
  background: #fff;
}
.main-wrap .era-divider .era-name span { color: #E60012; }

/* 시대 헤더 (이미지 + 부제 + 설명) */
.main-wrap .era-head {
  text-align: center;
  margin-bottom: 70px;
  position: relative;
  z-index: 2;
}
.main-wrap .era-head .era-image {
  width: 100%;
  max-width: 1080px;
  aspect-ratio: 4 / 1;
  margin: 0 auto 36px;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
}
.main-wrap .era-head .era-title {
  font-size: 26px;
  font-weight: 800;
  margin: 0 0 16px;
  letter-spacing: -0.5px;
  color: #1a1a1a;
  background: #fff;
  display: inline-block;
  padding: 0 24px;
}
.main-wrap .era-head .era-desc {
  font-size: 16px;
  color: #666;
  line-height: 1.85;
  max-width: 720px;
  margin: 0 auto;
  background: #fff;
  padding: 0 30px;
}

/* 연도 이벤트 - 좌우 번갈아 */
.main-wrap .history-events { padding: 0; position: relative; }
.main-wrap .history-event {
  position: relative;
  padding: 26px 0;
  width: 50%;
  z-index: 2;
  box-sizing: border-box;
}
/* 홀수: 좌측 (텍스트 우측 정렬) */
.main-wrap .history-event:nth-child(odd) {
  text-align: right;
  padding-right: 56px;
  margin-right: auto;
}
/* 짝수: 우측 (텍스트 좌측 정렬) */
.main-wrap .history-event:nth-child(even) {
  text-align: left;
  padding-left: 56px;
  margin-left: 50%;
}
/* 점 - 라인 위 가운데에 */
.main-wrap .history-event::before {
  content: '';
  position: absolute;
  top: 38px;
  width: 14px;
  height: 14px;
  background: #E60012;
  border: 3px solid #fff;
  border-radius: 50%;
  z-index: 3;
  box-shadow: 0 0 0 1px #E60012;
}
.main-wrap .history-event:nth-child(odd)::before {
  right: -8px;
}
.main-wrap .history-event:nth-child(even)::before {
  left: -8px;
}
.main-wrap .history-event .ev-year {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 36px;
  color: #1a1a1a;
  font-weight: 700;
  line-height: 1;
  margin: 0 0 18px;
  letter-spacing: 1px;
}
.main-wrap .history-event ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.main-wrap .history-event ul li {
  font-size: 16px;
  color: #555;
  line-height: 1.85;
  padding: 4px 0;
}
.main-wrap .history-event ul li b {
  color: #1a1a1a;
  font-weight: 700;
}

@media (max-width: 1100px) {
  .main-wrap .era-divider .era-name { font-size: 60px; padding: 0 20px; }
  .main-wrap .era-head .era-title { font-size: 22px; }
  .main-wrap .era-head .era-image { aspect-ratio: 16 / 9; }
  .main-wrap .history-event .ev-year { font-size: 28px; }
}
@media (max-width: 800px) {
  .main-wrap .history-wrap::before { left: 20px; transform: none; }
  .main-wrap .history-event { width: 100%; }
  .main-wrap .history-event:nth-child(odd),
  .main-wrap .history-event:nth-child(even) {
    text-align: left;
    padding-left: 50px;
    padding-right: 0;
    margin-left: 0;
  }
  .main-wrap .history-event:nth-child(odd)::before,
  .main-wrap .history-event:nth-child(even)::before {
    left: 14px;
    right: auto;
  }
}


/* ============================================
   RECRUIT PAGE
   ============================================ */
.main-wrap .recruit-intro {
  text-align: center;
  max-width: 820px;
  margin: 0 auto 56px;
}
.main-wrap .recruit-intro .label { justify-content: center; }
.main-wrap .recruit-intro h2 {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.4;
  margin: 0 0 18px;
  color: #1a1a1a;
}
.main-wrap .recruit-intro h2 .accent {
  color: #E60012;
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  line-height: inherit;
}
.main-wrap .recruit-intro .lead {
  font-size: 19px;
  color: #555;
  line-height: 1.7;
  margin: 0;
  font-weight: 400;
}

.main-wrap .recruit-image {
  width: 100%;
  aspect-ratio: 16 / 7;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  margin: 0 0 70px;
}

/* 인재상 4개 카드 */
.main-wrap .talent-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 50px;
}
.main-wrap .talent-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 36px 26px;
  text-align: center;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}
.main-wrap .talent-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0;
  width: 100%; height: 3px;
  background: #E60012;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s;
}
.main-wrap .talent-card:hover::before { transform: scaleX(1); }
.main-wrap .talent-card:hover {
  transform: translateY(-4px);
  border-color: #1a1a1a;
  box-shadow: 0 14px 32px rgba(0,0,0,0.08);
}
.main-wrap .talent-card .talent-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 14px;
  letter-spacing: 2px;
  color: #999;
  margin-bottom: 18px;
  font-weight: 700;
}
.main-wrap .talent-card .talent-icon {
  width: 60px; height: 60px;
  margin: 0 auto 20px;
  background: #f5f5f5;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: #1a1a1a;
  transition: all .3s;
}
.main-wrap .talent-card:hover .talent-icon {
  background: #E60012;
  color: #fff;
  transform: rotate(-8deg) scale(1.05);
}
.main-wrap .talent-card h4 {
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 12px;
  letter-spacing: -0.3px;
}
.main-wrap .talent-card p {
  font-size: 14px;
  color: #666;
  line-height: 1.7;
  margin: 0;
}

/* 채용 절차 */
.main-wrap .recruit-process-wrap {
  background: #1a1a1a;
  padding: 100px 80px;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.main-wrap .recruit-process-wrap::before {
  content: 'PROCESS';
  position: absolute;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 220px;
  color: rgba(255,255,255,0.04);
  letter-spacing: -4px;
  white-space: nowrap;
  pointer-events: none;
  font-weight: 700;
  right: -40px;
  top: 50px;
  line-height: 1;
}
.main-wrap .recruit-process-inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.main-wrap .recruit-process-wrap .section-head h2 { color: #fff; }
.main-wrap .recruit-process-wrap .section-head .label { color: #ff5555; }
.main-wrap .recruit-process-wrap .section-head .label::before { background: #ff5555; }
.main-wrap .recruit-process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.main-wrap .recruit-process-step {
  text-align: center;
  padding: 0 16px;
  position: relative;
}
.main-wrap .recruit-process-step:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 55px;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, rgba(255,255,255,0.18) 50%, transparent 50%);
  background-size: 8px 1px;
  background-repeat: repeat-x;
  z-index: 0;
}
.main-wrap .recruit-process-step .step-circle {
  width: 110px; height: 110px;
  border: 2px solid #E60012;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto 22px;
  background: #1a1a1a;
  transition: all .35s;
  position: relative;
  z-index: 1;
}
.main-wrap .recruit-process-step:hover .step-circle {
  background: #E60012;
  transform: translateY(-6px);
  box-shadow: 0 14px 32px rgba(230, 0, 18, 0.35);
}
.main-wrap .recruit-process-step .step-tag {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 12px;
  letter-spacing: 1.8px;
  color: #888;
  transition: color .35s;
  line-height: 1;
  margin-bottom: 6px;
}
.main-wrap .recruit-process-step:hover .step-tag { color: rgba(255,255,255,0.9); }
.main-wrap .recruit-process-step .step-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 38px;
  color: #ff5555;
  font-weight: 700;
  line-height: 1;
  transition: color .35s;
}
.main-wrap .recruit-process-step:hover .step-num { color: #fff; }
.main-wrap .recruit-process-step h4 {
  font-size: 17px;
  font-weight: 800;
  margin: 0 0 10px;
  color: #fff;
  letter-spacing: -0.3px;
}
.main-wrap .recruit-process-step p {
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  line-height: 1.7;
  margin: 0;
}

/* 복리후생 */
.main-wrap .benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 50px;
}
.main-wrap .benefit-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 32px 28px;
  transition: all .25s;
}
.main-wrap .benefit-card:hover {
  border-color: #1a1a1a;
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.08);
}
.main-wrap .benefit-card .benefit-icon {
  font-size: 30px;
  color: #E60012;
  margin-bottom: 18px;
}
.main-wrap .benefit-card h4 {
  font-size: 17px;
  font-weight: 800;
  margin: 0 0 10px;
  letter-spacing: -0.3px;
}
.main-wrap .benefit-card p {
  font-size: 14px;
  color: #666;
  line-height: 1.7;
  margin: 0;
}

/* CTA */
.main-wrap .recruit-cta {
  background: linear-gradient(rgba(15,15,15,0.85), rgba(15,15,15,0.9)),
              url('https://images.unsplash.com/photo-1522071820081-009f0129c71c?w=1800&q=80') center/cover no-repeat;
  background-attachment: fixed;
  color: #fff;
  text-align: center;
  padding: 100px 80px;
  position: relative;
}
.main-wrap .recruit-cta h2 {
  font-size: 36px;
  font-weight: 800;
  margin: 0 0 16px;
  letter-spacing: -1px;
  color: #fff;
}
.main-wrap .recruit-cta p {
  font-size: 16px;
  color: rgba(255,255,255,0.75);
  margin: 0 0 36px;
  line-height: 1.75;
}
.main-wrap .recruit-cta-btns {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

@media (max-width: 1100px) {
  .main-wrap .recruit-intro h2 { font-size: 26px; }
  .main-wrap .recruit-image { aspect-ratio: 16/10; margin-bottom: 40px; }
  .main-wrap .talent-grid { grid-template-columns: repeat(2, 1fr); }
  .main-wrap .recruit-process-wrap { padding: 70px 30px; }
  .main-wrap .recruit-process-grid { grid-template-columns: repeat(2, 1fr); gap: 30px 20px; }
  .main-wrap .recruit-process-step:not(:last-child)::after { display: none; }
  .main-wrap .benefits-grid { grid-template-columns: repeat(2, 1fr); }
  .main-wrap .recruit-cta { padding: 70px 30px; }
  .main-wrap .recruit-cta h2 { font-size: 28px; }
}
@media (max-width: 700px) {
  .main-wrap .talent-grid,
  .main-wrap .benefits-grid { grid-template-columns: 1fr; }
  .main-wrap .recruit-process-grid { grid-template-columns: 1fr; }
}


/* ============================================
   PERFORMANCE PAGE — V3 REDESIGN (PDF 기반)
   ============================================ */

/* ===== 01 사업영역 4가지 - PDF 10페이지 ===== */
.main-wrap .perf-area-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.main-wrap .perf-area-card {
  display: grid;
  grid-template-columns: 240px 1fr;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid #eee;
  transition: all .3s;
}
.main-wrap .perf-area-card:hover {
  border-color: #1a1a1a;
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(0,0,0,0.10);
}
.main-wrap .perf-area-photo {
  position: relative;
  background-size: cover;
  background-position: center;
  min-height: 220px;
}
.main-wrap .perf-area-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(26,26,26,0.4) 0%, rgba(26,26,26,0.7) 100%);
}
.main-wrap .perf-area-photo .area-num {
  position: absolute;
  top: 22px;
  left: 24px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 56px;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -1px;
  z-index: 2;
}
.main-wrap .perf-area-text {
  padding: 32px 32px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.main-wrap .perf-area-text .area-en {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 13px;
  letter-spacing: 2.5px;
  color: #E60012;
  margin-bottom: 10px;
}
.main-wrap .perf-area-text h3 {
  font-size: 24px;
  font-weight: 800;
  margin: 0 0 12px;
  letter-spacing: -0.5px;
  color: #1a1a1a;
}
.main-wrap .perf-area-text p {
  font-size: 14px;
  color: #666;
  line-height: 1.7;
  margin: 0;
}

/* ===== 02 생산공정 사업장 - 가로형 카드 ===== */
.main-wrap .perf-site-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.main-wrap .perf-site-card {
  display: grid;
  grid-template-columns: 200px 1fr;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 6px;
  overflow: hidden;
  transition: all .25s;
}
.main-wrap .perf-site-card:hover {
  border-color: #1a1a1a;
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,0.08);
}
.main-wrap .perf-site-img {
  background-size: cover;
  background-position: center;
  min-height: 220px;
  position: relative;
}
.main-wrap .perf-site-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(26,26,26,0.5));
}
.main-wrap .perf-site-img .site-tag-img {
  position: absolute;
  top: 14px;
  left: 14px;
  background: #1a1a1a;
  color: #fff;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  border-radius: 3px;
  z-index: 2;
}
.main-wrap .perf-site-body {
  padding: 22px 24px;
}
.main-wrap .perf-site-body h4 {
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 12px;
  letter-spacing: -0.3px;
  line-height: 1.3;
}
.main-wrap .perf-site-body .site-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 36px;
  color: #1a1a1a;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 14px;
  border-bottom: 1px solid #eee;
  padding-bottom: 14px;
}
.main-wrap .perf-site-body .site-num small {
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 13px;
  color: #888;
  font-weight: 400;
  margin-left: 6px;
}
.main-wrap .perf-site-card:hover .site-num { color: #E60012; }
.main-wrap .perf-site-body ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.main-wrap .perf-site-body ul li {
  font-size: 13.5px;
  color: #666;
  padding: 3px 0 3px 16px;
  position: relative;
  line-height: 1.6;
}
.main-wrap .perf-site-body ul li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #999;
  font-weight: 700;
}

/* ===== 03 건물종합관리 - 본사 메인 + 빌딩 리스트 ===== */
.main-wrap .perf-flagship {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 32px;
  border: 1px solid #eee;
}
.main-wrap .perf-flagship-img {
  position: relative;
  background-size: cover;
  background-position: center;
  min-height: 360px;
}
.main-wrap .perf-flagship-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(15,15,15,0.3) 0%, rgba(15,15,15,0.7) 100%);
}
.main-wrap .perf-flagship-img .flagship-area {
  position: absolute;
  bottom: 30px;
  left: 36px;
  z-index: 2;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 80px;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -2px;
  text-shadow: 0 4px 16px rgba(0,0,0,0.5);
}
.main-wrap .perf-flagship-img .flagship-area small {
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 22px;
  color: #fff;
  margin-left: 6px;
  font-weight: 600;
}
.main-wrap .perf-flagship-img .flagship-tag-img {
  position: absolute;
  top: 30px;
  left: 36px;
  z-index: 2;
  background: #E60012;
  color: #fff;
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  font-family: 'Bebas Neue', sans-serif;
}
.main-wrap .perf-flagship-body {
  padding: 40px 44px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.main-wrap .perf-flagship-body .label { margin-bottom: 14px; }
.main-wrap .perf-flagship-body h3 {
  font-size: 26px;
  font-weight: 800;
  margin: 0 0 14px;
  letter-spacing: -0.5px;
}
.main-wrap .perf-flagship-body p {
  font-size: 14px;
  color: #666;
  line-height: 1.7;
  margin: 0 0 24px;
}
.main-wrap .perf-flagship-services {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.main-wrap .perf-flagship-services .svc {
  padding: 10px 8px;
  background: #f5f5f5;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  color: #1a1a1a;
}

/* 빌딩 테이블 */
.main-wrap .perf-buildings-table {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid #eee;
}
.main-wrap .perf-buildings-table table {
  width: 100%;
  border-collapse: collapse;
}
.main-wrap .perf-buildings-table thead th {
  background: #1a1a1a;
  color: #fff;
  padding: 16px 24px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-align: left;
}
.main-wrap .perf-buildings-table thead th:nth-child(2) { text-align: center; width: 140px; }
.main-wrap .perf-buildings-table tbody td {
  padding: 18px 24px;
  font-size: 14px;
  border-bottom: 1px solid #f0f0f0;
  color: #555;
}
.main-wrap .perf-buildings-table tbody tr:last-child td { border-bottom: none; }
.main-wrap .perf-buildings-table tbody tr:hover td { background: #fafafa; }
.main-wrap .perf-buildings-table tbody td:first-child {
  font-weight: 700;
  color: #1a1a1a;
}
.main-wrap .perf-buildings-table tbody td:nth-child(2) {
  text-align: center;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 22px;
  color: #E60012;
  font-weight: 700;
  letter-spacing: 0.5px;
}
.main-wrap .perf-buildings-table tbody td:nth-child(2) small {
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 12px;
  color: #888;
  font-weight: 400;
}

/* ===== 04 학교/연구·전시시설 ===== */
.main-wrap .perf-edu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.main-wrap .perf-edu-card {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 6px;
  overflow: hidden;
  transition: all .25s;
}
.main-wrap .perf-edu-card:hover {
  border-color: #1a1a1a;
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(0,0,0,0.08);
}
.main-wrap .perf-edu-img {
  height: 180px;
  background-size: cover;
  background-position: center;
  position: relative;
}
.main-wrap .perf-edu-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(26,26,26,0.5));
}
.main-wrap .perf-edu-img .edu-num {
  position: absolute;
  top: 16px;
  left: 18px;
  z-index: 2;
  background: #E60012;
  color: #fff;
  padding: 6px 12px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.5px;
  border-radius: 3px;
}
.main-wrap .perf-edu-body {
  padding: 22px 24px;
}
.main-wrap .perf-edu-body .edu-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  color: #888;
  letter-spacing: 1px;
  margin-bottom: 8px;
  padding: 3px 8px;
  background: #f5f5f5;
  border-radius: 3px;
}
.main-wrap .perf-edu-body h4 {
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 8px;
  letter-spacing: -0.3px;
  line-height: 1.4;
}
.main-wrap .perf-edu-body p {
  font-size: 13.5px;
  color: #666;
  margin: 0;
  line-height: 1.65;
}

/* ===== 05 매장판매 - 헥사곤 브랜드 ===== */
.main-wrap .perf-brands-hexa-wrap {
  margin-top: 32px;
  padding: 36px 0;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
}
.main-wrap .perf-brands-hexa-wrap .hexa-title {
  text-align: center;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 14px;
  letter-spacing: 3px;
  color: rgba(255,255,255,0.5);
  margin-bottom: 24px;
  font-weight: 700;
}
.main-wrap .perf-brands-hexa {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
  padding: 0 30px;
}
.main-wrap .hexa-brand {
  aspect-ratio: 1 / 1.15;
  clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
  background: rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: -0.3px;
  text-align: center;
  padding: 0 8px;
  transition: all .25s;
  cursor: default;
}
.main-wrap .hexa-brand:hover {
  background: #E60012;
  transform: scale(1.05);
}

/* 반응형 */
@media (max-width: 1100px) {
  .main-wrap .perf-area-grid { grid-template-columns: 1fr; }
  .main-wrap .perf-area-card { grid-template-columns: 180px 1fr; }
  .main-wrap .perf-site-grid { grid-template-columns: 1fr; }
  .main-wrap .perf-site-card { grid-template-columns: 160px 1fr; }
  .main-wrap .perf-flagship { grid-template-columns: 1fr; }
  .main-wrap .perf-flagship-img { min-height: 280px; }
  .main-wrap .perf-flagship-img .flagship-area { font-size: 56px; }
  .main-wrap .perf-edu-grid { grid-template-columns: repeat(2, 1fr); }
  .main-wrap .perf-brands-hexa { grid-template-columns: repeat(4, 1fr); padding: 0 20px; }
  .main-wrap .perf-buildings-table { overflow-x: auto; }
}
@media (max-width: 700px) {
  .main-wrap .perf-area-card,
  .main-wrap .perf-site-card { grid-template-columns: 1fr; }
  .main-wrap .perf-area-photo,
  .main-wrap .perf-site-img { min-height: 180px; }
  .main-wrap .perf-edu-grid { grid-template-columns: 1fr; }
  .main-wrap .perf-flagship-services { grid-template-columns: repeat(2, 1fr); }
  .main-wrap .perf-brands-hexa { grid-template-columns: repeat(2, 1fr); }
  .main-wrap .perf-buildings-table thead { display: none; }
  .main-wrap .perf-buildings-table tbody td { display: block; padding: 8px 24px; border: none; }
  .main-wrap .perf-buildings-table tbody tr { border-bottom: 1px solid #f0f0f0; padding: 14px 0; }
}





/* ============================================
   BUSINESS DETAIL PAGES — STATIC IMPACT REDESIGN
   ============================================ */

/* biz-intro: 좌측 이미지에 통계 박스 부착 */
.main-wrap .biz-intro-img {
  position: relative;
  aspect-ratio: 4/3;
}
.main-wrap .biz-intro-img .biz-intro-stat {
  position: absolute;
  bottom: -28px;
  right: -28px;
  background: #1a1a1a;
  color: #fff;
  padding: 28px 32px;
  border-radius: 6px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.25);
  z-index: 3;
}
.main-wrap .biz-intro-img .biz-intro-stat .num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 52px;
  color: #E60012;
  line-height: 1;
  font-weight: 700;
  letter-spacing: -1px;
}
.main-wrap .biz-intro-img .biz-intro-stat .num small {
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 16px;
  color: #fff;
  margin-left: 4px;
  font-weight: 600;
}
.main-wrap .biz-intro-img .biz-intro-stat .lab {
  font-size: 12px;
  color: rgba(255,255,255,0.65);
  letter-spacing: 1.5px;
  margin-top: 6px;
  font-family: 'Bebas Neue', sans-serif;
}

/* biz-services: hover 확대 제거, 정적 임팩트 */
.main-wrap .biz-services {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  margin-top: 60px;
}
.main-wrap .biz-service {
  background: #fff;
  border: 1px solid #eee;
  padding: 0;
  border-radius: 10px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 180px 1fr;
  transition: border-color .2s;
}
.main-wrap .biz-service:hover {
  border-color: #1a1a1a;
  box-shadow: 0 14px 36px rgba(0,0,0,0.06);
  transform: none;
}
.main-wrap .biz-service-img {
  width: 100%; height: 100%;
  border-radius: 0;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
  transition: none;
  min-height: 200px;
}
.main-wrap .biz-service-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(15,15,15,0.25) 0%, rgba(15,15,15,0.65) 100%);
  opacity: 1;
  transition: none;
}
.main-wrap .biz-service-img .svc-num {
  position: absolute;
  bottom: 18px;
  left: 22px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 38px;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  z-index: 2;
  text-shadow: 0 2px 12px rgba(0,0,0,0.3);
}
.main-wrap .biz-service:hover .biz-service-img { transform: none; }
.main-wrap .biz-service:hover .biz-service-img::after {
  background: linear-gradient(135deg, rgba(230,0,18,0.4) 0%, rgba(230,0,18,0.8) 100%);
  opacity: 1;
}
.main-wrap .biz-service-body {
  padding: 28px 30px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.main-wrap .biz-service-body h4 {
  font-size: 20px;
  font-weight: 800;
  margin: 0 0 10px;
  letter-spacing: -0.5px;
  line-height: 1.35;
}
.main-wrap .biz-service-body p {
  color: #555;
  font-size: 15px;
  line-height: 1.85;
  margin: 0;
  font-weight: 400;
}

/* biz-features: 특징 4가지 강조 */
.main-wrap .biz-features {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: #1a1a1a;
  border-radius: 10px;
  margin-top: 60px;
  padding: 50px 30px;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.main-wrap .biz-features::before {
  content: 'FEATURES';
  position: absolute;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 180px;
  color: rgba(255,255,255,0.04);
  letter-spacing: -3px;
  white-space: nowrap;
  pointer-events: none;
  font-weight: 700;
  right: -30px;
  bottom: -40px;
  line-height: 1;
}
.main-wrap .biz-feature {
  text-align: center;
  padding: 0 22px;
  border-right: 1px solid rgba(255,255,255,0.1);
  position: relative;
  z-index: 1;
}
.main-wrap .biz-feature:last-child { border-right: none; }
.main-wrap .biz-feature i {
  font-size: 32px;
  color: #ff5555;
  margin-bottom: 16px;
  display: inline-block;
}
.main-wrap .biz-feature h4 {
  font-size: 16px;
  font-weight: 800;
  margin: 0 0 8px;
  color: #fff;
  letter-spacing: -0.3px;
}
.main-wrap .biz-feature p {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  line-height: 1.7;
  margin: 0;
}

/* biz-records: 주요 실적 리스트 (대형 도급 사업장) */
.main-wrap .biz-records {
  margin-top: 60px;
}
.main-wrap .biz-records-head {
  text-align: center;
  margin-bottom: 36px;
}
.main-wrap .biz-records-head h3 {
  font-size: 26px;
  font-weight: 800;
  margin: 0 0 10px;
  letter-spacing: -0.5px;
}
.main-wrap .biz-records-head p {
  font-size: 14px;
  color: #888;
  margin: 0;
}
.main-wrap .biz-records-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.main-wrap .biz-record {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 6px;
  padding: 22px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.main-wrap .biz-record .ridx {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 26px;
  color: #ddd;
  font-weight: 700;
  line-height: 1;
  flex: none;
}
.main-wrap .biz-record .rtxt {
  font-size: 14px;
  color: #1a1a1a;
  font-weight: 700;
  letter-spacing: -0.3px;
  line-height: 1.45;
}
.main-wrap .biz-record .rtxt small {
  display: block;
  font-weight: 400;
  color: #777;
  font-size: 12px;
  margin-top: 3px;
}

/* biz-process: hover 효과 제거 */
.main-wrap .biz-process-step:hover .step-circle {
  background: #fff;
  transform: none;
  box-shadow: none;
}
.main-wrap .biz-process-step:hover .step-tag { color: #888; }
.main-wrap .biz-process-step:hover .step-num { color: #E60012; }

/* biz-detail: 큰 인용 박스 */
.main-wrap .biz-quote {
  background: #f7f7f7;
  border-left: 4px solid #E60012;
  padding: 30px 36px;
  margin: 40px 0;
  border-radius: 0 8px 8px 0;
}
.main-wrap .biz-quote p {
  font-size: 17px;
  color: #333;
  line-height: 1.8;
  margin: 0;
  font-weight: 500;
  letter-spacing: -0.3px;
}
.main-wrap .biz-quote p strong { color: #E60012; }

@media (max-width: 1100px) {
  .main-wrap .biz-intro-img .biz-intro-stat {
    right: 12px;
    bottom: -20px;
    padding: 18px 22px;
  }
  .main-wrap .biz-intro-img .biz-intro-stat .num { font-size: 38px; }
  .main-wrap .biz-service { grid-template-columns: 140px 1fr; }
  .main-wrap .biz-features { grid-template-columns: repeat(2, 1fr); gap: 30px 0; padding: 40px 20px; }
  .main-wrap .biz-feature { padding: 0 16px; }
  .main-wrap .biz-feature:nth-child(2) { border-right: none; }
  .main-wrap .biz-records-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .main-wrap .biz-services { grid-template-columns: 1fr; }
  .main-wrap .biz-service { grid-template-columns: 1fr; }
  .main-wrap .biz-service-img { min-height: 180px; }
  .main-wrap .biz-features { grid-template-columns: 1fr; }
  .main-wrap .biz-feature { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.1); padding-bottom: 30px; }
  .main-wrap .biz-feature:last-child { border-bottom: none; padding-bottom: 0; }
  .main-wrap .biz-records-grid { grid-template-columns: 1fr; }
}


/* ============================================
   RECRUIT PAGE — STATIC IMPACT (영에버써치 참고)
   ============================================ */

/* talent-card: hover 회전 제거, 정적 강한 비주얼 */
.main-wrap .talent-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 50px;
}
.main-wrap .talent-card {
  background: #1a1a1a;
  border: none;
  border-radius: 10px;
  padding: 0;
  text-align: left;
  position: relative;
  overflow: hidden;
  min-height: 340px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.main-wrap .talent-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.45;
  transition: none;
}
.main-wrap .talent-card.t1::before { background-image: url('https://images.unsplash.com/photo-1521737711867-e3b97375f902?w=600&q=80'); }
.main-wrap .talent-card.t2::before { background-image: url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=600&q=80'); }
.main-wrap .talent-card.t3::before { background-image: url('https://images.unsplash.com/photo-1556761175-b413da4baf72?w=600&q=80'); }
.main-wrap .talent-card.t4::before { background-image: url('https://images.unsplash.com/photo-1522071820081-009f0129c71c?w=600&q=80'); }
.main-wrap .talent-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15,15,15,0.1) 0%, rgba(15,15,15,0.95) 90%);
  z-index: 1;
}
.main-wrap .talent-card:hover {
  transform: none;
  border: none;
  box-shadow: 0 16px 36px rgba(0,0,0,0.18);
}
.main-wrap .talent-card-num {
  position: absolute;
  top: 22px;
  left: 24px;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 28px;
  color: #ff5555;
  font-weight: 700;
  letter-spacing: 2px;
  z-index: 2;
}
.main-wrap .talent-card-icon {
  position: absolute;
  top: 22px;
  right: 24px;
  width: 48px;
  height: 48px;
  background: rgba(230,0,18,0.85);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 22px;
  z-index: 2;
  transform: none;
  transition: none;
}
.main-wrap .talent-card-body {
  position: relative;
  z-index: 2;
  padding: 28px 26px 32px;
  color: #fff;
}
.main-wrap .talent-card-body .tag-en {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 12px;
  letter-spacing: 2.5px;
  color: #ff5555;
  margin-bottom: 8px;
}
.main-wrap .talent-card-body h4 {
  font-size: 22px;
  font-weight: 800;
  margin: 0 0 12px;
  color: #fff;
  letter-spacing: -0.3px;
  line-height: 1.3;
}
.main-wrap .talent-card-body p {
  font-size: 14px;
  color: rgba(255,255,255,0.8);
  line-height: 1.7;
  margin: 0;
}

/* benefit-card: hover 효과 제거 */
.main-wrap .benefit-card {
  border-radius: 10px;
  padding: 32px 28px;
  transition: border-color .2s;
}
.main-wrap .benefit-card:hover {
  border-color: #1a1a1a;
  transform: none;
  box-shadow: 0 12px 30px rgba(0,0,0,0.04);
}
.main-wrap .benefit-card .benefit-icon-wrap {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  background: rgba(230,0,18,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
}
.main-wrap .benefit-card .benefit-icon-wrap i {
  color: #E60012;
  font-size: 24px;
  margin: 0;
}

/* recruit-process-step: hover 제거 */
.main-wrap .recruit-process-step:hover .step-circle {
  background: #1a1a1a;
  transform: none;
  box-shadow: none;
}
.main-wrap .recruit-process-step:hover .step-tag { color: #888; }
.main-wrap .recruit-process-step:hover .step-num { color: #ff5555; }



/* ============================================
   BUSINESS DETAIL — 핵심 서비스 V5 (펼친 + 균형 + 좌우여백)
   ============================================ */

/* 좌우 여백 크게 키움 */
.main-wrap .sub-section {
  padding-left: 100px;
  padding-right: 100px;
}

.main-wrap .section-head h2 { font-size: 34px; }
.main-wrap .section-head h2 small { font-size: 16px; margin-top: 16px; }

.main-wrap .biz-services {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 36px;
  align-items: stretch;
}

.main-wrap .biz-service {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #ececec;
  border-radius: 16px;
  overflow: hidden;
  padding: 0;
  transition: all .35s;
}
.main-wrap .biz-service:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(0,0,0,0.10);
  border-color: transparent;
}

.main-wrap .biz-service-img {
  order: 1;
  width: 100%;
  height: 260px;
  background-size: cover;
  background-position: center;
  margin: 0;
  position: relative;
  border-radius: 0;
  min-height: 0;
}
.main-wrap .biz-service-img::after { display: none; }
.main-wrap .biz-service-img .svc-num { display: none; }

/* 제목 + 빨간 라인 */
.main-wrap .biz-service-head {
  order: 2;
  margin: 36px 36px 20px;
  padding: 0;
  border: none;
  display: flex;
  align-items: stretch;
  gap: 16px;
}
.main-wrap .biz-service-head::before {
  content: '';
  display: block;
  width: 5px;
  background: #E60012;
  border-radius: 3px;
  flex: none;
}
.main-wrap .biz-service-head h4 {
  font-size: 28px;
  font-weight: 800;
  margin: 0;
  letter-spacing: -0.5px;
  line-height: 1.3;
  color: #1a1a1a;
  flex: 1;
  padding: 4px 0;
}

/* 설명 - 제목과 정렬 */
.main-wrap .biz-service-desc {
  order: 3;
  font-size: 16px;
  color: #555;
  line-height: 1.85;
  margin: 0 36px 24px 57px;
  min-height: 0;
}

/* 주요업무 박스 - 컴팩트 + 항상 펼친 상태 */
.main-wrap .biz-service-info {
  order: 4;
  background: #f7f7f8;
  color: #333;
  padding: 22px 28px 24px;
  margin: 0 36px 36px;
  border-radius: 10px;
  margin-top: auto;
  overflow: visible;
}
.main-wrap .biz-service-info-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 0 14px;
  margin-bottom: 14px;
  border-bottom: 1px solid #e5e5e5;
  cursor: default;
}
.main-wrap .biz-service-info-head:hover { background: transparent; }
.main-wrap .biz-service-info-head .title {
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -0.3px;
  color: #1a1a1a;
}
.main-wrap .biz-service-info-head .badge {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #E60012;
  font-size: 0;
  transform: none !important;
}
.main-wrap .biz-service-info ul {
  list-style: none;
  padding: 0;
  margin: 0;
  max-height: none;
  overflow: visible;
  opacity: 1;
}
.main-wrap .biz-service-info.open ul {
  max-height: none;
  padding: 0;
}
.main-wrap .biz-service-info ul li {
  font-size: 14.5px;
  color: #444;
  padding: 5px 0 5px 16px;
  position: relative;
  line-height: 1.65;
}
.main-wrap .biz-service-info ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 13px;
  width: 6px;
  height: 6px;
  background: #E60012;
  border-radius: 50%;
}

/* 반응형 */
@media (max-width: 1300px) {
  .main-wrap .sub-section { padding-left: 60px; padding-right: 60px; }
}
@media (max-width: 1100px) {
  .main-wrap .sub-section { padding-left: 30px; padding-right: 30px; }
  .main-wrap .biz-services { grid-template-columns: 1fr; }
  .main-wrap .biz-service-head h4 { font-size: 24px; }
  .main-wrap .biz-service-img { height: 220px; }
  .main-wrap .section-head h2 { font-size: 28px; }
}
@media (max-width: 700px) {
  .main-wrap .biz-service-head { margin: 28px 24px 18px; }
  .main-wrap .biz-service-desc { margin: 0 24px 20px 45px; font-size: 15px; }
  .main-wrap .biz-service-info { margin: 0 24px 24px; padding: 20px 24px; }
}



/* 강제 정렬 보정 — 위 V5 CSS 다음에 추가 */
.main-wrap .biz-service-desc {
  margin-left: 57px !important;
  margin-right: 36px !important;
  padding-left: 0 !important;
}

.main-wrap .sub-section {
  padding-left: 100px !important;
  padding-right: 100px !important;
}

@media (max-width: 1300px) {
  .main-wrap .sub-section {
    padding-left: 60px !important;
    padding-right: 60px !important;
  }
}
@media (max-width: 1100px) {
  .main-wrap .sub-section {
    padding-left: 30px !important;
    padding-right: 30px !important;
  }
}
@media (max-width: 700px) {
  .main-wrap .biz-service-desc {
    margin-left: 45px !important;
    margin-right: 24px !important;
  }
}





/* ============================================
   PRODUCTION 페이지 — 생산도급 (jhcareer 기반)
   ============================================ */

/* 대상업무 박스 */
.main-wrap .prod-targets {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
.main-wrap .prod-target-item {
  background: #fff;
  border: 1px solid #ececec;
  border-left: 4px solid #E60012;
  padding: 24px 28px;
  border-radius: 6px;
  font-size: 16px;
  line-height: 1.75;
  color: #333;
  font-weight: 500;
}
.main-wrap .prod-target-item strong { color: #1a1a1a; font-weight: 800; }

/* 도급 형태 2개 카드 */
.main-wrap .prod-contracts {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
}
.main-wrap .prod-contract {
  background: #fff;
  border: 1px solid #ececec;
  padding: 40px 40px;
  border-radius: 14px;
  transition: all .25s;
}
.main-wrap .prod-contract:hover {
  border-color: #1a1a1a;
  box-shadow: 0 20px 44px rgba(0,0,0,0.06);
}
.main-wrap .prod-contract .ct-tag {
  display: inline-block;
  padding: 8px 20px;
  background: #1a1a1a;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  border-radius: 100px;
  margin-bottom: 18px;
  letter-spacing: -0.3px;
}
.main-wrap .prod-contract.accent .ct-tag { background: #E60012; }
.main-wrap .prod-contract h4 {
  font-size: 26px;
  font-weight: 800;
  margin: 0 0 14px;
  letter-spacing: -0.5px;
  color: #1a1a1a;
}
.main-wrap .prod-contract p {
  font-size: 15.5px;
  line-height: 1.85;
  color: #555;
  margin: 0;
}
.main-wrap .prod-contract p strong { color: #1a1a1a; font-weight: 700; }

/* 9단계 Flow 리스트 */
.main-wrap .prod-flow {
  display: grid;
  gap: 14px;
}
.main-wrap .prod-flow-item {
  background: #fff;
  border: 1px solid #ececec;
  border-radius: 10px;
  padding: 26px 32px;
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 24px;
  align-items: center;
  transition: all .25s;
}
.main-wrap .prod-flow-item:hover {
  border-color: #1a1a1a;
  box-shadow: 0 14px 36px rgba(0,0,0,0.06);
  transform: translateX(4px);
}
.main-wrap .prod-flow-item .step-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 60px;
  color: #E60012;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -1px;
}
.main-wrap .prod-flow-item h5 {
  font-size: 19px;
  font-weight: 800;
  margin: 0 0 8px;
  letter-spacing: -0.3px;
  color: #1a1a1a;
}
.main-wrap .prod-flow-item p {
  font-size: 14.5px;
  color: #555;
  margin: 0;
  line-height: 1.7;
}

@media (max-width: 1100px) {
  .main-wrap .prod-targets,
  .main-wrap .prod-contracts { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .main-wrap .prod-flow-item { grid-template-columns: 1fr; gap: 6px; padding: 22px 24px; }
  .main-wrap .prod-flow-item .step-num { font-size: 44px; }
}



/* PRODUCTION 9단계 계약 Process - 3x3 그리드 */
.main-wrap .prod-process-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.main-wrap .prod-process-card {
  background: #fff;
  border: 1px solid #ececec;
  border-radius: 12px;
  padding: 32px 30px;
  position: relative;
  transition: all .25s;
}
.main-wrap .prod-process-card:hover {
  border-color: #1a1a1a;
  box-shadow: 0 18px 40px rgba(0,0,0,0.06);
  transform: translateY(-3px);
}
.main-wrap .prod-process-card .step-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 44px;
  color: #E60012;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -1px;
  margin-bottom: 14px;
  display: block;
}
.main-wrap .prod-process-card h5 {
  font-size: 18px;
  font-weight: 800;
  margin: 0 0 10px;
  letter-spacing: -0.3px;
  color: #1a1a1a;
  line-height: 1.35;
}
.main-wrap .prod-process-card p {
  font-size: 14px;
  color: #666;
  margin: 0;
  line-height: 1.7;
}
@media (max-width: 1100px) {
  .main-wrap .prod-process-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .main-wrap .prod-process-grid { grid-template-columns: 1fr; }
}




/* PRODUCTION 9단계 카드 글씨 키움 - 최종 */
.main-wrap .prod-process-card {
  padding: 36px 36px !important;
}
.main-wrap .prod-process-card .step-num {
  font-size: 60px !important;
  margin-bottom: 18px !important;
}
.main-wrap .prod-process-card h5 {
  font-size: 22px !important;
  margin-bottom: 14px !important;
  line-height: 1.35 !important;
}
.main-wrap .prod-process-card p {
  font-size: 16px !important;
  line-height: 1.8 !important;
}


/* ============================================
   MAIN PAGE — clients-head 모바일 깨짐 보정
   ============================================ */
@media (max-width: 768px) {
  .main-wrap .clients-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    margin-bottom: 32px;
  }
  .main-wrap .clients-head h2 {
    font-size: 26px !important;
    line-height: 1.3;
  }
  .main-wrap .clients-head h2 small {
    display: block;
    margin-left: 0;
    margin-top: 6px;
    font-size: 13px;
  }
  .main-wrap .clients-head .slider-nav {
    align-self: flex-end;
  }
}