@charset "utf-8";

/*------------------------------------------------
    Common
------------------------------------------------*/
/* 스타일 */
html, body, div.layout { z-index: 1; position: relative; width: 100%; min-width: 1280px; height: 100%; min-height: 100%; } /* 2023-08-08 수정 */

.hidden { display: none !important; }

/*------------------------------------------------
   Header
------------------------------------------------*/
/* 스타일 */
.footer{
    margin-top: 0!important;
}
div.layout div.header { z-index: 500; position: fixed; top: 0; left: 0; width: 100%; min-width: 1280px;  height: 95px; text-align: center; background: #fff; font-family: "Pretendard";}
div.layout div.header div.header_wrap { margin: 0 auto;  width: 1440px; height: 100%; box-sizing: border-box; text-align: center; }
div.layout div.header div.header_wrap .logo { float: left; padding: 25px 70px 0 0; font-size: 0; height: 44px; } 
div.layout div.header div.header_wrap .logo img { height: 100%; } 
div.layout div.header div.header_wrap .logo .logo_white { display: none; } 
div.layout div.header div.header_wrap .logo .logo_basic { display: block; } 

div.layout div.header div.header_wrap .gnb { z-index: 100; position: relative; float: left; margin-left: 25px; height: 100%;}
div.layout div.header div.header_wrap .gnb .gnb_menu { position: relative; display: inline-block; height: 100%; }
div.layout div.header div.header_wrap .gnb .gnb_menu > button { -webkit-tap-highlight-color: rgba(255, 255, 255, 0); display: inline-block; padding: 0; border: none; box-sizing: border-box; -webkit-box-sizing: border-box; outline: none; appearance: none; -webkit-appearance: none; text-decoration: none; text-align: left; cursor: pointer; }
div.layout div.header div.header_wrap .gnb .gnb_menu > button { position: relative; padding: 12px 25px;  font-size: 18px; color: #424242; text-align: center; background: transparent; box-sizing: border-box; top:26px;}
div.layout div.header div.header_wrap .gnb .gnb_menu > button.is_active { font-weight: 500;  }
/* div.layout div.header div.header_wrap .gnb .gnb_menu > button.is_active:before { content: ''; position: absolute; display: block; left: 30px; bottom: 22px; width: calc(100% - 60px); height: 3px; border-radius: 2px; background: #0064DD; } */

div.layout div.header div.header_wrap .gnb:hover .gnb_menu > button.is_active:before { display: none; }

/*div.layout div.header div.header_wrap .gnb .gnb_menu:hover > button:before { content: ''; position: absolute; display: block; left: 30px; bottom: 13px; width: calc(100% - 58px); height: 3px; border-radius: 2px; background: #0064DD; } 메뉴 하단 */

/* div.layout div.header div.header_wrap .gnb .gnb_menu:hover > button.is_active:before { content: ''; position: absolute; display: block; left: 30px; bottom: 22px; width: calc(100% - 60px); height: 3px; border-radius: 2px; background: #0064DD; } */

div.layout div.header div.header_wrap .gnb .gnb_menu .depth_box { z-index: 100; display: none; position: absolute; top: 82%; width: 239px; padding:10px 0; border-radius: 8px; border: 1px solid #e4e4e4; background: #fff; box-shadow: 0 4px 30px rgba(0, 0, 0, 0.03); box-sizing: border-box; overflow: hidden; } /* 2023-03-28 수정 */
div.layout div.header div.header_wrap .gnb .gnb_menu .depth_box > button { -webkit-tap-highlight-color: rgba(255, 255, 255, 0); display: inline-block; padding: 0; border: none; box-sizing: border-box; -webkit-box-sizing: border-box; outline: none; appearance: none; -webkit-appearance: none; text-decoration: none; text-align: left; cursor: pointer; }
div.layout div.header div.header_wrap .gnb .gnb_menu .depth_box > button { padding: 5px 15px; width: 100%; height: 39px; font-size: 16px; color: #333; background: transparent; text-align: left; width: 92%;} 
div.layout div.header div.header_wrap .gnb .gnb_menu .depth_box > button:hover { color: #515e78; background: #f0f4fc; font-weight: bold;  border-radius: 8px; width: 92%;}  /* 2023-03-28 수정 #DBEBFF */
div.layout div.header div.header_wrap .gnb .gnb_menu .depth_box > button.is_active { font-weight: bold; color: #333333; background: #DBEBFF; }

div.layout div.header div.header_wrap .util { z-index: 100; position: relative; float: right; _height: 100%; box-sizing: border-box; }
div.layout div.header div.header_wrap .util { display: inline-block; vertical-align: top;  padding-top: 34px; } 
div.layout div.header div.header_wrap .util button { -webkit-tap-highlight-color: rgba(255, 255, 255, 0); display: inline-block; padding: 0; border: none; box-sizing: border-box; -webkit-box-sizing: border-box; outline: none; appearance: none; -webkit-appearance: none; text-decoration: none; text-align: left; cursor: pointer; background: none; }
div.layout div.header div.header_wrap .util button { position:relative; padding: 7px 20px; width: auto; font-size: 14px; font-weight: 500; text-align: center; color: #616161; } /* 2023-03-29(2) 수정 */
div.layout div.header div.header_wrap .util button:hover{border-radius: 8px; color: #424242; background: #f3f3f5;}

 /* div.layout div.header div.header_wrap .util button:last-child { padding-left: 0; }2023-03-29(2) 추가 */
div.layout div.header div.header_wrap .util button.extend { margin:0 20px 0 8px; padding:0; width: 50px; height: 28px; line-height:26px; border-radius: 50px; color: #616161; background: #fff; border: 1px solid #E4E4E4; box-sizing: border-box; } /* 2023-03-29(2) 수정 */
div.layout div.header div.header_wrap .util span.extend { color: #0064DD; }


/* white type*/
div.layout div.header.white_ty { background: transparent; border-color: transparent; }
div.layout div.header.white_ty div.header_wrap .logo .logo_white { display: block; } 
div.layout div.header.white_ty div.header_wrap .logo .logo_basic { display: none; } 
div.layout div.header.white_ty div.header_wrap .gnb .gnb_menu > button { color: #fff; }
div.layout div.header.white_ty div.header_wrap .util button { color: #fff; }
div.layout div.header.white_ty div.header_wrap .util button.extend { color: #616161; }
div.layout div.header.white_ty div.header_wrap .util span.extend { color: #fff; }

/* 기능 - header_wrap */
div.layout:not(.mobile) div.header:hover { background: #fff; border-color: #E4E4E4; }
div.layout div.header.is_active { background: #fff; border-color: #E4E4E4; }

/* 기능 - header_wrap : white type */
div.layout:not(.mobile) div.header.white_ty:hover div.header_wrap .logo .logo_white { display: none; }
div.layout:not(.mobile) div.header.white_ty:hover div.header_wrap .logo .logo_basic { display: block; }
div.layout div.header.white_ty:hover div.header_wrap .gnb .gnb_menu > button { color: #333; }
div.layout div.header.white_ty:hover div.header_wrap .util button { color: #333; }
div.layout div.header.white_ty:hover div.header_wrap .util button.extend { color: #616161; }
div.layout div.header.white_ty:hover div.header_wrap .util span.extend { color: #0064DD; }

/* 기능 - gnb */
div.layout div.header div.header_wrap .gnb .gnb_menu > button:hover { 
    font-weight: 500;     
    background: #f2f4f8;
    border-radius: 8px;
    color: #222;
}
div.layout div.header div.header_wrap .gnb .gnb_menu:hover > button { 
    font-weight: 500;     

}
div.layout div.header div.header_wrap .gnb .gnb_menu:hover .depth_box { display: block; }
/* div.layout div.header div.header_wrap .util button:hover { color: #0064DD; } */
div.layout div.header div.header_wrap .util button.extend:hover { color: #757575; background: #F3F3F5; }


/*------------------------------------------------
    Main
------------------------------------------------*/
div.layout div.main_container { width: 100%; min-height: calc(100% - 180px); box-sizing: border-box; }


/*------------------------------------------------
    Sub
------------------------------------------------*/
/* 회원가입*/
div.layout div.signin { position: relative; padding: 64px 40px 80px 40px; margin: 0 auto; width: 1280px; min-height: calc(100% - 180px); box-sizing: border-box; }

/* 로그인 */
div.layout div.login { position: relative; padding: 64px 40px 80px 40px; margin: 0 auto; width: 500px; min-height: calc(100% - 180px); box-sizing: border-box; } /* 2023-03-28 수정 */

/* 마이페이지 */
div.layout div.mypage { position: relative; padding: 64px 40px 80px 40px; margin: 0 auto; width: 1280px; min-height: calc(100% - 180px); box-sizing: border-box; }

/* 정책 - 개인정보처리방침, 이용약관 */
div.layout div.policy { position: relative; padding: 64px 40px 80px 40px; margin: 0 auto; width: 1280px; min-height: calc(100% - 180px); box-sizing: border-box; }
div.layout div.policy .section_area { border-top: 2px solid #000; box-sizing: border-box; margin-top: 34px; padding-top: 40px; font-size: 16px; }


/*------------------------------------------------
    Container
------------------------------------------------*/
/* 스타일 */
div.layout div.container { position: relative; padding: 64px 40px 80px 0; margin: 0 auto; width: 1280px; min-height: calc(100% - 180px); box-sizing: border-box; }
div.layout div.container .contents_title { position: relative; padding-top: 60px; font-size: 32px; font-weight: 700; text-align: left; }
div.layout div.container .section_area { margin-top:40px;}


/* LNB */
div.layout div.container div.lnb_wrap { z-index: 90; position: absolute; top: 64px; left: 40px; padding-right: 40px; width: 240px; box-sizing: border-box; } 
div.layout div.container div.lnb_wrap div.lnb { padding-top: 60px; padding-bottom: 70px; } 
div.layout div.container div.contents_wrap { padding-left: 280px; }

div.lnb .lnb_title { border-top: 2px solid #000;  padding: 16px 20px; font-size: 18px; font-weight: 700; color: #333; border-bottom: 1px solid #E4E4E4; box-sizing: border-box; }
div.lnb .lnb_menu { background: #FAFAFA; padding: 20px 40px; border-bottom: 1px solid #E4E4E4; }
div.lnb .lnb_menu button { -webkit-tap-highlight-color: rgba(255, 255, 255, 0); display: inline-block; padding: 0; border: none; box-sizing: border-box; -webkit-box-sizing: border-box; outline: none; appearance: none; -webkit-appearance: none; text-decoration: none; text-align: left; cursor: pointer; }

/* 2뎁스 */
div.lnb .lnb_menu > .list { padding-top: 12px; }
div.lnb .lnb_menu > .list:first-child { padding-top: 0; }
div.lnb .lnb_menu > .list > button.title { position: relative; width: 100%; font-size: 16px; line-height: 23px; color: #616161; background: transparent; }
div.lnb .lnb_menu > .list > button.title.is_active { color: #333; font-weight: 700; }
div.lnb .lnb_menu > .list > button.title:hover { color: #333; font-weight: 700; }

/* LNB없는 페이지 */
div.layout div.container.no_lnb { position: relative; padding: 64px 40px 80px 40px !important; margin: 0 auto; width: 680px; min-height: calc(100% - 180px); box-sizing: border-box; }
div.layout div.container.no_lnb .section_area { margin-top: 0;}
div.layout div.container.no_lnb div.contents_wrap { padding-left: 0; }


/* 브래드크럼 */
.breadcrumb_pack { position: absolute; top: 68px; right: 0; text-align: right; font-size: 14px; color: #9e9e9e; font-weight: 400; }
.breadcrumb_pack .navi_path { display: inline-block; vertical-align: center; }
.breadcrumb_pack .navi_path span { display: inline-block; }
.breadcrumb_pack .navi_path span + span { padding-left: 24px; background: url('../image/common/ic_arrow_next.svg') no-repeat 0 1px; background-size: 20px 20px; }
.breadcrumb_pack .navi_path span:first-child { margin-bottom: -4px; text-indent: 10000px; width: 20px; height: 20px; background: url('../image/common/ic_home.svg') no-repeat center; background-size: 20px 20px; overflow: hidden; }
.breadcrumb_pack .navi_path span:last-child { font-weight: 500; color: #333; }
.breadcrumb_pack .navi_path + .navi_path { margin-left: 10px; }
 




/*------------------------------------------------
    Footer
------------------------------------------------*/
/* 스타일 */
/* div.layout div.footer { position: relative; width: 100%; background: #F3F3F5; box-sizing: border-box; } */
div.footer div.footer_wrap .footer_menu { width:100%; height:53px; text-align: center; border-bottom: 1px solid #E3E8EB; box-sizing: border-box; }
div.footer div.footer_wrap .footer_menu:after { content: ''; display: block; clear: both; font-size: 0; }
div.footer div.footer_wrap .footer_menu > div {  display: inline-block; width: 1200px; padding: 0 40px; }
div.footer div.footer_wrap .footer_menu .menu_list { float: left; }
div.footer div.footer_wrap .footer_menu .menu_list button { -webkit-tap-highlight-color: rgba(255, 255, 255, 0); display: inline-block; padding: 0; border: none; box-sizing: border-box; -webkit-box-sizing: border-box; outline: none; appearance: none; -webkit-appearance: none; text-decoration: none; text-align: left; cursor: pointer; }
div.footer div.footer_wrap .footer_menu .menu_list button { position: relative; padding: 0 20px; height: 53px; line-height: 53px; font-size: 14px; color: #333333; background: transparent; }
div.footer div.footer_wrap .footer_menu .menu_list button + button:before { content: ''; display: block; position: absolute; top: 50%; left: 0; margin-top: -6px; width: 1px; height: 12px; background: #E4E4E4; }
div.footer div.footer_wrap .footer_menu .menu_list button:first-child { padding-left: 0; }
div.footer div.footer_wrap .footer_menu .menu_list button:last-child { padding-right: 0; }
div.footer div.footer_wrap .footer_menu .family_site { float: right; }
div.footer div.footer_wrap .footer_menu .menu_list button.btn_privacy { font-weight: bold; color: #0064DD; }

/* 패밀리사이트 */
div.footer .family_site .family_select { position: relative; display: inline-block; width: 173px; margin-top: 8px; } /* 2023-03-28 수정 */
div.footer .family_site .family_select button { -webkit-tap-highlight-color: rgba(255, 255, 255, 0); display: inline-block; padding: 0; border: none; box-sizing: border-box; -webkit-box-sizing: border-box; outline: none; appearance: none; -webkit-appearance: none; text-decoration: none; cursor: pointer; }
div.footer .family_site .family_select .family_title { display: block; height: 36px; border-radius: 22px; border: 1px solid #DDDDDD; color: #333; background-color: transparent; box-sizing: border-box; cursor: pointer; }
div.footer .family_site .family_select .family_title { text-align: left; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; width: 173px; padding: 0 40px 0 20px; height: 36px; line-height: 34px; font-size: 14px; border-radius: 8px; background: transparent url('../image/common/ic_arrow_up_bk.svg') no-repeat center right 12px; background-size: 16px 16px; outline: none;  } /* 2023-03-28 수정 */
div.footer .family_site .family_select .family_list { z-index: 100; overflow: hidden; display: none; position: absolute; bottom: 40px; left: -1px; right: -1px; max-height: 350px; border-radius: 8px; border: 1px solid #e0e0e0; background: #fff; box-sizing: border-box; } /* 2023-03-28 수정 */
div.footer .family_site .family_select .family_list .inner { overflow-y: auto; height: 100%; max-height: 300px; padding: 10px 0; box-sizing: border-box; }
div.footer .family_site .family_select .family_list .option { background: transparent; position: relative; padding: 0 0 0 20px; height: 26px; text-overflow: ellipsis; overflow: hidden; white-space: nowrap; width: 100%; color: #000; text-align: left; } /* 2023-03-28 수정 */
div.footer .family_site .family_select .family_list .option:hover { background: #fafafc; }
div.footer .family_site .family_select .family_list .option.selected { font-weight: 500; }

div.footer div.footer_wrap .footer_info { padding-top: 20px; text-align: center; height: 107px; }
div.footer div.footer_wrap .footer_info > div {  display: inline-block; width: 1200px; padding: 0 40px; }
div.footer div.footer_wrap .footer_info:after { content: ''; display: block; clear: both; }
div.footer div.footer_wrap .footer_info .logo { float: left; width: 132px; padding:12px 28px 0 0; text-align: left; }
div.footer div.footer_wrap .footer_info .logo.logo_white { display: block; }
div.footer div.footer_wrap .footer_info .logo.logo_dark { display: none; }
div.footer div.footer_wrap .footer_info .descript { float: left; position: relative; width: calc(100% - 160px); text-align: left; font-size: 14px; color: #333; }
div.footer div.footer_wrap .footer_info .descript .dscr_right { position: absolute; top: 0; right: 0; text-align: right; }
div.footer div.footer_wrap .footer_info .descript .dscr_right > div { padding-top: 5px; line-height: 35px; font-weight: bold; font-size: 24px; color: #0064DD; }

/* dark type */
div.layout div.footer.dark_ty { background: #424242; font-weight: 400; }
div.footer.dark_ty div.footer_wrap .footer_menu { border-bottom: 1px solid #616161; }
div.footer.dark_ty div.footer_wrap .footer_menu .menu_list button { color: #fff; }
div.footer.dark_ty div.footer_wrap .footer_menu .menu_list button.btn_privacy { color: #A8D0FF; }
div.footer.dark_ty .family_site .family_select .family_title { color: #fff; background: transparent url('../image/common/ic_arrow_up_wh.svg') no-repeat center right 12px; }
div.footer.dark_ty div.footer_wrap .footer_info .logo.logo_white { display: none; }
div.footer.dark_ty div.footer_wrap .footer_info .logo.logo_dark { display: block; }
div.footer.dark_ty div.footer_wrap .footer_info .descript { color: #fff; }
div.footer.dark_ty div.footer_wrap .footer_info .descript .dscr_right > div { color: #fff; }

/* go top btn */
.go-top-btn-wrap { display:none; z-index:2; position: fixed; bottom: 80px; right: 10%; width: 60px; height: 60px; }
.go-top-btn-wrap .go-top-btn { display:block; width:100%; height:100%; padding-top:32px; background:#fff url('../image/common/ic_top.svg') no-repeat center 8px; text-align:center; color:#333333; font-size:14px; border: 1px solid #DEDEDE; border-radius:12px; box-sizing: border-box; }
.go-top-btn-wrap .go-top-btn:hover { background-color:#F3F3F5; }


/*------------------------------------------------
    Align (button, checkbox, radio)
------------------------------------------------*/
/* common */
.btn_align { padding-top: 44px !important; text-align: center; }
.btn_sub { padding-top: 12px !important; text-align: right; }

/* checkbox, radio */
.align_box .align_group { margin-top: -10px; margin-left: -16px; }
.align_box .align_group .radio_pack label { margin-top: 10px; margin-left: 16px; }
.align_box .align_group .checkbox_pack label { margin-top: 10px; margin-left: 16px; }



/*------------------------------------------------
    팝업
------------------------------------------------*/
/* 초기화 */
div.popup_area { z-index: 2; display: none; position: fixed; top: 0; right: 0; bottom: 0; left: 0; text-align: center; font-size: 0; } /* 2023-08-08 수정 */
div.popup_area.type_dim { background: rgba(0, 0, 0, 0.2); }
div.popup_area:before { content: ''; display: inline-block; height: 100%; vertical-align: middle; }

/* align */
div.popup_area div.popup_layer { z-index: 500; overflow: hidden; display: inline-block; position: relative; vertical-align: middle; text-align: left; box-sizing: border-box; }
div.popup_area div.popup_layer div.popup_body { box-sizing: border-box; }
div.popup_area div.popup_layer div.popup_body div.popup_container { -webkit-overflow-scrolling: touch; height: 100%; box-sizing: border-box; }
div.popup_area div.popup_layer div.popup_footer { z-index: 400; width: 100%; min-height: 20px; box-sizing: border-box; }
div.popup_area div.popup_layer div.popup_footer div.popup_btn_wrap { box-sizing: border-box; text-align: center; }

/* 스타일 */
div.popup_area { padding: 20px; }
div.popup_area div.popup_layer { max-width: 100%; width: 400px; max-height: 100%; border-radius: 8px; box-shadow: 0px 16px 48px rgba(0, 0, 0, 0.08); background: #ffffff; }
div.popup_area div.popup_layer div.popup_body div.popup_container { padding: 0 20px; }
div.popup_area div.popup_layer div.popup_body div.popup_container div.popup_contents { padding: 20px 0 17px 0; }
div.popup_area div.popup_layer div.popup_body div.popup_container div.popup_contents .popup_descript { font-size: 16px; line-height: 23px; text-align: center; }
div.popup_area div.popup_layer div.popup_footer div.popup_btn { padding: 0 20px 20px; }
div.popup_area div.popup_layer div.popup_footer div.popup_btn .btn_pack { text-align: center; }

/* 개인정보처리방침 - 이전개인정보처리방침 팝업 2023-08-08 */
div.privacy_area div.privacy_layer { position: absolute; transform: translateX(-50%); max-width: 100%; min-width: 987px; max-height: 850px; }
div.privacy_area div.privacy_layer div.popup_header { position: relative; padding: 0 20px; height: 52px; line-height: 52px; font-weight: bold; font-size: 20px; border-bottom: 1px solid #E4E4E4; }
div.privacy_area div.privacy_layer div.popup_header .header_close { position: absolute; top: 0; right: 0; width: 52px; height: 52px; border: 0; background: url('../image/common/ic_close_line.png') no-repeat center; background-size: 28px; text-indent: -1000px; overflow: hidden; cursor: pointer; }
div.privacy_area div.privacy_layer div.popup_body div.popup_container { overflow-y: scroll; max-height: 797px; padding: 0 28px; }
div.privacy_area div.privacy_layer div.popup_body div.popup_container div.popup_contents { padding: 28px 0 28px 0; }
div.privacy_area div.privacy_layer div.popup_body div.popup_container div.popup_contents .popup_descript { text-align: left; }

/* 스크롤 제어 */
.notScroll { overflow: hidden; width: 100%; height: 100%; touch-action:none; }

/* 서브페이지 레이아웃 */
.contents .contents_start_box{
    position: relative;
    padding: 60px 40px 100px 40px;
    margin: 0 auto;
    width: 1280px;
    min-height: calc(100% - 180px);
    box-sizing: border-box;
}