@charset "utf-8";
html {
    font-size: 16px;
}

body {
    font-size: 1em;
    color: #333;
    font-weight: 400;    /* 모바일에서 글자 크기 깨짐 방지 */
    -webkit-text-size-adjust: none;
    -moz-text-size-adjust: none;
    -ms-text-size-adjust: none;
    font-family: "Noto Sans KR", sans-serif;
    word-break: keep-all;
}

ul, dl, dt, dd {
    margin: 0;
    padding: 0;
    list-style: none
}

a {
    color: #333;
}

a:hover {
    color: #1e2188;
    text-decoration: none
}

a:link {
    text-decoration: none
}

*, button {
    outline: none;
}
#wrap {
    min-width:1200px;
}
#header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    min-width: 1200px;
    height: 86px;
    overflow: hidden;
    -webkit-transition: background .3s ease;
    -moz-transition: background .3s ease;
    -o-transition: background .3s ease;
    -ms-transition: background .3s ease;
    z-index: 30;
    border-bottom: 1px solid #e3e3e3;
    z-index: 100;
}

#header:before {
    content: "";
    position: absolute;
    top: 85px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #e3e3e3;
    z-index: 100;
}

#header.main-header {
    background-color: #fff;
    z-index: 102;
}

#header.main-header #logo .icon {
    background-image: url(/img/logo.png);
    width: 192px;
    height: 35px
}

#header.main-header #gnb .depth01-lists .depth01-list .depth01 {
    color: #222
}

#header.main-header #gnb .depth01-lists .depth01-list .depth01:hover {
    color: #1d2088;
}

#header.main-header #gnb .depth01-lists .depth01-list .depth02-lists {
    border-top: 2px solid #fff;
}

#header.main-header #gnb .depth01-lists .depth01-list:hover .depth02-lists {
    background-color: #f5f7f9;
    border-top: 2px solid #1d2088;
}

#header.main-header #gnb .depth01-lists .depth01-list .depth01.hover+.depth02-lists {
}

#header.main-header #gnb .depth01-lists .depth01-list .depth01.hover span:before, #header.hover #gnb .depth01-lists .depth01-list .depth01.hover span:before {
    background-color: #012b5d
}

#header.main-header #gnb .depth02-lists {
    opacity: 1;
    filter: alpha(opacity=100)
}

#header .inner {
    position: relative
}

#header #logo {
    position: absolute;
    top: 26px;
    left: 0
}

#header #gnb {
    margin-left: 400px;
    width: 100%;
}

#header #gnb .depth01-lists {
    display: inline-block;
    vertical-align: top
}

#header #gnb .depth01-lists .depth01-list {
    float: left;
    width: 160px;
    text-align: center
}

#header #gnb .depth01-lists .depth01-list:first-child .depth02-lists {
    border-left: 1px solid #dcdddd
}

#header #gnb .depth01-lists .depth01-list .depth01 {
    display: block;
    padding: 7px 0;
    margin: 23px 0 25px;
    font-family: "NanumSquare", sans-serif;
    font-weight: 400;
    font-size: 16px;
}

#header #gnb .depth01-lists .depth01-list .depth01 span {
    position: relative;
    display: inline-block;
    vertical-align: top
}

#header #gnb .depth01-lists .depth01-list .depth01 span:before {
    content: "";
    position: absolute;
    bottom: -7px;
    left: 0;
    width: 100%;
    height: 2px;
    -webkit-transition: background .3s ease;
    -moz-transition: background .3s ease;
    -o-transition: background .3s ease;
    -ms-transition: background .3s ease
}

#header #gnb .depth02-lists {
    height: 220px;
    padding-top: 20px;
    border-right: 1px solid #dcdddd;
    opacity: 0;
    filter: alpha(opacity=0);
    -webkit-transition: all .3s ease;
    -moz-transition: all .3s ease;
    -o-transition: all .3s ease;
    -ms-transition: all .3s ease
}

#header #gnb .depth02-lists .depth02-list .depth02 {
    display: block;
    padding: 10px 0;
    font-family: "Noto Sans KR", sans-serif;
    font-weight: 400;
    font-size: 15px;
    line-height: 15px;
    letter-spacing: -0.5px;
    color: #555;
    text-decoration: none;
    -webkit-transition: color .3s ease;
    -moz-transition: color .3s ease;
    -o-transition: color .3s ease;
    -ms-transition: color .3s ease
}

#header #gnb .depth02-lists .depth02-list .depth02:hover {
    font-weight: 500;
    color: #1d2088;
}

.icon {
    display: inline-block;
    vertical-align: top;
    overflow: hidden;
    text-indent: -999px;
}

#header #gnb .language {
    position: absolute;
    top: 30px;
    right: 0;
    font-family: "Roboto";
}

#header #gnb .language strong {
    font-size: 16px;
    color: #191c86;
    font-weight: 600;
}

#header #gnb .language i {
    font-style: normal;
    font-size: 12px;
    padding-left: 10px;
    padding-right: 10px;
}

#header #gnb .language span {
    font-size: 16px;
    color: #575757;
}

.main-slide-wrap {
    margin-top: 86px;
    overflow: hidden;
    position: relative;
}

.swiper-mainslide {
    width: 100%;
    height: 918px;
}

.swiper-slide.slide1 {
    background: url('/img/main_visual_1.jpg') center center no-repeat;
    background-size: cover;
}

.swiper-slide.slide2 {
    background: url('/img/main_visual_2.jpg') center center no-repeat;
}

.swiper-slide.slide3 {
    background: url('/img/main_visual_3.jpg') center center no-repeat;
}

.swiper-slide .txt {
    animation-delay: 0.7s;
}

.swiper-slide.slide1 .txt {
    position: absolute;
    left: 50%;
    top: 268px;
    margin-left: -550px;
}

.swiper-slide.slide2 .txt {
    position: absolute;
    left: 50%;
    top: 268px;
    margin-left: -550px;
}

.swiper-slide.slide3 .txt {
    position: absolute;
    left: 50%;
    top: 268px;
    margin-left: -550px;
}

.swiper-button-prev {
    position: absolute;
    left: 50%;
    top: 543px;
    margin-left: -550px;
    z-index: 100;
    cursor: pointer;
    width: 50px;
    height: 50px;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid #bbbbbb;
    transition: all .5s;
}

.swiper-button-prev:after {
    content: '\E93D';
    font-family: xeicon;
    font-size: 24px;
    color: #fff;
    position: absolute;
    top: 6px;
    left: 11px;
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
    opacity: .35;
    cursor: auto;
    pointer-events: none
}

.swiper-button-next:hover, .swiper-button-prev:hover {
    background: rgba(0, 0, 0, 0.7);
}

.swiper-button-next {
    position: absolute;
    left: 50%;
    top: 543px;
    margin-left: -486px;
    z-index: 100;
    cursor: pointer;
    width: 50px;
    height: 50px;
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid #bbbbbb;
    transition: all .5s;
}

.swiper-button-next:after {
    content: '\E940';
    font-family: xeicon;
    font-size: 24px;
    color: #fff;
    position: absolute;
    top: 6px;
    left: 14px;
}

.scroll-wrap {
    width: 104px;
    height: 107px;
    background: url(/img/scroll.png) top left no-repeat;
    left: 50%;
    margin-left: -52px;
    position: absolute;
    bottom: 30px;
    z-index: 50;
    cursor: pointer;
    padding: 0;
    border: 0;
}

.main-news-wrap {
    margin-top: 67px;
    margin-bottom: 50px;
}

.main-news-wrap .title {
    font-size: 23px;
    font-family: "Nanum Square";
    border-bottom: 1px solid #333333;
    font-weight: 700;
    padding-bottom: 14px;
    position: relative;
}

.main-news-wrap .title .more {
    position: absolute;
    top: 0;
    right: 0;
}

.main-news-wrap .cont {
    padding-top: 20px;
}

.main-news-wrap .cont > li {
    line-height: 2;
    position: relative;
    margin-left: 16px;
}

.main-news-wrap .cont > li:before {
    content: '';
    width: 4px;
    height: 4px;
    background: #161984;
    position: absolute;
    top: 14px;
    left: -16px;
}

.main-news-wrap .cont > li a {
    font-size: 16px;
    color: #333;
}

.main-news-wrap .cont > li a:hover {
    font-weight: 500;
}

.main-news-wrap .cont > li > span {
    position: absolute;
    right: 0;
    font-weight: 400;
    font-size: 15px;
}

footer {
    background: #f8f8f8;
    height: 120px;
}

footer .footer-wrap {
    height: 100%;
}

.h100 {
    height: 100%;
}

.footer-wrap .logo, .footer-wrap .banner {
    display: flex;
    align-items: center;
}

.footer-wrap .copyright {
    padding-top: 32px;
    color: #9b9b9b;
    font-size: 12px;
    padding-left: 30px;
    font-family: Roboto;
}

.footer-wrap .banner {
    width: 410px;
    position: relative;
    margin-left: 6px;
}

.footer-wrap .banner li {
    border: 1px solid #dfdfdf;
    width: 112px !important;
}

.footer-wrap .banner img.bimg {
    width: 110px;
}

.swiper-banner {
    width: 356px;
}

.swiper-button-prev-banner {
    background: url('/img/banner-left.png') 0 0 no-repeat;
    width: 10px;
    height: 17px;
    position: absolute;
    left: 6px;
    cursor: pointer;
}

.swiper-button-next-banner {
    background: url('/img/banner-right.png') 0 0 no-repeat;
    width: 10px;
    height: 17px;
    position: absolute;
    right: 6px;
    cursor: pointer;
}

.lnb-wrap {

    /*background:#1e2188;*/
    position: fixed;
    top: 86px;
    width: 100%;
    min-width: 1200px;
    height: 40px;    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#1e2188+0,434682+100 */
    background: rgb(30, 33, 136); /* Old browsers */
    background: -moz-linear-gradient(top, rgba(30, 33, 136, 1) 0%, rgba(67, 70, 130, 1) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top, rgba(30, 33, 136, 1) 0%, rgba(67, 70, 130, 1) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom, rgba(30, 33, 136, 1) 0%, rgba(67, 70, 130, 1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#1e2188', endColorstr='#434682', GradientType=0); /* IE6-9 */
    z-index: 100;
}

#lnb {
    width: 900px;
    margin: 0 auto;
}

#lnb > li {
    float: left;
    text-align: center;
    line-height: 38px;
    border-left: 1px solid #34557d;
}

#lnb li:last-child {
    border-right: 1px solid #34557d;
}

#lnb > li a {
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    opacity: 0.6;
    display: block;
    transition: opacity .3s ease
}

#lnb > li a:hover, #lnb > li a.active {
    opacity: 1;
}

.sub_visual_area {
    margin-top: 126px;
    display: flex;
    width: 100%;
    height: 120px;
    min-width: 1170px;
    align-items: center;
    justify-content: center;
}

.sub_visual_company {
    background: #fff url(/img/sub_visual_company.jpg) no-repeat center center;
}

.sub_visual_community {
    background: #fff url(/img/sub_visual_community.jpg) no-repeat center center;
}

.sub_visual_business {
    background: #fff url(/img/sub_visual_business.jpg) no-repeat center center;
}

.sub_visual_area .title {
    font-size: 35px;
    color: #333;
    font-weight: 500;
    text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.5);
}

.sub_visual_area .white {
    color: #fff;
    text-shadow: 2px 2px 11px rgba(0, 0, 0, .5);
}

#subwrap {
    padding-top: 25px;
    padding-bottom: 70px;
}

.sub_page_title {
    padding: 8px 0 8px 0;
    font-size: 29px;
    letter-spacing: -1px;
    color: #333333;
    text-align: center;
    font-weight: 400;
    font-family: "Nanum Square";
    margin: 5px 0 20px;
}

.sub_page_title span:after {
    content: '';
    display: block;
    width: 15px;
    height: 1px;
    margin: 10px auto 0;
    background: #1e2188;
}

.ceo-bg {
    background: #fff url(/img/ceo_bg.jpg) no-repeat right 90%;
}

.ceo p {
    font-size: 16px;
    font-family: "NanumSquare";
    padding-bottom: 7px;
    padding-left: 50px;
}

.ceo .welcome {
    font-size: 22px;
    font-family: "Nanum Square";
    font-weight: 700;
    text-align: center;
    width: 100%;
    padding-bottom: 50px;
}

.ceo .welcome > span {
    color: #1e2188;
}

.history-lists {
    margin-top: 35px;
    position: relative;
    display: inline-block;
    width: 100%;
    padding: 25px 0 95px;
    vertical-align: top
}

.history-lists:before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    width: 1px;
    height: 100%;
    background-color: #ccc;
}

.history-lists .even {
    position: relative;
    clear: both;
    float: left;
    width: 50%;
    margin-left: 50%;
    margin-top: 10px
}

.history-lists .even:before {
    content: "";
    position: absolute;
    top: 0;
    left: -3px;
    background-image: url('/img/sprite.png');
    background-position: 0 7px;
    width: 50px;
    height: 7px
}

.history-lists .even ul {
    padding-left: 56px;
    clear: both;
    margin-top: -18px
}

.history-lists .even ul li {
    display: inline-block;
    width: 100%;
    margin-top: 10px;
    vertical-align: top
}

.history-lists .even ul li .history-date {
    float: left;
    width: 70px;
    padding-right: 14px;
    font-family: "Roboto", sans-serif;
    font-weight: 500;
    font-size: 17px;
    line-height: 26px;
    color: #1e2188;
    text-align: right
}

.history-lists .even ul li .history-txt {
    overflow: hidden;
    font-family: "NanumSquare", sans-serif;
    font-weight: 300;
    font-size: 17px;
    line-height: 26px;
    color: #333;
    margin-bottom: 10px;
}

.history-lists .odd {
    position: relative;
    clear: both;
    float: left;
    width: 50%;
    margin-top: 10px
}

.history-lists .odd:before {
    content: "";
    position: absolute;
    top: 0;
    right: -4px;
    background-image: url('/img/sprite.png');
    background-position: 0 0;
    width: 50px;
    height: 7px
}

.history-lists .odd ul {
    padding-right: 56px;
    clear: both;
    margin-top: -18px
}

.history-lists .odd ul li {
    display: inline-block;
    width: 100%;
    margin-top: 10px;
    vertical-align: top;
    text-align: right
}

.history-lists .odd ul li .history-date {
    float: right;
    padding-left: 14px;
    width: 73px;
    font-family: "Roboto", sans-serif;
    font-weight: 500;
    font-size: 17px;
    line-height: 26px;
    color: #1e2188;
    text-align: left
}

.history-lists .odd ul li .history-txt {
    overflow: hidden;
    font-family: "NanumSquare", sans-serif;
    font-weight: 400;
    font-size: 17px;
    line-height: 26px;
    color: #333;
    margin-bottom: 10px;
}

.part .part-wrap.line1 {
    min-height: 600px;
}

.part .part-wrap.line2 {
    min-height: 400px;
}

.part .part-wrap .left {
    float: left;
    margin-right: 18px;
}

.part .part-wrap .right {
    float: right;
}

.part .part-wrap .cont {
    padding-left: 20px;
    padding-top: 25px;
    position: relative;
}

.part .part-wrap .cont .list {
    position: absolute;
    left: 194px;
    top: 26px;
    padding-left: 5px;
    font-family: "NanumSquare"
}

.part .part-wrap .title {
    position: relative;
    font-size: 25px;
    font-weight:400;
    color:#111;
}

.part .part-wrap .title:before {
    content: "";
    position: absolute;
    top: -5px;
    left: 0;
    width: 25px;
    height: 3px;
    background: #1e2188;
}

.li-dot li::before {
    content: "• ";
    color: #1e2188;
}

.li-dot li {
    padding-left: 0;
    text-indent: -11px !important;
    line-height: 28px
}
.li-dot.ov > li {
    padding-left: 10px;
}
.license .list li {
    background: #f9f9f9 url('/img/license_bg.png') -2px -7px no-repeat;
    color: #000;
    float: left;
    margin-right: 10px;
    display: block;
    width: 277px;
    padding: 50px 30px;
    margin-bottom: 10px;
    font-size: 20px;
    font-family: "Noto Sans KR";
    font-weight: 500;
    border: 1px solid #ddd;
}

.license .list li:nth-child(4n+0) {
    margin-right: 0;
}

.license .list li i {
    display: block;
    font-family: "Roboto";
    font-weight: 300;
    font-size: 0.9em;
}

.equip-wrap {
    padding: 30px 0;
    border-bottom: 1px solid #efefef
}

.equip-wrap:first-child {
    padding-top: 0;
}

.equip-wrap:last-child {
    border-bottom: 0;
}

.equip-wrap > .image {
    width: 300px;
    float: left;
}

.equip-wrap > .image img {
    border: 1px solid #ccc;
}

.equip-wrap > .cont {
    width: 840px;
    float: right;
    padding-top: 22px;
}

.equip-wrap > .cont .title {
    font-size: 25px;
    font-weight: 500;
    position: relative;
    padding-left: 6px;
}

.equip-wrap > .cont .title::before {
    content: "";
    position: absolute;
    top: 6px;
    left: -10px;
    width: 5px;
    height: 20px;
    background: #1e2188;
}

.equip-wrap > .cont .list {
    font-family: "NanumSquare";
    padding-left: 4px;
}

.patent img {
    width: 200px;
    border: 1px solid #ddd;
}

.patent .list {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.patent .list > li {
    width: 200px;
    float: left;
    margin-right: 35px;
    margin-bottom: 50px;
    position: relative;
}

.patent .list > li > p {
    text-align: center;
    font-weight: 500;
    font-size: 14.5px;
    padding-top: 10px;
    letter-spacing: -0.5px;
}

.patent .list > li:nth-child(5n+0) {
    margin-right: 0;
}

.patent .list > li {
    overflow: hidden;
}

.patent .list > li:hover .ov {
    transform: translateY(322px);
}

.patent .list > li .ov {
    position: absolute;
    top: -322px;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 282px;
    color: #fff;
    padding: 30px 15px;
    font-size: 14.5px;
    letter-spacing: -0.5px;
    transition: all .3s;
}

.patent .list > li .ov .plus {
    position: absolute;
    top: 42%;
    left: 38%;
    font-size: 40px;
    text-align: center;
}

.patent .list > li .ov .plus > img {
    border: 0;
    width: 50px;
}

.li-dot.ov li::before {
    color: #fff;
}

.li-dot.ov li.plus::before {
    content: none;
}

.lb-data .lb-caption {
    color: #fff;
}

h3.sub-title {
    font-size:25px;
    position: relative;
    padding-left: 15px;
    padding-bottom: 12px;
}

h3.sub-title::before {
    content: "";
    position: absolute;
    top: 5px;
    left: 0;
    width: 5px;
    height: 22px;
    background: #1e2188;
}

.line01 {
    height: 1px;
    width: 100%;
    background: #ddd;
    margin: 50px 0;
}

.table01 {
    width: 100%;
}

.table01 tr td {
    border: 1px solid #ededed;
}

.table01 th {
    font-size: 17px;
    line-height: 42px;
    background-color: #fafafa;
    border: 1px solid #ddd;
    border-top: 2px solid #666;
    border-bottom: 1px solid #afafaf;
    text-align: center;
    font-weight: 500;
}

.table01 td {
    text-align: center;
    border-left: 1px solid #ddd;
    font-weight: 400;
    padding: 15px 10px;
    vertical-align: middle
}

.table01 td:first-child {
}

.main-result h3.title {
    font-size: 20px;
    font-weight: 500;
    position: relative;
    padding-left: 12px;
    margin-top:50px;
}

.main-result h3.title::before {
    content: "";
    position: absolute;
    top: 5px;
    left: 0;
    width: 5px;
    height: 15px;
    background: #1e2188;
}

.main-result table {
    width: 100%;
}

.main-result table tr td {
    border: 1px solid #ededed;
}

.main-result table tr:first-child > td {
    font-size: 16px;
    line-height: 22px;
    background-color: #f3f3f3;
    border: 1px solid #ddd;
    border-top: 2px solid #666;
    border-bottom: 1px solid #afafaf;
    text-align: center;
    font-weight: 500;
}

.main-result table td {
    text-align: center;
    border-left: 1px solid #ddd;
    font-weight: 400;
    padding: 10px 10px;
    vertical-align: middle;
    font-size:15px;
}
.main-result table tr td:first-child {
    width:600px;
}
.main-result table tr td:nth-child(2n) {
    width:120px;
}
.main-result table tr td:nth-child(3n) {
    width:120px;
}
.main-result table tr td:last-child {
    width:260px;
}


.main-result .nav-tabs {
    justify-content: center;
}
.main-result .nav-tabs li {
    width:135px;
    height:40px;
    line-height:37px;
    border:1px solid #ddd;
    text-align: center;
    margin:2px;

}
.nav-tabs {
    border-bottom: 0;
}
.main-result .nav-tabs li > a {
    display:block;
    font-weight: 500;
    color:#555;
    transition: all 0.2s;
    font-family: "Roboto", "Noto Sans KR";
}
.main-result .nav-tabs li a.active,
.main-result .nav-tabs li a:hover {
    background-color:#1e2188;
}
.main-result .nav-tabs li a.active,
.main-result .nav-tabs li a:hover {
    color:#fff;
}
.main-result .nav-tabs li:nth-child(8n+1) {
    margin-left:0;
}
.main-result .nav-tabs li:nth-child(8n+8) {
    margin-right:0;
}

@media (min-width: 768px) {
    .container {
        max-width: 720px;
        min-width: 1140px;
    }
    .main-slide-wrap {
        max-height:876px
    }
}
.promotion .pcol1 {
    margin-right: 55px;
}
/*.promotion .pcol2 {
    margin-right: 62px;
}*/
.promotion .list > li > a > img {
    width: 150px;
    height:192px;
    border: 1px solid #ddd;
}

.promotion .list {
    width: 100%;
}

.promotion .list > li {
    width: 150px;
    float: left;
    margin-right: 15px;
    position: relative;
}
.promotion .pcol2 .list > li {
    margin-right: 0
}
.promotion .list > li > p {
    text-align: center;
    font-weight: 500;
    font-size: 14.5px;
    padding-top: 10px;
    letter-spacing: -0.5px;
}

.promotion .list > li:nth-child(5n+0) {
    margin-right: 0;
}

.promotion .list > li {
    overflow: hidden;
}

.promotion .list > li:hover .ov {
    transform: translateY(322px);
}

.promotion .list > li .ov {
    position: absolute;
    top: -322px;
    left: 0;
    background-color: rgba(0, 0, 0, 0.7);
    width: 100%;
    height: 282px;
    color: #fff;
    padding: 30px 15px;
    font-size: 14.5px;
    letter-spacing: -0.5px;
    transition: all .3s;
}

.promotion .list > li .ov .plus {
    position: absolute;
    top: 67px;
    left: 50px;
}

.promotion .list > li .ov .plus > img {
    border: 0;
    width: 50px;
}

h3.promotion-title {
    font-size:16px;
    font-family: "Roboto";
    position: relative;
    padding-left: 15px;
    padding-bottom: 12px;
}

h3.promotion-title::before {
    content: "";
    position: absolute;
    top: 3px;
    left: 0;
    width: 5px;
    height: 14px;
    background: #1e2188;
}
