/* 초기 값 셋팅 */
::-webkit-scrollbar {
    display: none;
}

.hidden {
    display: none;
}

.br {
    display: none;
}

#initial * {
    margin:initial;
    padding:initial;
    font-size:initial;
    border: initial;
    font: initial;
    vertical-align: initial;
    list-style:initial;
    font-style:initial;
    font-weight:initial;
}



#initial b {
    font-weight: bold !important;
}
#initial * img {
    width: auto !important;
    max-width: 100%;
}

#initial b * {
    font-weight: bold !important;
}

html {
    font: 400 16px/1.3 'IBM Plex Sans KR-medium';
}

body {
    word-break: keep-all;
    overflow-y: scroll;
    overflow-x: clip;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.main .section {
    height: 100vh;
    width: 100%;
    background: #fff;
}

body { 
    font: 1em/1.3 'IBM Plex Sans KR-medium';
    letter-spacing: -0.05px;
}

.__base_wrap {
    width:calc(100% - 1.875em);
    max-width: 1600px;
    margin: 0 auto;
}


/* 라인 공통으로 들어감 */

.line::before {
    content: '';
    display: block;
    width: 30px;
    height:1px;
    background: #000;
    margin-bottom: 10px;
    
}

/* 폰트 컬러 */
.white {
    color:#fff;
}

.blue {
    color:#3675FF;
}
.purple {
    color:#A384F0;
}

.glay {
    color:#474747;
}


/* 폰트에 컬러 포인트 */
.point {
    display: inline-flex;
    align-items: center;
    height: 25px;
    padding:0 10px;
    background: rgba(163,132,240, 41%)
}

/* 공통 그림자 */
    .shadow{
        box-shadow: 5px 3px 6px rgba(0,0,0,16%);
    }


/* 페이지 숫자 */

.pagination {
    justify-content: center;
    padding-bottom: 90px;
}

.pagination a {
    padding: 7px 13px;
    background: #F5F5F5;
    border-radius: 99999999999px;
    color: #999999;
}

.pagination .active {
    background: #474747;
    color: #fff;
}

.pagination a:hover {
    background: #474747;
    color: #fff;
    opacity: 1;
}

.pagination a + a {
    margin-left: 10px;
}


/* placeholder */

::placeholder {
    color: #c9c9c9;
    opacity: 0.2;
    font-weight: 100;
    font-size: 13px;
    font-style: italic;
    padding: 5px;
}
@media screen and (max-width: 550px) {
    ::placeholder {
        color: #c9c9c9;
        opacity: 0.2;
        font-weight: 100;
        font-size: 12px;
        font-style: italic;
        padding: 2px;
    }
}
i {
    vertical-align: middle;
}

.productpage .item_wrap .item_txt li a i {
    padding-right: 5px;
}



/* 공통 HEADER */
.header {
    overflow: hidden;
    position: fixed;
    z-index: 120;
    width: 100%;
    height: 70px;
    background:  linear-gradient(90deg, rgba(54,117,255,1) 0%, rgba(158,132,241,1) 100%);
}


.header .gnb_v1 {
    position: relative;
    z-index: 100;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: space-between;
    height: 70px;
    font-family: 'IBM Plex Sans KR-medium';
    color: #fff;
}


.header .gnb_v1 .main_gnb {
    height: 100%;
}
.header .gnb_v1 .main_gnb nav {
    height: 100%;
}


.header .gnb_v1 .logo a {
    display: inline-block;
    width:210px;
    height: 100%;
    filter: brightness(10);
}

.main {
    
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.5s ease-in-out;
}
.header .gnb_v1 .logo a img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}


.header .gnb_v1 .main_gnb .main_gnb_wrap{
    align-items: center;
    gap: 65px;
    height: 100%;
}

.header .gnb_v1 .main_gnb .main_gnb_wrap > li {
    height: 100%;
    border-bottom: 1px solid transparent;
    font-size: 18px;
}

.header .gnb_v1 .main_gnb .main_gnb_wrap .active {
    border-bottom: 1px solid #fff;
}

.header .gnb_v1 .main_gnb .main_gnb_wrap > li > a {
    display: flex;
    align-items: center;
    height: 100%;
}

.header .gnb_v1 .main_gnb .main_gnb_wrap > li:hover {
    border-bottom: 1px solid #3675FF;
}


/* 호버시 */
.header .gnb_v1 .product:hover::after{
    border:1px solid#3675FF
}

header.on {
    transition: height 0.3s;
    background: #fff;
}

header.on .gnb_v1{
    position:relative;
    color: #1A1A1A;
}

header.on .gnb_v1 .logo a{
    filter:none;
}

header.on::after{
    content: '';
    position: absolute;
    top: 70px;
    display: inline-block;
    width:100%;
    height:1px;
    background: #ddd;

}

.header .depth-1 {
    position: absolute;
    top:100%;
    left: 0;
    flex-direction: row;
    width:100%;
    font-size:20px;
}

.header .main_gnb_wrap .company_wrap .depth-1 {
    justify-content: center;
}


.header .depth-1 > li {
    width: calc(100% / 6);
    text-align:center;
    font-family: "IBM Plex Sans KR-semibold";
}

.header .depth-1 > li .depth-2_wrap {
    display: block;
    padding:20px 0 5px;

}

.header .company_wrap .depth-1 > li a {
    display: block;
    padding:20px 0 5px;
}

.header .depth-2_wrap::after{
    content: '';
    display: block;
    width:60%;
    height: 1px;
    background: #ddd;
    margin:10px auto;
}

.header .depth-2 {
    flex-wrap: wrap;
    flex-direction: column;
    gap: 10px;
    color:#7F7F7F;
    font-size:18px;
}

.header .nev_line::before   {
    content: '';
    display: inline-block;
    width: 1px;
    height: 500px;
    background: #ddd;
    position: absolute;
    top:0;
}


.header .main_gnb_wrap .depth-2 a:hover {
    color:#3675FF;
    padding:0 10px;
    background: linear-gradient(0deg, rgba(217,204,249,1) 50%, rgba(148,148,148,0) 50%);
    font-weight: 600;
}

.hamBtn {
    display: none;
}

.tablet_nav {
    
    display: block;
    position: fixed;
    top: 70px;
    left: -100%;
    z-index: 101;
    transform: translateX(-300%);
    transition: transform 0.5s;
    background: #f9f9f9;
    min-width: 260px;
    max-width: 500px;
    height: 100%;
    padding: 0px 25px 20px 20px;
    overflow-y: scroll;
}
.tablet_nav nav {
    height: 800px;
}
.tablet_nav + .ham_bg {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index:100;
    transition: all 0.3s;
    background-color: rgba(0,0,0,0.7);
    width: 100%;
    height: 200vh;
}

.tablet_nav nav .tab_depth-1 {
    display: none;
}

.tablet_nav nav .on .tab_depth-1 {
    display: block;
}


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

    .on {
        overflow: hidden;
    }

    .on .tablet_nav {
        left: 0;
        transform: translateX(0);
    }
    .on .tablet_nav + .ham_bg {
        display: block;
    }

    .header .gnb_v1 .main_gnb {
        display: none;
    }

    .header .main_gnb_wrap {
        display: none;
    }

    .li_wrap {
        font-size: 22px;
        color:#333;
    }

    .li_wrap i:not(.xi-message,.tab_up, .motor_wrap) {
        padding-right:10px;
    }

    .li_wrap i.xi-message {
        padding-left:10px;
    }

    .li_wrap > a {
        display: block;
        padding: 10px 0;
        border-bottom: 1px solid #eee;
        align-items: center
    }

    .li_wrap .tab_wrap {
        display: flex;
        justify-content: space-between;
    }

    .tab_gnb_wrap {
        flex-direction: column;
        gap: 10px;
    }

    .tab_depth-1 {
        flex-direction: column;
        font-size:18px;
        border-top: 1px solid #c2c2c2;
    }

    .tab_depth-1 a {
        position:relative;
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        height: 50px;
        padding: 10px 0;
        text-indent: 30px;
        color: #797979;
        border-bottom: 1px solid #f1f1f1
    }

    .tab_depth-1 a::before {
        content: '';
        position: absolute;
        top:50%;
        left: 0;
        display: inline-block;
        width: 3px;
        height: 3px;
        background: #797979;
        border-radius: 99999999999px;
    }

    .tab_gnb_wrap .depth-2 {
        overflow: hidden;
        flex-direction: column;
        height: 0;
        transition: height 0.3s;
        background: #eee;
    }

    .tab_depth-1 .on .depth-2 {
        height: calc(50px* 8);
        transition: height 0.3s;
    }

    .depth-2 a {
        display: flex;
        align-items: center;
        font-size: 16px;
        height:50px;
    }

    .depth-2 a:hover {
        background:#3675FF;
        color:#fff
    }

    .depth-2 a::before {
        width: 8px;
        left: 5px;
    }

    .ham_wrap {
        position: fixed;
        right: 20px;
        z-index: 500;
        top: calc(70px / 2);
        transform: translateY(-50%);
    }

    .hamBtn {
        display: inline-block;
    }

    .hamBtn i{
        font-size: 35px;
        color:#fff;
    }

    .header .depth-1 > li .depth-2_wrap{
        display: none;
    }
    .header .depth-2  {
        display: none;
    }

}  

@media screen and (max-width:550px) {
    .header {
        height: 50px;
    }
    .header .gnb_v1 {
        height: 50px;
    }
    .on .tablet_nav {
        top: 50px;
        width:100%;
    }
    .ham_wrap {
        top: calc(50px / 2);
    }
}



.tab_gnb_wrap .tab_up {
    height: 100%;
    transform: rotate(0deg);
    transition: all 0.3s;
}

.tab_gnb_wrap .on .tab_up {
    transform: rotate(180deg);

}

/* //공통 HEADER */

main:not(.history).section {
    overflow: hidden;
}

/* 공통 FOOTER */




.footer {
    position: absolute;
    display: flex;
    justify-content: center;
    flex-direction:column;
    overflow:hidden;
    width: 100%;
    max-height: 300px;
    min-height: 300px;
    background-color: #333;
    color: white;
    font-size: 14px;
}



.footer_wrap {
    flex-direction: column;
    gap: 20px;
    background: #333;
    padding-bottom: 30px;
}
.footer_wrap ul {
    margin-left: auto;
}
.footer h2 {
    width:200px;
}

.footer .__flex {
    justify-content: space-between;
}

.footer .item_wrap {
    flex-wrap: wrap;
}

.footer .ft-container {
    gap:60px;
    flex-wrap: wrap;
}

.footer .footer_download {
    align-items:flex-end;
}

.footer .ft-container dl {
    position: relative;
    width: calc((100% - 60px)/2 );
}

.footer .ft-container dl:nth-child(1)::after {
    content: '';
    display: block;
    position: absolute;
    top:0;
    right: -30px;
    width: 1px;
    height: 100%;
    background:#fff;
    opacity: 10%;
}

.footer .ft-container dd,dt {
    display: inline-block;
    padding-bottom: 5px;
}

.footer .ft-container dt {
    padding-right: 10px;
    opacity: 0.3;
}

.footer .ft-container dt.footer_city{
    position: relative;
    display: block;
    opacity: 100%;
    padding-bottom: 20px;
}

.footer .ft-container dt.footer_city::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 1px;
    background:#fff;
    opacity: 10%;
    margin-bottom: 10px;
}

.footer li + li::before {
    content: '';
    display: inline-block;
    width: 1px;
    height: 13px;
    background: #fff;
    margin:0 30px;
}
.footer .fax {
    padding-left: 30px;
}
.footer .download{
    display: block;
    margin-bottom: 10px;
    padding: 13px 42px;
    border: 1px solid #fff;
}

.copyright {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    padding-top: 10px;
    padding-bottom: 10px;
    margin-top: 30px;
    font-size: 12px;
    background: #1A1A1A;
}
.copyright p {
    display: inline-block;
}
.copyright a { 
    font-size: 13px;
    display: inline-block;
    padding:5px 10px;
    border: 1px solid #fff;
    border-radius: 99px;
}
.copyright a:hover {
    color: #1A1A1A;
    background: #fff;
    opacity: 1;
}

.line p.txt {
    font-size: 1.25em;
}


/* //공통 FOOTER */

@media screen and  (min-width: 768px) and  (max-width: 1025px) {
    
    .footer {
        overflow: hidden;
        max-height:800px;
        min-height:530px;
    }
    

    .footer .inner_wrap {
        display: flex;
        flex-direction: row;
        justify-content: flex-end;
        align-items: center;
        gap: 20px;
        margin-top: 25px;
    }

    .footer .download {
        text-align: center;
    }

    .footer .copyright {
        font-size:12px;
    }

    .footer .copyright p{
        margin-bottom: 10px;
    }
    .footer .ft-container dt {
        display: block;
    }

    .footer .fax {
        padding-left: 0;
    }
}

@media screen and (max-width: 768px) {
    .footer {
        overflow: hidden;
        min-height: 520px;

    }

    /* .footer h2 {
        width: calc((100% - 20px)/3 );
    } */

    .footer .ft-container {
        flex-direction: column;
        gap: 40px;
    }


    .footer .ft-container dl {
        width:100%;
    }

    .footer .ft-container dl:nth-child(1)::after {
        display: none;
    }

    .footer .inner_wrap {
        flex-direction: column;
        /* gap: 40px; */
    }

    .footer .info {
        width: 100%;
        /* justify-content: flex-end; */
        gap: 20px;
    }

    .footer .info a {
        padding: 10px 0;
    }

    .footer li + li::before {
        display: none;
    }

    .footer .download {
        margin: 10px;
    }

}


@media screen and (max-width: 446px) {
    .footer {
        min-height: 660px;
    }
    .footer .inner_wrap {
        gap: 20px;
    }

    .footer .ft-container {
        gap: 30px;
    }
}



