@charset "utf-8";

@font-face {
    font-family: "TheJamsil";
    src: url("/public/font/TheJamsil/The Jamsil 2 Light.woff2") format("woff2");
    font-weight: 300;
    font-style: normal;
}
@font-face {
    font-family: "TheJamsil";
    src: url("/public/font/TheJamsil/The Jamsil 3 Regular.woff2") format("woff2");
    font-weight: 400;
    font-style: normal;
}
@font-face {
    font-family: "TheJamsil";
    src: url("/public/font/TheJamsil/The Jamsil 4 Medium.woff2") format("woff2");
    font-weight: 500;
    font-style: normal;
}
@font-face {
    font-family: "TheJamsil";
    src: url("/public/font/TheJamsil/The Jamsil 5 Bold.woff2") format("woff2");
    font-weight: 600;
    font-style: normal;
}
@font-face {
    font-family: "TheJamsil";
    src: url("/public/font/TheJamsil/The Jamsil 6 ExtraBold.woff2") format("woff2");
    font-weight: 700;
    font-style: normal;
}

/* 주요색상 */
:root {
    --page-point-color: #234bcc;
}

#site {
    padding-top: 0;
    font-size: 16px;
    font-family: "TheJamsil", "notokr", sans-serif;
    color: #fff;
    letter-spacing: -0.02em;
    background: #000;
}

.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.navbar-inverse {
    position: fixed;
    margin-bottom: 0;
    background-color: transparent;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
    transition: background-color ease-in-out 0.15s;
}
.navbar.bg-colored {
    background-color: #fff;
    border-bottom-color: #fff;
    border-bottom: none;
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
}

.navbar-inverse .navbar-brand img {
    height: 40px;
    margin-top: 10px;
}

.navbar-inverse .navbar-nav > li > a {
    font-size: 17px;
    font-weight: 500;
    color: #fff;
    letter-spacing: 0;
}
.navbar-inverse .navbar-nav > li > a:hover,
.navbar-inverse .navbar-nav > li > a:focus {
    color: var(--page-point-color);
}

.navbar.bg-colored .navbar-nav > li > a {
    color: #333;
}
.navbar.bg-colored .navbar-nav > li > a:hover,
.navbar.bg-colored .navbar-nav > li > a:focus,
.navbar.bg-colored .navbar-nav > li:hover > a,
.navbar.bg-colored .navbar-nav > li:focus > a {
    color: var(--page-point-color);
}

.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;
}

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

.navbar-inverse .navbar-nav > li > a::after {
    content: "";
    left: 50%;
    bottom: 0;
    width: 0;
    height: 3px;
    position: absolute;
    background: var(--page-point-color);
    transform: translateX(-50%);
    transition: all 0.35s;
}

@media (max-width: 767px) {
    .navbar-inverse .navbar-toggle {
        border: 0;
        padding: 18px 0;
    }
    .navbar-inverse .navbar-toggle .icon-bar {
        background-color: #fff;
        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: rgba(0, 0, 0, 0.8);
        -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;
    }
    .navbar-inverse .navbar-nav .dropdown-menu > li > a {
        padding: 10px 15px;
        text-align: center;
        font-size: 15px;
        color: #fff;
        border-bottom: 1px solid rgba(255, 255, 255, 0.11);
        letter-spacing: 0.034em;
        font-weight: 300;
    }
    .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);
    }
    .navbar-inverse .navbar-nav > li > a:hover::after,
    .navbar-inverse .navbar-nav > li > a:focus::after,
    .navbar-inverse .navbar-nav .dropdown.open .dropdown-toggle::after,
    .navbar-inverse .navbar-nav .dropdown.open:hover .dropdown-toggle::after,
    .navbar-inverse .navbar-nav .dropdown.open:focus .dropdown-toggle::after {
        width: 160px;
    }
}

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

/* 슬라이드 공통 */
.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 li {
    width: 15px;
    height: 15px;
    background-color: rgba(255, 255, 255, 1);
    border: 2px solid #fff;
    margin: 0 6px;
    border-radius: 30px;
    transition: ease-in-out 0.15s all;
}
.carousel-indicators li.active {
    width: 15px;
    height: 15px;
    background-color: transparent;
    border-color: #70acbd;
    margin: 0 6px;
    box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.125);
    transform: rotate(45deg);
}

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

@media (max-width: 767px) {
    .carousel-control {
        font-size: 14px;
    }
    .carousel-indicators li,
    .carousel-indicators li.active {
        width: 10px;
        height: 10px;
    }
}

/* 푸터 */
#site footer {
    margin-top: 0px;
    color: #888;
    border-top: 1px solid #333;
}
#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: 22px;
    letter-spacing: 0em;
    font-weight: 300;
}
#site footer .footer-info ul li:first-child {
    font-weight: 400;
    display: block;
    margin-bottom: 2px;
    font-size: 15px;
    color: #aaa;
}
#site footer .footer-info .logo > img {
    opacity: 0.35;
    padding-top: 3px;
}
#site footer .footer-info ul li .tit {
    padding-right: 4px;
    font-weight: 500;
    opacity: 0.8;
}
#site footer .footer-info ul li.copy {
    color: #777;
    font-size: 10px;
    letter-spacing: 1px;
    margin-top: 5px;
}
#site footer .footer-info .info {
    padding-left: 50px;
}

/* 메인 페이지 */
#mainCarousel .carousel-inner .item {
    height: 800px;
}
#mainCarousel .carousel-caption h1 {
    margin: 0 0 40px;
    font-size: 80px;
    font-weight: 700;
    letter-spacing: -0.03em;
}
#mainCarousel .carousel-caption p {
    font-size: 32px;
    font-weight: 300;
    letter-spacing: -0.034em;
}

@media (max-width: 767px) {
    #mainCarousel .carousel-inner .item {
        height: 300px;
    }
    #mainCarousel .carousel-caption {
        top: 44%;
        right: 11%;
        left: 11%;
    }
    #mainCarousel .carousel-caption h1 {
        margin: 0 0 25px;
        font-size: 40px;
    }
    #mainCarousel .carousel-caption p {
        font-size: 17px;
    }
}

#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;
}

/* 메인 추가 스타일 */
.mainPage {
    padding: 120px 0;
}
.mainPage h2 {
    margin: 0 0 80px;
    font-size: 36px;
    font-weight: 700;
    line-height: 1;
    text-align: center;
}

/* 퀵 메뉴 이미지 관련 */
.mainPage .box-link > .item a {
    text-align: center;
    text-decoration: none;
}
.mainPage .box-link > .item .w_img {
    position: relative;
    overflow: hidden;
}
.mainPage .box-link > .item .w_img::before {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    background: #000;
    transition: all cubic-bezier(0.27, 0.51, 0.38, 1.01) 0.35s;
    opacity: 0.4;
    z-index: 100;
}
.mainPage .box-link > .item .w_img img {
    transform: scale(1);
    transition: all cubic-bezier(0.27, 0.51, 0.38, 1.01) 0.35s;
}
.mainPage .box-link > .item a:hover .w_img::before {
    opacity: 0;
}

/* ABOUT US 추가 */
.mainPage .box-link > .item .w_img1 {
    position: relative;
    overflow: hidden;
}
.mainPage .box-link > .item .w_img1::before {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    background: #000;
    transition: all cubic-bezier(0.27, 0.51, 0.38, 1.01) 0.35s;
    opacity: 0.4;
    z-index: 100;
}
.mainPage .box-link > .item .w_img1 img {
    transform: scale(1);
    transition: all cubic-bezier(0.27, 0.51, 0.38, 1.01) 0.35s;
}
.mainPage .box-link > .item a:hover .w_img1::before {
    opacity: 0;
}

/******NEWS 추가*********/
.mainPage .box-link > .item .w_img2 {
    position: relative;
    overflow: hidden;
}
.mainPage .box-link > .item .w_img2::before {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    background: #000;
    transition: all cubic-bezier(0.27, 0.51, 0.38, 1.01) 0.35s;
    opacity: 0.4;
    z-index: 100;
}
.mainPage .box-link > .item .w_img2 img {
    transform: scale(1);
    transition: all cubic-bezier(0.27, 0.51, 0.38, 1.01) 0.35s;
}
.mainPage .box-link > .item a:hover .w_img2::before {
    opacity: 0;
}

.mainPage .box-link > .item .text .tit {
    margin: 30px 0 0;
    font-size: 23px;
    font-weight: 500;
}
.mainPage .box-link > .item .text .more {
    height: 23px;
    display: flex;
    position: relative;
    margin: 30px auto 0;
    padding-top: 3px;
    padding-right: 15px;
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1em;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    transition: all ease 0.15s;
    display: inline-block;
}
.mainPage .box-link > .item .text .more::before {
    content: "\f318";
    top: 39%;
    right: 0;
    position: absolute;
    font-family: "Phosphor";
    transform: translateY(-50%);
}
.mainPage .box-link > .item a:hover .w_img img {
    transform: scale(1.125);
}
.mainPage .box-link > .item a:hover .w_img1 img {
    transform: scale(1.125);
}
.mainPage .box-link > .item a:hover .w_img2 img {
    transform: scale(1.125);
}
.mainPage .box-link > .item a:hover .text .more {
    padding-right: 25px;
}
.mainPage .box-link > .item a:hover .text .more::before {
    opacity: 1;
}

/*************** 서브 시작 ***************/
/* 공통 스타일 */
#site > .container {
    width: 100%;
    padding: 0;
}
.subPage > .pageTop {
    height: 330px;
    position: relative;
    color: #fff;
    background: #000 url("/public/img/sub/bg_subTop01.jpg") no-repeat center / cover;
}
#product01 > .pageTop {
    background: #000 url("/public/img/sub/bg_subTop02.jpg") no-repeat center / cover;
}
#news > .pageTop,
#press_release > .pageTop {
    background: #000 url("/public/img/sub/bg_subTop03.jpg") no-repeat center / cover;
}
#recruit > .pageTop,
#business > .pageTop {
    background: #000 url("/public/img/sub/bg_subTop04.jpg") no-repeat center / cover;
}
.subPage > .pageTop::before {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    display: block;
    background: #000;
    opacity: 0.1;
}
.subPage > .pageTop .container {
    height: 100%;
    position: relative;
}
.subPage > .pageTop .inner {
    top: 62%;
    /* top: 52%; */
    left: 50%;
    position: absolute;
    text-align: center;
    transform: translate(-50%, -50%);
}
#greeting > .pageTop .inner,
#history > .pageTop .inner,
#welfare > .pageTop .inner,
#location > .pageTop .inner {
    top: 52%;
    left: 0;
    position: relative;
    transform: none;
}
.subPage > .pageTop h2 {
    margin: 0;
    font-size: 50px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1;
}

/* Link */
.subPage .link {
    position: relative;
    text-align: center;
    border-bottom: 1px solid #555;
}
.subPage .link ul > li {
    display: inline-block;
    padding: 0 35px;
}
.subPage .link ul > li > a {
    padding: 0;
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 0.01em;
    line-height: 76px;
    background: transparent;
    color: #8b8d96;
}
.subPage .link ul > li > a::after {
    content: "";
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background-color: #ddd;
    position: absolute;
    right: -35px;
    top: calc(50% - 2px);
}
.subPage .link ul > li:last-child > a::after {
    content: none;
}
.subPage .link ul > li.active > a {
    color: #476ce1;
    opacity: 1;
}
.subPage .link ul > li.active > a::before {
    content: "";
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 2px;
    background: #476ce1;
    position: absolute;
}
.subPage .link ul > li:not(.active) > a:hover {
    color: #476ce1;
}

.subPage > .contents section {
    padding: 100px 0 150px;
}
.subPage > .contents .row:not(.page-title) + .row {
    margin-top: 100px;
}

.title-lv-1 {
    margin: 0 0 75px;
    font-size: 42px;
    font-weight: 500;
    line-height: 1;
    text-align: center;
}

.list-default {
    margin: 0;
    padding-left: 0;
    list-style-type: none;
}
.list-default > li {
    position: relative;
}

/* 회사소개 (페이지) */
.wrap-greet .image {
    padding: 0 65px 0 80px;
}
.wrap-greet .text .inner {
    padding: 0 90px 0 40px;
}
.wrap-greet .text .inner::before {
    content: "";
    display: block;
    width: 100px;
    height: 1px;
    background: #999;
    margin: 220px 0 80px;
}
.wrap-greet .text p {
    margin: 0 0 25px;
    font-size: 18px;
    line-height: 1.6;
}
.wrap-greet .text p:last-child {
    margin: 0;
}

/* 연혁 (페이지) */
.wrap-history > .con-left {
    padding-right: 120px;
}
.wrap-history .box-history {
    padding-top: 0px;
}
.box-history .block + .block {
    margin-top: 30px;
}
.box-history .left {
    margin-bottom: 15px;
}
.box-history .left .year {
    position: relative;
    margin: 0;
    font-size: 32px;
    font-weight: 500;
    letter-spacing: 0;
}
.box-history .left .year::before {
    content: "";
    top: 18px;
    right: -48px;
    width: 14px;
    height: 14px;
    position: absolute;
    display: block;
    background: #658aff;
    border-radius: 50%;
    z-index: 1;
    border: 3px solid #fff;
    display: none;
}
.box-history .left .year::after {
    content: "";
    top: 26px;
    left: 158px;
    width: 70px;
    height: 1px;
    position: absolute;
    display: block;
    background: #ddd;
    display: none;
}
.box-history .right ul > li {
    margin-bottom: 10px;
    padding: 14px 25px;
    color: #555;
    font-size: 17px;
    background: #f8f8f8;
    border-radius: 3px;
    line-height: 1em;
}
.box-history .right ul > li:last-child {
    margin-bottom: 0;
}
.box-history .right ul > li .month {
    font-weight: 600;
    letter-spacing: 0.02em;
    margin-right: 10px;
    color: #405cb7;
    font-size: 17px;
}

/* 복지 (페이지) */
.list-welfare {
    counter-reset: list-number;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
    gap: 20px;
    justify-content: center;
}
.list-welfare > li {
    counter-increment: list-number;
}
.list-welfare > li .inner {
    display: flex;
    align-items: center;
    position: relative;
    padding: 60px 25px 0;
    z-index: -1;
    flex-direction: column;
    border: 1px solid #d7e0ef;
    height: 260px;
}
.list-welfare > li .inner::before {
    content: "0" counter(list-number);
    left: 20px;
    top: 15px;
    position: absolute;
    font-size: 18px;
    font-weight: 300;
    color: #8fa3f1;
    z-index: -1;
    letter-spacing: 0.04em;
}
.list-welfare .icon > i[class^="ph-"] {
    font-size: 45px;
    color: #f3f7ff;
    background: #4d6ac9;
    margin-bottom: 30px;
    border-radius: 50%;
    padding: 20px;
}
.list-welfare .detail > .tit {
    margin: 0;
    font-size: 18px;
    font-weight: 400;
    text-align: center;
    line-height: 1.4em;
    letter-spacing: -0.034em;
}

/* 오시는길 (페이지) */
.box-contact .info {
    margin-top: 50px;
    margin-left: 3px;
}
.box-contact .info ul {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 12px 0;
}
.box-contact .info ul > li {
    padding-left: 130px;
    font-size: 16px;
}
.box-contact .info ul > li .tit {
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    position: absolute;
    font-size: 14px;
    font-weight: 700;
}
.box-contact .info ul > li .tit i[class^="ph-"] {
    width: 23px;
    height: 23px;
    margin-right: 7px;
    padding: 5px 5px 0;
    font-size: 13px;
    color: #fff;
    text-align: center;
    background: #4f6de4;
    border-radius: 50%;
}

.box-project {
    display: flex;
    gap: 70px;
    flex-direction: column;
}
.box-project > .image {
    position: relative;
}
.box-project > .image .tit {
    top: 50%;
    left: 50%;
    position: absolute;
    white-space: nowrap;
    transform: translate(-50%, -50%);
}
.box-project > .image .tit::before {
    content: "";
    top: 50%;
    left: 50%;
    width: 120%;
    height: 150%;
    position: absolute;
    display: flex;
    background: #000;
    transform: translate(-50%, -50%);
    border-radius: 5px;
    opacity: 0.5;
    z-index: -1;
}
.box-project > .image .tit h1 {
    margin: 0;
}
/* .box-project > .image {
    background: #fff;
}
.box-project > .detail ul {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 20px;
} */
.box-project > .detail ul li {
    border-top: 1px solid #18486e;
    /* border: 1px solid #18486e; */
    /* height: 150px; */
    align-self: center;
    padding: 50px 30px;
    padding-top: 40px;
    background: #121220;
}
.box-project > .detail ul li::before {
    content: "\f33f";
    display: block;
    position: absolute;
    left: 50%;
    top: -22px;
    font-size: 42px;
    font-family: "Phosphor";
    color: #70b8ff;
    line-height: 1em;
    transform: translateX(-50%);
    background: #000;
    border-radius: 100%;
}
.box-project > .detail ul li p {
    margin: 0;
    font-size: 22px;
    /* font-size: 18px; */
    font-weight: 300;
    color: #fff;
    line-height: 1.6em;
    text-align: center;
}
.box-project > .detail ul li + li {
    margin-top: 60px;
}
.box-project > .detail ul li img {
    width: 100%;
    margin-top: 30px;
}

/* 회사소개 (페이지) */
.box-business {
    position: relative;
    margin: 0 auto;
    padding: 100px;
    text-align: center;
    background: #000 url("/public/img/sub/box_business_bg2.png") no-repeat center / 80%;
    /* background: #000 url('/public/img/sub/box_business_bg.jpg') no-repeat center / cover; */
    border: 1px solid rgb(255 255 255 / 20%);
    border-radius: 10px;
}
.box-business::before {
    content: "";
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    display: block;
    background: #000;
    opacity: 0.3;
    /* opacity: 0.2; */
    border-radius: 10px;
}
.box-business .inner {
    position: relative;
}
.box-business .tit {
    margin: -50px 0 80px -40px;
    font-size: 16px;
    text-align: left;
    color: #fff;
    letter-spacing: 0.034em;
}
.box-business img {
    margin-bottom: 50px;
}
.box-business a {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: 20px 45px;
    padding-left: 50px;
    font-size: 18px;
    font-weight: 300;
    color: #fff;
    letter-spacing: 0.02em;
    text-decoration: none;
    line-height: 1em;
    border-radius: 31px;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.1);
    background: var(--page-point-color);
}
.box-business a:hover {
    color: #fff;
    background: var(--page-point-color);
}
.box-business a::before {
    content: "\f3bf";
    top: 1px;
    left: -10px;
    position: relative;
    font-size: 26px;
    font-family: "Phosphor";
}

/* 게시판, 주문폼 공통 스타일 */
.board_wrapper,
.calendar_wrapper {
    margin-top: 0;
    margin-bottom: 0;
    padding: 0;
}
.search_wrap {
    margin-top: 100px;
    margin-bottom: 0;
}
.board_wrapper .table.table_default {
    border-top: 1px solid #555;
}
.table.table_default tr th,
.table.table_default tr td {
    border-color: #e6e6e6;
}
.table.table_default tr td.writer,
.table.table_default tr td.regdate,
.table.table_default tr td.hits {
    color: #ccc;
}
.table.table_default tr td.subject {
    position: relative;
}
.table.table_default thead th {
    font-weight: 700;
    color: #fff;
    background: #000;
    border-color: #999;
    padding: 17px 15px;
    font-size: 16px;
}
.table.table_default tbody .subject .badge {
    top: 15px;
    position: absolute;
    padding: 4px 6px 3px;
    font-weight: 500;
    color: #fff;
    line-height: 1.3em;
    background: #333;
    border: none;
    border-radius: 0;
}
.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: 17px 20px 17px;
    border-top: 1px solid #eee;
}

: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: 40px 5px 38px;
    font-size: 26px;
    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: #ccc;
}
.board_data_view .header_wrap .info span strong {
    font-weight: 500;
    margin-right: 2px;
}

.board_data_view .header_wrap .info span + span {
    margin-left: 12px;
}

/* 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-top: none;
    border-bottom: 1px solid #e6e6e6;
}
.board_wrapper .table.board_write_table {
    border-top: 1px solid #333;
}
.board_wrapper .table.board_write_table tbody tr th {
    width: 220px;
    font-weight: 500;
    color: #333;
    background: #f5f5f5;
}
.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;
}

.board_wrapper {
    font-family: "notokr", sans-serif;
}

#board_write_form {
    padding: 50px;
    background: #fff;
}
#board_write_form .btn.btn-primary {
    background-color: #000;
    border-color: #000;
}
#board_write_form .btn.btn-primary:hover,
#board_write_form .btn.btn-primary:focus {
    color: #000;
    background-color: transparent;
}
.cke_chrome {
    color: #000;
}

/* 인재채용 (목록 게시판) */
#recruit .top-text {
    margin-bottom: 30px;
    padding: 20px;
    font-size: 18px;
    text-align: center;
    background: #2f4ccf;
}
#recruit .top-text .inner {
    position: relative;
    display: inline-block;
}
#recruit .top-text .inner::before {
    content: "";
    top: 0px;
    left: -10px;
    width: 6px;
    height: 6px;
    position: absolute;
    background: #fff;
    border-radius: 30px;
}
#recruit .top-text .tit {
    position: relative;
    display: inline-block;
    margin-right: 10px;
    font-weight: 500;
    color: #d9ecff;
    font-size: 16px;
}
#recruit .top-text .tit::after {
    content: "|";
    margin-left: 10px;
    font-weight: 100;
    color: #fff;
}
#recruit .top-text a {
    font-size: 18px;
    letter-spacing: 0.01em;
}
#recruit .top-text a:hover {
    color: #d9ecff;
}
/**************** 서브 끝 ****************/

/*********** 모바일 최적화 시작 ***********/
@media (max-width: 767px) {
    /* Small devices (col-xs-*) 모바일 */
    #site {
        padding-top: 66px;
        font-size: 15px;
    }
    p {
        line-height: 1.4em;
    }

    .navbar-inverse {
        position: fixed;
        background: #000 !important;
        border-bottom: none !important;
    }
    .navbar-inverse .navbar-brand img {
        height: 30px;
        margin-top: 4px;
    }
    .navbar-inverse .navbar-nav {
        display: block;
        margin: 15px -15px !important;
    }
    .navbar-inverse .navbar-nav > li {
        float: left;
        width: 100%;
    }
    .navbar-inverse .navbar-nav > li > a {
        padding: 10px 15px;
        font-size: 16px;
    }
    .navbar-inverse .navbar-nav > li > a:hover,
    .navbar-inverse .navbar-nav > li > a:focus {
        color: #476ce1;
    }
    .navbar.bg-colored .navbar-nav > li > a {
        color: #fff;
    }
    .navbar.bg-colored .navbar-nav > li > a:hover,
    .navbar.bg-colored .navbar-nav > li > a:focus,
    .navbar.bg-colored .navbar-nav > li:hover > a,
    .navbar.bg-colored .navbar-nav > li:focus > a {
        color: #476ce1;
    }
    .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 15px 0;
        color: #476ce1 !important;
    }
    .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: #f5f5f5;
    }
    .navbar-inverse .navbar-nav > .open .dropdown-menu > li > a::before {
        content: "· ";
    }
    .navbar-inverse .navbar-nav > .open .dropdown-menu > li > a:hover,
    .navbar-inverse .navbar-nav > .open .dropdown-menu > li > a:focus {
        font-weight: 600;
        color: #fff;
    }

    .mainPage {
        padding: 60px 0;
    }
    .mainPage h2 {
        margin: 0 0 40px;
        font-size: 30px;
    }
    .mainPage .box-link > .item + .item {
        margin-top: 10px;
    }
    .mainPage .box-link > .item .w_img {
        height: 80px;
    }
    .mainPage .box-link > .item .w_img img {
        top: 110%;
        left: 50%;
        position: absolute;
        transform: translate(-50%, -50%);
    }
    /* ABOUT US 섬네일 위치 조절 */
    .mainPage .box-link > .item .w_img1 {
        height: 80px;
    }
    .mainPage .box-link > .item .w_img1 img {
        top: 220%;
        left: 50%;
        position: absolute;
        transform: translate(-50%, -50%);
    }
    /* NEWS 섬네일 위치 조절 */
    .mainPage .box-link > .item .w_img2 {
        height: 80px;
    }
    .mainPage .box-link > .item .w_img2 img {
        top: 50%;
        left: 50%;
        position: absolute;
        transform: translate(-50%, -50%);
    }

    .mainPage .box-link > .item .text {
        top: 50%;
        left: 0;
        width: 100%;
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 15px;
        transform: translateY(-50%);
        z-index: 100;
    }
    .mainPage .box-link > .item .text .tit {
        margin: 0 0 0 20px;
        font-size: 20px;
    }
    .mainPage .box-link > .item .text .more {
        margin: 0 20px 0 0;
    }
    .mainPage .box-link > .item a:hover {
        color: var(--page-point-color);
    }
    .mainPage .box-link > .item a:hover .text .more {
        font-weight: 600;
        border-bottom-color: var(--page-point-color);
    }
    .mainPage .box-link > .item a:hover .w_img::before {
        background: #fff;
        opacity: 0.6;
    }
    .mainPage .box-link > .item a:hover .w_img img {
        transform: translate(-50%, -50%) scale(1.125);
    }

    #site footer .footer-info {
        padding: 25px 0;
        text-align: center;
    }
    #site footer .footer-info .logo > img {
        height: 50px;
        margin: 0 auto 15px;
    }
    #site footer .footer-info .info {
        padding-left: 15px;
    }
    #site footer .footer-info ul li {
        font-size: 12px;
        line-height: 18px;
    }
    #site footer .footer-info ul li:first-child {
        margin-right: 0;
        font-size: 13px;
    }

    .subPage > .pageTop {
        height: 160px;
    }
    .subPage > .pageTop .inner {
        top: 50%;
        width: 100%;
    }
    #greeting > .pageTop .inner,
    #history > .pageTop .inner,
    #welfare > .pageTop .inner,
    #location > .pageTop .inner {
        top: 35%;
    }
    .subPage > .pageTop h2 {
        font-size: 40px;
    }
    #recruit > .pageTop h2,
    #business > .pageTop h2 {
        font-size: 33px;
    }
    .subPage > .pageTop h2 img {
        height: 50px;
    }
    .subPage .link {
        margin-top: 15px;
        border-bottom: none;
    }
    .subPage .link ul {
        display: flex;
        flex-wrap: wrap;
    }
    .subPage .link ul > li {
        flex-basis: 50%;
        padding: 2px;
    }
    .subPage .link ul > li > a {
        font-size: 15px;
        line-height: 45px;
        border: 1px solid rgb(255 255 255 / 20%);
    }
    .subPage .link ul > li.active > a {
        color: #fff;
        background: #476ce1;
        border-color: #476ce1;
    }
    .subPage .link ul > li > a::before,
    .subPage .link ul > li > a::after {
        display: none;
    }
    .subPage .link ul > li:not(.active) > a:hover {
        border-color: rgb(255 255 255 / 50%);
    }
    .subPage > .contents section {
        padding: 60px 0 80px;
    }
    .title-lv-1 {
        margin: 0 0 50px;
        font-size: 34px;
    }

    .wrap-greet .image {
        padding: 0 60px;
    }
    .wrap-greet .text {
        margin-top: 45px;
    }
    .wrap-greet .text .inner {
        padding: 0;
    }
    .wrap-greet .text .inner::before {
        display: none;
    }
    .wrap-greet .text p {
        margin: 0 0 20px;
        font-size: 17px;
    }
    .wrap-history > .con-left {
        padding: 0 60px;
    }
    .wrap-history .box-history {
        padding-top: 45px;
    }
    .box-history .block + .block {
        margin-top: 35px;
    }
    .box-history .left .year {
        font-size: 28px;
    }
    .box-history .right ul > li {
        margin-bottom: 7px;
        padding: 15px;
        font-size: 16px;
    }
    .box-history .right ul > li .month {
        font-size: 16px;
    }
    .list-welfare {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    .list-welfare > li .inner {
        height: auto;
        padding: 30px 15px;
    }
    .list-welfare .icon > i[class^="ph-"] {
        font-size: 40px;
        margin-bottom: 20px;
        padding: 15px;
    }
    .list-welfare .detail > .tit {
        font-size: 17px;
    }
    .box-contact .map {
        height: 300px;
        overflow: hidden;
    }
    .box-contact .info {
        margin-top: 30px;
    }
    .box-contact .info ul > li {
        padding: 35px 0 0;
        font-size: 15px;
    }
    .box-project {
        gap: 50px;
    }
    .box-project > .detail ul {
        grid-template-columns: 1fr;
    }
    .box-project > .detail ul li {
        padding: 35px 15px 25px;
        padding-top: 25px;
    }
    .box-project > .detail ul li + li {
        margin-top: 15px;
    }
    .box-project > .detail ul li::before {
        font-size: 38px;
    }
    .box-project > .detail ul li p {
        font-size: 19px;
    }
    .box-project > .detail ul li img {
        margin-top: 15px;
    }

    #recruit .top-text {
        margin-bottom: 20px;
        padding: 15px;
        font-size: 17px;
    }
    #recruit .top-text .tit {
        font-size: 15px;
    }
    #recruit .top-text a {
        font-size: 17px;
    }
    .box-business {
        padding: 30px 20px;
        background-size: 170%;
    }
    .box-business .tit {
        margin: -10px 0 50px;
        font-size: 15px;
    }
    .box-business img {
        width: 170px;
        margin-bottom: 30px;
    }
    .box-business a {
        padding: 16px 40px 16px 45px;
        font-size: 17px;
    }

    .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;
    }

    .search_wrap {
        margin-top: 30px;
    }
    #board_write_form {
        padding: 15px;
    }
}
@media (min-width: 992px) and (max-width: 1199px) {
    /* Large devices (col-md-*) */
    .navbar-inverse .navbar-nav > li > a {
        padding-right: 28px;
        padding-left: 28px;
    }
}
/************ 모바일 최적화 끝 ************/
.root_daum_roughmap .cont{
    display: none;
}