@charset "utf-8";
@import url(//fonts.googleapis.com/earlyaccess/notosanskr.css);

html {
    overflow-x: hidden;
    overflow-y: scroll;
}
.body-layout {
    background-color: #fff;
}

/* 폰트 설정 */
.body-layout,
h1,
h2,
h3,
h4,
h5,
h6,
input,
textarea,
button {
    font-family: "Noto Sans KR", "NanumGothic", "나눔고딕", "NanumBarunGothic", "Apple SD Neo Gothic", "Malgun Gothic", "Gulim", sans-serif;
}
/* h1, h2, h3, h4, h5, h6, p { margin: 0px; } */
ol,
ul,
li {
    list-style: none;
    list-style-position: inside;
}

.navbar .caret,
.navbar .divider-vertical,
.navbar ~ br,
.footer-social-layout,
.footer_copy .text-center > br,
.topmarginLay_a {
    display: none;
}
/** 로고위치(상하) 조절 **/
.navbar-brand {
    padding: 0 !important;
    margin: 0 !important;
}
.navbar-brand img {
    margin: 14px 0 !important;
}
/** 모서리 각지게 **/

.none-radius {
    border-radius: 0px !important;
}

/** 최상단여백 크기 설정 **/

.topmarginLay_a {
    padding: 55px;
}

@media (max-width: 768px) {
    .topmarginLay_a {
        padding: 85px;
    }
}

@media (max-width: 768px) {
    .topmarginLay_a {
        padding: 85px;
    }
}

/** 각각의 페이지 타이틀 설정 **/

.panel-default > .vine-title-title {
    background-repeat: none;
    padding: 30px 0;
}

/** 타이틀백그라운드 이미지 **/

.custom-back1 {
    border-bottom: 1px solid #333;
}

/** 메뉴구분선 삭제 **/

.navbar-inverse .divider-vertical {
    display: none;
}

/** 서브메뉴 하단 보더처리 **/
/**페이지 타이틀**/

.vs-title-box {
    background: #fff;
    border: 1px solid #ddd;
    background-image: url(/skin/img/title-deco.png) no-repeat right bottom;
    margin: 0 0 55px;
}

.vs-title-img img {
    width: 100%;
}

/**ClearFix**/

.dh-board,
.dh-view-box {
    clear: both;
}

/**인트로 HTML 설정**/

.intro-html {
    margin: 25px 0;
}

.vs-intropanel {
    background: #fff;
    padding: 10px;
    border: 1px solid #ddd;
    min-height: 250px;
}

.vs-intropanel p {
    font-size: 11px;
}

.vs-intropanel a {
    color: #000;
    display: block;
}

/*Vine*/

.thumbnail {
    margin: 0 0 15px 0;
}

/* navigation */

.navbar {
    margin-bottom: 0;
}
.navbar-inverse {
    background: #fff;
    border: 0;
    border-top: 10px solid #0d3a97;
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
}
.navbar-collapse {
    margin: 0 -15px !important;
    border-bottom: 1px solid #eee !important;
}
.navbar-inverse .navbar-nav > li > a {
    margin: 5px 0 0;
    padding: 40px 20px;
    color: #222;
    font-size: 16px;
    font-weight: 400;
    letter-spacing: -0.02em;
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
    position: relative;
}
.navbar-inverse .navbar-nav > li:hover > a:before,
.navbar-inverse .navbar-nav > li > a:hover:before {
    content: "\f0d7";
    color: #b3b3b3;
    font-family: "FontAwesome" !important;
    position: absolute;
    bottom: 15px;
    left: 50%;
    margin-left: -4px;
}
.navbar-inverse .navbar-toggle .icon-bar {
    background-color: #4099ef;
}

.navbar-toggle {
    margin-top: 30px;
}

.btnEdit i,
.btnDelete i {
    color: #eee;
}

.navbar-inverse .navbar-nav > .open > a,
.navbar-inverse .navbar-nav > .open > a:focus,
.navbar-inverse .navbar-nav > .open > a:hover {
    color: #333;
    background: rgba(0, 0, 0, 0);
    box-shadow: none;
    -webkit-box-shadow: none;
}
.navbar-inverse .navbar-nav > .open > a,
.navbar-inverse .navbar-nav > li > a:focus,
.navbar-inverse .navbar-nav > li > a:hover {
    color: #0d3a97;
}
.navbar .glyphicon {
    color: #333;
}

.caret {
    display: none;
}
.navbar-nav .dropdown-menu {
    background: #0d3a97;
    left: 0;
    right: auto;
    min-width: 180px;
    margin: 0;
    padding: 4px 5px;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
    border: none;
    border-radius: 0 !important;
}
.navbar-nav .dropdown-menu > li > a {
    color: #eee;
    font-size: 13px;
    font-weight: 400;
    text-transform: capitalize;
    letter-spacing: -0.02em;
    margin: 1px 0;
    padding: 12px 15px;
}
.navbar-nav .dropdown-menu > li > a:focus,
.navbar-nav .dropdown-menu > li > a:hover {
    background: #fff;
    color: #1a83b6;
    text-decoration: none;
}
/* //navigation */
.intro-board-layout .page-header {
    padding-bottom: 10px;
    margin: 35px 0 20px;
    position: relative;
}

.intro-board-layout .page-header h4,
.intro-widgetBoardbox > a > h5 {
    color: #333;
    margin: 0;
    padding: 0;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: -0.06em;
}

.intro-board-layout .page-header .fa::before {
    content: url("/skin/img/default/btn_plus.png");
}

.intro-board-layout .page-header .fa {
    position: absolute;
    top: 0;
    right: 0;
}

.intro-board-widget-layout > .intro-board-layout .intro-boardbox {
    border-bottom: 1px solid #eee;
    margin-bottom: 20px;
}

@media (min-width: 768px) {
    .intro-board-widget-layout > .intro-board-layout .intro-boardbox {
        padding: 0;
    }
    .intro-board-widget-layout > .intro-widget-layout {
        padding-right: 0;
    }
    .intro-board-widget-layout > .intro-board-layout {
        padding: 0 15px 0 0;
    }
}

@media (max-width: 767px) {
    .intro-board-widget-layout > .intro-board-layout {
        padding: 0;
    }
}

.intro-board-widget-layout .intro-board-layout .thumbnail {
    border: 0;
    -webkit-box-shadow: 0 0 0 rgba(0, 0, 0, 0.075);
    box-shadow: 0 0 0 rgba(0, 0, 0, 0.075);
}

.intro-board-widget-layout .intro-board-layout .thumbnail a {
    background-size: cover !important;
    height: 90px !important;
    border: 0 !important;
}

.intro-board-widget-layout .intro-board-layout .thumbnail .caption {
    padding: 0 0 5px;
}

.intro-board-widget-layout .intro-board-layout .thumbnail .caption h5 a {
    font-size: 13px;
    font-weight: 600;
}

.dh-front-blog > .col-md-4 > .thumbnail {
    min-height: 0;
    margin-bottom: 0;
}

.dh-front-blog > .col-md-4 > .thumbnail > .caption h5 {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 10px 0 5px;
    padding: 0 !important;
}

.dh-front-blog > .col-md-4 > .thumbnail > .caption p a {
    font-size: 13px;
    color: #666;
    letter-spacing: -0.02em;
}

/*html 영역*/

.intro-html-layout,
.intro-html-layout .main-contents > div,
.intro-html-layout .main-contents > div > div > .main-sub-contents div:first-child {
    padding: 0;
}

@media (min-width: 768px) {
    .main-contents .title {
        padding: 0;
    }
}

@media (min-width: 768px) {
    .intro-html-layout .main-contents .tab-left {
        padding-left: 0;
    }
    .intro-html-layout .main-contents .tab-right {
        padding-right: 0;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .intro-board-widget-layout .intro-boardbox .dh-front-blog > div:last-child {
        display: none;
    }
}

@media (max-width: 991px) {
    .intro-html-layout .main-contents .main-sub-contents .col-md-7 {
        padding: 0;
    }
}

.main-contents img {
    margin-bottom: 15px;
}

.main-contents .main-sub-contents {
    border-top: 1px solid #eee;
    padding-top: 25px;
}

.intro-html-layout .main-contents .title {
    font-size: 16px;
    color: #333;
}

.intro-html-layout .main-contents .sub-title {
    font-size: 15px;
    font-weight: 600;
    color: #333;
    letter-spacing: -0.04em;
    margin: 0 0 15px;
}

.intro-html-layout .main-contents p {
    font-size: 13px;
    color: #666;
    letter-spacing: -0.04em;
}

.page-top-text {
    position: absolute;
    top: 50%;
    left: 0;
    color: #fff;
    width: 100%;
    text-align: center;
    margin: -28px 0 0;
}

.sub-page-top h3 {
    margin: 0 0 10px;
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.06em;
}

.sub-page-top .page-top-text p {
    color: #eee;
    font-size: 13px;
    letter-spacing: -0.04em;
}

@media (max-width: 767px) {
    .sub-page-top img {
        height: 100px;
    }
    .sub-page-top .page-top-text {
        top: 5px;
        left: 30px;
    }
}

@media (min-width: 767px) and (max-width: 991px) {
    .sub-page-top img {
        height: 100px;
    }
    .sub-page-top .page-top-text {
        top: 5px;
        left: 30px;
    }
}

/*=====----- 메일폼 설정 -----=====*/

.main-contact #mailForm {
    width: 80% !important;
    max-width: 1170px;
    margin: 0 auto;
    padding: 0 !important;
}
#mailForm .form-group {
    margin: 0;
    padding: 20px 30px;
    background: #f8f8f8;
    border-bottom: 1px solid #e0e0e0;
}
#mailForm .form-group:first-child {
    border-top: 1px solid #000;
}
#mailForm .form-group:nth-child(5) {
    background: none;
    border: none;
    padding: 25px 25px 20px;
}
#mailForm .form-group label {
    width: 15%;
    float: left;
    margin: 10px 0 0;
}

#mailForm .form-group input.form-control,
#mailForm .form-group textarea.form-control {
    width: 85%;
    max-width: 935px;
    border: 1px solid #d0d0d0;
    border-radius: 0;
    box-shadow: 0 0 0 rgba(0, 0, 0, 0);
}

#mailForm .form-group input.form-control {
    height: 40px;
}

#mailForm .form-group p.error,
#mailForm .form-group ~ p.error {
    margin: 0;
    color: #4099ef;
    font-size: 12px;
}

#mailForm .form-group ~ p.error {
    padding-left: 35px;
    margin: -15px 0 0;
}

#mailForm .form-group .checkbox {
    margin: -8px 0 0;
}

#mailForm .form-group .checkbox label {
    width: 100%;
    margin: 0;
}
input[type="button"].btn-block,
input[type="reset"].btn-block,
input[type="submit"].btn-block {
    width: 200px;
    margin: 60px auto 0 !important;
    margin-top: 30px;
    background: #222 !important;
    box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    color: #fff;
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
    padding: 14px 24px;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: -0.04em;
}
input[type="button"].btn-block:hover,
input[type="reset"].btn-block:hover,
input[type="submit"].btn-block:hover {
    background: #0d3a97 !important;
    color: #fff;
}

@media screen and (max-width: 991px) {
    #mailForm .form-group input.form-control,
    #mailForm .form-group textarea.form-control {
        max-width: 567px;
    }
}

@media screen and (max-width: 767px) {
    #mailForm .form-group {
        padding: 20px 15px;
    }
    #mailForm .form-group label {
        width: 20%;
        font-size: 13px;
        font-weight: 500;
        letter-spacing: -0.05em;
    }
    #mailForm .form-group input.form-control,
    #mailForm .form-group textarea.form-control {
        width: 80%;
    }
    #mailForm .form-group ~ p.error {
        padding-left: 15px;
        margin: 0;
    }
    input[type="button"].btn-block,
    input[type="reset"].btn-block,
    input[type="submit"].btn-block {
        margin-top: 80px;
    }
}

/*=====----- 게시판 설정 -----=====*/
.dh-board,
.img-bbs-default-index-layout .page_wrap ~ div,
.dh-view-box,
.form-horizontal,
#mailForm {
    width: 100%;
    max-width: 1170px;
    margin: 0 auto;
    padding: 0;
}
.bbs-list-index-layout .subPage .right_contents,
.bbs-list-view-layout .subPage .right_contents,
.bbs-list-edit-layout .subPage .right_contents {
    width: 100%;
    padding: 0;
}

/*=====----- 텍스트 게시판 설정 -----=====*/

.dh-board .table > thead > tr > th,
.dh-board .table > tbody > tr > th,
.dh-board .table > tfoot > tr > th,
.dh-board .table > thead > tr > td,
.dh-board .table > tbody > tr > td,
.dh-board .table > tfoot > tr > td {
    padding: 16px 20px;
    color: #666;
    font-size: 14px;
}

.dh-board .table > thead > tr > th {
    background: #f9f9f9;
    vertical-align: middle;
    border-bottom: 1px solid #ccc;
    font-size: 15px;
    font-weight: 500;
    color: #333;
    letter-spacing: -0.03em;
}

.dh-board .table > tbody > tr > td {
    border-bottom: 1px dotted #dedede;
}

.dh-board .table > tbody > tr > td > strong > a {
    color: #555;
}

.dh-board > .table-hover {
    border-top: 2px solid #2d2d2d;
    border-bottom: 1px solid #ccc;
    margin: 0px 0 30px;
}

.dh-board > .table-hover > tbody > tr:hover td {
    background-color: #f9f9f9;
}

.dh-board > .table-hover > tbody > tr:hover > td > strong > a {
    color: #000;
}

.dh-margin-top {
    margin-top: 40px;
    display: inline-block;
}

/* ----- 블로그 B타입 게시판 ----- */

.bbs-blog2-index-layout .dhb-txt-box-type-b {
    border: none;
    background-color: #fff;
    width: 25%;
    margin: 0 0 20px;
    padding: 0 10px;
}

.bbs-blog2-index-layout .dhb-txt-box-type-b > div {
    margin: 0;
    padding: 0;
    border: 1px solid #e5e5e5;
}

.dhb-txt-box-type-b-img-layout {
    padding: 0;
}

.dhb-txt-box-type-b-img-layout .thumb-hidden {
    border: none;
    min-height: 110px;
    max-height: 110px;
    box-shadow: 0 0 0 rgba(0, 0, 0, 0);
}

.dhb-txt-box-type-b-text-layout h4 {
    font-size: 14px;
    margin: 15px 0;
}

.dhb-txt-box-type-b-text-layout .txt-box-footer {
    margin-top: 0;
    float: none;
    text-align: left;
    display: none;
}

.txt-box-footer em {
    display: none;
}

.txt-box-footer em > span.regdate {
    font-style: normal;
    color: #666;
    font-size: 13px;
}

.txt-box-footer em > span:last-child {
    display: none;
}

.txt-box-footer small.hits {
    display: none;
}

@media screen and (max-width: 767px) {
    .bbs-blog2-index-layout .dhb-txt-box-type-b {
        width: 100%;
        margin: 10px 0 20px;
    }
}

/* ----- 게시판 버튼 설정 ----- */

.label {
    background: rgba(0, 0, 0, 0);
    padding: 0 5px;
    font-size: 90%;
}

.label-danger {
    color: #4099ef;
}

.label-primary {
    color: #4099ef;
}

.pagination > .active > a,
.pagination > .active > a:focus,
.pagination > .active > a:hover,
.pagination > .active > span,
.pagination > .active > span:focus,
.pagination > .active > span:hover {
    background-color: #4099ef;
    border: 1px solid #4099ef !important;
}

.pagination > li > a,
.pagination > li > span {
    color: #9d8478;
    border: 1px solid #fff !important;
}

.pagination > li > a:focus,
.pagination > li > a:hover,
.pagination > li > span:focus,
.pagination > li > span:hover {
    color: #9d8478;
}

.dh-margin-top form#insertForm {
    width: 100%;
    max-width: 100%;
    display: block;
    margin: 0 0 0;
}

.btnRead {
    font-weight: 500;
}

.btn-default,
.btn-primary,
.btn-danger {
    background-image: none;
}

.btn-group,
.btn-group-vertical {
    margin: 10px 0 30px;
}

/* ----- 게시글 뷰 페이지 설정 ----- */

.dh-view-box {
    margin-top: 0px;
}

.sns-box {
    display: none;
}

.dh-view-box > .row > .page-header {
    border-top: 2px solid #000;
    border-bottom: 1px solid #ccc;
    padding: 0 20px;
    margin: 0;
}

.dh-view-box > .row > .page-header > h4 {
    color: #333;
    font-size: 23px;
    margin: 14px 0;
}

.dh-view-box > .row > .dh-view-info {
    border-bottom: 1px solid #ccc;
    background: rgba(0, 0, 0, 0);
    padding: 8px 20px 8px;
    color: #888;
}

.dh-view-box > .row > .dh-view-info > span {
    padding: 0 15px 0 0;
}

.dh-view-box > .row > .dh-view-info > span > strong {
    color: #555;
    padding: 0 5px 0 0;
}

.dh-view-box .dh-attach h6 {
    margin: 0 0 0;
    padding: 5px 5px 0;
}

.dh-view-box > .row:nth-child(2) > div:nth-child(3) {
    padding: 30px 20px 60px !important;
    min-height: 300px;
}

@media screen and (max-width: 991px) {
    .dh-board,
    .img-bbs-default-index-layout .page_wrap ~ div,
    .dh-view-box,
    .form-horizontal,
    #mailForm {
        padding: 60px 15px;
    }
}

@media screen and (max-width: 767px) {
    .dh-board,
    .img-bbs-default-index-layout .page_wrap ~ div,
    .dh-view-box,
    .form-horizontal,
    #mailForm {
        padding: 40px 15px;
    }
}

/* 게시판 설정 끝 */

/* personal setting 0.29v */
/* layout */
.mt-20 {
    margin-top: 20px !important;
}
.mt-30 {
    margin-top: 30px !important;
}
.mt-40 {
    margin-top: 40px !important;
}
.mt-80 {
    margin-top: 80px !important;
}
.mb-20 {
    margin-bottom: 20px !important;
}
.mb-30 {
    margin-bottom: 30px !important;
}
.mb-40 {
    margin-bottom: 40px !important;
}
.mb-80 {
    margin-bottom: 80px !important;
}
.ml-20 {
    margin-left: 20px !important;
}
.ml-30 {
    margin-left: 30px !important;
}
.ml-40 {
    margin-left: 40px !important;
}
.mr-20 {
    margin-right: 20px !important;
}
.mr-30 {
    margin-right: 30px !important;
}
.mr-40 {
    margin-right: 40px !important;
}
.mg-0 {
    margin: 0 !important;
}
.pd-0 {
    margin: 0 !important;
}

/* img */
.img-cover {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}
.img-contain {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
}
.max-90 {
    width: 90% !important;
    margin: 0 auto;
    display: block;
}
.img-bordered {
    border: 1px solid #ddd;
}

/* align */
.absolute-center {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    padding: 0;
    margin: 0;
}
.horizontal-center {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    padding: 0;
    margin: 0;
}
.vertical-center {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    padding: 0;
    margin: 0;
}
.text-center-table thead th,
.text-center-table thead td,
.text-center-table tbody th,
.text-center-table tbody td {
    text-align: center !important;
    vertical-align: middle !important;
}
/* font */
.font-12 {
    font-size: 12px !important;
}
.font-14 {
    font-size: 14px !important;
}
.font-16 {
    font-size: 16px !important;
}
.font-18 {
    font-size: 18px !important;
}
.font-20 {
    font-size: 20px !important;
}
.font-22 {
    font-size: 22px !important;
}
.text-colored {
    color: #276dbf !important;
}
.text-bold {
    font-weight: bold !important;
}
.text-underline {
    text-decoration: underline !important;
}
.text-italic {
    font-style: italic !important;
}

/*list style*/
.li-none > li {
    list-style: none !important;
    margin-left: 20px;
}
.li-disc > li {
    list-style: disc !important;
    margin-left: 20px;
}
.li-circle > li {
    list-style: circle !important;
    margin-left: 20px;
}
.li-square > li {
    list-style: square !important;
    margin-left: 20px;
}
.li-dash > li {
    margin-left: 10px;
    padding-left: 20px;
    position: relative;
}
.li-dash > li:before {
    content: "-";
    display: block;
    position: absolute;
    left: 5px;
    top: 0;
}

/* component */
.card {
    display: block;
    position: relative;
    padding: 15px;
    margin-bottom: 10px;
    border: 1px solid #ddd;
    min-height: max-content;
}
/* custom setting */
.container_contents,
.footer_copy > div,
.sub-layout {
    width: 100%;
    padding: 0;
}
ul,
dl,
ol {
    padding: 0;
}
.body-layout {
    overflow-x: hidden;
}
p,
li,
dt,
dd {
    line-height: 1.6;
}
* {
    box-sizing: border-box;
    word-break: keep-all;
}

/* personal setting 0.29v end */
/* layout setting */
.navbar-inverse + .container {
    width: 100%;
    padding: 0;
    margin-top: -1px;
}
/* navigation setting */

/* mainpage setting */
.carousel .item {
    height: 560px;
    overflow: hidden;
}
.carousel .item img {
    width: 100%;
}
.carousel-caption {
    margin: -44px 0 0;
    padding: 0;
    top: 50%;
    bottom: auto;
    text-align: left;
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
}
.carousel-caption h2 {
    margin: 0;
    font-size: 55px;
    font-weight: 600;
    letter-spacing: -0.04em;
    line-height: 1;
    color: #fff;
}
.carousel-caption h2 span {
    display: block;
    margin-bottom: 10px;
    font-size: 24px;
    font-weight: 500;
    letter-spacing: 0.04em;
}
.carousel-caption p {
    margin-top: 20px;
    font-size: 16px;
    color: #ddd;
}
.main-content h3 {
    color: #222;
    position: relative;
    text-align: center;
    font-size: 34px;
    font-weight: 500;
    letter-spacing: 0.04em;
    margin: 0 0 40px;
    padding: 14px 0 0;
}
.main-content h3:before {
    content: "";
    display: block;
    width: 40px;
    height: 4px;
    background: #0d3a97;
    position: absolute;
    left: 50%;
    top: 0;
    transform: translatex(-50%);
}
.main-content h4 {
    margin: 0;
}
.main-service {
    padding: 60px 0;
    background: #fff;
}
.m-service-box {
    padding: 0 5px;
}
.main-service a {
    color: #222;
}
.main-service a img {
    transition: all 0.3s ease;
}
.main-service .img-box {
    background: #0d3a97;
    height: 400px;
    overflow: hidden;
}
.main-service a:hover {
    color: #0d3a97;
    text-decoration: none;
}
.main-service a:hover img {
    opacity: 0.4;
}
.main-service a:hover .numbering {
    color: #0d3a97;
}
.txt-box h4 {
    margin: 10px 0 0;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: -0.04em;
}
.main-service .txt-box:after {
    content: "";
    display: block;
    clear: both;
}
.main-service h4 {
    float: left;
    padding-left: 10px;
}
.main-service .more {
    float: right;
    margin: 10px 0 0;
    color: #fff;
    font-size: 13px;
    font-weight: 300;
    background: #0d3a97;
    padding: 4px 14px;
    line-height: 1;
    border-radius: 50px;
}
.main-service .numbering {
    margin-right: 8px;
    color: #888;
    font-weight: 400;
    letter-spacing: 0.04em;
}
.m-service-more .btn-primary {
    position: relative;
    left: 50%;
    transform: translatex(-50%);
    margin: 60px 0 0;
    padding: 14px 24px;
    border: none;
    border-radius: 6px;
    color: #fff;
    background: #222;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: -0.04em;
}
.m-service-more .btn-primary:hover {
    background: #0d3a97;
    color: #fff;
}

.main-intro {
    padding: 80px 0;
    background: #fff url(/skin/img/main/m-news-bg.png) no-repeat center;
}
.main-intro p {
    color: #222;
    font-size: 16px;
    letter-spacing: -0.02em;
    line-height: 1.8;
    margin: 0;
}

.main-news {
    background: #f6f6f6;
    padding: 60px 0;
    background-size: cover;
}
.list-row-regdate,
.row-separator,
.main-news .label-danger,
.intro-boardbox-15 {
    display: none;
}
.dh-front-list2-words {
    margin: 0 !important;
    padding: 30px 20px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
}
.dh-front-list2-words h6 {
    margin: 0 0 15px;
}
.dh-front-list2-words h6 a {
    color: #222;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: -0.04em;
    text-decoration: none;
}
.dh-front-list2-words h5 {
    margin: 0;
}
.dh-front-list2-words h5 a {
    color: #666;
    font-size: 14px;
    font-weight: 300;
    letter-spacing: -0.02em;
    line-height: 1.6;
    height: 90px;
    overflow: hidden;
    display: inline-block;
}
.dh-front-list2-words:hover {
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
}
.dh-front-list2-words:hover h6 a {
    color: #0d3a97;
}
.dh-front-list2-words:hover h5 a {
    text-decoration: underline;
}

.main-contact {
    background: #fff;
    padding: 60px 0;
}

/* footer setting */
.footer_copy > div {
    padding: 0 0 20px;
    background: #222;
    color: #888;
    font-size: 12px;
    letter-spacing: -0.02em;
}
.f-partner {
    padding: 20px 0;
    background: #eee;
}
.f-partner img {
    border-radius: 4px;
}
.footer_copy > div b {
    color: #aaa;
}
.footer_copy > .col-lg-12 > .container {
    padding-top: 25px;
}
/* subpage setting */
.subpage .pageheader {
    width: 100%;
    height: 260px;
    background: url(/skin/img/sub/subtop-bg.jpg) no-repeat center;
    background-size: cover;
}
.subpage .pageheader .container {
    position: relative;
    height: 100%;
}
.pageheader h2 {
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translatey(-50%);
    color: #fff;
    font-size: 34px;
    font-weight: bold;
    margin: 0;
}
.pageheader .breadcrumb {
    margin: 0;
    padding: 0;
    background: transparent;
    font-size: 12px;
    position: absolute;
    right: 15px;
    bottom: 10px;
    color: #b3b3b3;
    font-weight: 400;
}
.pageheader .breadcrumb > li + li:before {
    color: rgba(255, 255, 255, 0.4);
}
.subpage-content {
    padding: 60px 0;
}
.bbs-list-index-layout .subpage-content {
    padding: 60px 0 0;
}
#service03 .col-sm-12 {
    margin-bottom: 60px;
}
.subpage-content .title h3 {
    margin: 0 0 40px;
    padding: 0 0 20px;
    color: #222;
    font-size: 28px;
    font-weight: 500;
    letter-spacing: -0.04em;
    position: relative;
    text-align: center;
}
.subpage-content .title h3:before {
    content: "";
    background: #0d3a97;
    width: 20px;
    height: 2px;
    position: absolute;
    bottom: 0;
    left: 50%;
    margin-left: -10px;
}
.quote-box {
    padding: 30px 20px;
    border: 1px solid #e3e3e3;
}
.quote-box .li-disc {
    margin: 20px 0 0;
    color: #666;
    font-size: 14px;
    font-weight: 300;
}
.quote-box p {
    margin: 0;
    color: #444;
    font-size: 15px;
    font-weight: 400;
    letter-spacing: -0.02em;
    line-height: 1.8;
}
.subpage-content h4 {
    position: relative;
    margin: 40px 0 20px;
    padding-left: 20px;
    color: #444;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.04em;
}
.subpage-content h4:before {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: skew(-15deg) translatey(-50%);
    background: #0d3a97;
}
.subpage-content .column-2 {
    margin: 20px 0 20px;
    padding: 30px 30px;
    column-count: 2;
    column-rule: 1px solid #f3f3f3;
    column-gap: 60px;
    border: 1px solid #e3e3e3;
}
.subpage-content .column-2 > h4 {
    font-size: 16px;
    font-weight: 500;
}
.subpage-content .column-2 > h4:first-child {
    margin-top: 0;
}
.subpage-content .column-2 > h4:before {
    transform: none;
    width: 5px;
    height: 5px;
    top: 5px;
}
.subpage-content .column-2 p {
    color: #666;
    font-size: 14px;
    font-weight: 300;
    letter-spacing: -0.02em;
    line-height: 1.8;
}

/* subpage about */
.profile {
    position: relative;
    margin: 40px 0;
    padding: 30px 30px;
    border: 1px solid #e3e3e3;
}
.profile:after {
    content: "";
    display: block;
    clear: both;
}
.profile .img-box {
    float: left;
    width: 20%;
    min-height: 190px;
    margin: 0;
}
.profile .fa {
    display: block;
    margin: 0 auto;
    text-align: center;
    width: 140px;
    height: 160px;
    line-height: 150px;
    background: #ccc;
    color: #fff;
    font-size: 80px;
    border: 4px solid #fff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}
.profile .text-box {
    float: right;
    width: 80%;
}
.profile .text-box h4 {
    margin: 0 0 20px;
}
.profile h4 small {
    margin-left: 10px;
    opacity: 0.5;
}
#about03 .quote-box {
    margin-top: 20px;
    display: none;
}

/* subpage service */
#service01 .quote-box,
#service02 .quote-box,
#service03 .quote-box {
    margin-bottom: 40px;
}
#service05 .subpage-content h4 {
    margin: 0 0 20px;
}
#service05 .quote-box {
    margin-bottom: 40px;
}
#service05 .subpage-content dt,
#service08 .subpage-content dt {
    color: #222;
    margin: 20px 0 10px;
    font-size: 15px;
    letter-spacing: -0.02em;
}

/* subpage industry */
#industry01 h4,
#industry02 h4,
#industry03 h4,
#industry04 h4,
#industry05 h4,
#industry06 h4,
#industry07 h4 {
    margin: 0 0 20px;
}
#industry01 .quote-box,
#industry02 .quote-box,
#industry03 .quote-box,
#industry04 .quote-box,
#industry05 .quote-box {
    margin: 0 0 40px;
}
#industry03 .column-2,
#industry07 .column-2 {
    margin: 20px 0 40px;
}
#industry01 .li-disc {
    margin: 0 0 40px;
    color: #666;
    font-size: 14px;
    font-weight: 300;
    letter-spacing: -0.02em;
}

/* subpage corp */
#corp01 h4,
#corp02 h4,
#corp03 h4,
#corp04 h4,
#corp05 h4,
#corp06 h4 {
    margin: 0 0 20px;
}
#corp01 .quote-box,
#corp02 .quote-box,
#corp03 .quote-box,
#corp05 .quote-box,
#corp06 .quote-box {
    margin: 0 0 40px;
}
#corp05 .li-disc,
#corp06 .li-disc {
    margin: 0 0 40px;
}

/* subpage IT */
#it h4 {
    margin: 0 0 20px;
}
#it .quote-box {
    margin: 0 0 40px;
}

/* 20230131 */
@media (max-width: 767px) {
    body{
        padding-top: 88px;
    }
    .navbar-inverse{
        width: 100%;
        left: 0;
        top: 0;
        position: fixed;
    }
    .navbar-brand img {
        width: 170px;
        margin-left: 10px !important;
    }
    .navbar-inverse .navbar-toggle {
        border-color: #0d3a97;
        margin-top: 20px;
    }
    .navbar-inverse .navbar-toggle:focus,
    .navbar-inverse .navbar-toggle:hover {
        background-color: transparent;
        color: #fff;
    }
    .navbar-inverse .navbar-nav > li > a:focus,
    .navbar-inverse .navbar-nav > li > a:hover,
    .navbar-inverse .navbar-nav > .open > a,
    .navbar-inverse .navbar-nav > .open > a:focus,
    .navbar-inverse .navbar-nav > .open > a:hover,
    .navbar-inverse .navbar-nav > li > a {
        padding: 15px 20px;
        background-color: #0d3a97;
        color: #fff;
        margin-top: 0px;
    }
    .navbar .glyphicon {
        color: #fff;
    }
    .navbar-nav {
        margin-top: 0;
        margin-bottom: 0;
    }
    .navbar-collapse {
        border-bottom: 0 !important;
    }
    .navbar-inverse .navbar-nav > li:hover > a:before,
    .navbar-inverse .navbar-nav > li > a:hover:before {
        /* display: none; */
        content: none;
    }
    .navbar-nav .open .dropdown-menu {
        background-color: #052463;
    }
    .navbar-inverse .navbar-nav .open .dropdown-menu > li > a {
        color: #fff;
    }
    .carousel .item {
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        height: auto;
        aspect-ratio: 1/1;
    }
    .carousel-control,
    .carousel-control.right,
    .carousel-control.left {
        display: none;
    }
    .carousel-caption {
        margin-top: 0;
        left: 5%;
        right: 5%;
        top: 48%;
        text-align: center;
        transform: translateY(-50%);
    }
    .main-service .row {
        margin: 0;
    }
    .main-service .img-box {
        height: auto;
    }
    .main-service .txt-box {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-align: center;
    }
    .main-service h4 {
        padding-left: 0;
    }
    .main-service h4 span {
        display: block;
        margin-bottom: 10px;
    }
    .m-service-box {
        padding: 0 10px;
        margin-bottom: 30px;
    }
    .m-service-more .btn-primary {
        width: 100%;
        position: static;
        transform: none;
        margin: 30px auto 0;
    }
    .main-contact #mailForm {
        width: 100% !important;
    }
    #mailForm .form-group:nth-child(5) {
        overflow: hidden;
    }
    .f-partner .row::before,
    .f-partner .row::after {
        content: none;
    }
    .f-partner .row {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        flex-wrap: wrap;
        gap: 10px;
        margin: 0;
    }
    .f-partner .row > div {
        width: 100%;
        padding: 0;
    }
    .footer_copy .text-right,
    .footer_copy .text-left {
        text-align: center !important;
    }
    .subpage .pageheader {
        height: 170px;
    }
    .subpage .pageheader .container {
        width: 100%;
        margin: 0;
        text-align: center;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }
    .pageheader .breadcrumb,
    .pageheader h2 {
        position: static;
        transform: none;
    }
    .pageheader h2 {
        margin-top: 10px;
    }
    .pageheader .breadcrumb {
        margin-top: 10px;
    }
    .subpage-content .column-2 {
        column-count: 1;
    }
    #service02 img,
    #service01 img {
        margin-bottom: 30px;
    }
    .dh-board .table > :is(thead, tbody) > tr > :is(.num, .hits) {
        display: none;
    }
    .dh-margin-top::before,
    .dh-margin-top::after {
        content: none;
    }
    .dh-margin-top {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 20px;
    }
    .dh-board,
    .img-bbs-default-index-layout .page_wrap ~ div,
    .dh-view-box,
    .form-horizontal,
    #mailForm {
        padding-top: 0;
        padding-bottom: 0;
    }
}
