@charset "utf-8";
/* 시스템 사이트의 경우 :  메인+서브에 공통 적용되는 common.css 파일 추가해 메인+서브 공통부분, 서브에 적용되는 css 기재 / 메인에만 적용되는 main.css 추가해 메인 css 기재 */
/* 일반 사이트의 경우 : 메인+서브에 공통 적용되는 common.css 파일 추가해 메인+서브 공통부분 css / 메인에만 적용되는 main.css 추가해 메인 css 기재 / 서브에만 적용되는 sub.css 추가해 서브 css 기재 */
/* 시스템, 일반 사이트 공통 : 멤버십, 에러 등이 필요한 경우 퍼블 가이드 UI 요소에서 원하는 부분만 복사해서 common.css에 기재 */
/* basic.css, board.css에서 수정해서 사용할 것들은 common.css에 수정 css 적기 (basic, board 수정 X) */

body {word-break:break-all; color: #0F0F0F;}

/* button */
.btn {border-radius: .6rem; padding: 0 1.2rem !important;}
.btn.primary {background: #1571DA; color: #fff; border: 0 !important;}
.btn.secondary {background: #082D57; color: #fff; border: 0 !important;}
.btn.tertiary {background: #15AB9F; color: #fff; border: 0 !important;}
.btn.bd {background: #fff; border: .1rem solid #C2C2C2; color: #0F0F0F;}

.btn.sm {min-width: 5rem !important; height: 3.2rem !important; font-size: 1.5rem; font-weight: 500;}
.btn.md {min-width: 14.8rem !important; height: 4.8rem !important; font-size: 1.7rem; font-weight: 500;}
.btn.lg {min-width: 21.6rem !important; height: 5.6rem !important; font-size: 1.9rem; font-weight: 500;}

.btn_link::after {content: ''; display: inline-block; width: 1.6rem; height: 1.6rem; background: url(../images/icon/content/i_link_wh.svg) no-repeat center;}
.btn_logout::after {content: ''; display: inline-block; width: 1.6rem; height: 1.6rem; background: url(../images/common/i_logout.svg) no-repeat center;}
.btn_enlg::before {content: ''; display: inline-block; width: 1.6rem; height: 1.6rem; background: url(../images/common/i_enlarge.svg) no-repeat center;}

.btn.btn_excel {border-color: #005C32; color: #005C32; height: 4rem !important; background: url(../images/icon/file/ico_file_excel.svg) no-repeat 1.9rem 50% / auto 1.6rem; padding-left: 4.3rem !important; padding-right: 1.9rem !important;}
.btn.btn_save {height: 4rem !important; display: inline-flex; min-width: 14.4rem !important; justify-content: space-between; padding: 0 1.6rem !important;}
.btn.btn_save::after {content: ''; display: inline-block; width: 2.1rem; height: 2.1rem; background: url(../images/common/i_download.png) no-repeat center;}
.tbl .btn_upload {min-width: 11rem !important; border: .1rem solid #082D57; color: #082D57;}
.btn_upload::before {content:''; display: inline-block; width: 1.6rem; height: 1.6rem; background: url(../images/icon/content/i_upload.svg) no-repeat center;}
.btn_upload:focus {background-color: #F0F7FE !important;}

.btn:focus, .btn:focus-visible,
select:focus {outline: 0; box-shadow: inherit !important;}
.btn.btn_save:focus {background-color: transparent;}

.btn.primary:focus {background-color: #115AAE;}
.btn.secondary:focus {background-color: #04172C;}
.btn.tertiary:focus {background-color: #11897F;}
.btn.bd:focus {background-color: #F5F5F5;}

.btn.btn_excel:focus {background-color: #EBF2EF;}
.btn.btn_save:focus {border-color: #C2C2C2;}

.btn_wrap {text-align: center; margin-top: 4.8rem; display: flex; align-items: center; justify-content: center; gap: 1.2rem; flex-wrap: wrap;}
.btn_wrap:has(.btn_enlg) {display: none;}

/* select */
select {background: #fff url(../images/icon/content/ico_sel.svg) no-repeat right 1.2rem center; padding-left: 1.6rem;}
select.sm {height: 4rem; min-width: 14.4rem; border-radius: .6rem;}

.btn + select {margin-left: .3rem;}

/*** header ***/
#header {position: relative;height: 8rem;border-bottom: 1px solid #e4e4e4;background: #fff;z-index: 4999;}
#header .wrap {max-width: 162rem;margin: 0 auto;}
#header .logo * {display: block;}
#header .logo a {padding: 1.7rem 0 2.6rem;}
#header .utils ul {display: flex;align-items: center;}
#header .utils li + li {margin-left: 3rem;}
#header .utils a {display: inline-block;font-size: 1.4rem;font-weight: 400;line-height: 2.1rem;color: #2c2d2d;background: url(../images/common/i_login.png) no-repeat 0 50%;}
#header .gnb_bg {display: none;position: absolute;left: 0;width: 100%;border-top: 1px solid #dedede;background: #EFF7FF url(../images/common/dropdown_bg.png) no-repeat 0% 101%;box-shadow: 0.4rem 1.4rem 1rem 0rem rgba(0, 0, 0, 0.05);}
#header .gnb_bg::after {content: ''; display: block; width: 151.2rem; height: 100%; background: #fff; position: absolute; top: 0; right: 0; border-radius: 6rem 0 0 0;}
#header .gnb_area {overflow: hidden;position: relative;}

/** gnb **/
#wrapper:has(.sec01) #header .login_gnb {display: none;}
#wrapper:has(.login_section) #header .main_gnb {display: none;}
#wrapper:not(.login_section) #header #mo_gnb .login_util {display: none;}
#header .wrap {justify-content: flex-end;}
#header .gnb_area .wrap {display: flex;justify-content: space-between;align-items: center;}
#header .gnb {display: flex;position: relative;width: 100%; justify-content: center; gap: 1rem;}
#header .gnb > li {width: 16rem; height: 8rem;text-align: center;}
#header .gnb > li > a {display: flex;justify-content: center;align-items: center;height: 100%;font-size: 1.8rem;font-weight: 500;letter-spacing: -0.02em;text-align: center; position: relative; color: #1D1D1D;}
#header .gnb > li.link > a {gap: .8rem;}
#header .gnb > li.link > a::after {content: ''; display: block; width: 2rem; height: 2rem; background: url(../images/common/i_menu_link.svg) no-repeat center;}
#header .gnb > li.link.on > a::after {background: url(../images/common/i_menu_link_hv.svg) no-repeat center;}
#header .gnb > li.on > a {font-weight: 600; color: #1571DA;}
#header .gnb > li.on > a::before {content: ''; display: block; width: calc(100%); height: .3rem; background: #1571DA; position: absolute; bottom: 0;}
#header .gnb .gnb_txt {display: none;position: absolute;top: 8rem;padding: 3rem 0; text-align: left; width: 100%;}
#header .gnb .gnb_txt strong {display: block; font-size: 3.6rem;}
#header .gnb > li.on .gnb_txt {display: block;}
#header .gnb .dp2 {position: relative;padding: 2.9rem 0;font-size: 1.6rem;}
#header .gnb .dp2 li {display: flex;align-items: center;min-height: 4rem;}
#header .gnb .dp2 li a {display: block;width: 100%;padding: 1.1rem;font-size: 1.6rem;font-weight: 400;line-height: 2.4rem;color: #2c2c2c;letter-spacing: -0.04em;text-align: center;word-break: break-word;}
#header .gnb .dp2 li a:hover,
#header .gnb .dp2 li a:focus {font-weight: 500;color: #000;}

/* util */
#header .util {display: flex; align-items: center;}
#header .util .log {display: flex;}
#header .util span {font-size: 1.4rem; color: #1D1D1D; display: flex; align-items: center; margin-right: 1.6rem;}
#header .util span::before {content: ''; display: block; width: 1.6rem; height: 1.6rem; background: url(../images/common/i_time.svg); margin-right: .4rem;}
#header .util span strong {display: flex; align-items: center; color: #0C58BA; display: block; width: 5.7rem;}
#header .util span strong::before {content: ''; display: inline-block; width: .1rem; height: 1.2rem; background: #A3A7B1; margin: 0 .8rem;}
#header .util .btn_logout {margin-right: .8rem;}
#header .util .btn_menu {width: 2.4rem; height: 2.4rem; min-width: 2.4rem; background: url(../images/common/i_menu.svg) no-repeat center; border: 0; margin-left: 2.4rem; display: none;}
#header .util .btn_close {display: none; width: 2.4rem; height: 2.4rem; background: url(../images/common/i_close.svg) no-repeat center;}

/* mobile */
.mo_nav {position: fixed; top: 0; right: -100%; width: 100%; height: 100%; background: #fff; z-index: 10000; transition: right 0.3s ease; overflow-y: auto;}
.mo_nav.on {right: 0;}
.mo_nav .btn_close {background: url(../images/common/i_close.svg) no-repeat center; width: 2.4rem; height: 2.4rem; border: none;}


/*** footer ***/
#footer {background: #F4F7F9;}
#footer .wrap {width: 140rem; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; padding: 2.5rem 0;}
#footer .wrap .lt {display: flex; align-items: center;}
#footer .wrap .lt .logo {font-size: inherit;}
#footer .wrap .lt .logo a {display: block;}
#footer .wrap .lt .box {font-size: 1.6rem; color: #9AA1A6; margin-left: 6.4rem; line-height: 2.4rem;}
#footer .wrap .lt .box p + p {margin-top: .2rem;}
#footer .wrap .lt .box p br {display: none;}
#footer .wrap .family {width: 18.4rem; height: 4rem; background: #D8E1E8 url(../images/common/i_arrow_bottom.png) no-repeat 95%; border-radius: 1rem; border: 0; color: #71757E; font-size: 1.5rem;}

@media (hover: hover) and (min-width: 1024px) {  
    .btn.primary:hover {background-color: #115AAE;}
    .btn.secondary:hover {background-color: #04172C;}
    .btn.tertiary:hover {background-color: #11897F;}
    .btn.bd:hover {background-color: #F5F5F5;}
    .btn.btn_excel:hover {background-color: #EBF2EF;}  
    .btn.btn_save:hover {border-color: #c2c2c2;}
    .btn_upload:hover {background-color: #F0F7FE !important;}

    .search_basic .btn.btn_reset:hover {background-color: #F0F7FE;}
    .search_basic .btn.btn_search:hover {background-color: #04172C;}
}
@media screen and (max-width: 1440px) {

    /*** header ***/
    #header { padding: 0 1.6rem;}
    #header .gnb > li {width: 12rem;}

    /*** footer ***/
    #footer .wrap {width: 100%; padding: 2.4rem 2rem;}

}
@media screen and (max-width: 1320px) {    

    /*** footer ***/
    #footer .wrap .lt .box p br {display: block;}
}

@media screen and (max-width: 1280px) {    

    /*** header ***/
    #header {height: 5.6rem;}
    #header .gnb_area,
    #header .gnb_area .wrap {height: 100%;}
    #header .logo a {padding: 0;}
    #header .logo img {height: 2.326rem;}
    #header .gnb,
    #header .gnb_bg,
    #header .gnb_area .util span,
    #header .gnb_area .util .btn_logout,
    #header .gnb_area .util .btn_link,
    #header .gnb_txt {display: none;}

    #header .util .btn_menu {display: block;}
    
    #header .gnb .dp2 li a {font-size: 1.7rem; font-weight: 400; line-height: 2.6rem; padding: 1.3rem 2rem 1.3rem 4rem; text-align: left; position: relative;}
    #header .gnb .dp2 li a::before {content: ''; width: .4rem; height: .4rem; border-radius: 50%; display: inline-block; background: #000; position: absolute; top: 50%; transform: translateY(-50%); left: 2.6rem;}
    #header .gnb .dp2 li:first-child {margin-top: 1.2rem;}
    #header .gnb .dp2 li:last-child {margin-bottom: 1.2rem;}
    #header .gnb li.link .dp2 {display: none !important;}

    #header #mo_gnb ul {display: block;}
    #header #mo_gnb .util {flex-direction: column-reverse; align-items: inherit;}
    #header #mo_gnb .util .log {justify-content: space-between; padding: .8rem 2rem; border-top: .1rem solid #dbdbdb; border-bottom: .1rem solid #dbdbdb;}
    #header #mo_gnb .util .btn_link{width: 18.2rem; margin: 1rem 2rem; padding: 0 !important;}
    #header #mo_gnb .util .btn_menu {display: none;}
    #header #mo_gnb .util .btn_close {display: block; position: absolute; top: 1.6rem; right: 2rem;}
    #header #mo_gnb {display: flex; flex-direction: column-reverse;}
    #header #mo_gnb .gnb > li {width: 100%; height: 100%;}
    #header #mo_gnb .gnb > li > a {font-size: 1.9rem; line-height: 2.9rem; padding: 1.9rem 2rem; justify-content: space-between; border-bottom: .1rem solid #dbdbdb;}
    #header #mo_gnb .gnb > li > a::after {content: ''; display: block; width: 2.4rem; height: 2.4rem; background: url(../images/common/i_gnb_down.svg) no-repeat center; transition: .3s;}
    #header #mo_gnb .gnb > li.active > a::after {transform: rotate(180deg);}
    #header #mo_gnb .gnb > li:last-child > a::after {background: url(../images/common/i_menu_link.svg) no-repeat center;}
    #header #mo_gnb .gnb > li:last-child.active > a::after {transform: inherit;}
    #header #mo_gnb .gnb > li > ul.dp2 {background: #EFF7FF; height: 0; overflow: hidden; transition: height 0.3s ease, padding 0.3s ease; padding: 0;}
    #header #mo_gnb .gnb > li.active > ul.dp2 {border-bottom: .1rem solid #dbdbdb;}
    #header #mo_gnb .gnb > li.active > a {border-bottom: .1rem solid #000;}
}

@media screen and (max-width: 1024px) {
    html {font-size: 12px} /* 1rem = 12px */

    /*** footer ***/
    #footer .wrap {flex-direction: column-reverse; align-items: flex-start;}
    #footer .wrap .lt {display: block;}
    #footer .wrap .lt .logo {margin-top: 2rem;}
    #footer .wrap .lt .logo img {width: 19rem;}
    #footer .wrap .lt .box {margin-left: 0; margin-top: 1.4rem;}
    #footer .wrap .lt .box p {font-size: 1.2rem; line-height: 1.65rem;}
    #footer .wrap .lt .box p + p {margin-top: 0;}
    #footer .wrap .lt .box p br {display: block;}
    #footer .wrap .family {width: 100%;}
    
}

@media screen and (max-width: 767px) { 
    /* 모바일 버전 스타일 (태블릿 대비 모바일에서 달라지는 스타일) */
    html {font-size: 11px} /* 1rem = 11px */

}
@media screen and (max-width: 480px) { 
    /* 모바일 버전 스타일2 (모바일 작은 화면에서 달라지는 스타일) */
    html {font-size: 10px;} /* 1rem = 10px */
}

@media screen and (max-width: 350px) { 
    .btn_wrap .btn {min-width: 100% !important; margin-left: 0 !important; margin-top: 0 !important;}
}