@charset "utf-8";
/* @import url("https://fonts.googleapis.com/css2?family=Inter:wght@200;300;400;500;600;700;800&display=swap"); */

/* @font-face {
    font-family: "Nanum Myeongjo", serif;
    font-weight: 400;
    font-style: normal;
    src: url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjo.eot");
    src: url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjo.eot?#iefix") format("embedded-opentype"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjo.woff2") format("woff2"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjo.woff") format("woff"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjo.ttf") format("truetype");
    font-display: swap;
}
@font-face {
    font-family: "Nanum Myeongjo", serif;
    font-weight: 700;
    font-style: normal;
    src: url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoBold.eot");
    src: url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoBold.eot?#iefix") format("embedded-opentype"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoBold.woff2") format("woff2"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoBold.woff") format("woff"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoBold.ttf") format("truetype");
    font-display: swap;
}
@font-face {
    font-family: "Nanum Myeongjo", serif;
    font-weight: 800;
    font-style: normal;
    src: url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoExtraBold.eot");
    src: url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoExtraBold.eot?#iefix") format("embedded-opentype"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoExtraBold.woff2") format("woff2"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoExtraBold.woff") format("woff"), url("https://cdn.jsdelivr.net/gh/webfontworld/NanumMyeongjo/NanumMyeongjoExtraBold.ttf") format("truetype");
    font-display: swap;
} */
/* 주요색상 */
:root {
    --page-point-color: #345276;
    --page-secondary-color: #99a591;
    --page-third-color: #d7b78e;
}

#site {
    padding-top: 0;
    font-size: 16px;
    font-family: "Inter", "notokr", sans-serif;
    letter-spacing: -0.034em;
}

.btn {
    transition: all ease 0.15s;
    -webkit-transition: all ease 0.15s;
    -moz-transition: all ease 0.15s;
    -ms-transition: all ease 0.15s;
    -o-transition: all ease 0.15s;
}

a,
a:hover,
a:focus {
    color: inherit;
}

a[href^="mailto"] {
    color: inherit;
}

p {
    line-height: 1.5em;
}

.btn.btn-primary {
    background-color: var(--page-point-color);
    border-color: var(--page-point-color);
}
.btn.btn-primary:hover,
.btn.btn-primary:focus {
    color: var(--page-point-color);
    background-color: #fff;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
li,
td,
dt,
dd,
figcaption {
    word-break: keep-all;
}

/* 불필요 항목 삭제 */
.navbar .caret {
    display: none;
}

/* 상단 메뉴 */
.navbar-inverse {
    background: #fff;
    position: static;
    margin-bottom: 0;
    border: 0;
}

.navbar-inverse .navbar-brand {
    height: auto;
    margin-top: 20px;
    font-size: 31px;
    font-weight: 900;
    color: var(--page-point-color);
}
.navbar-inverse .navbar-brand:hover,
.navbar-inverse .navbar-brand:focus {
    color: var(--page-point-color);
}

.navbar-inverse .navbar-nav > li > a {
    font-size: 17px;
    font-weight: 800;
    color: #333;
    font-family: "Nanum Myeongjo", serif;
}
.navbar-inverse .navbar-nav > li > a:hover,
.navbar-inverse .navbar-nav > li > a:focus {
    color: #345276;
}

.navbar-inverse .navbar-nav .dropdown.open .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:hover .dropdown-toggle,
.navbar-inverse .navbar-nav .dropdown.open:focus .dropdown-toggle {
    background: none;
    color: var(--page-point-color);
}

@media (max-width: 767px) {
    .navbar-inverse .navbar-toggle {
        border: 0;
        padding: 18px 0;
    }
    .navbar-inverse .navbar-toggle .icon-bar {
        background-color: #333;
        transition: ease-in-out 0.15s all;
        opacity: 1;
        position: relative;
    }
    .navbar-inverse .navbar-toggle:hover,
    .navbar-inverse .navbar-toggle:focus {
        background: none;
        border-color: var(--page-point-color);
    }
    .navbar-inverse .navbar-toggle:hover .icon-bar,
    .navbar-inverse .navbar-toggle:focus .icon-bar {
        background-color: var(--page-point-color);
    }
    .navbar-inverse .navbar-collapse,
    .navbar-inverse .navbar-form {
        border-color: transparent;
    }

    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(1) {
        transform: rotate(45deg);
        top: 6px;
    }
    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(2) {
        opacity: 0;
    }
    .navbar-inverse.open .navbar-toggle > .icon-bar:nth-of-type(3) {
        transform: rotate(-45deg);
        top: -6px;
    }
}

@media (min-width: 768px) {
    .navbar-inverse .navbar-nav .dropdown-menu {
        left: 50%;
        right: auto;
        transform: translate(-50%, 0);
        border-radius: 0;
        border: 0;
        padding: 0;
        background: #fff;
        -webkit-box-shadow: 0 4px 8px rgba(0, 0, 0, 0.125);
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.125);
        animation-fill-mode: both;
        animation-duration: 0.4s;
        animation-name: fadeIn;
        border-top: 4px solid #345276;
    }
    .navbar-inverse .navbar-nav .dropdown-menu > li > a {
        padding: 12px 15px;
        text-align: center;
        font-size: 15px;
        color: #333;
        border-bottom: 1px solid #eee;
        letter-spacing: 0;
    }
    .navbar-inverse .navbar-nav .dropdown-menu > li:last-child > a {
        border-bottom: 0;
    }
    .navbar-inverse .navbar-nav .dropdown-menu > li > a:hover,
    .navbar-inverse .navbar-nav .dropdown-menu > li > a:focus {
        background: transparent;
        background: var(--page-point-color);
        color: #fff;
    }
}

@media (min-width: 992px) {
    .navbar-inverse .navbar-nav > li > a {
        padding: 35px 30px 37px;
    }
}

/* 슬라이드 공통 */
.carousel-control {
    text-shadow: 0px 2px 6px rgba(0, 0, 0, 0.125);
    transition: ease-in-out 0.15s all;
}
.carousel-control.left .glyphicon::before {
    content: "\f053";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}
.carousel-control.right .glyphicon::before {
    content: "\f054";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
}
.carousel-indicators {
    top: 73%;
    bottom: auto;
    text-align: left;
}
.carousel-indicators li {
    width: 12px;
    height: 12px;
    background-color: rgba(255, 255, 255, 0.1);
    border: 1px solid #fff;
    margin: 0 4px;
    border-radius: 30px;
    transition: ease-in-out 0.15s all;
}
.carousel-indicators li.active {
    width: 12px;
    height: 12px;
    background-color: #fff;
    margin: 0 4px;
    box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.125);
    transform: rotate(45deg);
}

.carousel-caption {
    text-shadow: none;
}

@media (max-width: 767px) {
    .carousel-control {
        font-size: 14px;
    }
    .carousel-indicators {
        top: auto;
        bottom: 5%;
        text-align: center;
    }
    .carousel-indicators li,
    .carousel-indicators li.active {
        width: 42px;
        height: 8px;
        transform: none;
    }
}

/* 푸터 */
#site footer {
    margin-top: 0px;
    background-color: #3c3d3f;
    color: #ddd;
}
#site footer .footer-info {
    padding: 45px 0;
}
#site footer .footer-info ul {
    position: relative;
    margin: 0;
    padding: 0;
    font-size: 0;
}
#site footer .footer-info ul li {
    list-style: none;
    display: inline-block;
    font-size: 14px;
    margin-right: 15px;
    line-height: 24px;
    color: #ccc;
    letter-spacing: 0;
}
#site footer .footer-info ul li:first-child {
    letter-spacing: 0;
    font-weight: 700;
    display: block;
    margin-bottom: 3px;
    color: #eee;
}
#site footer .footer-info ul li.copy {
    margin-top: 2px;
    font-size: 13px;
    color: #777;
    letter-spacing: 0;
}

/* 메인 페이지 */
#mainCarousel .carousel-inner .item {
    height: calc(100vh - 95px);
}
#mainCarousel .carousel-caption {
    top: 45%;
    text-align: left;
}
#mainCarousel .carousel-caption h1 {
    margin-bottom: 15px;
    font-size: 30px;
    font-weight: 600;
    letter-spacing: 0;
}
#mainCarousel .carousel-caption p {
    font-size: 56px;
    font-weight: 500;
    letter-spacing: -0.045em;
}
#mainCarousel .carousel-caption a.btn {
    margin-top: 40px;
    padding: 12px 45px;
    font-size: 16px;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(255, 255, 255, 0.21);
    border-radius: 50px;
}
#mainCarousel .carousel-caption a.btn:hover {
    color: #fff;
    background-color: var(--page-point-color);
    border-color: var(--page-point-color);
}
@media (max-width: 767px) {
    #mainCarousel .carousel-inner .item {
        height: calc(100vh - 226px);
    }
    #mainCarousel .carousel-caption {
        right: 5%;
        left: 5%;
        text-align: center;
    }
    #mainCarousel .carousel-caption h1 {
        font-size: 20px;
    }
    #mainCarousel .carousel-caption p {
        font-size: 28px;
    }
    #mainCarousel .carousel-caption a.btn {
        margin-top: 25px;
        padding: 9px 40px;
        font-size: 15px;
    }
    #mainCarousel .carousel-control {
        display: none;
    }
}

#section_a684ec {
    padding: 20px 0;
}

#section_b53b3a {
    min-height: 400px;
}

#section_b53b3a .container {
    width: 100%;
    padding: 0;
}

.root_daum_roughmap {
    width: 100% !important;
    padding: 0 !important;
}

.root_daum_roughmap .map_border {
    display: none !important;
}

@media (min-width: 767px) {
    #section_a684ec div[class^="board_box_"] {
        width: 50%;
    }
}

.board_box_blog2 .row {
    margin-left: -5px;
    margin-right: -5px;
}

.board_box_blog2 .row > div[class^="col-"] {
    padding-left: 5px;
    padding-right: 5px;
}

.board_box_blog2 .inner {
    margin-top: 0;
    margin-bottom: 0;
}

.board_box_blog2 .inner .bottom {
    padding: 12px 10px;
}

.board_box_blog2 .inner .bottom .title {
    margin-bottom: 0;
}

.board_box_blog2 .inner .bottom .title a {
    font-size: 14px;
}

.board_box_blog2 .inner .bottom .info {
    display: none;
}

.board_box_blog2 .inner .top a .thumb {
    height: 100px;
}

/*************** 서브 시작 ***************/
/* 공통 스타일 */
#site > .container {
    width: 100%;
    padding: 0;
}
.subPage > .pageTop {
    height: 270px;
    position: relative;
    color: #fff;
    background: #000 url(/public/img/sub/bg_subTop.jpg) no-repeat 0 50% / cover;
    z-index: -1;
}
.subPage > .pageTop::before {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    display: block;
    background: #000;
    opacity: 0.45;
}
.subPage > .pageTop h1,
.subPage > .pageTop h2 {
    top: 43%;
    left: 50%;
    position: absolute;
    font-size: 45px;
    font-weight: 600;
    color: #fff;
    transform: translate(-50%, -50%);
    font-family: "Nanum Myeongjo", serif;
    letter-spacing: 0;
}

/* Link */
.subPage .link {
    margin-top: 70px;
}
.subPage .link ul {
    display: flex;
    justify-content: center;
    background: #fff;
}
.subPage .link ul > li {
    flex: 1 1 0;
}
.subPage .link ul > li > a {
    padding: 18px 0 18px;
    font-size: 17px;
    font-weight: 800;
    color: #999;
    line-height: 1.2em;
    text-align: center;
    font-family: "Nanum Myeongjo", serif;
    border-bottom: 1px solid #345276 !important;
    background: #fafafa;
    border: 1px solid #e5e5e5;
}
.subPage .link ul > li:first-child > a {
    border-right: 0;
}
.subPage .link ul > li:last-child > a {
    border-left: 0;
}
.subPage .link ul > li:first-child > a::after {
    display: none;
}
.subPage .link ul > li.active > a {
    color: #345276;
    background: #fff;
    border-bottom: 0 !important;
    border: 1px solid #345276;
}
.subPage .link ul > li > a:hover,
.subPage .link ul > li > a:focus {
    color: #345276;
    font-weight: 800;
    background: #fafafa;
}
.subPage .link ul > li.active > a:hover {
    background: #fff;
}
.subPage .link ul > li.active > a::before,
.subPage .link ul > li:not(.active) > a:hover::before,
.subPage .link ul > li:not(.active) > a:focus::before {
    width: 100%;
}

.subPage > .contents section {
    padding: 100px 0 140px;
}
#greeting .contents section::before {
    /* content: ''; */
    display: block;
    position: absolute;
    width: 100%;
    height: 305px;
    background: #f6f6f6;
    bottom: 0;
    left: 0;
}
#greeting .contents section {
    position: relative;
}
.subPage > .contents .row:not(.page-title) + .row {
    margin-top: 100px;
}

.title-lv-1 {
    margin: 0 0 100px;
    font-size: 40px;
    font-weight: 900;
    color: #222;
    letter-spacing: 0;
    line-height: 1em;
    text-align: center;
    font-family: "Nanum Myeongjo", serif;
}
#greeting .title-lv-1 {
    margin: 0 0 80px;
}
.title-lv-2 {
    margin: 0 0 45px;
    font-size: 30px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1em;
    font-family: "Nanum Myeongjo", serif;
    padding-left: 14px;
    position: relative;
}
.title-lv-2::before {
    content: "";
    display: block;
    position: absolute;
    width: 5px;
    height: 26px;
    background: #333;
    left: 0;
    top: 1px;
}
.list-default {
    margin: 0;
    padding-left: 0;
    list-style-type: none;
}
.list-default > li {
    position: relative;
}
.list-style-1 {
    padding-left: 3px;
}
.list-style-1 > li {
    padding-left: 10px;
}
.list-style-1 > li + li {
    padding-top: 3px;
}
.list-style-1 > li::before {
    content: "";
    top: 10px;
    left: 1px;
    width: 4px;
    height: 4px;
    position: absolute;
    background: #333;
    border-radius: 50%;
}
.list-dash > li {
    padding-left: 12px;
}
.list-dash > li + li {
    margin-top: 2px;
}
.list-dash > li::before {
    content: "-";
    top: -2px;
    left: 0;
    position: absolute;
}

table.tb-default {
    margin-bottom: 0;
}
table.tb-default > thead > tr > th,
table.tb-default > tbody > tr > th,
table.tb-default > tbody > tr > td {
    padding: 16px;
    border-bottom: 1px solid #e3e3e3;
    text-align: center;
    vertical-align: middle;
}
table.tb-style-1 {
    border-top: 2px solid var(--page-point-color) !important;
}
table.tb-style-1 > thead > tr > th,
table.tb-style-1 > tbody > tr > th,
table.tb-style-1 > tbody > tr > td {
    padding: 16px;
    font-size: 15px;
    line-height: 1.5;
    font-weight: 600;
}
table.tb-style-1 > thead > tr > th {
    padding: 14px 12px;
    background: #f7f8fa;
}
table.tb-style-1 > tbody > tr > td {
    font-weight: 400;
}
table.tb-style-1 > tbody > tr > th {
    background: #f7f8fa;
}

/* 인사말 (페이지) */
.wrap-greet {
    /* max-width: 900px; */
    width: fit-content;
    margin-inline: auto;
}
.wrap-greet .image {
    padding: 0 30px 0 90px;
}
.wrap-greet .image img {
    margin-left: 90px;
}
.wrap-greet .text {
    position: relative;
    padding: 35px 0 0px 0px;
}
.wrap-greet .text h3 {
    margin: 25px 0 42px;
    font-size: 32px;
    font-weight: 700;
    color: var(--page-point-color);
    line-height: 1.5;
    font-family: "Nanum Myeongjo", serif;
    word-spacing: -0.45em
    /* text-align: justify; */
}
/* .wrap-greet .text h3::after {
    content: "";
    display: block;
    width: 50px;
    height: 1px;
    margin: 40px auto 50px;
    background-color: var(--page-point-color);
} */
.wrap-greet .text p {
    margin-bottom: 30px;
    font-size: 17px;
    color: #555;
    line-height: 1.6;
    /* text-align: justify; */
}
.wrap-greet .text p.t-l {
    text-align: left;
}
.wrap-greet .text p strong {
    color: var(--page-point-color);
    font-weight: 600;
}
.wrap-greet .text p:last-child {
    margin-bottom: 0;
}
.wrap-greet .text ul {
    margin-bottom: 30px;
    /* text-align: left; */
    /* max-width: 700px; */
    margin-inline: auto;
    /* text-align: justify; */
}
.wrap-greet .text li {
    margin-bottom: 10px;
}
.wrap-greet .text li strong {
    /* display: block; */
    /* margin-bottom: 5px; */
    color: var(--page-point-color);
}
/* 연혁 (페이지) */
.wrap-history > .con-left {
    padding-right: 30px;
}
.wrap-history .box-history {
    padding-left: 60px;
    margin-top: 10px;
}
.box-history .block {
    display: flex;
    gap: 30px;
}
.box-history .block + .block {
    margin-top: 50px;
}
.box-history .left {
    flex-basis: 28%;
}
.box-history .right {
    flex-basis: 70%;
    padding-top: 15px;
    border-top: 2px solid #c8d2c1;
}
.box-history .left .year {
    margin: 0px 0 0;
    font-size: 52px;
    font-weight: 900;
    color: #bdc7b6;
    position: relative;
    letter-spacing: 0;
    font-family: "Nanum Myeongjo", serif;
    font-style: italic;
}
.box-history .left .year::before {
    content: "";
    display: block;
    position: absolute;
    width: 15px;
    height: 15px;
    background: #8d9e81;
    right: -14px;
    top: 21px;
    border: 4px solid #e5ede0;
    border-radius: 50%;
    /* transform: rotate(45deg); */
}

.box-history .left .year::after {
    content: "";
    display: block;
    position: absolute;
    width: 46px;
    height: 1px;
    left: 140px;
    top: 50%;
    border: 1px dashed #ddd;
    transform: translateY(-50%);
}
.box-history .right ul > li {
    margin-bottom: 15px;
    padding-bottom: 15px;
    color: #555;
    border-bottom: 1px solid #e6ece1;
}
.box-history .right ul > li:last-child {
    margin-bottom: 0;
}

/* 오시는길 (페이지) */
.box-location > .info,
.box-location > .info .item {
    display: flex;
    justify-content: flex-start;
}
.box-location > .info {
    padding: 44px 50px 45px;
    background: #fff;
    z-index: 1;
    position: relative;
    margin: -50px 50px 0px;
    box-shadow: 3px 2px 10px #e5e5e5;
}
.box-location > .info .item + .item {
    margin-left: 50px;
}
.box-location .item .icon span[class^="material"] {
    width: 55px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 25px;
    font-weight: 400;
    color: #fff;
    background: #345276;
    border-radius: 50px;
    /* border: 6px solid #d7e0eb; */
}
.box-location .item .detail {
    padding-left: 20px;
}
.box-location .detail .tit {
    /* font-family: 'NanumMyeongjo'; */
    font-size: 17px;
    font-weight: 600;
    color: #345276;
    margin: 4px 0 6px;
}
.box-location .detail span {
    font-size: 17px;
}

/* SNP needle (페이지) */
.wrap-prod > .image {
    padding-right: 20px;
}
.wrap-prod > .image img {
    padding: 20px;
    border: 1px solid #ddd;
}
.wrap-prod > .detail {
    padding-left: 20px;
}
.wrap-prod > .detail table > thead > tr > th {
    width: 25%;
}
.wrap-prod > .detail ul {
    margin-top: 20px;
}
#products .wrap-prod > .detail li {
    font-size: 15px;
    margin-bottom: 3px;
}
.wrap-solution > .top {
    margin-bottom: 20px;
}
.wrap-solution > .top p {
    margin-top: -35px;
    font-size: 18px;
    font-weight: 400;
    color: #777;
}
.wrap-solution > .top p.right {
    right: 15px;
    bottom: 0;
    position: absolute;
    font-size: 15px;
}
.box-solution {
    display: flex;
    margin: 0 -15px;
}
.box-solution > .item {
    flex-basis: 33.333%;
    padding: 0 10px;
}
.box-solution > .item .inner {
    height: 100%;
    padding: 40px 40px;
    border: 1px solid #e6f1df;
    position: relative;
    background: #f8f9f7;
}
.box-solution > .item .no {
    font-size: 86px;
    font-weight: 900;
    color: #99a5911c;
    line-height: 1em;
    text-align: center;
    font-family: "Nanum Myeongjo", serif;
    font-style: italic;
    position: absolute;
    right: 43px;
    top: 35px;
}
.box-solution > .item .tit {
    margin: 15px 0 0;
    font-size: 20px;
    font-weight: 600;
    color: #718662;
}
#products .inner p {
    border-top: 1px solid #ddd;
    padding-top: 27px;
    margin-top: 27px;
    font-size: 16px;
}
.box-solution > .item .icon {
    display: flex;
    align-items: center;
    font-weight: 600;
    color: #819374;
    line-height: 1em;
}
.box-solution > .item .icon i {
    font-size: 60px;
}
.box-solution > .item p strong {
    position: relative;
    font-weight: 600;
}
.box-solution > .item p strong::before {
    content: "";
    bottom: 0;
    left: 0;
    width: 100%;
    height: 6px;
    position: absolute;
    background: #f2e8db;
    transform: skewX(-20deg);
    z-index: -1;
}

/* 인증서 (페이지) */
.box-certifi {
    display: flex;
    justify-content: center;
    gap: 35px;
}
.box-certifi > .item {
    flex-basis: 33.333%;
}
.box-certifi figure img {
    padding: 20px;
    border: 1px solid #e5e5e5;
    box-shadow: 3px 2px 10px #eee;
}
.box-certifi figure figcaption {
    margin-top: 20px;
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    background: #f5f5f5;
    padding: 15px 0;
}

/* 연구개발현황 (페이지) */
#rnd02 table > thead > tr > th:nth-child(1) {
    width: 70px;
}
#rnd02 table > tbody > tr > td:last-child {
    text-align: left;
}

/* 보유특허 (페이지) */
#rnd03 table > thead > tr > th:nth-child(2) {
    width: 9%;
}
#rnd03 table > thead > tr > th:nth-child(4),
#rnd03 table > thead > tr > th:nth-child(5),
#rnd03 table > thead > tr > th:nth-child(6),
#rnd03 table > thead > tr > th:nth-child(7) {
    width: 11%;
}

/* 게시판, 주문폼 공통 스타일 */
.board_wrapper,
.calendar_wrapper {
    margin-top: 0;
    margin-bottom: 0;
    padding: 0;
}
.search_wrap {
    margin-bottom: 0;
}
.board_wrapper .table.table_default {
    border-top: 2px solid #555;
}
.table.table_default tr th,
.table.table_default tr td {
    border-color: #e6e6e6;
    padding: 18px 15px;
}
.table.table_default tr td.writer,
.table.table_default tr td.regdate,
.table.table_default tr td.hits {
    color: #999;
}
.table.table_default tr td.subject {
    position: relative;
}
.table.table_default thead th {
    font-weight: 600;
    background: #fff;
    border-color: #ccc;
    padding: 15px 15px;
    font-size: 16px;
}
.table.table_default tbody .subject .badge {
    top: 19px;
    position: absolute;
    padding: 4px 6px 3px;
    font-weight: 500;
    color: #fff;
    line-height: 1.3em;
    background: var(--page-point-color);
    border: none;
    border-radius: 1px;
}
.table.table_default tbody .subject a {
    font-size: 16px;
}
.table.table_default tbody .subject a:hover {
    text-decoration: underline;
}
.table.table_default tbody .subject span > .badge + a {
    padding-left: 62px;
}
:where(.table_video, .table_blog2) .inner :where(.bottom .title a, .title a) {
    font-weight: 500;
    letter-spacing: -0.02em;
}
:where(.table_video, .table_blog2, .table_pd) .inner .bottom {
    padding: 20px 15px 20px;
}
:where(.table_video, .table_blog2) dd {
    margin-bottom: 55px;
}
:where(.table_video, .table_blog2, .table_pd) .inner .top a {
    background: #000;
}
.board_data_view {
    border-top: 1px solid #555;
    border-bottom: 1px solid #ccc;
}
.board_data_view .header_wrap {
    padding: 0;
    border-bottom: 1px solid #ccc;
}
.board_data_view .header_wrap .title {
    padding: 45px 0px 43px;
    font-size: 25px;
    font-weight: 500;
    line-height: 1.3em;
    border-bottom: 1px solid #eee;
}
.board_data_view .header_wrap .info {
    margin: 0;
    padding: 11px 0 11px;
}
.board_data_view .header_wrap .info span {
    font-size: 13px;
    color: #909090;
}
.board_data_view p {
    font-size: 18px;
}

/* Pagenation */
.pagination_wrap ul li.active a,
.pagination_wrap ul li.active a:hover,
.pagination_wrap ul li.active a:focus {
    color: var(--page-point-color);
}
.pagination_wrap ul li.box a {
    border: none;
}
.pagination_wrap ul li.box:hover a,
.pagination_wrap ul li.box:focus a {
    color: var(--page-point-color);
}

.board_wrapper .text-center {
    margin-bottom: 0;
}

#reply_list span {
    font-size: 16px !important;
}

/* 게시글 작성 */
.board_wrapper .table.board_write_table tbody tr th,
.board_wrapper .table.board_write_table tbody tr td {
    font-size: 15px;
    border-color: #e6e6e6;
}
.board_wrapper .table.board_write_table {
    border-top: 2px solid #333;
}
.board_wrapper .table.board_write_table tbody tr th {
    width: 200px;
    padding-left: 25px;
    font-size: 15px;
    font-weight: 600;
    color: #333;
    background: #f6f6f6;
}
.btn.btn-outline-primary:hover,
.btn.btn-outline-primary:focus {
    background-color: #819374;
    color: #fff;
}
.btn.btn-outline-primary {
    background: none;
    border: 1px solid #819374;
    color: #819374;
}
.board_wrapper .table.board_write_table tbody tr th > span.required_text {
    color: #ff0000;
}
.board_wrapper .table.board_write_table .files .fileInput .file_add {
    padding: 6px 8px;
}
.form-control {
    letter-spacing: -0.03em;
    font-size: 15px;
}

/* 주문폼 */
.board_wrapper .table.board_write_table tbody tr td .form-control {
    width: 350px;
}
.board_wrapper .table.board_write_table tbody tr td .text-muted {
    margin-top: 10px !important;
    font-size: 14px;
}
.board_wrapper .table.board_write_table .checkbox a {
    font-weight: 500;
    color: var(--page-point-color);
    text-decoration: underline;
}
.form-control:not([readonly]):focus {
    border-color: #555;
}
input + #list_btn {
    display: none;
}
/**************** 서브 끝 ****************/

/*********** 모바일 최적화 시작 ***********/
@media (max-width: 1199px) {
    /* Small·Medium·Large devices */
    .box-location > .info {
        flex-direction: column;
    }
    .box-location > .info .item + .item {
        margin: 15px 0 0;
    }
}
@media (max-width: 767px) {
    /* Small devices (col-xs-*) 모바일 */
    #site {
        padding-top: 66px;
        font-size: 15px;
    }
    p {
        line-height: 1.4em;
    }

    .navbar-inverse {
        position: fixed;
        border-bottom: 1px solid #ddd;
    }
    .navbar-inverse .navbar-brand {
        margin-top: 10px;
        font-size: 28px;
    }
    .navbar-inverse .navbar-nav {
        display: block;
        margin: 0 -15px !important;
    }
    .navbar-inverse .navbar-nav > .open {
        background-color: #f6f6f6;
    }
    .navbar-inverse .navbar-nav > li {
        float: left;
        width: 100%;
    }
    .navbar-inverse .navbar-nav > li > a {
        padding: 12px 15px;
        font-size: 16px;
        border-top: 1px solid #eee;
        border-right: 1px solid #eee;
        transition: padding ease 0.3s;
    }
    .navbar-inverse .navbar-nav .dropdown.open .dropdown-toggle,
    .navbar-inverse .navbar-nav .dropdown.open:hover .dropdown-toggle,
    .navbar-inverse .navbar-nav .dropdown.open:focus .dropdown-toggle {
        padding: 15px;
        color: #fff !important;
        background: var(--page-point-color);
        border: var(--page-point-color);
    }
    .navbar-inverse .navbar-nav .dropdown.open .dropdown-toggle .caret,
    .navbar-inverse .navbar-nav .dropdown.open:hover .dropdown-toggle .caret,
    .navbar-inverse .navbar-nav .dropdown.open:focus .dropdown-toggle .caret {
        border-top-color: #fff;
    }
    .navbar-inverse .navbar-nav > .open .dropdown-menu {
        padding: 10px 0;
    }
    .navbar-inverse .navbar-nav > .open .dropdown-menu > li > a {
        padding: 5px 25px;
        font-size: 15px;
        color: #111;
    }
    .navbar-inverse .navbar-nav > li#gnb_68 > a {
        display: flex;
        align-items: center;
        gap: 5px;
    }
    .navbar-inverse .navbar-nav > li#gnb_68 > a img {
        width: 22px;
    }
    .navbar-inverse .navbar-nav > .open .dropdown-menu > li > a:hover,
    .navbar-inverse .navbar-nav > .open .dropdown-menu > li > a:focus {
        font-weight: 600;
        color: #111;
    }
    .navbar .caret {
        display: block;
        border: none;
    }
    .navbar .caret::after {
        content: "\f105";
        top: 13px;
        right: 20px;
        position: absolute;
        font-size: 14px;
        font-family: "Fontawesome";
        transition: transform ease 0.3s;
    }
    .navbar-inverse .navbar-nav .dropdown.open .caret::after {
        font-weight: 300;
        transform: rotate(90deg);
    }

    #site footer .footer-info {
        padding: 30px 0;
    }
    #site footer .footer-info ul li {
        font-size: 12px;
        line-height: 20px;
    }
    #site footer .footer-info ul li:first-child {
        display: inline-block;
        margin-bottom: 0;
    }
    #site footer .footer-info ul li.copy {
        margin-top: 0;
        font-size: 11px;
    }

    .subPage > .pageTop {
        height: 170px;
    }
    .subPage > .pageTop h1,
    .subPage > .pageTop h2 {
        font-size: 37px;
    }
    .subPage .link {
        margin-top: 15px;
    }
    .subPage .link ul > li > a {
        padding: 13px 0;
        font-size: 14px;
    }
    .subPage > .contents section {
        padding: 60px 0 80px;
    }
    .title-lv-1 {
        margin: 0 0 50px;
        font-size: 32px;
    }
    .title-lv-2 {
        margin: 0 0 35px;
        font-size: 27px;
        padding-left: 12px;
    }
    .title-lv-2::before {
        width: 4px;
        height: 22px;
    }
    table.tb-style-1 > tbody > tr > td,
    table.tb-style-1 > tbody > tr > th,
    table.tb-style-1 > thead > tr > th {
        padding: 12px;
        font-size: 14px;
        line-height: 1.3;
    }
    table.tb-style-1 > tbody > tr > td span[class^="material"] {
        font-size: 21px;
    }
    .subPage > .contents .row:not(.page-title) + .row {
        margin-top: 60px;
    }

    #greeting .contents section::before {
        height: 275px;
    }
    .wrap-greet .image {
        padding: 0 60px;
    }
    .wrap-greet .image img {
        margin: 0 auto;
    }
    .wrap-greet .text {
        padding: 45px 15px 0;
    }
    .wrap-greet .text h3 {
        margin: 0 0 30px;
        font-size: 26px;
        line-height: 1.3;
    }
    .wrap-greet .text p {
        margin-bottom: 21px;
        font-size: 16px;
    }
    .wrap-history > .con-left {
        padding: 0 60px;
    }
    .wrap-history > .con-right {
        margin-top: 45px;
    }
    .wrap-history .box-history {
        margin-top: 0;
        padding-left: 0;
    }
    .box-history .block {
        flex-direction: column;
        gap: 15px;
    }
    .box-history .block + .block {
        margin-top: 35px;
    }
    .box-history .left .year {
        padding-left: 30px;
        font-size: 38px;
    }
    .box-history .left .year::before {
        top: 15px;
        right: auto;
        left: 0;
        width: 12px;
        height: 12px;
        border-width: 3px;
    }
    .box-history .left .year::after {
        top: 21px;
        right: auto;
        left: 0;
        width: 32px;
        z-index: -1;
    }
    .box-history .right {
        padding-top: 10px;
    }
    .box-history .right ul > li {
        padding-bottom: 10px;
        padding-left: 5px;
    }
    .box-location .map > * {
        height: 300px;
    }
    .box-location > .info {
        margin: 15px 0 0;
        padding: 30px 15px;
    }
    .box-location .item .icon span[class^="material"] {
        width: 45px;
        height: 45px;
        font-size: 22px;
    }
    .box-location .item .detail {
        padding-left: 15px;
    }
    .box-location .detail .tit {
        font-size: 16px;
    }
    .box-location .detail span {
        font-size: 15px;
    }
    .wrap-prod > .image {
        padding-right: 15px;
    }
    .wrap-prod > .detail {
        margin-top: 30px;
        padding-left: 15px;
    }
    #products .wrap-prod > .detail li {
        font-size: 14px;
        margin-bottom: 2px;
    }
    .wrap-solution > .top p {
        margin-top: 0;
        font-size: 17px;
    }
    .wrap-solution > .top p:nth-of-type(1) {
        margin: -20px 0 3px;
    }
    .wrap-solution > .top p.right {
        position: static;
        font-size: 14px;
    }
    .box-solution {
        flex-direction: column;
    }
    .box-solution > .item + .item {
        margin-top: 15px;
    }
    .box-solution > .item .inner {
        padding: 30px;
        text-align: center;
    }
    .box-solution > .item .no {
        right: 33px;
        top: 25px;
        font-size: 66px;
    }
    .box-solution > .item .icon {
        justify-content: center;
    }
    .box-solution > .item .icon i {
        font-size: 55px;
    }
    .box-solution > .item .tit {
        margin: 12px 0 0;
        font-size: 18px;
    }
    #products .inner p {
        margin: 20px 0 0;
        padding-top: 20px;
        font-size: 15px;
    }
    .box-certifi {
        flex-direction: column;
        gap: 20px;
    }
    .box-certifi figure img {
        padding: 15px;
    }
    .box-certifi figure figcaption {
        margin-top: 15px;
        padding: 12px 0;
        font-size: 15px;
    }

    .board_wrapper .table colgroup,
    .board_wrapper .table tr .num,
    .board_wrapper .table tr .hits {
        display: none;
    }
    .board_wrapper .table .subject {
        width: 55%;
    }
    .board_wrapper .table .writer {
        width: 20%;
    }
    .board_wrapper .table .regdate {
        width: 25%;
    }
    .board_wrapper .table.table_default tr th,
    .board_wrapper .table.table_default tr td {
        padding: 10px;
        font-size: 12px;
    }
    .table.table_default tbody .subject .badge {
        top: 9px;
        font-size: 10px;
    }
    .table.table_default tr td.subject a {
        font-size: 13px;
    }
    .table.table_default tbody .subject span > .badge + a {
        padding-left: 54px;
    }
    .board_data_view .header_wrap {
        padding: 0;
    }
    .board_data_view .header_wrap .title {
        padding: 25px 5px 23px;
        font-size: 20px;
    }
    .board_data_view .header_wrap .info {
        padding: 8px 0;
    }
    .board_data_view .header_wrap .info span {
        font-size: 11px;
    }
    .board_data_view .contents_wrap {
        padding: 40px 15px;
    }
    .board_wrapper .table.board_write_table tbody tr td .form-control,
    .board_wrapper .table.board_write_table .form-control.form-control-big,
    .member_wrapper #join_form .table .form-control,
    .member_wrapper #join_form .table .form-control.form-control-big {
        width: 100%;
    }
    .board_wrapper .table.board_write_table .files .fileInput input {
        width: 100%;
    }
    .board_wrapper .table.board_write_table .files .fileInput .file_add {
        width: 100%;
        margin: 0 0 15px;
        padding: 6px 12px;
    }
    .member_wrapper .text-center .btn.btn-lg,
    .board_wrapper .text-center .btn.btn-lg {
        width: 100%;
        margin: 0;
        padding: 9px;
    }
    .board_wrapper .text-center .btn#write_btn,
    .member_wrapper .text-center .btn#join_btn,
    .board_wrapper .text-center .btn#list_btn {
        margin-top: 20px;
    }
    .member_wrapper {
        padding-top: 60px;
        padding-bottom: 100px;
    }
    .board_data_view p {
        font-size: 17px;
    }
}
@media (min-width: 768px) and (max-width: 1199px) {
    /* Medium·Large devices */
    .wrap-greet .image img {
        margin-left: 0;
    }
    .wrap-greet .text {
        padding: 0 0 0 15px;
    }
    .wrap-history .box-history {
        padding-left: 0;
    }
    .box-history .left .year::after {
        left: 120px;
    }
}
/************ 모바일 최적화 끝 ************/
