@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;height:100px;transition: all 0.3s ease;position: fixed;left: 0;top: 0;z-index: 9999;background:#fff;}
#hd_wrapper {position:absolute;top:0;left:50%;transform:translateX(-50%);z-index:9999;width: calc(100vw - 80px);zoom:1}
#hd_wrapper .gnb-container{position:relative;height:100px;}
#mob-gnb,#menu-btn{display: none;}
.logo{z-index: 100;width:300px;height:40px;transition: all 0.4s ease-in-out;}
#logo > a {position: relative;width: 100%;height: 100%;display: block;}
#logo > a > img {position: absolute;top: 50%;left: 0;transform:translateY(-50%);}
#hd .gw-hd-right{position: relative;z-index: 100;}
#hd_wrapper .hd_login{display:flex;gap:0.5rem;text-transform: uppercase;font-size: 14px;transition: all 0.4s ease-in-out;}
#hd_wrapper .hd_login li {float:left;line-height:13px}
#hd_wrapper .hd_login li> a {padding:0 12px;position:relative;display: flex;align-items:center;justify-content:space-between;min-width: 90px;width:auto;height: 30px;border-radius: 30px; font-size:14px;  color:#000; font-weight:600;background: rgba(0,0,0,0.05);}

/* 햄버거메뉴 */
#menu-btn{position: relative; width:60px; height:33px; display:flex; flex-direction:column; justify-content: space-between; margin-left:20px; box-sizing:border-box;cursor: pointer;}
#menu-btn .gw-line{position: relative; top:0; display:block; width:100%; height:4px; background:#000;border-bottom:none; margin: 1px auto; transition:top 0.4s 0.4s, transform 0.4s 0s, background 0.4s ease-in-out;}
#menu-btn .gw-txt-box{position: absolute; top:50%; transform:translateY(-50%); display: block; width:100%; text-align:center; transition: height 0.4s 0.4s; overflow:hidden;}
#menu-btn .gw-txt{font-size:14px; line-height:2; font-weight:800; font-family:"Outfit", sans-serif;transition:all 0.4s ease-in-out;}
/* active */
#menu-btn.active{z-index:100000;}
#menu-btn.active .gw-txt-box{height:0; transition: height 0.4s 0s;}
#menu-btn.active .gw-txt-box .gw-txt{color:#fff !important;}
#menu-btn.active .gw-line{transition:top 0.4s 0s, transform 0.4s 0.4s; background:#fff !important;}
#menu-btn.active .gw-line:nth-child(1){top:13px;transform: rotate(45deg);}
#menu-btn.active .gw-line:nth-child(3){top:-13px;transform: rotate(-45deg);}

/*1차메뉴*/
#gnb{padding-left:310px;position:absolute;top:0;left:0;z-index:99;width:100%;height: 100%;box-shadow: 0 15px 10px rgba(34, 34, 34, .02);text-align: left;}
#gnb .gnb_wrap > ul{display: inline-block;height: 100%;}
.gnb_1da{padding: 0;}
#gnb .gnb_1dli{position:relative; float:left; word-break:keep-all;}
#gnb .gnb_1dli > a span{position:relative;}
#gnb .gnb_1dli > a span:before{content: ""; display: block; position: absolute; bottom: 0; left: 0; width: 100%; height: 2px; background: var(--main-color); transform-origin: 100% 50%; transition: transform .6s cubic-bezier(0.3, 0, 0.1, 1); transition-delay: 0s; z-index: 3; transform: scale(0, 1);}
#gnb .gnb_1dli:hover > a span:before{transform: scale(1, 1); transition-delay: 0s; transform-origin: 0% 50%; }
.gnb_1dli.gnb_al_li_plus .gnb_1da{padding: 0 30px;position: relative;z-index: 100;display: block;line-height: 100px;text-align: center;font-size: var(--main-text01);letter-spacing: -0.02em;font-weight: 700;transition: all 0.4s 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 {display: inline-block;}
.gnb_2dul_box {padding:20px 0; position: absolute;top: 80px;left: 0;z-index: 99;visibility: hidden;opacity: 0;width: 240px;text-align: left;border-radius: 20px;transition: all 0.3s cubic-bezier(0.4, 0, 1, 1);}
.gnb_2dul_box:before{content:"";position:absolute; top:0; left:0; right:0;height:0;background:#fff;box-shadow: 5px 5px 20px rgba(0, 0, 0, 0.1);border-radius:20px;transition:all 0.2s cubic-bezier(0.4, 0, 1, 1);}
.gnb_2dli{padding: 0 14px;}
.gnb_2da{position:relative;z-index:10;display:block;padding:10px 0;line-height:1.3;font-weight:600;transform:translateY(-20px);transition: all 0.4s ease-in-out;}
.gnb_2da > span{display:inline-block;position:relative;background: linear-gradient(90deg, var(--main-color), var(--main-color) 50%, rgba(0,0,0,0.2) 0);background-clip: text;-webkit-background-clip: text;-webkit-text-fill-color: transparent;background-size: 200% 100%;background-position: 100%;transition:background-position 0.4s;}
.gnb_2dli:hover .gnb_2da > span{background-position:0;}

/*gnb_1dli 마우스를 올렸을 때*/
#gnb .hassub.on .gnb_1da{color:var(--main-color);}


/*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);}

#mob-gnb {visibility: hidden;opacity: 0;display:block;position: fixed;top: 0;left: 0;z-index: 1;max-width: 100vw;width: 100%;height: 0;background: rgba(0, 0, 0, 0.5);backdrop-filter:blur(30px) brightness(0.95);transition: opacity 0.5s ease, visibility 0.5s ease;}
#mob-gnb .menu-list{margin:0 auto;width: 1720px;height: 0;display:flex;align-items:center;place-content:center;border-left:1px solid rgba(255,255,255,0.07);border-right: 1px solid rgba(255,255,255,0.07);}
#mob-gnb .menu-list > ul {display: flex;place-content: center;width:100%;}
#mob-gnb .menu-list > ul > li {padding:0 10px 0 30px;position:relative;flex: 1;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.07);}
#mob-gnb .menu-list > ul > li:after { content:"";position: absolute; top:50%; left:0;width:100%; height:100vh; background: transparent linear-gradient(180deg, var(--main-color) 0%, var(--main-color) 100%) 0 0 no-repeat padding-box; opacity:0.5; transform: translateY(0%) scale(1,0); z-index:-1;transition:all 0.4s ease-in-out;}
#mob-gnb .menu-list > ul > li:hover:after{transform: translateY(-50%) scale(1,1);}
#mob-gnb .menu-list > ul > li > .dep01{margin-bottom:20px;position: relative;z-index: 10;display:block;width: 100%;font-size: var(--main-title04);font-weight:600;color:#fff;transition: all 0.4s ease-in-out;}
#mob-gnb .menu-list > ul > li > .dep01 .hassub{display: inline-block;}
#mob-gnb .dep02 > li{position:relative;z-index:10;width: 100%;opacity: 0;transform: translateY(50px);transition: opacity 0.5s ease, transform 0.5s ease;}
#mob-gnb .dep02 > li a{padding:5px 0;display: block;width: 100%;font-weight:600;transition:all 0.4s ease-in-out;}
#mob-gnb .dep02 > li a span{display:inline-block;position:relative;background: linear-gradient(90deg, #fff, #fff 50%, rgba(255,255,255,0.5) 0);background-clip: text;-webkit-background-clip: text;-webkit-text-fill-color: transparent;background-size: 200% 100%;background-position: 100%;transition:background-position 0.4s;}
#mob-gnb .dep02 > li:hover a span{background-position:0;}
.mob-hd-login{display: none;}

html.on,body.on{overflow: hidden;}
#gnb.on{display: none;}
#hd.on #hd_wrapper{width: 1720px;}
#hd_wrapper .hd_login.on li> a{color: #fff;}
#mob-gnb.on {visibility: visible;opacity: 1;z-index: 999;height:100vh;}
#mob-gnb.on .menu-list{height: 100%;}
#mob-gnb.on .menu-list > ul > li {opacity: 1;transform: translateY(0);}
#mob-gnb.on .dep02 > li{opacity: 1;transform: translateY(0);}
