@charset "utf-8";

/* =================================================================
 * 공통
 * ================================================================= */
.xw-center { display:table; margin-left:auto; margin-right:auto; }
.mb-0 { margin-bottom: 0; }
.mb-10 { margin-bottom: 10px; }
.mb-20 { margin-bottom: 20px; }
.mb-30 { margin-bottom: 30px; }
.mb-50 { margin-bottom: 50px; }
.d-ib { display: inline-block; }
.w-lg { font-size: 1.1em; }
.w-strong { color: #e45236; }
.w-strong2 { color: #a10f2b; }
.w-300 { font-weight: 300; }
.w-500 { font-weight: 500; }
.w-600 { font-weight: bold; }

.btn { font-size: 15px; }
.content.ct-bg { background: #f5f5f5; }

.headline {
    position: relative; top: 10px; padding-bottom: 50px;
    font-size: 22px; font-weight: 500; text-align: center; color: #333;
}
.headline:before {
    content: ""; position: absolute; top: -5px; left: 50%; margin-left: -15px;
    width: 30px; height: 2px; background-color: #90bf39;
}
@media (max-width: 767px) {
    .headline { font-size: 20px; padding-bottom: 30px; }
}
.headline-line { position: relative; }
.headline-line:before {
    content: ""; position: absolute; top: 50%; left: -40px; width: 30px; height: 1px; background-color: #333;
}
.headline-line:after {
    content: ""; position: absolute; top: 50%; right: -40px; width: 30px; height: 1px; background-color: #333;
}

.skew { position: relative; overflow: hidden; background-color: #90bf39; }
.skew-25r {
    transform:skewX(25deg);
    -webkit-transform:skewX(25deg);
    -ms-transform:skewX(25deg);
}
.skew-25l {
    transform:skewX(-25deg);
    -webkit-transform:skewX(-25deg);
    -ms-transform:skewX(-25deg);
}
.skew-y-25r {
    transform:skewY(25deg);
    -webkit-transform:skewY(25deg);
    -ms-transform:skewY(25deg);
}
.skew-y-25l {
    transform:skewY(-25deg);
    -webkit-transform:skewY(-25deg);
    -ms-transform:skewY(-25deg);
}

/* 메뉴이미지 V1 시작 */
.menu_v1 {
    position: relative; display: block; height: 100px; min-width: 100px;
    color: #fff; background-color: #627080; border-radius: 0 10px 10px 0;
    margin-left: 50px; padding: 6px 0 6px 0px; z-index: 3;
    text-align: center;
}
.menu_v1:before {
    content: ""; width: 90px; height: 86px; background-color: #3aafbe; border-radius: 10px 0 0 10px;
    position: absolute; left: -50px; top: 7px; z-index: 2;
}
.menu_v1:after {
    content: ""; width: 60px; height: 60px; background-color: #3aafbe; border-radius: 45%;
    position: absolute; left: 0px; top: 20px; z-index: 1;
}
.menu_v1 > i.fa { position: absolute; left: -20px; top: 32px; color: #fff; z-index: 4; font-size: 36px; }

.bg_main, .bg_main_before:before, .bg_main_after:after { background-color: #90bf39 !important; }
.bg_cyan, .bg_cyan_before:before, .bg_cyan_after:after { background-color: #3aafbe !important; }
.bg_blue, .bg_blue_before:before, .bg_blue_after:after { background-color: #4a92cc !important; }
.bg_orange, .bg_orange_before:before, .bg_orange_after:after { background-color: #e6663f !important; }
.bg_green, .bg_green_before:before, .bg_green_after:after { background-color: #8bc34a !important; }
.bg_purple, .bg_purple_before:before, .bg_purple_after:after { background-color: #9b6bcc !important; }
.bg_yellow, .bg_yellow_before:before, .bg_yellow_after:after { background-color: #f1c40f !important; }
.bg_black, .bg_black_before:before, .bg_black_after:after { background-color: #333 !important; }

.color_main, .color_main_before:before, .color_main_after:after { color: #90bf39 !important; }
.color_cyan, .color_cyan_before:before, .color_cyan_after:after { color: #3aafbe !important; }
.color_blue, .color_blue_before:before, .color_blue_after:after { color: #4a92cc !important; }
.color_orange, .color_orange_before:before, .color_orange_after:after { color: #e6663f !important; }
.color_green, .color_green_before:before, .color_green_after:after { color: #8bc34a !important; }
.color_purple, .color_purple_before:before, .color_purple_after:after { color: #9b6bcc !important; }
.color_yellow, .color_yellow_before:before, .color_yellow_after:after { color: #f1c40f !important; }
.color_gray, .color_gray_before:before, .color_gray_after:after { color: #777 !important; }
.color_white, .color_white_before:before, .color_white_after:after { color: #fff !important; }
/* 메뉴이미지 V1 끝 */

.division-bar {
    background-color: #627080; color: #fff;
    text-align: center; font-size: 28px; font-weight: bold; padding: 50px;
}
@media (max-width: 767px) {
    .division-bar { font-size: 18px; padding: 20px; }
}

/* 이미지 */
.ct-img-wrap { overflow: hidden; position: relative; text-align: center; }
.ct-img {
    background-size: cover; background-repeat: no-repeat; background-position: center center;
    position: relative; overflow: hidden;
    display: block;
    transition-duration : 1.5s;
    -webkit-transition-duration : 1.5s;
    -ms-transition-duration : 1.5s;
    animation-duration : 1.5s;
    -webkit-animation-duration : 1.5s;
    -ms-animation-duration : 1.5s;
}
.ct-img-tent {
    position: absolute;
    bottom: 0px; left: 0px; right: 0px;
    background-color: #90bf39;
    text-align: center;
    padding: 5px 2px;
    color: #fff;
    font-weight: 300;
    white-space: nowrap;
    overflow: hidden;
    transition-duration : 1s;
    -webkit-transition-duration : 1s;
    -ms-transition-duration : 1s;
    animation-duration : 1s;
    -webkit-animation-duration : 1s;
    -ms-animation-duration : 1s;
}
.ct-img-tent.tent-top {
    top: -30px; bottom: 0;
    padding: 55px 0;
}
.ct-img:hover ~ .ct-img-tent { bottom: 7px; }

.ct-img-mark {
    width: 180px;
    position: absolute; bottom: 20px; left: 50%; margin-left: -90px;
    padding: 2px 10px;
    border: 2px solid #ddd; color: #fff; background-color: #333;
    opacity: 0;
    -webkit-transition: opacity 1.5s, background-color 1.5s;
    transition: opacity 1.5s, background-color 1.5s;
}
.ct-img:hover ~ .ct-img-mark { opacity: 1; }

.rotate-tr {
    display: inline-block;
    transform: rotate(5deg);
    -webkit-transform: rotate(5deg);
    -ms-transform:rotate(5deg);
}
.rotate-tl {
    display: inline-block;
    transform: rotate(-5deg);
    -webkit-transform: rotate(-5deg);
    -ms-transform:rotate(-5deg);
}


/* =========================================================================================
 * 메인
 * ========================================================================================= */
.body-wrap[data-page="index"] .top-header { background-color: rgba(0,0,0,.3); box-shadow: 0px 1px 0px rgba(0,0,0,.3); }
.body-wrap[data-page="index"] .top-header .logo .logo-img { background-image: url('/img/logo_text_white.png'); }
.body-wrap[data-page="index"] .gnb .navbar-nav > li > a,
.body-wrap[data-page="index"] .gnb .navbar-nav > li:hover > a,
.body-wrap[data-page="index"] .gnb .navbar-nav > li.active > a { color:#fff; }
.body-wrap[data-page="index"] .gnb .submenu > li > a { color:#fff; }
.body-wrap[data-page="index"] .gnb .submenu { background: rgba(63,57,51,.9); }
.body-wrap[data-page="index"] .gnb .submenu > li { border-bottom: 1px solid rgba(30,30,30,.2); }
.body-wrap[data-page="index"] .gnb .submenu > li:hover > a { background: rgba(63,57,51,1); }

.body-wrap[data-page="index"] .swiper-pagination-bullet:not(.swiper-pagination-bullet-active) { background: #eee; }
@media (max-width: 767px) {
    .body-wrap[data-page="index"] .top-header { background-color: #fff; box-shadow: 0px 1px 0px #eee; }
    .body-wrap[data-page="index"] .top-header .logo .logo-img { background-image: url('/img/logo_text.png'); }
    .body-wrap[data-page="index"] .gnb .navbar-nav > li > a,
    .body-wrap[data-page="index"] .gnb .navbar-nav > li:hover > a,
    .body-wrap[data-page="index"] .gnb .navbar-nav > li.active > a,
    .body-wrap[data-page="index"] .gnb .submenu > li > a { color:#333; }
    .body-wrap[data-page="index"] .gnb .submenu { background: rgba(255,255,255,1); }
    .body-wrap[data-page="index"] .gnb .submenu > li { border-bottom: 1px solid #f7f7f7; }
    .body-wrap[data-page="index"] .gnb .submenu > li:hover > a { background: #f7f7f7; }
}

#index .index-content1 { padding: 70px 0; max-width: 950px; margin: 0 auto; }
#index .index-content1 .content-img {
    background-image: url('/img/logo_white.png'); height: 200px;
    background-position: top center; background-repeat: no-repeat;
}
#index .index-content1 .content-txt { padding-top: 35px; }
#index .index-content1 .content-txt p {
    line-height: 1em; font-weight: 300; font-size: 36px; letter-spacing: 3px;
    padding: 3px 10px; color: #fff; background-color: rgba(136,117,102,.0);
}
#index .index-content1 .content-txt p:not(:last-child) { margin-bottom: 40px; }
@media (min-width: 768px) and (max-width: 1023px) {
    #index .index-content1 .content-txt { padding-top: 45px; }
    #index .index-content1 .content-txt p { font-size: 30px; }
}
@media (max-width: 767px) {
    #index .index-content1 { padding: 10px 0 35px 0; }
    #index .index-content1 .content-img  { background-image: none; height: 55px; margin-bottom: 30px; }
    #index .index-content1 .content-txt { padding-top: 0px; margin-left: -20px; margin-right: -20px; text-align: center; }
    #index .index-content1 .content-txt p { font-size: 22px; letter-spacing: 1px; }
    #index .index-content1 .content-txt p:not(:last-child) { margin-bottom: 20px; }
}

#index .product-swiper { text-align: center; padding: 15px 25px 10px 25px; background-color: rgba(0,0,0,.3); }
#index .product-swiper .product-title { margin-bottom: 25px; font-size: 18px; color: #fff; font-weight: 300; }
#index .product-swiper .product-title .headline-line:before, #index .product-swiper .product-title .headline-line:after {
    background-color: #fff;
}
#index .product-swiper .swiper-container { padding-bottom: 50px; }
#index .product-swiper .swiper-slide img { width: 100%; }
#index .product-swiper .swiper-slide .ct-img-tent { font-size: 13px; }
@media (min-width: 768px) and (max-width: 1023px) {
    #index .product-swiper .product-title { font-size: 16px; }
}
@media (max-width: 767px) {
    #index .product-swiper { padding: 10px 25px 0 25px; }
    #index .product-swiper .product-title { margin-bottom: 15px; font-size: 15px; }
    #index .product-swiper .swiper-slide .ct-img-tent { font-size: 12px; padding: 4px 3px; }
}

/* 메인 게시판 최신글 리스트 */
/*
.board-wrap { border-top: 2px solid #90bf39; min-height: 265px; }
.board-wrap .board-title {
    position: relative; font-size: 18px; font-weight: 500; margin-bottom: 20px; padding-bottom: 10px;
    border-bottom: 1px solid #ddd;
}
.board-wrap .board-title > a { display: block; }
.board-wrap .board-title i {
    position: absolute; right: 10px; top: 5px; font-size: 16px; font-size: 500;
}
*/

/* =========================================================================================
 * 회사소개
 * ========================================================================================= */
/* 4LABS 소개 */
#company { text-align: justify; word-break : break-all; }
#company .logo-wrap { position: relative; text-align: center; }
#company .logo-wrap img { width: 60%; margin-top: 5px; }
#company .logo-wrap svg { padding: 5px 0px 15px 0px; margin-left: 30px; width: 120px; color: #90bf39; }

#company .vision { margin-top: 70px; }
#company .vision > div {
    display: inline-block; padding: 2px 15px; margin-bottom: 10px; border-radius: 5px;
    background-color: #806c73; color: #fff;
}
#company .vision > ul { margin-left: -15px; }
#company .vision > ul > li { padding: 5px 0; }
@media (max-width: 991px) {
    #company .logo-wrap img { width: 80%; }
    #company .vision { margin-top: 50px; }
}
@media (max-width: 767px) {
    #company .vision { margin-top: 40px; }
}

/* 회사 연혁 */
#history .history-list {
    max-width: 900px; margin-left: auto; margin-right: auto; display: table;
}
#history .history-list dl { position: relative; margin-bottom: 15px; text-align: justify; word-break : break-all; }
#history .history-list dl > dt { display: inline-block; position: absolute; visibility: hidden; }
#history .history-list dl.year-visible > dt {
    font-size: 24px; font-weight: 400; color: #74825c; top: 5px; visibility: visible;
}
#history .history-list dl.year-visible > dt:before {
    position: absolute; left: 0; width: 55px; content: ''; height: 1px; background-color: #74825c;
}
#history .history-list dl.year-visible:not(:first-child) { margin-top: 50px; }
#history .history-list dl > dd { display: inline-block; list-style: none; padding: 0; margin: 0; }
#history .history-list dl > dd:nth-of-type(1) { position: absolute; margin-left: 130px; }
#history .history-list dl > dd:nth-of-type(2) { margin-left: 165px; }
@media(max-width: 767px) {
    #history .history-list {
        background-image: url("/img/worldmap-op.png");
        background-position: right center;
        background-repeat: no-repeat;
        background-size: contain;
    }
    #history .history-list dl { margin-bottom: 10px; }
    #history .history-list dl.year-visible:not(:first-child) { margin-top: 30px; }
    #history .history-list dl.year-visible > dt { display: block; position: relative; margin-bottom: 15px; font-size: 20px; }
    #history .history-list dl.year-visible > dt:before { width: 45px; }
    #history .history-list dl > dd:nth-of-type(1) { margin-left: 0; }
    #history .history-list dl > dd:nth-of-type(2) { margin-left: 30px; }
}

/* 특허/인증/수상 이력 */
#certification .certify-list { padding: 15px 0; }
#certification .certify-unit { width: 55%; margin: 0 auto; margin-bottom: 40px; }
#certification .certify-list > .row:last-of-type > div > .certify-unit { margin-bottom: 0px; }
#certification .certify-unit img { border: 5px solid #ccc; width: 100%; }
#certification .certify-unit img:hover { border: 5px solid #90bf39; transition:all 700ms ease; cursor: pointer; }
#certification .certify-unit ul { margin: 10px 0 0 -20px; list-style: square; font-size: .9em; text-align: justify; word-break : break-all; }

#certification .certify-view-bg {
    display:none; position:fixed; background-color:rgba(0,0,0,.8); top:0px; left:0px; width:100%; height:100%; z-index:1998;
}
#certification .certify-view-bg .certify-view { margin: 0 auto; margin-top: 80px; width: 510px; border: 5px solid #90bf39; z-index:1999; }
#certification .certify-view-bg .certify-view img { width: 100%; }
@media (max-width: 1023px) {
    #certification .certify-list { padding: 0px; }
    #certification .certify-unit { width: 80%; }
}
@media (max-width: 767px) {
    #certification .certify-list > .row:last-of-type > div > .certify-unit { margin-bottom: 40px; }
    #certification .certify-list > .row:last-of-type > div:last-of-type > .certify-unit { margin-bottom: 0px; }
}

/* 오시는길 */
#location .location-info { margin-top: 20px; text-align:justify; word-break : break-all; }
#location .location-info > table td { padding: 2px; }
#location .location-info > table tr > td:first-of-type { padding-right: 20px; vertical-align: top; min-width: 95px; }
@media (max-width: 767px) {
    #location .location-info > table tr > td:first-of-type { padding-right: 5px; }
}

/* =========================================================================================
 * 무선충전모듈
 * ========================================================================================= */
#product { max-width: 940px; position: relative; }
#product .product-title {
    display: inline-block; margin: 5px auto; padding: 3px 15px; border-radius: 5px; width: 86%;
    color: #fff; background: #806c73;
}
#product img { width: 100%; }

#product .product-info { margin-left: auto; margin-right: auto; display: table; text-align:justify; word-break : break-all; }
#product .product-info dl { margin-bottom: 50px; }
#product .product-info dl:last-child { margin-bottom: 0; }
#product .product-info dt { margin-bottom: 10px; font-size: 1.1em; font-weight: 500; }
#product .product-info dd > ul { list-style: square; margin-left: -20px; }
#product .product-info dd > ul > li { margin-bottom: 10px; }

#product .product-info .product-info-title { margin-bottom: 10px; font-size: 1.1em; font-weight: 500; }
#product .product-info table { margin-bottom: 0; }
#product .product-info table tr:first-child td { border-top: 1px solid #555; }
#product .product-info table tr:last-child td { border-bottom: 1px solid #555; }
#product .product-nav { padding-top: 5px; text-align: right; }
#product .product-nav a {
    padding: 0px 8px; font-size: 28px; line-height: 1; color: #fff; background-color: #888; opacity: .7;
}
#product .product-nav a:hover { opacity: 1; }
@media (max-width: 767px) {
    #product img { margin-bottom: 30px; }
    #product .product-info dl { margin-bottom: 30px; }
    #product .product-info table td { padding: 8px 2px; font-size: 13.5px; }
}

/* 고속무선충전 송신모듈 */

/* 무선충전 수신모듈 */
#product.product-rx .product-title { width: 78%; }
@media (max-width: 767px) {
    #product.product-rx .product-title { width: 55%; }
    #product.product-rx img { width: 70%; }
}

/* 무선충전 코일 */
#product.product-coil .product-info { width: 90%; }
@media (max-width: 767px) {
    #product.product-coil .product-info { width: 100%; }
}

/* =========================================================================================
 * OEM/ODM 개발
 * ========================================================================================= */
#product.product-oem .product-info { margin-top: 20px; }
#product.product-oem[data-oem="12"] .product-img-wrap,
#product.product-oem[data-oem="5"] .product-img-wrap,
#product.product-oem[data-oem="3"] .product-img-wrap,
#product.product-oem[data-oem="2"] .product-img-wrap { text-align: right; }
#product.product-oem[data-oem="12"] img { width: 80%; }
#product.product-oem[data-oem="5"] img { width: 70%; }
#product.product-oem[data-oem="3"] img { width: 70%; }
#product.product-oem[data-oem="2"] img { width: 85%; }
@media (max-width: 1023px) {
    #product.product-oem .product-info { margin-top: 0; }
}
@media (max-width: 767px) {
    #product.product-oem .product-info { margin-top: 0; }
    #product.product-oem[data-oem="12"] .product-img-wrap,
    #product.product-oem[data-oem="5"] .product-img-wrap,
    #product.product-oem[data-oem="3"] .product-img-wrap,
    #product.product-oem[data-oem="2"] .product-img-wrap { text-align: center; }
    #product.product-oem[data-oem="5"] img { width: 65%; }
}

/* =========================================================================================
 * 제휴/문의
 * ========================================================================================= */
#contact { max-width: 900px; margin: 0 auto; }
#contact .contact-msg { padding-left: 5px; padding-right: 5px; text-align:justify; word-break : break-all; }
#contact table { border-top: 2px solid #555; }
#contact table tr:last-of-type > td { border-top: 1px solid #555; }
#contact table tr > td:first-of-type { padding-left: 20px; vertical-align: middle; width: 28%; }

#contact table input, #contact table textarea, #contact table select {
    border: 1px solid #bbb; border-radius: 4px; padding: 3px 5px; background-color: transparent;
}
#contact table button { width: 100px; color: #555; }
#contact table button:hover { background-color: #90bf39; color: #fff; }
#contact table .far, #contact table .fas { margin-right: 5px; }

@media (max-width: 767px) {
    #contact table td { padding: 4px; }
    body:lang(en) #contact table tr > td:first-of-type { padding: 4px 0; width: 32%; }
    #contact table input, #contact table textarea, #contact table select { padding: 2px 5px; }
}
