* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    min-height: 100%;
}

body {
    font-family: "Malgun Gothic", "Apple SD Gothic Neo", Arial, sans-serif;
    color: #25201f;
    background: #f7f4f2;
}

body,
td,
th,
input,
button,
textarea,
select {
    font-family: "Malgun Gothic", "Apple SD Gothic Neo", Arial, sans-serif;
}

a {
    color: #3a2422;
    text-decoration: none;
}

a:hover,
a:focus {
    color: #d71920;
    text-decoration: none;
}

.jm-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

.jm-wrap {
    width: 978px;
    margin: 0 auto;
    text-align: left;
}

.jm-news-page {
    min-height: 100vh;
    background: linear-gradient(180deg, #ffffff 0, #fff7f5 260px, #f7f4f2 100%);
    text-align: center;
}

.jm-topbar {
    height: 35px;
    background: #fff;
    border-bottom: 0;
    color: #685d5a;
    font-size: 13px;
}

.jm-topbar .jm-wrap {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 9px;
    height: 35px;
    color: #685d5a;
    line-height: 34px;
}

.jm-topbar a {
    color: #685d5a;
    font-weight: 600;
}

.jm-topbar a:hover {
    color: #d71920;
    font-weight: 700;
}

.jm-masthead {
    background: #fff;
}

.jm-masthead-inner {
    display: grid;
    grid-template-columns: 370px 330px 250px;
    align-items: center;
    gap: 14px;
    min-height: 101px;
}

.jm-logo {
    color: #050505;
    font-size: 38px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -1px;
    white-space: nowrap;
}

.jm-logo:hover,
.jm-logo:focus {
    color: #050505;
    text-decoration: none;
}

.jm-search {
    display: flex;
    align-items: stretch;
    justify-content: flex-start;
    width: 100%;
    margin-top: 0;
}

.jm-search input {
    width: 280px;
    height: 32px;
    padding: 0 10px;
    border: 1px solid #dfd2cf;
    border-right: 0;
    border-radius: 5px 0 0 5px;
    background: #fff;
    color: #25201f;
    font-size: 14px;
    line-height: 32px !important;
}

.jm-search button {
    width: 50px;
    height: 32px;
    padding: 0;
    border: 0;
    border-radius: 0 5px 5px 0;
    background: #d71920;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
}

.jm-ad,
.jm-top-banner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 62px;
}

.jm-ad {
    padding: 10px 16px;
    background: #fff100;
    color: #003a78;
    font-weight: 900;
    line-height: 1.3;
}

.jm-top-banner {
    overflow: hidden;
    background: transparent;
}

.jm-top-banner #tour_container {
    display: block !important;
    position: relative !important;
    width: 250px;
    height: 70px;
}

.jm-top-banner #tour_image_container {
    position: relative !important;
}

.jm-top-banner img {
    display: block;
    max-width: 250px;
    height: auto;
}

.jm-ad strong {
    font-size: 18px;
}

.jm-ad span {
    font-size: 15px;
}

.jm-home-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 4px;
    background: #1f1b1b;
    color: #fff;
    font-size: 14px;
    font-weight: 900;
}

.jm-home-link:hover,
.jm-home-link:focus {
    background: #d71920;
    color: #fff;
}

.jm-mainnav {
    background: #171717;
    box-shadow: 0 8px 18px rgba(31, 24, 24, .13);
}

.jm-mainnav .jm-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 50px;
    overflow: visible;
}

.jm-nav-links {
    display: flex;
    align-items: center;
    min-height: 50px;
}

.jm-nav-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 96px;
    height: 50px;
    padding: 0 10px;
    border-left: 1px solid rgba(255, 255, 255, .12);
    border-right: 1px solid rgba(0, 0, 0, .18);
    color: #fff;
    font-size: 14px;
    font-weight: 800;
    white-space: nowrap;
}

.jm-nav-links a:last-child {
    border-right: 1px solid rgba(0, 0, 0, .18);
}

.jm-nav-links a:hover,
.jm-nav-links a:focus {
    background: #d71920;
}

.jm-nav-login {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 4px;
    min-height: 50px;
    padding-left: 12px;
    white-space: nowrap;
}

.jm-login-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 52px;
    height: 26px;
    margin: 0 0 0 4px;
    padding: 0 8px;
    border: 1px solid rgba(255, 255, 255, .25);
    border-radius: 4px;
    background: rgba(255, 255, 255, .12);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
}

.jm-login-btn:hover,
.jm-login-btn:focus {
    background: #fff;
    color: #171717;
}

.jm-site-menu {
    position: relative;
    display: inline-flex;
    align-items: center;
    height: 26px;
}

.jm-site-menu summary {
    list-style: none;
}

.jm-site-menu summary::-webkit-details-marker {
    display: none;
}

.jm-menu-icon {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    width: 32px;
    height: 32px;
    border: 1px solid rgba(255, 255, 255, .35);
    border-radius: 4px;
    background: rgba(255, 255, 255, .12);
    cursor: pointer;
}

.jm-menu-icon span {
    display: block;
    width: 17px;
    height: 2px;
    border-radius: 2px;
    background: #fff;
}

.jm-site-menu-panel {
    position: absolute;
    top: 41px;
    right: 0;
    z-index: 50;
    display: none;
    width: 210px;
    padding: 7px 0;
    border: 1px solid #dfd2cf;
    border-radius: 5px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(31, 24, 24, .18);
}

.jm-site-menu[open] .jm-site-menu-panel {
    display: block;
}

.jm-site-menu-panel a {
    display: block;
    padding: 9px 13px;
    color: #2e2524;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.25;
}

.jm-site-menu-panel a:hover,
.jm-site-menu-panel a:focus {
    background: #fff1f1;
    color: #d71920;
}

.jm-layout {
    display: grid;
    grid-template-columns: 480px 225px 250px;
    gap: 10px;
    padding: 24px 0 70px;
}

.jm-board-content {
    padding: 22px 0 70px;
}

.jm-company-page {
    padding: 42px 0 76px;
}

.jm-company-hero {
    display: grid;
    grid-template-columns: 360px minmax(0, 1fr);
    align-items: stretch;
    gap: 34px;
    padding: 32px;
    border: 1px solid #e4e8ee;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 12px 28px rgba(31, 24, 24, .05);
}

.jm-company-photo {
    margin: 0;
    min-height: 260px;
    overflow: hidden;
    border: 1px solid #e4e8ee;
    border-radius: 6px;
    background: #f7f4f2;
}

.jm-company-photo img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 260px;
    object-fit: cover;
}

.jm-company-intro {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.jm-company-hero h1 {
    margin: 4px 0 0;
    color: #171717;
    font-size: 32px;
    line-height: 1.28;
    font-weight: 800;
    letter-spacing: 0;
}

.jm-company-lead {
    max-width: 680px;
    margin: 14px 0 0;
    color: #354b63;
    font-size: 16px;
    line-height: 1.75;
}

.jm-company-info {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 26px 0 0;
    padding: 0;
    border-top: 1px solid #e4e8ee;
    border-bottom: 1px solid #e4e8ee;
}

.jm-company-info div {
    padding: 16px 18px;
    border-left: 1px solid #e4e8ee;
}

.jm-company-info div:first-child {
    border-left: 0;
}

.jm-company-info dt {
    margin: 0 0 6px;
    color: #7a8794;
    font-size: 12px;
    font-weight: 700;
}

.jm-company-info dd {
    margin: 0;
    color: #171717;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.45;
}

.jm-company-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-top: 18px;
}

.jm-company-grid article {
    min-height: 158px;
    padding: 24px;
    border: 1px solid #e4e8ee;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(31, 24, 24, .04);
}

.jm-company-grid span {
    display: block;
    margin: 0 0 16px;
    color: #d71920;
    font-size: 13px;
    font-weight: 800;
}

.jm-company-grid h2 {
    margin: 0 0 10px;
    color: #171717;
    font-size: 18px;
    font-weight: 800;
}

.jm-company-grid p {
    margin: 0;
    color: #354b63;
    font-size: 14px;
    line-height: 1.7;
}

.jm-board-content #board,
.jm-board-content .tbl_wrap,
.jm-board-content #bo_v,
.jm-board-content #bo_list,
.jm-board-content form {
    max-width: 100%;
}

.jm-board-content #board,
.jm-board-content #bo_v,
.jm-board-content #bo_list,
.jm-board-content .tbl_wrap {
    background: #fff;
}

.jm-maincol,
.jm-midcol,
.jm-sidecol {
    min-width: 0;
}

.jm-lead-card,
.jm-section,
.jm-sidebox {
    background: #fff;
    border: 1px solid #eadfdb;
    border-radius: 7px;
    box-shadow: 0 10px 24px rgba(31, 24, 24, .05);
}

.jm-lead-card {
    display: grid;
    grid-template-columns: 185px 1fr;
    gap: 14px;
    padding: 18px 14px;
}

.jm-lead-photo {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 112px;
    min-height: 112px;
    border: 1px solid #e9ddd9;
    background: linear-gradient(180deg, #fffafa 0%, #f6eeee 100%);
    color: #766966;
    text-align: center;
    overflow: hidden;
}

.jm-lead-photo img {
    display: block;
    width: 100%;
    height: 112px;
    object-fit: cover;
    object-position: center center;
}

.jm-lead-photo strong {
    font-size: 48px;
    line-height: 1;
    font-weight: 900;
}

.jm-lead-photo span {
    margin-top: 8px;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0;
}

.jm-lead-copy {
    min-width: 0;
}

.jm-kicker {
    margin: 0 0 6px;
    color: #d71920;
    font-size: 13px;
    font-weight: 800;
}

.jm-lead-copy h1 {
    margin: 0;
    color: #171717;
    font-size: 20px;
    line-height: 1.32;
    font-weight: 800;
}

.jm-lead-copy p {
    margin: 10px 0 0;
    color: #354b63;
    font-size: 13px;
    line-height: 1.55;
}

.jm-section,
.jm-sidebox {
    margin-top: 10px;
    padding: 14px 16px;
}

.jm-maincol > .jm-section:first-child,
.jm-midcol > .jm-section:first-child,
.jm-sidecol > .jm-sidebox:first-child {
    margin-top: 0;
}

.jm-section h2,
.jm-sidebox h2 {
    margin: 0 0 11px;
    padding-bottom: 9px;
    border-bottom: 1px solid #eadfdb;
    color: #171717;
    font-size: 17px;
    line-height: 1.25;
    font-weight: 800;
}

.jm-section h2 a,
.jm-sidebox h2 a,
.jm-lead-copy h1 a {
    color: inherit;
}

.jm-section h2 a:hover,
.jm-section h2 a:focus,
.jm-sidebox h2 a:hover,
.jm-sidebox h2 a:focus,
.jm-lead-copy h1 a:hover,
.jm-lead-copy h1 a:focus {
    color: #d71920;
}

.jm-activity-list {
    display: grid;
    gap: 12px;
}

.jm-activity-list article {
    padding-bottom: 11px;
    border-bottom: 1px solid #f0e6e3;
}

.jm-activity-list article:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.jm-activity-list h3 {
    margin: 0;
    color: #25201f;
    font-size: 15px;
    line-height: 1.35;
    font-weight: 800;
}

.jm-activity-list p,
.jm-note,
.jm-sidebox p {
    margin: 6px 0 0;
    color: #354b63;
    font-size: 13px;
    line-height: 1.55;
}

.jm-compact {
    padding: 13px 12px;
}

.jm-sidebox a {
    display: block;
    padding: 9px 0;
    border-bottom: 1px solid #f0e6e3;
    color: #3a2422;
    font-size: 14px;
    font-weight: 800;
}

.jm-sidebox a:last-child {
    border-bottom: 0;
}

.jm-sidebox a:hover {
    color: #d71920;
}

.jm-banner-box {
    margin-top: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    overflow: hidden;
}

.jm-banner-box h2 {
    margin-bottom: 10px;
}

.jm-banner-box img {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
}

.jm-banner-box [id],
.jm-top-banner [id] {
    max-width: 100%;
}

.jm-latest-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.jm-latest-list li {
    border-bottom: 1px solid #f0e6e3;
}

.jm-latest-list li:last-child {
    border-bottom: 0;
}

.jm-latest-list a {
    display: block;
    padding: 8px 0;
    color: #3a2422;
    font-size: 13px;
    line-height: 1.45;
    font-weight: 700;
}

.jm-latest-list a:before {
    content: "- ";
    color: #455a70;
}

.jm-latest-list .jm-latest-link.has-thumb {
    display: grid;
    grid-template-columns: 78px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    min-height: 70px;
}

.jm-latest-list .jm-latest-link.has-thumb:before {
    content: none;
}

.jm-latest-thumb {
    display: block;
    width: 78px;
    height: 54px;
    overflow: hidden;
    border: 1px solid #e9ddd9;
    background: #f7f4f2;
}

.jm-latest-thumb img {
    display: block;
    width: 78px;
    height: 54px;
    object-fit: cover;
}

.jm-latest-text {
    display: block;
    min-width: 0;
}

.jm-latest-list a:hover,
.jm-latest-list a:focus {
    color: #d71920;
}

.jm-latest-date {
    display: none;
}

.jm-board-empty,
.jm-latest-empty {
    margin: 0;
    padding: 10px;
    background: #fff7f5;
    border: 1px solid #eadfdb;
    color: #675b58;
    font-size: 13px;
    line-height: 1.55;
}

.jm-board-content #bo_list,
.jm-board-content #bo_gall {
    max-width: 100%;
}

.jm-board-content table {
    table-layout: auto;
}

.jm-board-thumb-head,
.jm-board-thumb-cell {
    width: 94px;
    text-align: center;
}

.jm-board-thumb {
    display: inline-block;
    width: 78px;
    height: 54px;
    overflow: hidden;
    border: 1px solid #eadfdb;
    background: #f7f4f2;
    vertical-align: middle;
}

.jm-board-thumb img,
.jm-board-content .jm-board-thumb img {
    display: block;
    width: 78px !important;
    max-width: 78px !important;
    height: 54px !important;
    object-fit: cover;
}

.jm-board-content .td_subject {
    text-align: left;
}

.jm-board-content .jm-board-thumb-cell {
    overflow: hidden;
}

.jm-board-content #bo_gall .gall_href {
    position: relative !important;
    float: none !important;
    grid-column: 1 !important;
    grid-row: 1 / span 4 !important;
    width: 174px !important;
    height: 124px !important;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
    overflow: hidden;
}

.jm-board-content #bo_gall .gall_href + .gall_text_href,
.jm-board-content #bo_gall .gall_href ~ .gall_text_href {
    margin-left: 0 !important;
}

.jm-board-content #bo_gall .gall_href > a {
    display: block;
    width: 174px !important;
    height: 124px !important;
    overflow: hidden;
}

.jm-board-content #bo_gall .gall_href img {
    display: block;
    width: 174px !important;
    max-width: 174px !important;
    height: 124px !important;
    object-fit: cover;
}

.jm-board-content #bo_gall .gall_con {
    overflow: hidden;
}

.jm-board-content #bo_gall #gall_ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.jm-board-content #bo_gall .gall_li {
    float: none !important;
    clear: both !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 16px 0 !important;
    border-top: 1px solid #f0e6e3;
    overflow: hidden;
}

.jm-board-content #bo_gall .gall_li:first-child {
    border-top: 0;
}

.jm-board-content #bo_gall .gall_con {
    display: grid !important;
    grid-template-columns: 174px minmax(0, 1fr) !important;
    gap: 8px 16px !important;
    align-items: start !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    text-align: left !important;
}

.jm-board-content #bo_gall .gall_text_href {
    position: relative !important;
    float: none !important;
    grid-column: 2 !important;
    grid-row: 1 !important;
    width: auto !important;
    min-width: 0;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
    z-index: 1;
}

.jm-board-content #bo_gall .gall_text_href,
.jm-board-content #bo_gall .gall_con > li:not(.gall_href):not(.gall_text_href) {
    transform: none !important;
    left: auto !important;
    top: auto !important;
}

.jm-board-content #bo_gall .gall_text_href a {
    color: #3a2422;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.35;
    text-align: left !important;
}

.jm-board-content #bo_gall .gall_text_href a,
.jm-board-content #bo_gall .gall_con > li:not(.gall_href):not(.gall_text_href) {
    display: block;
    max-width: 100%;
}

.jm-board-content #bo_gall .gall_text_href input[type="checkbox"] {
    margin: 0 5px 0 0;
    vertical-align: middle;
}

.jm-board-content #bo_gall .gall_con > li:not(.gall_href):not(.gall_text_href) {
    position: relative !important;
    float: none !important;
    grid-column: 2 !important;
    color: #766966;
    font-size: 12px;
    line-height: 1.45;
    margin: 0 !important;
    padding: 0 !important;
    text-align: left !important;
}

.jm-ft-tb {
    clear: both;
    display: inline-block;
    position: relative;
    width: 100%;
    margin-top: 60px;
    padding: 0;
    background: #fff;
    text-align: center;
    font-size: 13px;
}

.jm-ft {
    display: block;
    position: relative;
    width: 980px;
    margin: 0 auto;
    padding: 0 0 15px 0;
    border-top: 0;
}

.jm-ft > div {
    position: relative;
    width: 980px;
    margin: 0 auto;
    padding: 0;
    text-align: center;
}

.jm-ft ul {
    display: block;
    zoom: 1;
    margin: 0 0 15px;
    padding: 13px 0 10px 170px;
    border-bottom: 1px solid #ddd;
    list-style: none;
    text-align: center;
}

.jm-ft ul:after {
    display: block;
    visibility: hidden;
    clear: both;
    content: "";
}

.jm-ft li {
    display: block;
    float: left;
    padding: 0;
    color: #777;
    font-size: 13px;
    line-height: 1.4;
}

.jm-ft a {
    color: #3a2422;
}

.jm-ft a:hover,
.jm-ft a:focus {
    color: inherit;
    text-decoration: none;
}

.jm-ft .jm-fm-logo a {
    display: block;
    float: left;
    width: 250px;
    margin-top: 20px;
    color: #555;
    font-size: 32px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -1px;
    white-space: nowrap;
}

.jm-ft .jm-fm-logo a:hover,
.jm-ft .jm-fm-logo a:focus {
    color: #555;
    text-decoration: none;
}

.jm-ft .fm_add {
    float: left;
    margin: 20px 0 0;
    color: #777;
    font-size: 13px;
    line-height: 1.7em;
    text-align: left;
}

.jm-ft > div:after {
    display: block;
    clear: both;
    content: "";
}

@media (max-width: 1020px) {
    .jm-wrap {
        width: calc(100% - 28px);
    }

    .jm-masthead-inner {
        grid-template-columns: 1fr;
        gap: 14px;
        padding: 18px 0;
    }

    .jm-search {
        justify-content: flex-start;
    }

    .jm-search input {
        width: min(360px, calc(100% - 50px));
    }

    .jm-ad {
        max-width: 320px;
    }

    .jm-mainnav .jm-wrap {
        overflow-x: auto;
    }

    .jm-nav-links a {
        flex: 0 0 auto;
        min-width: 94px;
    }

    .jm-nav-login {
        flex: 0 0 auto;
    }

    .jm-layout {
        grid-template-columns: 1fr;
    }

    .jm-company-hero {
        grid-template-columns: 1fr;
        padding: 22px;
    }

    .jm-company-info {
        grid-template-columns: 1fr;
    }

    .jm-company-info div,
    .jm-company-info div:first-child {
        border-left: 0;
        border-top: 1px solid #e4e8ee;
    }

    .jm-company-info div:first-child {
        border-top: 0;
    }

    .jm-company-grid {
        grid-template-columns: 1fr;
    }

    .jm-ft,
    .jm-ft > div {
        width: 96%;
    }

    .jm-lead-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 520px) {
    .jm-logo {
        font-size: 34px;
    }

    .jm-topbar .jm-wrap {
        justify-content: center;
    }

    .jm-lead-copy h1 {
        font-size: 18px;
    }
}
