@charset "utf-8";
/*
 * Name     : main.css
 * Version  : 1.0
 * Author   : onepixel studio
 * Date     : 2020-05-15
 ---------------------------------------------------
 Table of contents
 ---------------------------------------------------
    01. Hero
    02. Common
    03. Notify
    04. About
    05. Product
    06. Banner group
    07. Contact form
    08. Wide map
    09. Media queries
---------------------------------------------------
*/

/* ------------------------------
 * Hero
------------------------------ */
.main .hero-swiper {height: 100vh}
.main .hero-swiper .swiper-slide {background-size: cover; background-position: center; background-repeat: no-repeat}
.main .hero-swiper .item-01 {background-image: url(../images/main_hero_img01.jpg)}
.main .hero-swiper .item-02 {background-image: url(../images/main_hero_img02.jpg)}
.main .hero-swiper .item-03 {background-image: url(../images/main_hero_img03.jpg)}
.main .hero-swiper .item-04 {background-image: url(../images/main_hero_img04.jpg)}
.main .hero-swiper .item-05 {background-image: url(../images/main_hero_img05.jpg)}
.main .hero-swiper .item-06 {background-image: url(../images/main_hero_img06.jpg)}
.main .hero-swiper .hero-caption {padding: 0 200px}

.main .hero-swiper .hero-caption h2, .main .hero-swiper .hero-caption h3 {font-weight: 600; color: #fff; line-height: 1.15; opacity: 0; transform: translateX(-30px); transition: opacity .8s, transform .8s; transition-delay: 350ms}
.main .hero-swiper .hero-caption h2 {font-size: 68px; text-shadow: 0 0 10px rgba(0,0,0,.8);}
.main .hero-swiper .hero-caption h3 {font-size: 58px; text-shadow: 0 0 10px rgba(0,0,0,.8);}
.main .hero-swiper .hero-caption h2 a {text-shadow: none;}
.main .hero-swiper .hero-caption h3 span {display:inline-block; font-size: 22px; vertical-align:top; margin-top:10px; margin-left:5px}
.main .hero-swiper .hero-caption p {font-size: 18px; color: #fff; line-height: 1.5; letter-spacing: -0.05rem; opacity: 0; transform: translateX(-30px); transition: opacity .8s, transform .8s; transition-delay: 500ms; text-shadow: 0 0 10px rgba(0,0,0,.8);}
.main .hero-swiper .hero-caption .btn-more {display: inline-block; font-size: 15px; font-weight: 700; color: #212529; letter-spacing: -0.05rem; text-align: center; margin-top: 40px; padding: 13px 30px; min-width: 150px; border-radius: 30px; background-color: #fff; opacity: 0; transform: translateX(-30px); transition: box-shadow .2s, opacity .8s 1s, transform .8s 1s}
.main .hero-swiper .hero-caption .btn-more:hover {box-shadow: 6px 6px 14px rgba(0,0,0,.24)}
.main .hero-swiper .swiper-slide-active .hero-caption h2, .main .hero-swiper .swiper-slide-active .hero-caption h3, .main .hero-swiper .swiper-slide-active .hero-caption p, .main .hero-swiper .swiper-slide-active .hero-caption .btn-more {opacity: 1; transform: translateX(0)}
.main .hero-swiper .navigation-arrow > button {position: absolute; top: 50%; width: 120px; font-size: 15px; font-weight: 600; color: #fff; letter-spacing: 0.1rem; margin-top: -10px; padding: 0; border: 0; background-color: transparent; cursor: pointer; outline: 0; z-index: 10}
.main .hero-swiper .navigation-arrow > button .arrow {position: absolute; display: inline-block; top: 10px; width: 40px; height: 2px; background-color: #fff; transition: width .35s}
.main .hero-swiper .navigation-arrow > button .arrow:before {content: ''; position: absolute; display: block; top: -5px; width: 13px; height: 2px; background-color: #fff}
.main .hero-swiper .navigation-arrow > .prev {left: 30px; padding-left: 40px}
.main .hero-swiper .navigation-arrow > .prev .arrow {left: 0}
.main .hero-swiper .navigation-arrow > .prev .arrow:before {left: -1px; transform: rotate(-45deg)}
.main .hero-swiper .navigation-arrow > .next {right: 30px; padding-right: 40px}
.main .hero-swiper .navigation-arrow > .next .arrow {right: 0}
.main .hero-swiper .navigation-arrow > .next .arrow:before {right: -1px; transform: rotate(45deg)}
.main .hero-swiper .navigation-arrow > button:hover .arrow {width: 25px}
.main .hero-swiper .swiper-pagination {bottom: 6%}
.main .hero-swiper .swiper-pagination .swiper-pagination-bullet {width: 10px; height: 10px; margin: 0 6px; background-color: rgba(255,255,255,.6)}
.main .hero-swiper .swiper-pagination .swiper-pagination-bullet-active {background-color: #fff}
.main .hero-swiper .scroll-indicator {position: absolute; bottom: 12%; left: 0; right: 0; width: 80px; margin: auto; z-index: 10; cursor: pointer}
.main .hero-swiper .scroll-indicator span {display: block; font-size: 12px; font-weight: 700; color: #fff; text-align: center; letter-spacing: 0.05rem; margin-bottom: 12px}
.main .hero-swiper .scroll-indicator .mouse {position: relative; width: 36px; height: 58px; margin: auto; border: 2px solid rgba(255,255,255,.6); border-radius: 36px}
.main .hero-swiper .scroll-indicator .wheel {position: absolute; top: 8px; left: 50%; width: 3px; height: 8px; margin-left: -1.5px; border-radius: 6px; background-color: #fff; animation: wheel-ani 1s linear infinite}
@keyframes wheel-ani {
    0% {opacity: 0; transform: translateY(0)}
    25% {opacity: 1; transform: translateY(10px)}
    75% {opacity: 1; transform: translateY(10px)}
    100% {opacity: 0; transform: translateY(10px)}
}

/* ------------------------------
 * Common
------------------------------ */
.main .large-heading h2 {font-size: 38px; font-weight: 700; color: #212529}
.main .large-heading h2 span {display:inline-block; vertical-align: top; font-size:22px; margin-top:5px}
.main .large-heading p {font-size: 17px; color: #343a40; line-height: 1.7; letter-spacing: -0.05rem}
.main .large-heading .view-more {display: inline-block; font-size: 19px; font-weight: 500; color: #333}
.main .large-heading .view-more:after {content: ''; display: block; margin-top: 6px; height: 2px; background-color: #333; opacity: 0; transform: translateY(6px); transition: opacity .2s, transform .2s}
.main .large-heading .view-more:hover:after {opacity: 1; transform: translateY(0)}

/* ------------------------------
 * Notify
------------------------------ */
.main .notify {padding: 20px 0; border-bottom: 1px solid #eaeaea}
.main .notify .notify-wrap {font-size: 0}
.main .notify .notify-wrap h4, .notify .notify-wrap .article-area {display: inline-block; vertical-align: middle}
.main .notify .notify-wrap h4 {font-size: 14px; font-weight: 600; color: #fff; text-align: center; width: 90px; padding: 10px; border-radius: 30px; background-color: #4263eb}
.main .notify .notify-wrap .article-area {width: calc(100% - 90px); padding-left: 15px}
.main .notify .notify-wrap .article-list {width: 100%; table-layout: fixed}
.main .notify .notify-wrap .article-list td[width='1%'] {display: none}
.main .notify .notify-wrap .article-list td div {display: inline-block; max-width: 100%}
.main .notify .notify-wrap .article-area a {display: inline-block; font-size: 14px; color: #868e96; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; overflow: hidden}

/* ------------------------------
 * About
------------------------------ */
.main .about {padding-top: 100px; padding-bottom: 100px}
.main .about .col-item figure {margin-bottom: 0}
.main .about .col-item .info {padding: 42px 20px 0}
.main .about .col-item .info h3 {font-size: 21px; font-weight: 700; color: #212529; letter-spacing: -0.06rem; margin-bottom: 16px}
.main .about .col-item .info p {font-size: 15px; color: #333; line-height: 1.75}

/* ------------------------------
 * Product
------------------------------ */
.main .product {padding-top: 100px; padding-bottom: 100px; background-color: #f7f7f7}
.main .product .article-list, .main .product .article-list table, .main .product .article-list tbody, .main .product .article-list table tr, .main .product .article-list td {display: block; width: 100%}
.main .product .article-list > tbody > tr {display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-left: -8px; margin-right: -8px}
.main .product .article-list > tbody > tr > td {position: relative; display: block; -ms-flex: 0 0 25%; flex: 0 0 25%; max-width: 25%; width: 100%; margin-bottom: 32px; padding-left: 8px; padding-right: 8px}
.main .product.column-2 .article-list > tbody > tr > td {-ms-flex: 0 0 50%; flex: 0 0 50%; max-width: 50%}
.main .product.column-3 .article-list > tbody > tr > td {-ms-flex: 0 0 33.333333%; flex: 0 0 33.333333%; max-width: 33.333333%}
.main .product.column-4 .article-list > tbody > tr > td {-ms-flex: 0 0 25%; flex: 0 0 25%; max-width: 25%}
.main .product.column-5 .article-list > tbody > tr > td {-ms-flex: 0 0 20%; flex: 0 0 20%; max-width: 20%}
.main .product.column-6 .article-list > tbody > tr > td {-ms-flex: 0 0 16.666666%; flex: 0 0 16.666666%; max-width: 16.666666%}
.main .product .article-list td {padding: 0; text-align: left !important}
.main .product .article-list br {display: none}
.main .product .article-list a {display: block; text-align: left}
.main .product .article-list table td[style] {font-family: 'Montserrat','Spoqa Han Sans',sans-serif !important; font-size: 14px; font-weight: 600; color: #4263eb; padding: 32px; border: 1px solid #d9d9d9; border-top: 0; background-color: #fff}
.main .product .article-list .board_output_gallery_img {position: relative; padding-bottom: 75%; overflow: hidden}
.main .product .article-list .board_output_gallery_img a {position: absolute; top: 0; left: 0; width: 100%; height: 100%}
.main .product .article-list .board_output_imgs {position: absolute; display: block; top: 0; left: 0; width: 100% !important; height: 100% !important; object-fit: cover}
.main .product .article-list .board_output_gallery_subject {display: block; margin-top: 12px}
.main .product .article-list .board_output_gallery_subject a {display: -webkit-box; font-size: 21px; font-weight: 700; color: #212529; line-height: 1.4; letter-spacing: -1px; word-break: keep-all; height: 59px; text-overflow: ellipsis; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: 2}

.main .product .article-list  .item-inner {border: 1px solid #d9d9d9; transition: box-shadow .3s}
.main .product .article-list  .item-inner figure {margin-bottom: 0}
.main .product .article-list  .item-inner .info {padding: 32px; background-color: #fff}
.main .product .article-list  .item-inner .info .category {display: inline-block; font-size: 15px; color: #fff; padding: 8px 20px; background-color: #4263eb}
.main .product .article-list  .item-inner .info p {display: -webkit-box; font-size: 21px; font-weight: 700; color: #212529; line-height: 1.4; height: 59px; /*margin: 12px 0 32px;*/margin-top: 12px; text-overflow: ellipsis; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: 2}
.main .product .article-list  .item-inner .info .price {display: block; font-size: 18px; font-weight: 700; color: #ff6161}
.main .product .article-list  > a:hover .item-inner {box-shadow: 10px 10px 16px rgba(0,0,0,.12)}

/* ------------------------------
 * Banner group
------------------------------ */
.main .banner-group .col-banner > a {display: block}
.main .banner-group .col-banner figure {position: relative; height: 400px; margin-bottom: 0; overflow: hidden}
.main .banner-group .col-banner figure:before {content: ''; position: absolute; display: block; top: 0; left: 0; bottom: 0; right: 0; background-color: rgba(0,0,0,.4); opacity: 0; transition: opacity .5s; z-index: 5}
.main .banner-group .col-banner figure img {height: 100%; transition: transform .6s ease-out; object-fit: cover}
.main .banner-group .col-banner figure figcaption {position: absolute; left: 0; bottom: 0; right: 0; padding: 48px; z-index: 10; transform: translateY(80px); transition: transform .5s}
.main .banner-group .col-banner figure figcaption h3 {font-size: 24px; font-weight: 600; color: #fff; margin-bottom: 12px}
.main .banner-group .col-banner figure figcaption p {font-size: 17px; font-weight: 500; color: #fff; line-height: 1.7; opacity: .7}
.main .banner-group .col-banner figure figcaption .btn-view {display: inline-block; font-size: 15px; font-weight: 500; color: #fff; text-align: center; margin-top: 28px; padding: 14px 32px; min-width: 150px; border: 1px solid #fff; border-radius: 30px; opacity: 0; transition: opacity .5s ease-out, color .25s, background-color .25s, box-shadow .25s}
.main .banner-group .col-banner figure figcaption .btn-view:hover {color: #212529; background-color: #fff; box-shadow: 0 8px 16px rgba(0,0,0,.12)}
.main .banner-group .col-banner figure:hover:before {opacity: 1}
.main .banner-group .col-banner figure:hover img {transform: scale(1.1)}
.main .banner-group .col-banner figure:hover figcaption {transform: translateY(0)}
.main .banner-group .col-banner figure:hover figcaption .btn-view {opacity: 1}

/* ------------------------------
 * Contact form
------------------------------ */
.main .contact-form {padding-top: 100px; padding-bottom: 100px}
.main .contact-form .contact-desc {font-weight: 500; color: #666; letter-spacing: -0.05rem; line-height: 1.8}
.main .contact-form .info-group + .info-group {margin-top: 24px}
.main .contact-form .info-group .info-icon {font-size: 22px; color: #868e96; vertical-align: middle}
.main .contact-form .info-group .info-icon span {font-size: 16px}
.main .contact-form .info-group p {font-size: 14px; font-weight: 500; color: #555; line-height: 1.8; letter-spacing: -0.05rem; margin-top: 8px}
.main .contact-form .info-group p em {display:inline-block; width:1px; height:11px; vertical-align:middle; background-color:#ccc; margin:0 8px}
.main .contact-form .info-group p a {display: inline-block; color: #343a40; letter-spacing: 0; transition: color .3s}
.main .contact-form .info-group p a:after {content: ''; display: block; height: 2px; margin-top: 4px; background-color: #000; opacity: 0; transform: translateY(4px); transition: opacity .3s, transform .3s}
.main .contact-form .info-group p a:hover {color: #000}
.main .contact-form .info-group p a:hover:after {opacity: 1; transform: translateY(0)}

.main .contact-form .table-form {display: block; width: 100%}
.main .contact-form .table-form > tbody {display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-left: -4px; margin-right: -4px}
.main .contact-form .table-form > tbody > tr {position: relative; display: none; -ms-flex: 0 0 50%; flex: 0 0 50%; max-width: 50%; width: 100%; height: auto !important; margin-bottom: 8px; padding-left: 4px; padding-right: 4px}
.main .contact-form .table-form > tbody > tr[height] {display: block}
.main .contact-form .table-form > tbody > tr:nth-last-child(2) {-ms-flex: 0 0 100%; flex: 0 0 100%; max-width: 100%}
.main .contact-form .table-form td {display: block; width: 100%; font-size: 0}
.main .contact-form .table-form td br {display: none}
.main .contact-form .table-form .formmail_title_bgcolor {display: none}
.main .contact-form .table-form .formmail_cell_bgcolor {font-family: inherit !important}
.main .contact-form .formmail_cell_bgcolor select, .main .contact-form .formmail_cell_bgcolor input[type=text], .main .contact-form .formmail_cell_bgcolor textarea {display: block; font-family: inherit !important; font-size: 14px; color: #495057; width: 100%; height: 50px; padding: 8px 16px; border: 1px solid #d9d9d9; border-radius: 6px; background-color: #fff; transition: border-color .15s ease-in-out, background-color .15s ease-in-out, box-shadow .15s ease-in-out; outline: 0; -webkit-appearance: none}
.main .contact-form .formmail_cell_bgcolor select {padding-right: 36px; background-image: url(../images/select_arrow_down.svg); background-size: 20px 20px; background-position: right 15px center; background-repeat: no-repeat}
.main .contact-form .formmail_cell_bgcolor textarea {height: 170px !important; padding: 16px !important; resize: none}
.main .contact-form .formmail_cell_bgcolor select:focus, .main .contact-form .formmail_cell_bgcolor input[type=text]:focus, .main .contact-form .formmail_cell_bgcolor textarea:focus {border-color: #367bf5}


/* ------------------------------
 * Partners
------------------------------ */
.main .partners {padding-top: 100px; padding-bottom: 100px; background-color: #f8f9fa}
.main .partners .col-item {margin-bottom: 6px}
.main .partners .col-item img {display: block; width: 100%}

/* ------------------------------
 * Wide map
------------------------------ */
.main .wide-map iframe {display: block; width: 100% !important; height: 500px}
.main .wide-map .root_daum_roughmap .wrap_controllers {display: none !important}
.main .wide-map .root_daum_roughmap .map_border {width: 0; height: 0; border: 0 !important}

/* ------------------------------
 * Media queries
------------------------------ */
@media (max-width: 991px) {
    .main .hero-swiper {height: 750px}
    .main .hero-swiper .hero-caption {padding: 0 140px}
    .main .hero-swiper .hero-caption h2 {font-size: 40px}

    .main .hero-swiper .navigation-arrow > .prev {left: 15px}
    .main .hero-swiper .navigation-arrow > .next {right: 15px}

    .main .large-heading h2 {font-size: 32px}

    .main .about {padding-top: 80px; padding-bottom: 80px}
    .main .about .col-item .info {padding: 28px 20px 0}
    .main .about .col-item .info h3 {font-size: 19px}

    .main .banner-group .col-banner figure figcaption {padding: 36px; transform: translateY(0)}
    .main .banner-group .col-banner figure figcaption .btn-view {opacity: 1}

    .main .product .article-list > tbody > tr > td {-ms-flex: 0 0 50% !important; flex: 0 0 50% !important; max-width: 50% !important; margin-bottom: 16px}

    .main .partners {padding-top: 80px; padding-bottom: 80px}
}

@media (max-width: 767px) {
    .main .hero-swiper {height: 500px}
    .main .hero-swiper .hero-caption {padding: 0 70px}
    .main .hero-swiper .hero-caption .caption-inner {padding-bottom: 60px}
    .main .hero-swiper .hero-caption h2 {font-size: 32px}
    .main .hero-swiper .hero-caption p {font-size: 15px}
    .main .hero-swiper .hero-caption .btn-more {margin-top: 32px}
    .main .hero-swiper .navigation-arrow > button .arrow {width: 30px}
    .main .hero-swiper .navigation-arrow > button span[lang='en'] {display: none}
    .main .hero-swiper .scroll-indicator .mouse {width: 28px; height: 45px}
    .main .hero-swiper .scroll-indicator .wheel {top: 5px; height: 6px}
    .main .hero-swiper .swiper-pagination {bottom: 20px}

    .main .large-heading h2 {font-size: 28px}
    .main .large-heading p {font-size: 15px}
    .main .large-heading .view-more {font-size: 15px}

    .main .notify .notify-wrap .article-area a {font-size: 13px}

    .main .about {padding-top: 60px; padding-bottom: 60px}
    .main .about .col-item + .col-item {margin-top: 48px}
    .main .about .col-item .info h3 {font-size: 17px}
    .main .about .col-item .info p {font-size: 14px}

    .main .banner-group .col-banner figure {height: 270px}
    .main .banner-group .col-banner figure figcaption {padding: 28px}
    .main .banner-group .col-banner figure figcaption h3 {font-size: 19px}
    .main .banner-group .col-banner figure figcaption p {font-size: 15px}
    .main .banner-group .col-banner figure figcaption .btn-view {min-width: inherit; padding: 13px 28px}

    .main .product {padding-top: 60px; padding-bottom: 60px}
    .main .product .article-list table td[style] {font-size: 12px; padding: 20px}
    .main .product .article-list .board_output_gallery_subject a {font-size: 15px; height: 42px}

    .main .contact-form {padding-top: 60px; padding-bottom: 60px}
    .main .contact-form .contact-desc {font-size: 14px}
    .main .contact-form .info-group + .info-group {margin-top: 20px}
    .main .contact-form .info-group p {font-size: 13px}
    .main .contact-form .col-form {margin-top: 32px}

    .main .partners {padding-top: 60px; padding-bottom: 60px}

    .root_daum_roughmap .wrap_map {height: 300px !important}
}

@media (max-width: 575px) {
    .main .hero-swiper .scroll-indicator {display: none}
    .main .contact-form .submit-button .button {display: block; width: 100%}

    .main .product .article-list > tbody > tr {margin-left: -3px; margin-right: -3px}
    .main .product .article-list > tbody > tr > td {margin-bottom: 8px; padding-left: 3px; padding-right: 3px}
    .main .product .article-list .board_output_gallery_subject {margin-top: 8px}

    .main .contact-form .table-form > tbody > tr {-ms-flex: 0 0 100%; flex: 0 0 100%; max-width: 100%}
    .main .contact-form .formmail_cell_bgcolor textarea {height: 120px !important}
}