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

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

******************************************************************/
.gw-footer-container{top: 0; left: 0; width: 100%; display: flex; align-items: flex-end; justify-content: center; z-index: 99; transition: transform 0.6s;}
.gw-footer-container #ft {width: 100%;}
.gw-footer-container.on{transform: translateY(0) !important;}
#ft {margin:0 auto;width:100vw;position:relative;}
#ft_wr {padding: 0 10px;position:relative;text-align: center;background: #eee;width: 100%;display: flex;align-items: center;justify-content: center;flex-direction: column;}
#ft .ft-top {padding: 20px 0;width: 100%;max-width: 1400px;}
#ft .ft-top  #ft_link {place-content: center;gap:0;}
#ft .ft-top  #ft_link a {padding:0 14px;position:relative;display:block;color: #222;font-family:"Pretendard_M", sans-serif;transition: all .3s;}
#ft .ft-top  #ft_link a:not(:last-child):after {content: "";display: inline-block;position: absolute;right: 0;top: 50%;transform: translateY(-50%);width: 1px;height: 13px;background:rgba(255,255,255,0.3);}
#ft .ft-top  #ft_link a:hover{color: #fff;}
#ft .ft-top .gw-sns-container > li > a{display:block;width: 45px;height: 45px;border-radius: 100%;background: rgba(0,0,0,0.2);color: #fff;transition: all .3s;}
#ft .ft-top .kakao{width: 27px;height: 26px;opacity: 0.5;transition: all .3s;}
#ft .ft-top .gw-sns-container > li > a i {color:rgba(255,255,255,0.7);}
#ft .ft-top .gw-sns-container > li > a:hover {background: #fff;}
#ft .ft-top .gw-sns-container > li > a:hover i {color:rgba(0,0,0,0.5) !important;}
#ft .ft-top .gw-sns-container > li > a:hover .kakao {mix-blend-mode: difference;}
#ft .ft-bottom {padding: 45px 10px;margin: 0 auto;color: #222;border-top: 1px solid rgba(0, 0, 0, .2);font-size: 14px;background: #eee;text-align: left;width: 100%;max-width: 1400px;}
#ft .ft-bottom #ft-logo {width: 300px;}
#ft .ft-bottom #ft-logo > img {width: auto;height: 100%;object-fit: cover;max-width: 200px;}
#ft .ft-bottom h2 {margin-bottom: 12px;color: #fff;font-size: 16px;}
#ft .ft-bottom .ft_info{font-size: 14px;color: #a5a5a5;line-height:1.75;}
#ft .ft-bottom .ft_info > p > span{position: relative;margin:0 8px;color: #666;}
#ft .ft-bottom .ft_info > p > span:first-child {margin-left: 0;}
#ft .ft-bottom .ft_info > p > span:not(:last-child):after {content: '';display: block;width: 1px;height: 12px;position: absolute;right: -10px;top: 50%;margin-top: -6px;background: rgba(255,255,255,0.3);}
#ft .ft-bottom .gw-btn03 {padding: 6px 9px;display: inline-block;border-radius:5px;color: #666;font-size: 12px;background: #ddd;border: none;margin-bottom: 5px;margin-left: 5px;}
#ft .ft-bottom .ft-right .family-site-container{position:relative; width:210px; text-align:left;}
#ft .ft-bottom .ft-right .family-site-container > button{padding:20px;color: #222;border-bottom: 3px solid rgba(0,0,0,0.2);width:100%;text-align:left;}
#ft .ft-bottom .ft-right .family-site-list{position:absolute; bottom:100%; left:0px; width:100%;  padding:10px 0;  z-index:11;background: #fff; display:none;}
#ft .ft-bottom .ft-right .family-site-list > li > a{display:block; padding:10px; color:#333; font-size:12px;font-family: 'Pretendard_R', sans-serif;}
#ft .ft-bottom .ft-right .family-site-list > li > a:hover{color:#000;}
#ft .ft-bottom .ft-right .gw-arrow{transition:all 0.3s;}
#ft .ft-bottom .ft-right .gw-arrow.on{transform: rotate(180deg);}

/* 퀵버튼 */
.ft-quick-container{position:fixed;bottom:15px;right:40px;z-index: 999;}
.ft-quick-container > li {margin-bottom: 10px;display:flex;align-items:center;place-content:center;width: calc((100vw - (100vw - 143px)) / 2);height: calc((100vw - (100vw - 143px)) / 2);box-shadow: 0px 4px 10px rgba(0,0,0,.15);border-radius: 100%;border:none;background:#fff;font-size: 14px;transition: all .3s;}
.ft-quick-container > li:last-child{margin-bottom:0;background: #333;border-left: none;}
.ft-quick-container .tnb_darkmode {flex-direction: column;gap: 5px;color: #666;cursor: pointer;transition: all .3s;}
.ft-quick-container .tnb_darkmode:hover{color: var(--main-color);}
.ft-quick-container .tnb_admin > a {display: flex;flex-direction: column;align-items: center;gap: 5px;color: #666;transition: all .3s;}
.ft-quick-container .tnb_admin > a:hover{color: var(--main-color);}
#gw-top_btn {display: flex;flex-direction: column;gap: 5px;align-items: center;place-content:center;width:100%;height:100%;border-radius:100%;color: #fff;font-family: "Play", sans-serif;font-weight: 700;text-transform: uppercase;z-index:90;transition: all .3s;}
#gw-top_btn > i{color: #fff;}
.ft-quick-container > li:last-child:hover {background: var(--main-color);}


/*다크모드*/
body.dark-mode #ft_wr{background: #111;color: #fff;}
body.dark-mode #ft_link a{color: #fff;}
body.dark-mode #ft .gw-btn03{background: #333;color: #fff;}
/* ===== 퀵메뉴 (세로 바 / 캐릭터형) ===== */
#quick-menu {
    position: fixed;
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    width: 88px;
    z-index: 999;
    border-radius: 28px;
    overflow: hidden;
    background: #ffffff;
    /* border: 1px solid rgba(19,70,212,0.06); */
    box-shadow: 0 12px 32px rgba(19,70,212,0.14), 0 2px 8px rgba(0,0,0,0.06);
    animation: quickFloat 3.4s ease-in-out infinite;
}
/* 공통 항목 */
.quick-item {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 15px 6px;
    text-decoration: none;
    color: #5a5f6b;
    border-bottom: 1px solid rgba(0,0,0,0.05);
    transition: background .25s, color .25s;
}
.quick-item .quick-ico {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 14px;
    background: #f4f6fb;
    transition: background .25s, transform .25s;
}
.quick-item .quick-txt {
    font-size: 12px;
    font-weight: 700;
    line-height: 1.3;
    text-align: center;
    letter-spacing: -0.02em;
}
.quick-item .quick-ico svg { stroke: #6b7180; transition: stroke .25s; }
/* 호버 */
.quick-item:hover { color: #1346d4; }
.quick-item:hover .quick-ico { background: #e7eefc; transform: translateY(-2px); }
.quick-item:hover .quick-ico svg { stroke: #1346d4; }
.quick-item:hover .quick-txt { color: #1346d4; }
/* 상단 강조 헤더 */
.quick-head {
    background: linear-gradient(160deg, #1346d4 0%, #0d3299 100%);
    color: #fff;
    padding: 22px 6px 20px;
    border-bottom: none;
    border-radius: 28px 28px 0 0;
}
.quick-head .quick-ico { background: rgba(255,255,255,0.16); }
.quick-head .quick-ico svg { stroke: #fff; }
.quick-head .quick-txt {
    font-size: 13px;
    font-weight: 800;
    color:#fff;
    letter-spacing: 0;
}
.quick-head:hover { background: linear-gradient(160deg, #0f3bb8 0%, #0a2880 100%); color: #fff; }
.quick-head:hover .quick-ico { background: rgba(255,255,255,0.26); }
.quick-head:hover .quick-ico svg { stroke: #fff; }
.quick-head:hover .quick-txt { color: #fff; }
/* 유튜브(캐릭터) 영역 */
.quick-char {
    border-bottom: none;
    border-radius: 0 0 28px 28px;
}
.quick-char .quick-ico { background: #fdeaec; }
.quick-char:hover .quick-ico { background: #fbdadd; transform: translateY(-2px); }
.quick-char:hover { color: #e63946; }
.quick-char:hover .quick-txt { color: #e63946; }
/* 둥둥 떠다니는 애니메이션 */
@keyframes quickFloat {
    0%, 100% { transform: translateY(-50%); }
    50%      { transform: translateY(calc(-50% - 6px)); }
}
/* 모바일에서 숨김 */
@media screen and (max-width: 768px) {
    #quick-menu { display: none; }
}
@media screen and (max-width: 1200px) {
    #ft .ft-top #ft_link a {
        font-size:14px;
        padding:0px 15px 0px 0px;
    }
}
@media all and (max-width:960px) {
    #ft .ft-top {
        flex-direction:column;
        align-items:center;
        gap:20px;
    }
    #ft .ft-top #ft_link {
        display:flex;
        flex-wrap:Wrap;
        gap: 10px !important;
    }
}
/* 모바일에서 숨김 */
@media screen and (max-width: 768px) {
    #quick-menu {
        display: none;
    }
    #ft .ft-top #ft_link {
        gap:15px;
    }
    #ft .ft-top #ft_link a {
        font-size:12px;
        padding: 0px;
    }
    #ft .ft-bottom .ft_info > p > span {
        font-size:12px;
        width: 100%;
        display: block;
        padding: 0px;
        margin: 0px;
    }
    #ft .ft-bottom .ft-right .family-site-container > button {
        padding:10px;
        width:100%;
    }
    .ft-right {
        margin:0 auto;
    }
    #ft .ft-bottom, .ft-left {
        width:100%;
    }
    #ft .ft-bottom .ft_info {
        text-align:center;
    }
    #ft .ft-bottom {
        text-align:center;
    }
    #ft .ft-bottom #ft-logo {
        margin:0 auto;
    }
}