@charset "utf-8";

/* font-face */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Ubuntu:ital,wght@0,300;0,400;0,500;0,700;1,300;1,400;1,500;1,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100..900&display=swap');
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css");

@font-face {
    font-family: 'LINESeedKR-Bd';
    src: url('https://fastly.jsdelivr.net/gh/projectnoonnu/noonfonts_11-01@1.0/LINESeedKR-Bd.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
}
@font-face {
    font-family: 'LINESeedKR-Rg';
    src: url('https://cdn.jsdelivr.net/gh/wizfile/font/LINESeedKR-Rg.eot');
    src:url('https://cdn.jsdelivr.net/gh/wizfile/font/LINESeedKR-Rg.woff') format('woff');
    font-style: normal;
}

:root {
    --font-120: 120px;
    --lh-120: 120px;
    --font-100: 100px;
    --lh-100: 100px;
    --font-80: 80px;
    --lh-80: 80px;
    --font-70: 70px;
    --lh-70: 70px;
    --font-65: 65px;
    --lh-65: 65px;
    --font-60: 60px;
    --lh-60: 60px;
    --font-55: 55px;
    --lh-55: 55px;
    --font-48: 48px;
    --lh-48: 48px;
    --font-44: 44px;
    --lh-44: 44px;
    --font-40: 40px;
    --lh-40: 40px;
    --font-37: 37px;
    --lh-37: 37px;
    --font-35: 35px;
    --lh-35: 35px;
    --font-32: 32px;
    --lh-32: 32px;
    --font-30: 30px;
    --lh-30: 30px;
    --font-28: 28px;
    --lh-28: 28px;
    --font-25: 25px;
    --lh-25: 25px;
    --font-24: 25px;
    --lh-24: 25px;
    --font-20: 20px;
    --lh-20: 20px;
    --font-18: 18px;
    --lh-18: 18px;
    --font-17: 17px;
    --lh-17: 17px;
    --font-16: 16px;
    --lh-16: 16px;
    --font-14: 14px;
    --lh-14: 14px;
    --font-13: 13px;
    --lh-13: 13px;
    --acc-color: #005BAC;
    --dom-color: #0089DE;
    --sec-color: #1C86C9;
    --bas-color: #000;
    --font-inter: 'Inter', sans-serif;
    --font-pretendard: 'Pretendard Variable', sans-serif;
    --font-ubuntu: 'Ubuntu', sans-serif;
    --font-noto: 'Noto Sans KR', sans-serif;
    --font-line: 'LINESeedKR-Bd', sans-serif;
    --font-line-rg: 'LINESeedKR-Rg', sans-serif;

}

.scrollLock { overflow: hidden; }
div.inner_wrap { max-width: 1400px; width: 100%; margin: 0 auto; }

/* scroll Bar */
body::-webkit-scrollbar { width: 10px; }
body::-webkit-scrollbar-thumb { background-color: var(--dom-color); }
body::-webkit-scrollbar-track { background-color: #f9f9f9; }

div.mbnav { display: none; }

/* Header */
header#header_wrap { position: fixed; left: 0; top: 0; width: 100%; height: 120px; padding: 0 100px; display: flex; justify-content: space-between; align-items: center; z-index: 150; }

header#header_wrap > div#hd_left { width: 100%; max-width: 250px; transition: all 0.3s; }
header#header_wrap > div#hd_left.active { opacity: 0; visibility: hidden; }
header#header_wrap > div#hd_left a { display: inline-block; width: 100%; height: 100%; }
header#header_wrap > div#hd_left a > img { display: inline-block; width: 100%; height: 100%; object-fit: cover; }

header#header_wrap > div#hd_center { z-index: 300; transition: all 0.3s; margin-left: calc(50% - 250px); margin-right: auto; }
header#header_wrap > div#hd_center > div.menu_wrap { display: flex; flex-direction: column; justify-content: space-between; width: 60px; height: 60px; padding: 19px 13px; border-radius: 9999px; border: 1px solid #fff; cursor: pointer; transition: all 0.3s; }
header#header_wrap > div#hd_center > div.menu_wrap > span { position: relative; display: block; width: 100%; height: 2px; background-color: #fff; transition: all 0.3s; }
header#header_wrap > div#hd_center > div.menu_wrap.on > span:nth-of-type(1) { transform: rotate(45deg); top: 9px; }
header#header_wrap > div#hd_center > div.menu_wrap.on > span:nth-of-type(2) { opacity: 0; visibility: hidden; }
header#header_wrap > div#hd_center > div.menu_wrap.on > span:nth-of-type(3) { transform: rotate(-45deg); top: -9px; }


header#header_wrap > div#hd_right {/* width: fit-content; *//* height: 100%; *//* transition: all 0.1s; */}
header#header_wrap > div#hd_right.active { opacity: 0; visibility: hidden; display: none; }
header#header_wrap > div#hd_right > ul.hd_util { display: flex; justify-content: center; align-items: center; column-gap: 15px; width: 100%; height: 100%; }
header#header_wrap > div#hd_right > ul.hd_util > li > a { font-size: 14px; font-family: var(--font-pretendard); color: #fff; }

header#header_wrap.scrolled { background-color: rgba(255, 255, 255, 0.9); }
header#header_wrap.scrolled > div#hd_center > div.menu_wrap { border: 1px solid var(--acc-color); }
header#header_wrap.scrolled > div#hd_center > div.menu_wrap > span { background-color: var(--acc-color); }
header#header_wrap.scrolled > div#hd_right > ul.hd_util > li > a { color: var(--acc-color); }

/* footer */
footer { padding: 64.25px 0; background-color: #f5f5f5; }
footer > div { display: flex; align-items: center; column-gap: 70px; }
footer div.footer_logo > a { display:inline-block; width: 100%; height: 100%; }
footer div.footer_logo > a > img { display: inline-block; width: 100%; height: 100%; object-fit: cover; }
footer > div div#ft_link { display: flex; align-items: center; column-gap: 30px; margin-bottom: 28px; }
footer > div div#ft_link > a { display: inline-block; width: fit-content; font-family: var(--font-pretendard); font-weight: 400; font-size: 18px;; color: #333; transition: all 0.3s; }
footer > div div#ft_link > a:nth-of-type(2) { font-weight: 700; color: var(--acc-color); }

footer > div div.footer_info_wrap { display: flex; align-items: center; column-gap: 30px; margin-bottom: 7px; }
footer > div div.footer_info_wrap > p { font-family: var(--font-pretendard); font-weight: 400; font-size: 18px; color: #666; }

footer > div div#footer_copy > p { font-family: var(--font-pretendard); font-weight: 400; font-size: 18px; color: #666; }

@media screen and (max-width: 1410px){
    div.inner_wrap { padding: 0 30px; }
}

@media screen and (max-width: 1180px){

    footer > div div.footer_info_wrap { column-gap: 20px; }
    footer > div div#ft_link > a { font-size: 18px; }
    footer > div div.footer_info_wrap > p { font-size: 16px; }
    footer > div div#footer_copy > p { font-size: 16px; }

    footer > div div.footer_info_wrap { flex-wrap: wrap; row-gap: 10px; }
}

@media screen and (max-width: 1024px){
    header#header_wrap { padding: 0 30px; }
    header#header_wrap > div#hd_left { width: 20%; }
    header#header_wrap > div#hd_center { margin-left: 0; margin-right: 0; }
    div.inner_wrap { padding: 0 30px; }

    header#header_wrap {display: none;}
    div.mbnav{display: block;position:fixed;top:0;left:0;width:100%;z-index:100;/* overflow: hidden; */padding: 20px 0;background-color: transparent;}
    div.mbnav.scrolled { background-color: rgba(255, 255, 255, 0.9); }
    .mbnav .top-bar { display: flex; justify-content: space-between; align-items: center; padding: 0 15px; }
    .mbnav .top-bar .headlogo { display: block; width: fit-content; height: fit-content; padding-left: 0; }
    .mbnav .top-bar .headlogo img{width: 100%;}

    /* 토글 사이드바 버튼 아이콘 */
    .hambtn.menu_wrap { display: flex; flex-direction: column; justify-content: space-between; width: 40px; height: 40px; padding: 8px 4px; border-radius: 9999px; border: 1px solid #fff; cursor: pointer; transition: all 0.3s; z-index: 150; }
    .hambtn.menu_wrap > span { position: relative; display: block; width: 80%; height: 2px; background-color: #fff; transition: all 0.3s; margin: 0 auto; }

    .hambtn.menu_wrap > span:nth-of-type(1) { top: 3px; }
    .hambtn.menu_wrap > span:nth-of-type(3) { top: -3px; }

    div.mbnav.scrolled .hambtn.menu_wrap { border: 1px solid var(--acc-color); }
    div.mbnav.scrolled .hambtn.menu_wrap > span { background-color: var(--acc-color); }

    .hambtn.menu_wrap.active > span:nth-of-type(1) { top: 10px; transform: rotate(45deg); }
    .hambtn.menu_wrap.active > span:nth-of-type(2) { opacity: 0; visibility: hidden; }
    .hambtn.menu_wrap.menu_wrap.active > span:nth-of-type(3) { top: -10px; transform: rotate(-45deg); }

    .hambtn.menu_wrap.active { border: 1px solid #fff !important; }
    .hambtn.menu_wrap.active > span { background-color: #fff !important; }

    .sidebar { display: none; position:fixed; top:0; left:0; width:100%; height:100%; background-color:rgba(255,255,255,0); visibility:hidden; transition:visibility .5s, background-color .5s; }
    .sidebar.active { background-color:rgba(0, 91, 172, 0.5); visibility:visible; display: block; }

    /* 좌측 사이드바 */
    .rightside { position:fixed; top:0; right:-250px; width:250px; height:100%; background-color:rgba(0, 91, 172, 0.9); padding-top:100px; transition:left .5s; }
    .sidebar.active > .rightside {right:0;}

    .rightside > ul.hd_login { position: relative; padding-left: 15px; margin-top: 50px; }
    .rightside > ul.hd_login li a { font-size: 16px; color: #000 !important; transition: all 0.3s; }
    .rightside > ul.hd_login li:first-child { padding-right: 15px; border: none;}
    .rightside > ul.hd_login li:nth-of-type(2) { padding: 0 15px; }
    .rightside > ul.hd_login li.tnb_admin { padding-left: 15px; margin-top: 20px; border: none; }
    .rightside > ul.hd_login li:hover a { font-weight: 800; }

    .rightside > .menuBox ul > li{padding:15px; cursor: pointer;}

    .rightside > .menuBox ul > li > a { color: #fff; padding: 0; font-size: 16px; font-weight: 500; transition: all 0.3s; }
    .rightside > .menuBox ul > li:hover > a{color: #fff; font-weight: 800;}
    .rightside > .menuBox ul > li > a:not(:only-child)::after { content:"+"; width: 10px; float:right; }
    .rightside > .menuBox ul > li.active > a:not(:only-child)::after { content:"-"; }
    .rightside > .menuBox > ul ul { display:none; background-color:transparent; margin-top: 15px; border-top: 1px solid #fff; border-bottom: 1px solid #fff; }
    .rightside > .menuBox > ul > li > ul > a{ font-size: 14px; font-weight: 500; color: #fff; border-bottom: 0; font-family: 'Noto Sans KR' !important; display: block; padding: 5px 0; }
    .rightside > .menuBox > ul > li > ul > a:hover{color: var(--acc-color); background: transparent;}
    .rightside > .menuBox > ul ul ul {background-color:#dfdfdf;}
    .rightside > .menuBox ul > li.active > ul {display:block; padding:5px;}


}

@media screen and (max-width: 768px){

    .gnb_2dul { min-width: revert; }
    
    header#header_wrap { height: auto; padding: 20px 30px; }
    header#header_wrap > div#hd_center { order: 2; }
    header#header_wrap > div#hd_center > div.menu_wrap { width: 40px; height: 40px; padding: 8px 6px; justify-content: space-around; }
    header#header_wrap > div#hd_center > div.menu_wrap.on > span:nth-of-type(1) { top: 7px; }
    header#header_wrap > div#hd_center > div.menu_wrap.on > span:nth-of-type(3) { top: -7px; }

    header#header_wrap > div#hd_left { width: 30%; }
    header#header_wrap > div#hd_right { display: none; order: 1; }
    header#header_wrap > div#hd_right.active { display: block; opacity: 1; visibility: visible; margin-left: auto; margin-right: 30px; }

    footer { padding: 30px 0; }
    footer > div { flex-direction: column; justify-content: center; align-items: center; row-gap: 20px; text-align: center; }
    footer > div div#ft_link { justify-content: center; }
    footer > div div.footer_info_wrap { justify-content: center; }

    footer > div div#ft_link > a { font-size: 16px; }
    footer > div div.footer_info_wrap > p { font-size: 14px; }
    footer > div div#footer_copy > p { font-size: 14px; }
}


@media screen and (max-width: 550px){
    .mbnav .top-bar .headlogo img { width: 80%; }
}

@media screen and (max-width: 500px){

    div.inner_wrap { padding: 0 15px; }
    
    header#header_wrap { padding: 20px 15px; }
    header#header_wrap > div#hd_left { width: 40%; }
    
    header#header_wrap > div#hd_right.active { margin-right: auto; }

    footer div.footer_logo { width: 30%; }

    footer > div div#ft_link > a { font-size: 15px; }
    footer > div div#ft_link { column-gap: 10px; }
}


.lang {position:relative; display:flex;}
.lang button {-webkit-appearance: button; background-color: transparent; background-image: none; border:0;}
.lang button img:first-child {margin-right:9px;}
.lang .lang_list {position: absolute;top: 40px;left: -10px;width:72px;opacity:0;transition: all 0.3s ease 0s;clear: both;}
.lang .lang_list > li a {display: block;width: 100%;padding: 10px 0;background: #fff;font-family: "Pretendard Variable", sans-serif;text-align: center;transition: background-color 0.3s ease 0s;}
.lang .lang_list > li a:hover {background: var(--acc-color);color: #fff;}
.lang:hover .lang_list,
.lang button:hover ~ .lang_list, 
.lang_list:hover {opacity:1;}

@media screen and (max-width: 1024px){
    .mbnav .top-bar .lang {position: absolute;top: 0;bottom: 0;right: 70px;margin: auto;}
    .mbnav .top-bar .lang .lang_list {top: 60px;}
}
