@charset "UTF-8";
/*****************************************************************

Copyright C 그누위즈 테마 All rights reserved.
gnuwiz@naver.com & master@gnuwiz.com
본 페이지는 유료콘텐츠 그누위즈 테마 CSS입니다. 불법복제시 법적인 제제를 받으실 수 있습니다.
라이센스를 삭제하지 마세요. 라이센스 삭제시 불법 사용으로 간주될 수 있습니다.

******************************************************************/

/*페이지 로딩*/
#loading-screen {position: fixed;width: 100%;height: 100%;background: #fff;display: flex;flex-direction: column;justify-content: center;align-items: center;z-index:99999;}
.spinner {border: 2px solid rgba(0, 0, 0, .1);border-top-color: var(--main-color);border-radius: 50%;width: 50px;height: 50px;animation: spin 0.5s linear infinite;}
@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}


#hd{width:100vw;transition: all 0.3s ease;position: fixed;left: 0;top: 0;background:#fff;border-bottom: 1px solid #e8e8e8;z-index: 9999;}
#hd_wrapper {position:relative;margin:0 auto;width: calc(100vw - 80px);zoom:1}
#hd_wrapper .gnb-container{height:100px;}
#mob-gnb,#menu-btn{display: none;}
.logo{z-index: 100;width:300px;height:40px;transition: all .3s;}
#logo > a {position: relative;width: 100%;height: 100%;display: block;}
#logo > a > img {position: absolute;top: 50%;left: 0;transform:translateY(-50%);}
#hd_wrapper .hd_login{position:absolute;top:50%;right:50px;transform:translateY(-50%);text-transform: uppercase;font-size: 14px;transition: all .3s;}
#hd_wrapper .hd_login li {float:left;margin:0 5px;line-height:13px}
#hd_wrapper .hd_login li:first-child {border-left:0}
#hd_wrapper .hd_login li> a {position:relative; text-align:left;padding:5px 10px; font-size:12px;  color:#000; border-radius: 30px; background: rgba(0,0,0,0.05);border: 1px solid rgba(0,0,0,0.05);}
#hd_wrapper .hd_login li:first-child > a{color: #666;background: #fff;border: 1px solid #ddd;}
#hd_wrapper .hd_login a{color: #222;}

/*1차메뉴*/
#gnb{position:relative;display:flex;align-items:center;place-content:center;height: 100%;background: #fff;box-shadow: 0 15px 10px rgba(34, 34, 34, .02);}
#gnb .gnb_wrap > ul{display: flex;height: 100%;place-content:center;}
.gnb_1da{padding: 0;}
#gnb .gnb_1dli{position:relative;flex:1;display: flex;place-content: center;align-items: center;text-align: center;}
.gnb_1dli.gnb_al_li_plus .gnb_1da{position:relative;padding:0;transition: all 0.3s ease-in-out;}
.gnb_1dli.gnb_al_li_plus .gnb_1da:before {content: "";display: none;position: absolute;top: -10px;left: 50%;transform: translateX(-50%);width: 5px;height: 5px;border-radius: 100%;background: var(--main-color);}
.gw-side-menu-container01 > [class*="gw-side-menu-depth"] > button{border-radius: 50px;}

/*2차메뉴*/
#gnb .gnb_wrap {margin:0 auto;position:relative;width: 60%;height: 100%;}
.gnb_2dul_box {padding:20px 0;position:absolute;top:90px;left:50%;transform: translateX(-50%);z-index:99;width:100%;text-align:center;visibility:hidden;opacity:0;transition:all 0.3s cubic-bezier(0.4, 0, 1, 1);border-radius:20px;box-shadow:0px 10px 30px rgba(0, 0, 0, 0.25);}
.gnb_2dul_box:before{content:"";position:absolute; top:0px; left:0px; right:0px;height:0; border-radius: 20px;transition:all 0.3s cubic-bezier(0.4, 0, 1, 1);background: var(--main-color);}
.gnb_2dli{padding: 0 14px;}
a.gnb_2da{position:relative;z-index:10;display:block;padding:10px 0;color:#fff;line-height:1.3;opacity:0.7;font-size:14px;font-family:"NotoKr_M", sans-serif;transform:translateY(-20px);transition: all .3s;}
a.gnb_2da:after{content:"";display:block; width:0;height:2px;background:#fff;position:absolute;bottom:0;left: 50%;transform: translateX(-50%);transition: all .3s;}
a.gnb_2da:hover{opacity: 1;}
a.gnb_2da:hover:after{width: 100%;}

/*gnb_1dli 마우스를 올렸을 때*/
#gnb .hassub.on .gnb_1da{color:var(--main-color);}
#gnb .hassub.on .gnb_1da:before{display: block;}

/*2차 메뉴 활성화*/
.gnb_2dul.show .gnb_2dul_box{display:block;opacity: 1;visibility: visible;}
.gnb_2dul.show .gnb_2dul_box:before{height:100%;}
.gnb_2dul.show a.gnb_2da{transform: translateY(0);}


/* 햄버거메뉴 */
#menu-btn {display: inline-block;position: absolute;top:50%;right:0;transform:translateY(-50%);z-index:9999;width: 30px;height: 30px;transition: .1s;cursor: pointer;}
#menu-btn span {position: absolute;width: 5px;height: 5px;background: var(--main-color);display: block;border-radius: 50%;transition: all .3s cubic-bezier(.8, .5, .2, 1.4);}
#menu-btn:hover span{transform: scale(1.2);}
#menu-btn span:nth-child(1){left: 0;top: 0;opacity: 0.5;}
#menu-btn span:nth-child(2){left: 12px;top: 0;}
#menu-btn span:nth-child(3){right: 0;top: 0;opacity: 0.5;}
#menu-btn span:nth-child(4){left: 0;top: 12px;}
#menu-btn span:nth-child(5){position: absolute;left: 12px;top: 12px;opacity: 0.5;}
#menu-btn span:nth-child(6){right: 0px;top: 12px;}
#menu-btn span:nth-child(7){left: 0px;bottom: 0px;opacity: 0.5;}
#menu-btn span:nth-child(8){position: absolute;left: 12px;bottom: 0px;}
#menu-btn span:nth-child(9){right: 0px;bottom: 0px;opacity: 0.5;}
#menu-btn.active{transform:translateY(-50%) rotate(180deg);cursor: pointer;transition: .2s cubic-bezier(.8, .5, .2, 1.4);}
#menu-btn.active span{border-radius: 50%;transition-delay: 200ms;transition: .5s cubic-bezier(.8, .5, .2, 1.4);background: #fff;}
#menu-btn.active span:nth-child(2) {left: 6px;top: 6px;}
#menu-btn.active span:nth-child(4) {left: 6px;top: 18px;}
#menu-btn.active span:nth-child(6) {right: 6px;top: 6px;}
#menu-btn.active span:nth-child(8) {left: 18px;bottom: 6px;}

#mob-gnb {visibility: hidden;opacity: 0;display:block;position: fixed;top: 0;left: 0;z-index: 100;max-width: 100vw;width: 100%;height: 100vh;background: rgba(0, 0, 0, 0.5);backdrop-filter: blur(30px);transition: opacity 0.5s ease, visibility 0.5s ease;}
#mob-gnb .menu-list{width: 100%;height: 100%;display:flex;align-items:center;place-content:center;}
#mob-gnb .menu-list > ul {display: flex;place-content: center;width:100%;}
#mob-gnb .menu-list > ul > li {position:relative;flex: 1;text-align: center;opacity: 0;transform: translateY(-50px);transition: opacity 0.5s ease, transform 0.5s ease;}
#mob-gnb .menu-list > ul > li:not(:last-child):before {content: "";display: block;position: absolute;right: 0;top: -200%;height: 300vh;width: 1px;background: rgba(255,255,255,0.3);}
#mob-gnb .menu-list > ul > li:after {content: "";display: block;width: 100%;height: 300vh;background: var(--main-color);position: absolute;top: -200%;left: 0;opacity: 0;visibility: hidden;transition: all 0.3s;}
#mob-gnb .menu-list > ul > li:hover:after{opacity: 1;visibility: visible;}
#mob-gnb .menu-list > ul > li > .dep01{position: relative;z-index: 10;display:block;width: 100%;height:55px;line-height:55px;font-family:'NotoKr_B' , sans-serif; font-size: var(--main-title04);font-family: 'NanumSquareNeoExtraBold', sans-serif;color:#fff;transition: all .3s;}
#mob-gnb .menu-list > ul > li > .dep01 .hassub{display: inline-block;}
#mob-gnb .menu-list > ul > li > .dep01 .hassub:after {content: "";display: block;width: 0;height: 2px;background: #fff;position: absolute;bottom: 5px;left: 50%;transform: translateX(-50%);transition: all 0.3s;}
#mob-gnb .dep02 > li{position:relative;z-index:10;padding:0 40px;width: 100%;height: 45px;line-height: 45px;opacity: 0;transform: translateY(50px);transition: opacity 0.5s ease, transform 0.5s ease;}
#mob-gnb .dep02 > li a{display: block;width: 100%;color:rgba(255,255,255,0.5);font-family:'NotoKr_M' , sans-serif;transition:all .3s;}
#mob-gnb .menu-list > ul > li:hover > .dep01 .hassub:after{width: 100%;}
#mob-gnb .dep02 > li a:hover{color:rgba(255,255,255,1.0);}
.mob-hd-login{display: none;}

html.on,body.on{overflow: hidden;}
#logo.on{display: none;}
#mob-gnb.on {visibility: visible;opacity: 1;z-index: 999;}
#mob-gnb.on .menu-list > ul > li {opacity: 1;transform: translateY(0);}
#mob-gnb.on .dep02 > li{opacity: 1;transform: translateY(0);}



/*다크모드*/
body.dark-mode #hd{background: #111;border-bottom:1px solid #222;}
body.dark-mode #menu-btn span{background: #fff;}
body.dark-mode #gnb{background: #111;}
body.dark-mode .gnb_1da{color:rgba(255, 255, 255, 0.6);}
body.dark-mode  #gnb .gnb_1dli:hover > a {color:rgba(255, 255, 255, 1);}
body.dark-mode .gnb_1dli.active .gnb_1da{color:rgba(255, 255, 255, 1);}
body.dark-mode #gnb_all .gnb_al_li li a:hover{color:#fff;}
body.dark-mode #hd_wrapper .hd_login li> a{color:#fff;border: 1px solid rgba(255, 255, 255, 0.6);}
body.dark-mode #hd_wrapper .hd_login li:first-child > a{background:#333;}
body.dark-mode  #gnb .hassub.on:after{color: #fff;}
body.dark-mode .gnb_2dul{background: #111;}