@charset "utf-8";

/****************************************************************************
 *  게시판 리스트
 ****************************************************************************/
#bo_list { position: relative; margin-bottom: 20px; font-size: 15px; }
#bo_list::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_list .td_board    { text-align: center; }
#bo_list .td_chk      { text-align: center; vertical-align: middle; }
#bo_list .td_subject  { text-align: left; padding: 10px 0; }
#bo_list .td_date     { text-align: center; }
#bo_list .td_datetime { text-align: center; }
#bo_list .td_group    { text-align: center; }
#bo_list .td_mb_id    { text-align: center; }
#bo_list .td_mng      { text-align: center; }
#bo_list .td_name     { text-align: center; }
#bo_list .td_nick     { text-align: center; }
#bo_list .td_num      { text-align: center; }
#bo_list .td_num2     { text-align: center; }
#bo_list .td_numbig   { text-align: center; }
#bo_list .txt_active  { color: #5d910b; }
#bo_list .txt_expired { color: #ccc; }

#bo_list thead th,
#bo_list tbody td { padding: 12px 0; line-height: 1.5; vertical-align: middle; }
#bo_list tbody .even td { background: #fbfbfb; }

/* 체크박스 가운데 정렬 — th.all_chk / td.td_chk 공통 */
#bo_list thead th.all_chk,
#bo_list td.td_chk {
    text-align: center;
    vertical-align: middle;
}

/* label을 flex로 만들어 체크박스 아이콘을 완전 가운데 정렬 */
#bo_list thead th.all_chk input[type="checkbox"] + label,
#bo_list td.td_chk input[type="checkbox"] + label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* style.css 전역의 vertical-align:top 덮어쓰기 */
#bo_list thead th.all_chk input,
#bo_list td.td_chk input {
    vertical-align: middle !important;
}

@media screen and (max-width: 768px) {
    .tbl_wrap { width: 100%; overflow-x: auto; }
    .tbl_wrap table { width: 100%; }
    .tbl_wrap table th:not(.tb_view) { display: none; }
    .tbl_wrap table td:not(.tb_view) { display: none; }
    .tbl_wrap table col:not(.tb_view) { display: none; }
    .tbl_wrap table th,
    .tbl_wrap table td { padding: 4px; }
}


/****************************************************************************
 *  카테고리
 ****************************************************************************/
#bo_cate { background: #ecf2f3; padding: 7px; margin: 20px 0; border: 1px solid #bed1d4; }
#bo_cate h2 { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
#bo_cate ul::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_cate li { display: inline-block; padding: 2px; }
#bo_cate a { display: block; line-height: 26px; padding: 0 10px; border-radius: 3px; border: 1px solid transparent; }
#bo_cate a:focus,
#bo_cate a:hover,
#bo_cate a:active { text-decoration: none; background: #d2d6dc; }
#bo_cate #bo_cate_on {
    z-index: 2;
    background: #3497d9; color: #fff; font-weight: bold;
    border-bottom-color: #1977b5;
    box-shadow: inset 0 2px 5px rgb(33, 135, 202);
}
.td_subject img { margin-left: 5px; }


/****************************************************************************
 *  게시판 공통
 ****************************************************************************/

/* 커스텀 체크박스 */
.selec_chk { position: absolute; top: 0; left: 0; width: 0; height: 0; opacity: 0; outline: 0; z-index: -1; overflow: hidden; }
.chk_box { position: relative; }
.chk_box input[type="checkbox"] + label { position: relative; color: #676e70; }
.chk_box input[type="checkbox"] + label:hover { color: #2172f8; }
.chk_box input[type="checkbox"] + label span {
    float: left; width: 15px; height: 15px; display: block;
    background: #fff; border: 1px solid #d0d4df; border-radius: 3px;
}
.write_div .chk_box input[type="checkbox"] + label,
.bo_vc_w  .chk_box input[type="checkbox"] + label { padding-left: 20px; }
.write_div .chk_box input[type="checkbox"] + label span,
.bo_vc_w  .chk_box input[type="checkbox"] + label span {
    position: absolute; top: 2px; left: 0;
    width: 15px; height: 15px; display: block; margin: 0;
    background: #fff; border: 1px solid #d0d4df; border-radius: 3px;
}
.chk_box input[type="checkbox"]:checked + label { color: #000; }
.chk_box input[type="checkbox"]:checked + label span {
    background: url(./img/chk.png) no-repeat 50% 50% #3a8afd;
    border-color: #1471f6; border-radius: 3px;
}

/* 버튼 상단 영역 */
#bo_btn_top { position: relative; margin-bottom: 10px; }
#bo_btn_top::after { display: block; visibility: hidden; clear: both; content: ""; }

.bo_fx { clear: both; display: block; margin-top: 30px; }
.bo_fx::after { display: block; visibility: hidden; clear: both; content: ""; }
.bo_fx .more_btn { float: left; }
.bo_fx .more_btn button,
.bo_fx .more_btn a,
.bo_fx .adm_btn a { margin-bottom: 10px; }
.bo_fx .adm_btn { float: right; }
.bo_fx .adm_btn li { display: inline-block; }

#bo_list_total { float: left; padding-top: 16px; font-size: 14px; height: 45px; margin: 0; }

#bo_btn_top .page_num { float: left; height: 30px; line-height: 30px; padding-top: 8px; }
#bo_btn_top .page_num > span { float: left; position: relative; }
#bo_btn_top .page_num > span > em { font-weight: 500; font-style: normal; color: #c70010; }
#bo_btn_top .page_num > span > em ~ em { color: #1d1614; }
#bo_btn_top .page_num > span + span { padding-left: 10px; margin-left: 10px; }
#bo_btn_top .page_num > span + span::after {
    position: absolute; top: 8px; left: 0;
    width: 1px; height: 16px; background: #e0e0e0; content: "";
}

#bo_btn_top .btn_bo_user { float: right; margin: 0; padding: 0; list-style: none; }
#bo_btn_top .btn_bo_user li { float: left; margin-left: 5px; }


/****************************************************************************
 *  검색 폼 (#bo_sch)
 *  — float 기반 원본 구조 유지, theme.css 전역 select 간섭 차단
 ****************************************************************************/
#bo_sch {
    float: right;
    display: flex;
    align-items: center;
    height: 37px;
    border: 1px solid #ccc;
    background: #fff;
    border-radius: 0;
    overflow: hidden;
}

#bo_sch::after { display: block; visibility: hidden; clear: both; content: ""; }

#bo_sch legend,
#bo_sch h3 {
    position: absolute; margin: 0; padding: 0;
    font-size: 0; line-height: 0;
    text-indent: -9999em; overflow: hidden;
}

#bo_sch form {
    display: flex;
    align-items: center;
    height: 100%;
}

#bo_sch select {
    float: none !important;
    flex-shrink: 0;
    flex-grow: 0;
    width: auto !important;
    height: 37px !important;
    border: 0 !important;
    border-right: 1px solid #ddd !important;
    padding: 0 8px !important;
    background: #f8f8f8 !important;
    font-size: 13px;
    border-radius: 0 !important;
    box-shadow: none !important;
    -webkit-appearance: auto !important;
    appearance: auto !important;
    outline: none;
}

#bo_sch .sch_input {
    float: none !important;
    flex: 1;
    height: 37px !important;
    border: 0 !important;
    border-right: 1px solid #ddd !important;
    padding: 0 8px !important;
    background: #fff !important;
    font-size: 13px;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none;
    min-width: 140px;
}

#bo_sch .sch_btn {
    float: none !important;
    flex-shrink: 0;
    height: 37px;
    padding: 0 15px;
    border: none;
    background-color: #888;
    color: #fff;
    font-size: 16px;
    line-height: 37px;
    border-radius: 0;
    cursor: pointer;
}
#bo_sch .sch_btn:hover { background: #666; }

@media screen and (max-width: 640px) {
    #bo_btn_top .page_num { width: 100%; }
    #bo_btn_top .page_num > span + span { float: right; }
    #bo_btn_top .page_num > span + span::after { display: none; }

    #bo_sch {
        clear: both; float: none;
        width: 100%; height: auto;
        flex-wrap: wrap;
        background-color: #f0f0f0;
        padding: 10px;
        border-radius: 0;
    }

    #bo_sch form { width: 100%; flex-wrap: wrap; }

    #bo_sch select {
        width: 100% !important;
        height: 36px !important;
        border-right: 0 !important;
        border-bottom: 1px solid #ddd !important;
    }

    #bo_sch .sch_input {
        flex: 1;
        height: 36px !important;
        border: 1px solid #ccc !important;
        border-right: 0 !important;
        border-radius: 3px 0 0 3px !important;
        background: #fff !important;
        min-width: 0;
    }

    #bo_sch .sch_btn { height: 36px; line-height: 36px; }
}


/****************************************************************************
 *  옵션 버튼 (선택삭제·복사·이동)
 ****************************************************************************/
.more_opt {
    display: none; position: absolute; top: 45px; right: 0;
    background: #fff; border: 1px solid #b8bfc4; z-index: 999;
}
.more_opt::before {
    content: ""; position: absolute; top: -8px; right: 13px;
    width: 0; height: 0; border-style: solid;
    border-width: 0 6px 8px 6px;
    border-color: transparent transparent #b8bfc4 transparent;
}
.more_opt::after {
    content: ""; position: absolute; top: -6px; right: 13px;
    width: 0; height: 0; border-style: solid;
    border-width: 0 6px 8px 6px;
    border-color: transparent transparent #fff transparent;
}
.more_opt li { border-bottom: 1px solid #f1f1f1; padding: 10px; width: 90px; margin: 0; color: #6b757c; text-align: left; }
.more_opt li:last-child { border-bottom: 0; }
.more_opt li button,
.more_opt li a { width: 100%; border: 0; background: #fff; color: #6b757c; }
.more_opt li:hover a,
.more_opt li:hover button { color: #000; }
.more_opt li i { float: right; line-height: 20px; }


/****************************************************************************
 *  공지사항·제목 아이콘
 ****************************************************************************/
.bo_notice td { background: #fff6fa !important; border-bottom: 1px solid #f8e6ee; }
.bo_notice .notice_icon { display: inline-block; border-radius: 5px; font-weight: bold; color: #f9267f; }
.td_num2 i { font-size: 13px; padding: 1px 0; }

.bo_tit_wrap { display: flex; width: 100%; }
.bo_cate_link { display: inline-block; margin-right: 5px; }
.bo_tit { display: inline-block; line-height: 2; width: 100%; }
.bo_tit .bx-gray:hover { background: transparent; border: 1px solid #ccc; color: #666 !important; }
.bo_current { display: inline-block; color: #ffac0e; font-size: 16px; font-weight: 500; }

#bo_list .profile_img img { border-radius: 50%; }
#bo_list .cnt_cmt { background-color: #6F727F; color: #fff; padding: 2px 6px; border-radius: 12px; font-size: 11px; font-weight: 500; }
#bo_list .sv_wrap .sv { position: absolute; left: -20px; }

#bo_list .bo_tit .fa-download,
#bo_list .bo_tit .fa-link,
#bo_list .bo_tit .new_icon,
#bo_list .bo_tit .fa-heart {
    display: inline-block;
    width: 16px; height: 16px; line-height: 16px;
    font-size: 9px; color: #fff; text-align: center;
    border-radius: 2px; margin-right: 2px; vertical-align: middle;
}
#bo_list .bo_tit .fa-download { background: #e89f31; }
#bo_list .bo_tit .fa-link     { background: #ad68d8; }
#bo_list .bo_tit .new_icon    { background: #f36100; font-size: 0.833em; }
#bo_list .bo_tit .fa-heart    { background: #e52955; }
#bo_list .bo_tit .fa-lock {
    display: inline-block;
    width: 16px; height: 16px; line-height: 14px;
    font-size: 9px; color: #4f818c; background: #cbe3e8;
    text-align: center; border-radius: 2px;
    border: 1px solid #a2c6ce; vertical-align: middle;
}


/****************************************************************************
 *  게시판 쓰기 — 자동저장
 ****************************************************************************/
#char_count_desc { display: block; margin: 0 0 5px; padding: 0; }
#char_count_wrap  { margin: 5px 0 0; text-align: right; }
#char_count { font-weight: bold; }

#autosave_wrapper { position: relative; }
#autosave_pop {
    display: none; z-index: 10; position: absolute !important;
    top: 34px; right: 0; width: 350px;
    height: auto !important; max-height: 180px;
    border: 1px solid #565656; background: #fff;
    box-shadow: 2px 2px 3px 0 rgba(0,0,0,0.2);
}
#autosave_pop::before {
    content: ""; position: absolute; top: -8px; right: 45px;
    width: 0; height: 0; border-style: solid;
    border-width: 0 6px 8px 6px;
    border-color: transparent transparent #000 transparent;
}
#autosave_pop::after {
    content: ""; position: absolute; top: -7px; right: 45px;
    width: 0; height: 0; border-style: solid;
    border-width: 0 6px 8px 6px;
    border-color: transparent transparent #fff transparent;
}
html.no-overflowscrolling #autosave_pop { height: auto; max-height: 10000px !important; }
#autosave_pop strong { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
#autosave_pop div    { text-align: center; margin: 0 !important; }
#autosave_pop button { margin: 0; padding: 0; border: 0; }
#autosave_pop ul { padding: 15px; border-top: 1px solid #e9e9e9; list-style: none; overflow-y: scroll; height: 130px; border-bottom: 1px solid #e8e8e8; }
#autosave_pop li { padding: 8px 5px; border-bottom: 1px solid #fff; background: #eee; }
#autosave_pop li::after { display: block; visibility: hidden; clear: both; content: ""; }
#autosave_pop a    { display: block; float: left; }
#autosave_pop span { display: block; float: right; font-size: 0.92em; font-style: italic; color: #999; }
.autosave_close { cursor: pointer; width: 100%; height: 30px; background: none; color: #888; font-weight: bold; font-size: 0.92em; }
.autosave_close:hover { background: #f3f3f3; color: #3597d9; }
.autosave_content { display: none; }
.autosave_del { background: url(../img/close_btn.png) no-repeat 50% 50%; text-indent: -999px; overflow: hidden; height: 20px; width: 20px; }


/****************************************************************************
 *  게시판 읽기
 ****************************************************************************/
#bo_v { margin-bottom: 20px; padding: 20px 0; font-size: 16px; background: #fff; }

#bo_v_title .bo_v_cate {
    display: inline-block; line-height: 26px;
    background: #3497d9; color: #fff; font-weight: bold;
    border-bottom: 1px solid #1977b5; padding: 0 10px; border-radius: 3px;
    box-shadow: inset 0 2px 5px rgb(33, 135, 202);
}
#bo_v_title .bo_v_tit { display: block; font-size: 28px; font-weight: 700; margin: 10px 0; }

#bo_v_info { padding: 10px 0; font-size: 14px; border-bottom: 1px solid #ddd; color: #666; }
#bo_v_info::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_v_info h2 { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
#bo_v_info strong { display: inline-block; margin: 0 10px 0 0; font-weight: normal; }
#bo_v_info .sv_member,
#bo_v_info .sv_guest,
#bo_v_info .member,
#bo_v_info .guest { font-weight: bold; }
#bo_v_info .profile_img img { border-radius: 50%; }
#bo_v_info .sv_member { color: #000; }
#bo_v_info .if_view    { display: inline-block; background: url(./img/icon_view.png)    no-repeat 50% 50%; height: 15px; width: 20px; overflow: hidden; text-indent: -999px; vertical-align: middle; margin-right: 3px; }
#bo_v_info .if_comment { display: inline-block; background: url(./img/icon_comment.png) no-repeat 50% 50%; height: 15px; width: 20px; overflow: hidden; text-indent: -999px; vertical-align: middle; margin-right: 3px; }
#bo_v_info .if_date    { float: right; margin: 0; color: #888; }

.post-toolbar { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; }
.toolbar-left  { display: flex; gap: 10px; }
.toolbar-right a { color: #333; font-size: 18px; text-decoration: none; }
.toolbar-right a:hover,
.toolbar-right button:hover { color: #000; }
.toolbar-left .circle-button {
    position: relative; box-sizing: border-box; display: block; height: auto;
    font-family: 돋움, Dotum, Arial, sans-serif; font-size: 12px;
    letter-spacing: -0.5px; line-height: 20px;
    padding: 2px 10px; border: 1px solid #d1d1d1; border-radius: 20px;
}
.toolbar-left .count { line-height: 20px; padding-left: 2px; }
.toolbar-left i { color: #666; }
.toolbar-right { position: relative; text-align: right; }
.toolbar-right .btn { color: #555; font-weight: normal; font-size: 12px; line-height: 26px; height: 28px; border-radius: 0; border-color: #d5d5d5; }
.toolbar-right .btn:hover { background: #fff; }

/* 공유 */
#bo_v_share { position: relative; margin: 20px 0; text-align: right; }
#bo_v_share .btn { padding: 0 10px 0 0; color: #555; font-weight: normal; font-size: 1em; line-height: 30px; height: 32px; border-radius: 0; border-color: #d5d5d5; }
#bo_v_share .btn:hover { background: #fff; }
#bo_v_share .btn i { margin-right: 5px; background: #eee; color: #333; text-align: center; width: 30px; line-height: 30px; vertical-align: top; }

.bo_v_snswr { position: relative; display: inline-block; margin-left: -1px; }
#bo_v_sns {
    display: none; position: absolute; top: -50px; left: 50%; margin-left: -90px;
    width: 180px; padding: 0; list-style: none;
}
#bo_v_sns::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_v_sns::before {
    content: ""; position: absolute; bottom: -7px; left: 84px;
    width: 0; height: 0; border-style: solid;
    border-width: 7px 6px 0 6px;
    border-color: #415b92 transparent transparent transparent;
}
#bo_v_sns li { float: left; width: 60px; text-align: center; }
#bo_v_sns li a { height: 40px; padding: 10px 0; }
#bo_v_sns li .sns_f { display: block; background: #415b92; }
#bo_v_sns li .sns_t { display: block; background: #35b3dc; }
#bo_v_sns li .sns_g { display: block; background: #d5503a; }
#bo_v_sns li .sns_k { display: block; background: #ffeb00; }
#bo_v_sns li img { vertical-align: top; }

@media screen and (max-width: 768px) { #bo_v_title .bo_v_tit { font-size: 16px; } }
@media screen and (max-width: 640px) {
    #bo_v_info #bo_v_share { clear: both; float: none; display: block; text-align: center; }
    #bo_v_info .profile_info { margin: 10px 0; }
    #bo_v_info .profile_info, #bo_v_share { line-height: 20px; }
    #bo_v_share { margin-bottom: 5px; }
}
@media screen and (max-width: 480px) {
    #bo_v_info .profile_info .profile_info_ct .mobile { display: block; }
}

/* sns 공유  */
.share-dropdown { position: absolute; top: 100%; right: 0; min-width: 300px; background: #fff; border: 1px solid #e0e0e0; border-radius: 8px; opacity: 0; visibility: hidden; transform: translateY(-10px); transition: all 0.3s ease; z-index: 1000; margin-top: 5px; box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.share-dropdown.active { opacity: 1; visibility: visible; transform: translateY(0); }
.share-content { padding: 20px; }
.share-buttons { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; margin-bottom: 20px; }
.share-btn { display: flex; flex-direction: column; align-items: center; background: none; border: none; cursor: pointer; padding: 15px 10px; border-radius: 8px; transition: background 0.2s ease; text-decoration: none; color: inherit; }
.share-btn:hover { background: #f5f5f5; }
.share-btn .icon { width: 58px; height: 58px; margin-bottom: 8px; display: block; }
.share-btn .text { font-size: 12px; color: #666; font-weight: 500; }
.facebook-icon { background: url('./img/sns/shareFacebook.png') center center no-repeat;}
.kakao-icon { background: url('./img/sns/shareKakao.png') center center no-repeat;}
.line-icon { background: url('./img/sns/shareLine.png') center center no-repeat;}
.blog-icon { background: url('./img/sns/shareNaver.png') center center no-repeat;}
.band-icon { background: url('./img/sns/shareNaverBand.png') center center no-repeat;}
.twitter-icon { background: url('./img/sns/shareTwitter.png') center center no-repeat;}
.copy-section { border-top: 1px solid #f0f0f0; padding-top: 20px; }
.copy-input { display: flex; border: 1px solid #ddd; border-radius: 6px; overflow: hidden; }
.copy-input .input { flex: 1; padding: 12px 15px; border: none; background: #f9f9f9; font-size: 14px; color: #666; outline: none; }
.copy-input .copy-btn { padding: 12px 20px; background: #007bff; color: white; border: none; cursor: pointer; font-size: 14px; font-weight: 500; transition: background 0.2s ease; }
.copy-input .copy-btn:hover { background: #0056b3; color:#fff;}
.copy-success { color: #28a745; font-size: 12px; margin-top: 5px; opacity: 0; transition: opacity 0.3s ease; }
.copy-success.show { opacity: 1; }
@media (max-width: 480px) { 
	.share-dropdown { min-width: 280px; } 
	.share-content { padding: 15px; } 
	.share-buttons { gap: 10px; } 
	.share-btn { padding: 12px 8px; } 
	.share-btn .icon { width: 35px; height: 35px; } 
	.share-btn .text { font-size: 11px; } 
}
.share-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 999; display: none; }
.share-overlay.active { display: block; }

/* 첨부파일 */
#bo_v_file { margin: 10px 0; border: 1px solid #d4d4d4; border-radius: 5px; }
#bo_v_file h2 { padding: 10px; border-bottom: 1px solid #e8e8e8; background: #f3f3f3; }
#bo_v_file ul { margin: 0; padding: 5px 0; list-style: none; overflow: hidden; }
#bo_v_file li { position: relative; padding: 5px; line-height: 20px; white-space: nowrap; }
#bo_v_file i  { padding: 0 5px; color: #333; }
#bo_v_file a  { position: relative; color: #666; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#bo_v_file a:focus, #bo_v_file a:hover, #bo_v_file a:active { color: #f79646; }
#bo_v_file .bo_v_file_cnt { float: right; margin-left: 30px; color: #888; }

/* 링크 */
#bo_v_link { margin: 10px 0; border: 1px solid #d4d4d4; border-radius: 5px; }
#bo_v_link h2 { padding: 10px; border-bottom: 1px solid #e8e8e8; background: #f3f3f3; }
#bo_v_link ul { margin: 0; padding: 5px 0; list-style: none; overflow: hidden; }
#bo_v_link li { position: relative; padding: 5px; line-height: 20px; white-space: nowrap; }
#bo_v_link i  { padding: 0 5px; color: #333; }
#bo_v_link a  { position: relative; color: #666; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#bo_v_link a:focus, #bo_v_link a:hover, #bo_v_link a:active { color: #f79646; }
#bo_v_link .bo_v_link_cnt { float: right; margin-left: 30px; color: #888; }

/* 상단/하단 버튼 */
#bo_v_top { position: relative; float: right; }
#bo_v_top::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_v_top h2, #bo_v_bot h2 { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
#bo_v_top ul { padding: 0; list-style: none; word-break: break-all; background: #fff; }
#bo_v_bot { }
#bo_v_bot::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_v_bot ul { padding: 0; list-style: none; }

.bo_v_com { margin: 20px 0; float: right; }
.bo_v_com > li { position: relative; float: left; margin-left: 5px; }

/* 이전글·다음글 */
.bo_v_nb { position: relative; margin: 20px 0; clear: both; text-align: left; }
.bo_v_nb::after { display: block; visibility: hidden; clear: both; content: ""; }
.bo_v_nb li { border-top: 1px solid #f1f1f1; height: auto; padding: 15px; line-height: 1.2; }
.bo_v_nb li:last-child { border-bottom: 1px solid #f1f1f1; }
.bo_v_nb li:hover { background: #f6f6f6; }
.bo_v_nb li i { font-size: 13px; color: #b3b3b3; }
.bo_v_nb li .nb_tit  { display: inline-block; padding-right: 10px; color: #b3b3b3; }
.bo_v_nb li .nb_date { float: right; display: inline-block; color: #b3b3b3; }
@media screen and (max-width: 480px) { .bo_v_nb li .nb_date { display: none; } }

/* 본문 */
#bo_v_atc { padding: 10px 0; min-height: 200px; height: auto !important; }
#bo_v_atc_title { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
#bo_v_img { width: 100%; overflow: hidden; }
#bo_v_img::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_v_img a.view_image { display: block; }
#bo_v_img img { margin-bottom: 20px; max-width: 100%; height: auto; }
#bo_v_con { margin: 10px 0 20px; width: 100%; line-height: 1.5; min-height: 200px; font-size: 16px; word-break: break-all; overflow: hidden; }
#bo_v_con a { color: #000; text-decoration: underline; }
#bo_v_con img { max-width: 100%; height: auto; }

/* 추천/비추천 */
#bo_v_act { margin-bottom: 20px; text-align: center; }
#bo_v_act .bo_v_act_gng { position: relative; }
#bo_v_act a { vertical-align: middle; color: #4a5158; }
#bo_v_act a:hover { background-color: #fff; color: #ff484f; border-color: #ff484f; }
#bo_v_act i { font-size: 20px; display: block; }
#bo_v_act_good, #bo_v_act_nogood {
    display: none; position: absolute; top: 50%; left: 50%;
    white-space: nowrap; transform: translate(-50%, -50%);
    background-color: rgba(0,0,0,0.8); color: #fff;
    border-radius: 5px; z-index: 9999;
}
#bo_v_act .bo_v_good   { display: inline-block; color: #1e90ff; border: 1px solid #dedede; width: 80px; line-height: 24px; padding: 10px; border-radius: 3px; }
#bo_v_act .bo_v_nogood { display: inline-block; color: #ff4500; border: 1px solid #dedede; width: 80px; line-height: 24px; padding: 10px; border-radius: 3px; }
#bo_v_act .bo_v_good strong,
#bo_v_act .bo_v_nogood strong { color: #333; font-weight: bold; font-size: 18px; }


/****************************************************************************
 *  댓글
 ****************************************************************************/
.cmt_btn { width: 100%; text-align: left; border: 0; border-bottom: 1px solid #f0f0f0; background: #fff; font-weight: bold; margin: 30px 0 0; padding: 0 0 15px; }
.cmt_btn span.total { position: relative; display: inline-block; margin-right: 5px; font-size: 1em; color: #3a8afd; }
.cmt_btn span.cmt_more { float: right; display: inline-block; width: 15px; height: 10px; background: url(./img/btn_cmt.png) no-repeat right 2px; margin-top: 5px; }
.cmt_btn_op span.cmt_more { background-position: right -8px; }
.cmt_btn b { font-size: 1.2em; color: #000; }
.cmt_btn span.total::after { position: absolute; bottom: -17px; left: 0; display: inline-block; background: #3a8afd; content: ""; width: 100%; height: 2px; }

#bo_vc h2 { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
#bo_vc article { margin: 20px 0; position: relative; }
#bo_vc article::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_vc article .profile_img img { border-radius: 50%; }
#bo_vc article .pf_img { float: left; margin-right: 10px; }
#bo_vc article .pf_img img { border-radius: 50%; width: 50px; height: 50px; margin-bottom: 5px; }
#bo_vc article .cm_wrap { float: left; width: calc(100% - 60px); }
#bo_vc article .cm_wrap .profile_img img { display: none; }
#bo_vc header { position: relative; width: 100%; }
#bo_vc header::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_vc header .profile_img { display: none; }
#bo_vc header .icon_reply { position: absolute; top: 15px; left: -20px; }
#bo_vc .member, #bo_vc .guest, #bo_vc .sv_member, #bo_vc .sv_guest { font-weight: bold; }
.bo_vc_hdinfo { margin-left: 10px; color: #777; }
#bo_vc h1 { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
#bo_vc p a { text-decoration: underline; }
#bo_vc p a.s_cmt { text-decoration: underline; color: #ed6479; }
#bo_vc_empty { margin: 0; padding: 80px 0 !important; color: #777; text-align: center; }
#bo_vc #bo_vc_winfo { float: left; }
#bo_vc .bo_vl_opt { position: absolute; top: 0; right: 0; }
#bo_vc .bo_vl_opt button { background: none; }
#bo_vc .bo_vl_opt .btn_opt { width: 20px; font-size: 18px; color: #ccc; border: 0; }
#bo_vc .bo_vl_opt .btn_opt:hover { color: #777; }

#bo_vc .cmt_contents {
    display: block; position: relative; margin: 10px 0 0 5px; padding: 7px;
    background: #feffff; border: 1px solid #dadada; border-radius: 5px; box-sizing: border-box;
}
#bo_vc .cmt_contents::after {
    content: ""; display: inline-block; position: absolute; top: 5px; left: -10px;
    border: 5px solid transparent; border-top-color: #dadada; border-right-color: #dadada;
}
#bo_vc .cmt_contents .bo_cv_act { text-align: right; margin: 5px; }
#bo_vc .cmt_contents .bo_cv_act li { display: inline-block; margin-left: 5px; }
#bo_vc .cmt_contents .bo_cv_act li strong { font-weight: bold; }
#bo_vc .cmt_contents p { line-height: 1.5; }
#bo_vc .cmt_contents textarea { margin-top: 20px; }

@media screen and (max-width: 480px) {
    #bo_vc article .pf_img img { width: 40px; height: 40px; }
    .info .bo_vc_hdinfo { display: block; margin: 5px 0 0 0; }
}

/* 댓글 옵션 */
.bo_vc_act {
    display: none; position: absolute; right: 0; top: 40px;
    width: 120px; text-align: center; padding: 10px;
    border: 1px solid #b8bfc4; margin: 0; background: #fff; z-index: 9999;
}
.bo_vc_act::before {
    content: ""; position: absolute; top: -8px; right: 5px;
    width: 0; height: 0; border-style: solid;
    border-width: 0 6px 8px 6px;
    border-color: transparent transparent #b8bfc4 transparent;
}
.bo_vc_act::after {
    content: ""; position: absolute; top: -6px; right: 5px;
    width: 0; height: 0; border-style: solid;
    border-width: 0 6px 8px 6px;
    border-color: transparent transparent #fff transparent;
}
.bo_vc_act li { border-bottom: 1px solid #f0f0f0; }
.bo_vc_act li:last-child { border-bottom: 0; }
.bo_vc_act li a { display: inline-block; padding: 10px 15px; }
.bo_vc_act li a:hover { color: #3a8afd; }

/* 댓글 쓰기 */
.bo_vc_w { position: relative; margin: 10px 0; display: block; }
.bo_vc_w::after { display: block; visibility: hidden; clear: both; content: ""; }
.bo_vc_w h2 { position: absolute; font-size: 0; line-height: 0; overflow: hidden; }
.bo_vc_w #char_cnt { display: block; margin: 0 0 5px; }
.bo_vc_w textarea {
    border: 1px solid #ccc; background: #fff; color: #000;
    vertical-align: middle; border-radius: 3px; padding: 5px;
    width: 100%; height: 120px;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.1);
}
.bo_vc_w_info { float: left; }
.bo_vc_w_info::after { display: block; visibility: hidden; clear: both; content: ""; }
.bo_vc_w_info .frm_input { float: left; margin-right: 5px; }
.bo_vc_w_info #captcha { padding-top: 10px; display: block; clear: both; }
.bo_vc_w .btn_confirm { clear: both; }
.bo_vc_w .btn_confirm label { display: inline-block; margin-right: 10px; border-radius: 3px; font-size: 1.5em; text-align: center; }
.bo_vc_w .btn_submit { padding: 0 20px; border-radius: 3px; font-weight: bold; font-size: 1.083em; }
.bo_vc_w .btn_confirm .secret_cm label { font-size: 1em !important; }
.bo_vc_w_wr::after { display: block; visibility: hidden; clear: both; content: ""; }
.secret_cm { display: inline-block; float: left; }

/* SNS 동시 등록 */
#bo_vc_send_sns { display: inline-block; float: left; }
#bo_vc_sns { display: inline-block; margin: 0; padding: 0; list-style: none; }
#bo_vc_sns::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_vc_sns li { float: left; margin: 0 5px 0 0; }
#bo_vc_sns .sns_li_f { border-radius: 3px; background: #3a589b; height: 40px; line-height: 40px; padding: 0 0 0 10px; }
#bo_vc_sns .sns_li_t { border-radius: 3px; background: #00aced; height: 40px; line-height: 40px; padding: 0 0 0 10px; }
#bo_vc_sns .sns_li_off { background: #bbb; }
#bo_vc_sns a { display: inline-block; padding: 0 15px 0 5px; }
#bo_vc_sns input { margin: 0 5px 0 0; }


/****************************************************************************
 *  게시판 쓰기
 ****************************************************************************/
#bo_w .bo_v_option li { display: inline-block; float: left; text-align: left; margin: 0 5px 0 0; }
#bo_w .bo_v_option li label { vertical-align: baseline; }
#bo_w .bo_v_option .chk_box input[type="checkbox"] + label span { margin-left: 0; margin-right: 5px; }
#bo_w .write_div { margin: 10px 0; position: relative; }
#bo_w .write_div::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_w .bo_w_info::after { display: block; visibility: hidden; clear: both; content: ""; }
#bo_w .bo_w_info .frm_input { float: left; margin-bottom: 1%; }
#bo_w #wr_password, #bo_w #wr_homepage { margin-left: 1%; }
#bo_w .wr_content.smarteditor2 iframe { background: #fff; }
#bo_w .bo_w_tit { position: relative; }
#bo_w .bo_w_tit .frm_input { padding-right: 120px; }
#bo_w .bo_w_tit #btn_autosave { position: absolute; top: 5px; right: 5px; line-height: 30px; height: 30px; }
#bo_w .bo_w_link label { position: absolute; top: 1px; left: 1px; border-radius: 3px 0 0 3px; height: 38px; line-height: 38px; width: 40px; font-size: 1.2em; text-align: center; color: #b2b2b2; }
#bo_w .bo_w_link .frm_input { padding-left: 50px; }
#bo_w .bo_w_flie .lb_icon { position: absolute; top: 0; left: 0; border-radius: 3px 0 0 3px; height: 38px; line-height: 38px; width: 40px; font-size: 1.2em; text-align: center; color: #b2b2b2; }
#bo_w .bo_w_flie .frm_file { padding-left: 50px; margin-top: 3px; }
#bo_w .bo_w_flie .file_wr { position: relative; border: 1px solid #ccc; background: #fff; color: #000; vertical-align: middle; border-radius: 3px; padding: 5px; height: 40px; margin: 0; }
#bo_w .bo_w_flie .frm_input { margin: 10px 0 0; }
#bo_w .bo_w_flie .file_del { position: absolute; top: 10px; right: 10px; font-size: 0.92em; color: #7d7d7d; }
#bo_w .bo_w_select select { border: 1px solid #d0d3db; width: 100%; height: 40px; border-radius: 3px; }
#bo_w .btn_submit { padding: 0 20px; font-size: 1.167em; }
#bo_w .btn_cancel  { border-radius: 3px; font-size: 1.167em; }


/****************************************************************************
 *  스마트에디터 / 기타
 ****************************************************************************/
#commentEditor { position: relative; padding: 10px; background-color: #eee; border: 1px solid #ccc; border-radius: 5px !important; box-sizing: border-box; }
#commentEditor textarea { margin-top: 30px; }
#commentEditor #char_cnt { position: absolute; top: 10px; left: 15px; }

.pdf-container { width: 100%; height: 80vh; border: 1px solid #ccc; border-radius: 10px; margin: 20px 0; overflow: hidden; background-color: #f9f9fa; }
.pdf-container iframe { width: 100%; height: 100%; border: none; }


/****************************************************************************
 *  테이블 공통
 ****************************************************************************/
.tbl_wrap table {
    width: 100%; border-collapse: collapse; border-spacing: 0;
    border: none; border-top: 1px solid #c1d1d5; border-bottom: 1px solid #c1d1d5;
}
.tbl_wrap caption { padding: 10px 0; font-weight: bold; text-align: left; }

.tbl_head01 { margin: 0 0 10px; }
.tbl_head01 caption { padding: 0; font-size: 0; line-height: 0; overflow: hidden; }
.tbl_head01 thead th {
    padding: 10px 0; font-weight: normal; text-align: center;
    border-bottom: 1px solid #ddd; background: #fafafa; height: 40px;
}
/* 체크박스 th만 vertical-align 예외 처리 (읽기 페이지 깨짐 방지) */
.tbl_head01 thead th input              { vertical-align: top; }
.tbl_head01 thead th.chk_box input     { vertical-align: middle !important; }

.tbl_head01 tfoot th,
.tbl_head01 tfoot td { padding: 10px 0; border-top: 1px solid #c1d1d5; border-bottom: 1px solid #c1d1d5; background: #d7e0e2; text-align: center; }
.tbl_head01 tbody th { padding: 8px 0; border-bottom: 1px solid #e8e8e8; }
.tbl_head01 td { color: #666; background: #fff; padding: 10px 5px; border-top: 1px solid #ecf0f1; line-height: 1.4em; height: 60px; word-break: break-all; }