@charset "utf-8";

#shGnb{
    display:flex;
    align-items:center;
    justify-content:space-between;
    position:relative;
    width:100%;
    height:90px;
    padding:0 100px;
}

.sh_lnb_bg{
    display:none;
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:400px;
    background-color:#fff;
    box-shadow:0px 8px 5px rgba(0,0,0,10%);
}

/* 로고 */
#shGnb .sh_logo{
    position:relative;
    z-index:20;
}

/* 대분류 */
#shGnb .sh_nav{
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    width:max-content;
}

#shGnb .sh_nav > li{
    float:left;
    position:relative;
    padding:0 33px;
    line-height:70px;
}

#shGnb .sh_nav > li > a{
    display:block;
    font-size:21px;
    font-weight:500;
    color:#fff;
    text-transform:uppercase;
    transition:all .2s;
}

#shGnb.on .sh_nav > li > a{
    color:#222;
}

#shGnb.on #pfBtn span,
#shGnb.on #pfBtn span:after,
#shGnb.on #pfBtn span:before{
    background:var(--primary);
}

/* 소분류 */
#shGnb .sh_lnb_s{
    display:none;
    position:absolute;
    left:50%;
    transform:translateX(-50%);
    min-width:100%;
    width:max-content;
    min-height:145px;
    font-size:16px;
}

#shGnb .sh_lnb_s li a{
    display:block;
    line-height:1.8;
    text-align:center;
    color:#999;
    transition:all .2s;
}

/* sns */
#shGnb .sh_tip{
    margin-left:auto;
    display:flex;
    align-items:center;
}

#shGnb .sh_tip li+li{
    margin-left:14px;
    border-left:1px solid rgba(255,255,255,.4);
    line-height:10px;
}

#shGnb .sh_tip li a{
    margin-left:15px;
    font-size:14px;
    color:#fff;
    font-family:var(--e-font);
}

#shGnb.on .sh_tip li a,
#shGnb.sub .sh_tip li a{
    color:#222;
}

/* PC 회원 메뉴 */
.sh_member_menu{
    position:absolute;
    top:50%;
    right:150px;
    transform:translateY(-50%);
    z-index:30;
    display:flex;
    align-items:center;
    gap:8px;
}

.sh_member_menu a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:36px;
    padding:0 12px;
    border:1px solid rgba(255,255,255,0.28);
    border-radius:999px;
    font-size:13px;
    font-weight:600;
    color:#fff;
    text-decoration:none;
    white-space:nowrap;
    transition:all .2s ease;
    background:rgba(255,255,255,0.04);
}

.sh_member_menu a:hover{
    background:#fff;
    color:#111;
    border-color:#fff;
}

#shGnb.on .sh_member_menu a,
#shGnb.sub .sh_member_menu a{
    color:#222;
    border-color:rgba(0,0,0,0.15);
    background:#fff;
}

#shGnb.on .sh_member_menu a:hover,
#shGnb.sub .sh_member_menu a:hover{
    background:var(--primary);
    color:#fff;
    border-color:var(--primary);
}

/* 메뉴버튼 */
#pfBtn{
    display:flex;
    position:absolute;
    top:50%;
    right:100px;
    transform:translateY(-50%);
    z-index:101;
    width:30px;
    height:30px;
    cursor:pointer;
    transition:all .2s;
}

#pfBtn span{
    display:block;
    position:relative;
    width:26px;
    height:2px;
    margin:auto;
    background:#fff;
    transition:all .2s;
}

#pfBtn span:before,
#pfBtn span:after{
    display:block;
    content:"";
    position:absolute;
    top:0;
    width:100%;
    height:2px;
    background:#fff;
    transition:all .2s;
}

#pfBtn span:before{
    top:-9px;
}

#pfBtn span:after{
    top:9px;
}

#pfBtn.active{
    position:fixed;
    right:100px;
    top:45px;
    transform:none;
}

#pfBtn.active span{
    border:none;
    background:transparent;
}

#pfBtn.active span:before{
    top:0;
    transform:rotate(45deg);
    background:var(--primary);
}

#pfBtn.active span:after{
    top:0;
    transform:rotate(-45deg);
    background:var(--primary);
}

/* 메뉴오픈 */
#allWrap{
    display:none;
    position:fixed;
    top:0;
    left:0;
    z-index:100;
    width:100%;
    height:100%;
    color:#08151d;
    transform:rotateX(8deg) translateY(50px);
    background-color:#fff;
    transition:transform .6s;
}

#allWrap.active{
    transform:rotateX(0) translateY(0);
}

#allWrap .inner{
    position:relative;
    width:1040px;
    height:100%;
    margin:0 auto;
}

#allWrap .ci{
    padding:40px 0 50px;
    text-align:center;
}

#allWrap .tit{
    padding:40px 0;
    font-size:15px;
    font-weight:700;
    font-family:var(--e-font);
}

#allWrap .cont{
    position:relative;
    padding:0 40px;
    border-top:1px solid rgba(0,0,0,.15);
}

#allWrap .cont:before{
    display:block;
    content:"";
    position:absolute;
    left:0;
    top:-1px;
    width:200px;
    height:1px;
    background-color:rgba(0,0,0,.6);
}

#allWrap .sitemap > ul:after{
    display:block;
    content:"";
    visibility:hidden;
    clear:both;
}

#allWrap .sitemap > ul > li{
    float:left;
}

#allWrap .sitemap > ul > li+li{
    margin-left:100px;
}

#allWrap .sitemap .bmn{
    display:inline-block;
    position:relative;
    margin-bottom:25px;
    font-size:18px;
    font-weight:700;
    color:#111;
    text-transform:uppercase;
    letter-spacing:-.5px;
    transition:all .2s;
}

#allWrap .sitemap .bmn:after{
    opacity:0;
    display:block;
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    width:12px;
    height:2px;
    margin-bottom:-10px;
    background-color:#08151d;
    transition:all .2s;
}

#allWrap .sitemap .smn li a{
    font-size:15px;
    line-height:2;
    color:#888;
    transition:color .2s;
}

#allWrap .cs{
    position:absolute;
    bottom:150px;
    width:100%;
    font-family:var(--e-font),var(--k-font);
}

#allWrap .cs .tel{
    display:inline-block;
    vertical-align:top;
    font-size:24px;
    font-weight:700;
}

#allWrap .cs .etc{
    display:inline-block;
    vertical-align:top;
    margin-left:80px;
    line-height:1.8;
}

/* 반응형 메뉴 */
#topmenuM{
    display:none;
    position:relative;
    width:100%;
    padding:15px;
    line-height:1.8;
    background-color:#fff;
    font-family:'notokr-regular';
}

/* 로고 */
#m_logo{
    position:relative;
}

#m_logo a{
    display:inline-block;
}

/* 상단 버튼 및 오픈메뉴 */
#m_navBtn{
    position:absolute;
    top:32px;
    right:15px;
    z-index:8;
    width:30px;
    height:30px;
}

#m_navBtn span{
    display:block;
    position:relative;
    top:50%;
    transform:translateY(-50%);
    width:100%;
    height:2px;
}

#m_navBtn span:before,
#m_navBtn span:after{
    display:block;
    content:"";
    position:absolute;
    top:-6px;
    width:30px;
    height:2px;
    background-color:var(--primary);
    -webkit-transition:all .1s;
    transition:all .1s;
}

#m_navBtn span:after{
    top:6px;
    width:16px;
    right:0;
    background-color:var(--primary);
}

#m_navBtn.on{
    position:fixed;
}

#m_navBtn.on span:before{
    top:0;
    right:-4px;
    transform:rotate(45deg);
    background-color:#222;
}

#m_navBtn.on span:after{
    top:0;
    right:-4px;
    width:30px;
    transform:rotate(-45deg);
    background-color:#222;
}

#navWrap{
    display:none;
    position:fixed;
    left:0;
    top:0;
    z-index:7;
    width:100%;
    height:100%;
    background-color:rgba(0,0,0,.7);
}

#navWrap .inner{
    overflow-y:scroll;
    opacity:0;
    position:fixed;
    right:-40px;
    top:0;
    z-index:9;
    min-width:300px;
    width:75%;
    height:100%;
    padding:60px 0;
    background-color:#fff;
    -webkit-transition:all .1s;
    transition:all .1s;
}

#navWrap.on .inner{
    opacity:1;
    right:0;
    -webkit-transition:all .4s;
    transition:all .4s;
}

#navWrap .inner:before,
#navWrap .inner:after{
    opacity:0;
    display:block;
    position:fixed;
    top:0;
    right:-40px;
    z-index:1;
    content:"";
    min-width:300px;
    width:70%;
    height:60px;
    background-color:#fff;
    -webkit-transition:all .1s;
    transition:all .1s;
}

#navWrap .inner:after{
    top:auto;
    bottom:0;
}

#navWrap.on .inner:before,
#navWrap.on .inner:after{
    opacity:1;
    right:0;
    -webkit-transition:all .4s;
    transition:all .4s;
}

#navWrap .inner .mo_hd_copy{
    position:fixed;
    right:0;
    bottom:15px;
    z-index:2;
    min-width:300px;
    width:70%;
    font-size:12px;
    text-align:center;
    color:#888;
}

#navWrap .user_tip{
    padding:10px 20px;
    background-color:#f5f5f5;
}

#navWrap .user_tip li{
    display:inline-block;
}

#navWrap .user_tip li+li{
    margin-left:10px;
}

/* 모바일 회원 메뉴 */
.m_member_menu{
    display:none;
}

/* 대분류 */
#topmenuM .m_lnb .m_bmenu{
    display:block;
    position:relative;
    width:100%;
    height:52px;
    padding:0 20px;
    border:none;
    border-bottom:1px solid #ddd;
    background:none;
    font-size:16px;
    line-height:52px;
    color:#222;
    text-align:left;
    font-family:'notokr-medium';
}

#topmenuM .m_lnb .m_bmenu:after{
    float:right;
    content:"\f107";
    font-family:'fontawesome';
}

#topmenuM .m_lnb .m_bmenu.on:after{
    content:"\f106";
}

/* 소분류 */
#topmenuM .m_smenu{
    display:none;
    padding:15px 20px;
    border-bottom:1px solid #ddd;
    background-color:#f2f3f5;
}

#topmenuM .m_smenu li a{
    font-size:14px;
    color:#777;
}

/* hover */
@media (hover:hover){
    #shGnb .sh_lnb_s li a:hover{
        color:var(--primary);
    }

    #allWrap .sitemap > ul > li:hover .bmn:after{
        opacity:1;
        margin-bottom:-20px;
    }

    #allWrap .sitemap > ul > li:hover .bmn{
        transform:translateY(-5px);
    }

    #allWrap .sitemap .smn li a:hover{
        color:#08151d;
    }
}

/* 반응형 */
@media (max-width:1380px){
    #shGnb{
        padding:0 5%;
    }

    .sh_member_menu{
        right:calc(5% + 50px);
    }

    #pfBtn{
        right:5%;
    }

    #pfBtn.active{
        right:5%;
    }
}

@media (max-width:1024px){
    #shGnb{
        display:none !important;
    }

    #topmenuM{
        display:block !important;
        background-color:transparent;
    }

    .sh_member_menu{
        display:none !important;
    }

    .m_member_menu{
        display:flex;
        gap:8px;
        margin:0 20px 18px;
        padding:0 0 18px;
        border-bottom:1px solid #ddd;
    }

    .m_member_menu a{
        flex:1 1 0;
        display:flex;
        align-items:center;
        justify-content:center;
        min-height:44px;
        padding:0 12px;
        border:1px solid #ddd;
        border-radius:10px;
        font-size:14px;
        font-weight:700;
        color:#222;
        background:#fff;
        text-decoration:none;
        white-space:nowrap;
    }

    #navWrap .inner{
        width:82%;
    }

    #navWrap .inner:before,
    #navWrap .inner:after,
    #navWrap .inner .mo_hd_copy{
        width:82%;
    }
}