@charset "utf-8";

body {color: #000;}

.section {position: relative;}
.section .wrap {width: 132rem; margin: 0 auto;}

.section .wrap2 {width: 132rem; margin: 0 auto; display: flex; justify-content: space-between; gap: 2.4rem;}
.section .wrap2 .lt {width: 87rem;}
.section .wrap2 .rt {width: calc(100% - 89.4rem);}

/** sec01 **/
.sec01 .main_visual {background: url(../images/main/main_visual.png) no-repeat center; height: 45rem; text-align: center; color: #fff; padding-top: 10.7rem;}
.sec01 .main_visual p {font-size: 1.8rem; font-weight: 400; line-height: 2.1rem; margin-bottom: 2.4rem;}
.sec01 .main_visual h2 {font-size: 5.2rem; font-family: 'GmarketSans'; font-weight: 100; line-height: 7.2rem;}
.sec01 .main_visual h2 span {font-weight: 700;}

/** sec02 **/
/* tab */
.tit_wrap {display: flex; justify-content: space-between; align-items: center; margin-bottom: 2.4rem;}
.tit_wrap h3 {font-size: 2.8rem;}
.tit_wrap .l_box {display: flex; align-items: center; gap: 3.2rem;}
.tit_wrap .l_box .tab.line > .tab_menu {border-bottom: 0; display: flex; gap: 1.6rem;}
.tit_wrap .l_box .tab.line > .tab_menu li {position:relative;min-width:inherit; font-size: 1.8rem; color: rgba(0, 0, 0, .4);}
.tit_wrap .l_box .tab.line > .tab_menu li.on {font-weight:700;}
.tit_wrap .l_box .tab.line > .tab_menu li.on::before {content:'';position:absolute;bottom: -.2rem; width: 100%;height: .2rem;}
.tit_wrap .l_box .tab.line > .tab_menu li a {padding: 0;}

.tit_wrap .r_box .navi {display: flex; align-items: center; gap: .8rem;}
.tit_wrap .r_box .navi .btn {position: inherit; margin-top: 0; min-width: 2.8rem; height: 2.8rem; border-radius: 50%; width: 2.8rem; padding: 0;}
.tit_wrap .r_box .navi .btn::after {content: none;}
.tit_wrap .r_box .navi .btn i {color: #636363 !important;}

.sec02 {background: #F3F6FB; padding: 14rem 0;}

.sec02 .quick_menu {width: 103.2rem; height: 15rem; position: absolute; top: -5rem; left: 50%; transform: translate(-50%);}
.sec02 .quick_menu ul {display: flex; align-items: center; justify-content: center; width: 100%; height: 10rem; background: #fff; font-size: 1.6rem; line-height: 1.8rem; gap: 7.95rem; border-radius: 1.2rem; border: .1rem solid #ddd;}
.sec02 .quick_menu ul li {width: 8.7rem; height: 100%;}
.sec02 .quick_menu ul li a {display: flex; flex-direction: column; justify-content: center; align-items: center; width: 100%; height: 100%; gap: 1.8rem; transition: .2s;}
.sec02 .quick_menu ul li.quick_c {width: 15rem; height: 15rem; color: #fff;}
.sec02 .quick_menu ul li.quick_c a {width: 100%; height: 100%; background: #0070FF; border-radius: 50%; border: .6rem solid #fff;}
.sec02 .quick_menu ul li.quick_c a i {color: #fff;}
.sec02 .quick_menu ul li a i {font-size: 3.2rem; font-weight: 400; color: #222; transition: .2s;}


.sec02 .wrap .ntc_wrap {display: flex; gap: 2.4rem;}
.sec02 .wrap .ntc_wrap > div {width: 50%;}

.sec02 .employ .list_box {background: #fff; border: .1rem solid #ddd; padding: 2.7rem 3.6rem; border-radius: 1.2rem; min-height: 38rem;}
.sec02 .employ .list_box ul li {border-bottom: .1rem solid #ddd;}
.sec02 .employ .list_box ul li a {display: flex; align-items: center; padding: 1.6rem 0 1.8rem; gap: 1.2rem; width: 100%; height: 100%;}
.sec02 .employ .list_box ul li:last-child {border-bottom: 0;}
.sec02 .employ .list_box ul li a p {display: flex; align-items: center; gap: 1.2rem; width: 48rem;}
.sec02 .employ .list_box ul li a p .tit {font-size: 1.8rem; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: calc(100% - 3.6rem);}
.sec02 .employ .list_box ul li a .status {font-size: 1.6rem; font-weight: 700;}
.sec02 .employ .list_box ul li a .new {font-size: 1.4rem; font-weight: 700; line-height: 2.4rem; border-radius: 50%; background: #F57F20; display: inline-block; width: 2.4rem; height: 2.4rem; text-align: center; color: #fff;}
.sec02 span.cp_bg {font-size: 1.6rem; font-weight: 600; line-height: 1.8rem; padding: .6rem 1.2rem; border-radius: .8rem;}
.sec02 span.cp_bg.large {background: rgba(0, 112, 255, 0.15); color: #0070FF;}
.sec02 span.cp_bg.venture {background: rgba(9, 192, 177, 0.15); color: #36B4A9;}
.sec02 span.cp_bg.small {background: rgba(131, 103, 255, 0.15); color: #676FFF;}

.sec02 .guide .guide_list {display: flex; flex-direction: column; gap: 2.4rem;}
.sec02 .guide .guide_list li {height: 17.8rem; background: #fff; border: .1rem solid #ddd; border-radius: 1.2rem;}
.sec02 .guide .guide_list li a {display: flex; align-items: center; justify-content: space-between; width: 100%; height: 100%; padding: 5rem;}
.sec02 .guide .guide_list li a p {position: relative; padding-left: 11.4rem;}
.sec02 .guide .guide_list li a p::before {content: ''; display: block; width: 5.4rem; height: 5.4rem; position: absolute; top: 50%; left: 0; transform: translateY(-50%);}
.sec02 .guide .guide_list li:nth-child(1) a p::before {background: url(../images/main/i_consult01.png) no-repeat center;}
.sec02 .guide .guide_list li:nth-child(2) a p::before {background: url(../images/main/i_consult02.png) no-repeat center;}
.sec02 .guide .guide_list li a p::after {content: ''; display: inline-block; width: .1rem; height: 1.9rem; background: #636363; position: absolute; top: 50%; left: 8.4rem; transform: translateY(-50%);}
.sec02 .guide .guide_list li a p strong {font-size: 2rem; line-height: 2.4rem; font-weight: 700; display: block; margin-bottom: 1.2rem;}
.sec02 .guide .guide_list li a p span {font-size: 1.6rem; line-height: 1.8rem;}
.sec02 .guide .guide_list li a .go {font-size: 1.6rem; line-height: 1.8rem; color: #0070FF; background: #F3F6FB; border-radius: 5rem; padding: 1.15rem 5rem 1.15rem 2rem; position: relative; transition: .2s;}
.sec02 .guide .guide_list li a .go::after {content: ''; display: inline-block; width: 1.45rem; height: .8rem; background: url(../images/main/i_arrow_right.png) no-repeat center; position: absolute; top: 50%; right: 2.55rem; transform: translateY(-50%);}


/** sec03 **/
.sec03 {padding: 15.5rem 0 8rem;}
.sec03 .banner {display: flex; align-items: center; background: #0070FF url(../images/main/consult_bn_bg.png) no-repeat right 14rem center; border-radius: 1.2rem; color: #fff; padding: 5.6rem 10rem; position: absolute; width: 132rem; top: -9rem; left: 50%; transform: translateX(-50%);}
.sec03 .banner strong {font-size: 3.4rem; font-weight: 700; margin-right: 4.8rem;}
.sec03 .banner span {color: rgba(255, 255, 255, .7); font-size: 1.8rem; font-weight: 400; line-height: 3rem;}

.sec03 .cls_swiper ul li {border-radius: 1.2rem; overflow: hidden; border: .1rem solid #ddd;}
.sec03 .cls_swiper ul li .profile {display: flex; align-items: center; gap: 1.6rem; padding: 2.4rem;}
.sec03 .cls_swiper ul li .profile .photo {width: 5.6rem; height: 5.6rem; border-radius: 50%; overflow: hidden; border: .1rem solid #fff; background: #ccc;}
.sec03 .cls_swiper ul li .profile .photo img {width: 100%; height: 100%; object-fit: cover;}
.sec03 .cls_swiper ul li .profile span {font-size: 1.8rem;}

.sec03 .cls_swiper ul li .intro {padding: 2.4rem; background: #F3F6FB; display: flex; flex-direction: column; gap: 5.4rem;}
.sec03 .cls_swiper ul li .intro .intro_txt {font-size: 1.8rem; line-height: 2.2rem; font-weight: 700; display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp: 3;}
.sec03 .cls_swiper ul li .intro .field_box {display: flex; align-items: center; gap: .8rem;}
.sec03 .cls_swiper ul li .intro .field_box .field {font-size: 1.6rem; line-height: 1.8rem; padding: .6rem 1.2rem; background: #fff; border-radius: .8rem; display: block; width: 8rem;}
.sec03 .cls_swiper ul li .intro .field_box p {width: calc(100% - 8.8rem); font-size: 1.6rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}

.sec04 { background: #FBFBFB; height: 8rem;}
.sec04 .wrap2 {background: url(../images/main/sec03_bg.png) no-repeat left 2rem; height: 100%; padding: 2rem 0; align-items: center;}
.sec04 .wrap2 .bn_wrap {display: flex; margin-left: auto; align-items: center; gap: 4.8rem;}
.sec04 .wrap2 .bn_wrap strong {font-size: 1.5rem; font-weight: 700; line-height: 1.8rem;}
.sec04 .wrap2 .bn_wrap ul {display: flex; gap: 8rem;}
.sec04 .wrap2 .bn_wrap ul li a {display: flex; align-items: center; gap: 2.8rem; font-size: 1.3rem; line-height: 1.8rem;}
.sec04 .wrap2 .bn_wrap ul li a::before {content: ''; display: inline-block; width: 10.6rem; height: 2.8rem; background: url(../images/common/header_logo.svg) no-repeat center; background-size: 100%;}

/** 반응형 **/
@media (hover: hover) {
    .sec02 .guide .guide_list li:hover a .go {background: #0070FF; color: #fff;}
    .sec02 .guide .guide_list li:hover a .go::after {background: url(../images/main/i_arrow_right_hv.png) no-repeat center;}

    .sec02 .quick_menu ul li:hover * {color: #0070FF;}
    .sec02 .quick_menu ul li.quick_c:hover a {background: #fff; color: #0070FF; border-color: #0070FF;}
    .sec02 .quick_menu ul li.quick_c:hover a i{ color: #0070FF;}

    .sec02 .employ .list_box ul li:hover a p .tit {text-decoration: underline;}
}

@media (max-width: 1320px) {    
}
@media (max-width: 1280px) {
    html {font-size: 75%;} /* 1rem = 12px */

    .section .wrap {width: 100%;}
    .tit_wrap h3 {font-size: 2.2rem;}
    
    .section .wrap2 {flex-direction: column; padding: 0 1.6rem; width: 100%;}
    .section .wrap2 .lt,
    .section .wrap2 .rt {width: 100%;}

    /** sec01 **/
    .sec01 .main_visual {height: 40rem; background-size: cover; padding-top: 14rem;}
    .sec01 .main_visual p {font-size: 1.5rem; margin-bottom: 1.2rem;}
    .sec01 .main_visual h2 {font-size: 2.6rem; line-height: 4rem;}

    /** sec02 **/
    .sec02 {padding: 28rem 1.6rem 14rem;}
    .sec02 .quick_menu {width: calc(100% - 3.2rem); height: inherit; top: -6rem;}
    .sec02 .quick_menu ul {height: 100%; padding: 7.3rem 3.6rem 4rem; gap: 2.4rem 1.6rem;}    
    .sec02 .quick_menu ul li {width: 25%;}
    .sec02 .quick_menu ul li.quick_c {position: absolute; top: -5.5rem; width: 11rem; height: 11rem; font-weight: 700;}
    .sec02 .quick_menu ul li a {font-size: 1.3rem; gap: 1.2rem; line-height: 1.8rem;}
    .sec02 .quick_menu ul li a i {font-size: 2.4rem; line-height: 3.6rem;}

    .sec02 .wrap .ntc_wrap {flex-direction: column; gap: 9rem;}
    .sec02 .wrap .ntc_wrap > div {width: 100%;}
    .sec02 .employ .list_box {padding: 1.2rem 2.4rem;}
    .sec02 .employ .list_box ul li a {flex-direction: column; align-items: flex-start; gap: .8rem; padding: 2.4rem 0}
    .sec02 .employ .list_box ul li a p {width: 100%;}
    .sec02 .employ .list_box ul li a p .tit {white-space: inherit; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; font-size: 1.6rem;}
    .sec02 .guide .guide_list {gap: 1.2rem;}
    .sec02 .guide .guide_list li {height: 13.2rem;}
    .sec02 .guide .guide_list li a {padding: 3.2rem 3rem;}
    .sec02 .guide .guide_list li a p {padding-left: 9.8rem;}
    .sec02 .guide .guide_list li a p::before {width: 4.8rem; height: 4.8rem; background-size: 100% !important;}
    .sec02 .guide .guide_list li a p::after {left: 7.3rem;}
    .sec02 .guide .guide_list li a p strong {font-size: 1.7rem;}
    .sec02 .guide .guide_list li a p span {font-size: 1.3rem;}

    /** sec03 **/
    .sec03 {padding-left: 1.6rem; padding-top: 8.5rem;}
    .sec03 .consult .tit_wrap {padding-right: 1.6rem;}
    .sec03 .banner {width: calc(100% - 3.2rem); padding: 3.8rem 2.4rem; background: #0070FF url(../images/main/consult_bn_bg.png) no-repeat right 2.4rem center;}
    
     /** sec04 **/
    .sec04 .wrap2 {background: none; flex-direction: row; justify-content: center;}
    .sec04 .wrap2 .bn_wrap {margin-left: initial;}
    .sec04 .wrap2 .bn_wrap strong {display: none;}
}


@media screen and (max-width: 768px) { 
    /* 모바일 버전 스타일 (태블릿 대비 모바일에서 달라지는 스타일) */
    html {font-size: 68.75%;} /* 1rem = 11px */

    .sec01 .main_visual {background: url(../images/main/mo_section_bg.png) no-repeat center; background-size: 100%;}
    
    .sec02 .quick_menu ul {flex-wrap: wrap;}    
    .sec02 .quick_menu ul li {width: calc(50% - .8rem);}

    .sec02 .guide .guide_list li a .go {display: none;}
    .sec03 .banner strong {display: none;}
    .sec03 .banner span {font-size: 1.3rem; line-height: 1.6rem;}
}

@media screen and (max-width: 480px) { 
    /* 모바일 버전 스타일2 (모바일 작은 화면에서 달라지는 스타일) */
    html {font-size: 62.5%;} /* 1rem = 10px */
    
    .tit_wrap .l_box .tab {display: none;}
    .sec03 .banner {padding: 3.8rem 2.4rem 3.8rem 12.7rem; background: #0070FF url(../images/main/consult_bn_bg.png) no-repeat left 2.4rem center; background-size: 7.7rem;}
    
    .sec04 .wrap2 .bn_wrap ul {gap: 5rem;}
    .sec04 .wrap2 .bn_wrap ul li a {flex-direction: column; gap: 1rem;}
}

@media screen and (max-width: 410px) { 
    /* 모바일 버전 스타일2 (모바일 작은 화면에서 달라지는 스타일) */

    .sec03 .banner {padding: 3.8rem 2.4rem 3.8rem 8.7rem; background: #0070FF url(../images/main/consult_bn_bg.png) no-repeat left 2.4rem center; background-size: 5rem;}
}