@charset "utf-8";
/**
 * @author https://www.cosmosfarm.com
 */

a.kboard-avatar-button-small,
input.kboard-avatar-button-small,
button.kboard-avatar-button-small { position: relative; display: inline-block; zoom: 1; margin: 0; padding: 0 15px; width: auto; height: 32px; line-height: 32px; font-size: 14px; font-weight: bold; letter-spacing: normal; color: #545861 !important; background: #fff !important; border: 1px solid #f1f1f1; border-radius: 8px; text-decoration: none !important; cursor: pointer; vertical-align: middle; text-shadow: none; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05); transition-duration: 0.3s; box-sizing: content-box; }
a.kboard-avatar-button-small:hover,
a.kboard-avatar-button-small:focus,
a.kboard-avatar-button-small:active,
input.kboard-avatar-button-small:hover,
input.kboard-avatar-button-small:focus,
input.kboard-avatar-button-small:active,
button.kboard-avatar-button-small:hover,
button.kboard-avatar-button-small:focus,
button.kboard-avatar-button-small:active { box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); transform: translateY(-1px); }

.kboard-avatar-poweredby { float: left; padding-bottom: 15px; width: 100%; font-size: 14px; }
.kboard-avatar-new-notify { display: inline-block; *display: inline; zoom: 1; padding: 2px 2px; line-height: 10px; font-size: 10px; color: white; background-color: #f61b5d; font-weight: normal; }
.kboard-avatar-cut-strings { width: auto; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; word-wrap: normal; }

#kboard-avatar-list { display: inline-block; *display: inline; zoom: 1; margin: 0; width: 100%; }
#kboard-avatar-list form { margin: 0; padding: 0; }
#kboard-avatar-list .kboard-list-header { float: left; display: table; padding-bottom: 15px; width: 100%; }
#kboard-avatar-list .kboard-list-header .kboard-total-count { *float: left; display: table-cell; font-size: 14px; }
#kboard-avatar-list .kboard-list-header .kboard-sort { *float: right; display: table-cell; text-align: right; }
#kboard-avatar-list .kboard-list-header .kboard-sort select { display: inline; margin: 0; padding: 0; width: auto; min-width: 0; max-width: none; height: 26px; min-height: 0; line-height: 26px; font-size: 13px; color: #666666; border-radius: 0; border: 1px solid #f1f1f1; background: white; vertical-align: middle; box-shadow: none; box-sizing: content-box; text-indent: 0; -webkit-appearance: menulist; -moz-appearance: menulist; appearance: menulist; }
#kboard-avatar-list .kboard-category { float: left; padding-bottom: 15px; width: 100%; }
#kboard-avatar-list .kboard-category.category-mobile { display: none; }
#kboard-avatar-list .kboard-category.category-pc { display: block; }
#kboard-avatar-list .kboard-category select { display: inline; margin: 0 0 5px 0; padding: 0; width: 100%; min-width: 100%; height: 28px; min-height: 0; line-height: 28px; font-size: 13px; color: #666666; border-radius: 0; border: 1px solid #f1f1f1; background: white; vertical-align: middle; box-shadow: none; box-sizing: border-box; text-indent: 0; -webkit-appearance: menulist; -moz-appearance: menulist; appearance: menulist; }
#kboard-avatar-list .kboard-category .kboard-category-list { margin: 0 0 5px 0; padding: 0; list-style: none; border: 0; background-color: #f9f9f9; overflow: hidden; }
#kboard-avatar-list .kboard-category .kboard-category-list li { display: inline-block; *display: inline; zoom: 1; margin: 0; padding: 0 5px; border: 0; list-style: none; }
#kboard-avatar-list .kboard-category .kboard-category-list li::before,
#kboard-avatar-list .kboard-category .kboard-category-list li::after { display: none; }
#kboard-avatar-list .kboard-category .kboard-category-list li a { display: block; padding: 10px 10px 8px 10px; font-size: 14px; border: 0; border-bottom: 2px solid transparent; text-decoration: none; text-shadow: none; box-shadow: none; color: #515151; }
#kboard-avatar-list .kboard-category .kboard-category-list li.kboard-category-selected a { font-weight: bold; border-bottom: 2px solid #545861; color: #545861; }
#kboard-avatar-list .kboard-tree-category-wrap { float: left; padding-bottom: 15px; width: 100%; }
#kboard-avatar-list .kboard-tree-category-wrap select { display: inline; margin: 0 0 5px 0; padding: 0; width: 100%; height: 28px; line-height: 28px; font-size: 13px; color: #666666; border-radius: 0; border: 1px solid #f1f1f1; background: white; vertical-align: middle; box-shadow: none; box-sizing: border-box; text-indent: 0; -webkit-appearance: menulist; -moz-appearance: menulist; appearance: menulist; }
#kboard-avatar-list .kboard-tree-category-search .kboard-search-option-wrap.type-select { width: auto; }
#kboard-avatar-list .kboard-tree-category-search .kboard-search-option-wrap.type-tab { width: 100%; }
#kboard-avatar-list .kboard-tree-category { float: left; margin: 0 0 5px 0; padding: 0; width: 100%; list-style: none; border: 0; background-color: #f9f9f9; overflow: hidden; }
#kboard-avatar-list .kboard-tree-category li { display: inline-block; *display: inline; zoom: 1; margin: 0; padding: 0 5px; border: 0; list-style: none; }
#kboard-avatar-list .kboard-tree-category li::before,
#kboard-avatar-list .kboard-tree-category li::after { display: none; }
#kboard-avatar-list .kboard-tree-category li a { display: block; padding: 10px 10px 8px 10px; font-size: 14px; border: 0; border-bottom: 2px solid transparent; text-decoration: none; text-shadow: none; box-shadow: none; color: #515151; }
#kboard-avatar-list .kboard-tree-category li.kboard-category-selected a { font-weight: bold; border-bottom: 2px solid #545861; color: #545861; }
#kboard-avatar-list .kboard-tree-category-search { float: left; width: 100%; }
#kboard-avatar-list .kboard-tree-category-search .kboard-search-option-wrap { margin-right: 5px; float: left; }
#kboard-avatar-list .kboard-list { float: left; width: 100%; background-color: white; }
#kboard-avatar-list .kboard-list table { display: table; table-layout: fixed; margin: 0; padding: 0; width: 100%; border: 0; font-size: 14px; border-collapse: collapse; }
#kboard-avatar-list .kboard-list table a { color: black; text-decoration: none; border: 0; box-shadow: none; font-size: 14px; }
#kboard-avatar-list .kboard-list table tr { border: 0; background-color: transparent; transition-duration: 0.3s; }
#kboard-avatar-list .kboard-list table td { padding: 10px 0; height: auto; text-align: center; vertical-align: middle; font-size: 14px; }
#kboard-avatar-list .kboard-list table td.kboard-list-uid { width: 65px; }
#kboard-avatar-list .kboard-list table td.kboard-list-title { width: auto; }
#kboard-avatar-list .kboard-list table td.kboard-list-user { width: 120px; white-space: nowrap; }
#kboard-avatar-list .kboard-list table td.kboard-list-date { width: 75px; white-space: nowrap; }
#kboard-avatar-list .kboard-list table td.kboard-list-vote { width: 70px; white-space: nowrap; }
#kboard-avatar-list .kboard-list table td.kboard-list-view { width: 70px; white-space: nowrap; }
#kboard-avatar-list .kboard-list thead { background-color: transparent; }
#kboard-avatar-list .kboard-list thead tr td { font-weight: bold; color: #545861; border: 0; border-bottom: 2px solid #f1f1f1; }
#kboard-avatar-list .kboard-list tbody tr td { word-break: break-all; border: 0; border-bottom: 1px solid #f1f1f1; }
#kboard-avatar-list .kboard-list tbody tr:hover { background-color: #f7f7f7; }
#kboard-avatar-list .kboard-list tbody tr.kboard-list-notice { background-color: #f4f4f4; }
#kboard-avatar-list .kboard-list tbody tr.kboard-list-selected .kboard-avatar-cut-strings { font-weight: bold; }
#kboard-avatar-list .kboard-list tbody td.kboard-list-title { text-align: left; }
#kboard-avatar-list .kboard-list tbody td.kboard-list-title img { display: inline; margin: 0; width: auto; height: auto; vertical-align: middle; max-width: 100%; }
#kboard-avatar-list .kboard-list tbody td.kboard-list-title .kboard-comments-count { color: #00a8e7; }
#kboard-avatar-list .kboard-list tbody td.kboard-list-user img.avatar { display: inline; margin: 0; width: 24px; max-width: none; height: 24px; vertical-align: middle; border-radius: 50%; }
#kboard-avatar-list .kboard-list .kboard-mobile-contents { display: none; font-size: 13px; color: #999999; }
#kboard-avatar-list .kboard-list .kboard-mobile-contents .contents-item { display: inline; margin: 0; padding: 0; }
#kboard-avatar-list .kboard-list .kboard-mobile-contents .contents-item img.avatar { display: inline; margin: 0; width: 24px; max-width: none; height: 24px; vertical-align: middle; border-radius: 50%; }
#kboard-avatar-list .kboard-list .kboard-mobile-contents .contents-separator { display: inline; margin: 0; padding: 0 2px; color: #bebebe; }
#kboard-avatar-list .kboard-pagination { float: left; padding: 15px 0; width: 100%; }
#kboard-avatar-list .kboard-pagination .kboard-pagination-pages { float: left; margin: 0; padding: 0; width: 100%; list-style: none; text-align: center; border: 0; }
#kboard-avatar-list .kboard-pagination .kboard-pagination-pages li { display: inline-block; margin: 0 2px; padding: 0; background: none; border: 0; list-style: none; }
#kboard-avatar-list .kboard-pagination .kboard-pagination-pages li a { display: block; margin: 0; padding: 0 12px; height: 32px; line-height: 32px; font-size: 14px; color: #545861; text-decoration: none; border: 1px solid #f1f1f1; background-color: #fff; border-radius: 8px; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05); transition-duration: 0.3s; }
#kboard-avatar-list .kboard-pagination .kboard-pagination-pages li:hover a,
#kboard-avatar-list .kboard-pagination .kboard-pagination-pages li.active a { border: 1px solid #e0e0e0; color: #333; background-color: #fff; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1); transform: translateY(-1px); }
#kboard-avatar-list .kboard-pagination .kboard-pagination-pages li:before { display: none; }
#kboard-avatar-list .kboard-pagination .kboard-pagination-pages li:after { display: none; }
#kboard-avatar-list .kboard-search { float: left; padding-bottom: 15px; width: 100%; text-align: center; }
#kboard-avatar-list .kboard-search select { display: inline; margin: 0; padding: 0 10px; width: 100px; min-width: 0; max-width: 100px; height: 32px; min-height: 0; font-size: 14px; color: #666666; border-radius: 8px; border: 1px solid #f1f1f1; background: none; background-color: white; line-height: 32px; vertical-align: middle; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05); box-sizing: content-box; -webkit-appearance: menulist; -moz-appearance: menulist; appearance: menulist; }
#kboard-avatar-list .kboard-search input { display: inline; margin: 0; padding: 0 10px; width: 200px; min-width: 0; max-width: 200px; height: 32px; min-height: 0; font-size: 14px; color: #666666; border-radius: 8px; border: 1px solid #f1f1f1; background: none; background-color: white; line-height: 32px; vertical-align: middle; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05); box-sizing: content-box; }
#kboard-avatar-list .kboard-control { float: left; padding-bottom: 15px; width: 100%; text-align: right; }

#kboard-avatar-editor { overflow: hidden; }
#kboard-avatar-editor form { margin: 0; padding: 0; }
#kboard-avatar-editor select { display: inline; margin: 0; padding: 0 5px; font-size: 14px; width: 30%; height: 28px; line-height: 28px; color: #666666; border-radius: 0; border: 0; border-bottom: 1px solid #dcdcdc; box-shadow: none; background: none; background-color: transparent; box-sizing: content-box; vertical-align: middle; text-indent: 0; -webkit-appearance: menulist; -moz-appearance: menulist; appearance: menulist; }
#kboard-avatar-editor input[type=text],
#kboard-avatar-editor input[type=email],
#kboard-avatar-editor input[type=number],
#kboard-avatar-editor input[type=date],
#kboard-avatar-editor input[type=password] { display: inline; margin: 0; padding: 0 5px; width: 30%; height: 28px; line-height: 28px; font-size: 14px; color: #666666; border-radius: 0; border: 0; border-bottom: 1px solid #dcdcdc; box-shadow: none; background: none; background-color: transparent; box-sizing: content-box; vertical-align: middle; }
#kboard-avatar-editor input[type=checkbox] { width: auto; -webkit-appearance: checkbox; -moz-appearance: checkbox; appearance: checkbox; }
#kboard-avatar-editor input[type=radio] { width: auto; -webkit-appearance: radio; -moz-appearance: radio; appearance: radio; }
#kboard-avatar-editor select:hover,
#kboard-avatar-editor input[type=text]:hover,
#kboard-avatar-editor input[type=email]:hover,
#kboard-avatar-editor input[type=number]:hover,
#kboard-avatar-editor input[type=date]:hover,
#kboard-avatar-editor input[type=password]:hover { border-bottom: 1px solid #9e9e9e; }
#kboard-avatar-editor select:focus,
#kboard-avatar-editor input[type=text]:focus,
#kboard-avatar-editor input[type=email]:focus,
#kboard-avatar-editor input[type=number]:focus,
#kboard-avatar-editor input[type=date]:focus,
#kboard-avatar-editor input[type=password]:focus { border-bottom: 2px solid #9e9e9e; }
#kboard-avatar-editor input[type=file] { display: inline; margin: 0; padding: 0; width: 30%; font-size: 13px; color: #666666; border-radius: 0; border: 0; box-shadow: none; background-color: transparent; }
#kboard-avatar-editor .kboard-attr-title input { width: 70%; }
#kboard-avatar-editor .kboard-attr-row { float: left; padding: 5px 0; width: 100%; background-color: white; }
#kboard-avatar-editor .kboard-attr-row .attr-name { display: inline; float: left; margin: 0; padding: 0 10px 0 10px; width: 120px; line-height: 30px; color: #545861; font-size: 14px; font-weight: bold; }
#kboard-avatar-editor .kboard-attr-row .attr-name img { display: inline; margin: 0; padding: 0; width: auto; max-width: 100%; vertical-align: middle; }
#kboard-avatar-editor .kboard-attr-row .attr-name .attr-required-text { color: red; font-weight: normal; font-size: 13px; }
#kboard-avatar-editor .kboard-attr-row.kboard-attr-content .attr-name { display: none; }
#kboard-avatar-editor .kboard-attr-row .attr-value { margin: 0 0 0 140px; padding: 0; line-height: 30px; font-size: 14px; }
#kboard-avatar-editor .kboard-attr-row .attr-value .attr-value-option { display: inline; padding-right: 20px; width: auto; font-size: 14px; cursor: pointer; }
#kboard-avatar-editor .kboard-attr-row .attr-value .attr-value-option input { cursor: pointer; }
#kboard-avatar-editor .kboard-attr-row .attr-value .attr-value-label { display: inline; padding-right: 5px; width: auto; cursor: pointer; }
#kboard-avatar-editor .kboard-attr-row .attr-value .attr-value-label input { cursor: pointer; }
#kboard-avatar-editor .kboard-attr-row .attr-value .description { margin: 0; color: #666666; }
#kboard-avatar-editor .kboard-attr-row .attr-value .kboard-tree-category-wrap { overflow: hidden; }
#kboard-avatar-editor .kboard-attr-row .attr-value .kboard-tree-category-wrap select { clear: both; float: left; margin-bottom: 5px; width: 30%; }
#kboard-avatar-editor .kboard-content { float: left; margin: 0; padding: 9px 0; width: 100%; background-color: white; }
#kboard-avatar-editor .kboard-content .editor-textarea { display: inline; margin: 0; padding: 5px; width: 100%; min-width: 100%; max-width: 100%; height: 250px; min-height: 0; font-size: 14px; border: 1px solid #dcdcdc; box-shadow: none; background: none; background-color: transparent; box-sizing: border-box; text-indent: 0; }
#kboard-avatar-editor .kboard-control { float: left; padding: 15px 0; width: 100%; }
#kboard-avatar-editor .kboard-control .left { position: static; float: left; }
#kboard-avatar-editor .kboard-control .right { position: static; float: right; width: 50%; text-align: right; }
#kboard-avatar-editor.confirm { margin: 100px auto; max-width: 590px; }
#kboard-avatar-editor.confirm input[type=password] { width: 100%; box-sizing: border-box; }

#kboard-avatar-document { display: inline-block; *display: inline; zoom: 1; margin: 0; width: 100%; }


/* =================================================================
   📌 공지사항 상세 페이지 전용 CSS (notice_preview_v2 기준)
   - body 접두사로 테마 CSS 완전 우선순위 확보
   - 목록(list.php) 스타일에 절대 영향 없음
================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700&display=swap');

body #kboard-document {
    font-family: 'Noto Sans KR', -apple-system, BlinkMacSystemFont, sans-serif !important;
    /* 1. 화면 중앙 정렬 */
    display: flex !important;
    justify-content: center !important;
    padding: 20px 16px !important;
    box-sizing: border-box !important;
    width: 100% !important;
}

body #kboard-document #kboard-thumbnail-document {
    width: 100% !important;
    max-width: 860px !important;
    margin: 0 !important;
    padding: 0 !important;
}

body #kboard-document .kboard-document-wrap {
    background: #ffffff !important;
    border: 1px solid #dde3f0 !important;
    border-radius: 14px !important;
    box-shadow: 0 2px 12px rgba(99,102,241,0.08), 0 8px 24px rgba(59,130,246,0.06) !important;
    overflow: hidden !important;
    float: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* ─── 헤더 ─── */
body #kboard-document .kboard-document-wrap .kboard-title {
    background: linear-gradient(135deg, #eef2ff 0%, #ede9fe 50%, #dbeafe 100%) !important;
    padding: 32px 36px 26px !important;
    position: relative !important;
    overflow: hidden !important;
    border: none !important;
    float: none !important;
    width: auto !important;
    box-sizing: border-box !important;
}

body #kboard-document .kboard-document-wrap .kboard-title::before {
    content: '' !important; position: absolute !important;
    top: -16px !important; right: 72px !important;
    width: 56px !important; height: 56px !important;
    background: rgba(251,191,36,0.5) !important;
    border-radius: 50% !important; pointer-events: none !important;
}

body #kboard-document .kboard-document-wrap .kboard-title::after {
    content: '' !important; position: absolute !important;
    bottom: -8px !important; right: 148px !important;
    width: 20px !important; height: 20px !important;
    background: rgba(99,102,241,0.3) !important;
    border-radius: 3px !important; transform: rotate(45deg) !important;
    pointer-events: none !important;
}

body #kboard-document .kboard-document-wrap .kboard-title h1 {
    font-size: 22px !important; font-weight: 700 !important;
    color: #1e293b !important; line-height: 1.45 !important;
    margin: 0 !important; padding: 0 !important;
    letter-spacing: -0.3px !important; position: relative !important;
    z-index: 1 !important; text-align: left !important;
    text-shadow: none !important; background: none !important; border: none !important;
}

/* ─── 2. 메타 정보 (자연스러운 스타일) ─── */
body #kboard-document .kboard-document-wrap .kboard-detail {
    display: flex !important; flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 6px !important;
    padding: 14px 36px 16px !important; margin: 0 !important;
    background: linear-gradient(135deg, #eef2ff 0%, #ede9fe 50%, #dbeafe 100%) !important;
    border: none !important;
    border-bottom: 1px solid rgba(99,102,241,0.15) !important;
    float: none !important; width: auto !important; box-sizing: border-box !important;
    position: relative !important; z-index: 1 !important; font-size: 13px !important;
}

body #kboard-document .kboard-document-wrap .kboard-detail .detail-attr {
    display: inline-flex !important; align-items: center !important;
    gap: 4px !important; padding: 0 !important; margin: 0 !important;
    float: none !important; line-height: 1.5 !important;
    border: none !important; color: #64748b !important; font-size: 13px !important;
}

/* 작성일: 왼쪽에서 자동 밀어내기 (남은 공간 차지) */
body #kboard-document .kboard-document-wrap .kboard-detail .detail-date {
    margin-left: auto !important;
}

/* 날짜 앞 · 제거 (공백으로 구분됨) */
body #kboard-document .kboard-document-wrap .kboard-detail .detail-date::before {
    content: none !important; margin: 0 !important;
}

/* 조회수 앞 · 유지 */
body #kboard-document .kboard-document-wrap .kboard-detail .detail-view::before {
    content: '·' !important; margin: 0 8px !important; color: #cbd5e1 !important; font-size: 14px !important;
}

body #kboard-document .kboard-document-wrap .kboard-detail .detail-attr + .detail-attr::before {
    content: none !important;
}

body #kboard-document .kboard-document-wrap .kboard-detail .detail-name {
    font-weight: 500 !important; color: #94a3b8 !important;
    font-size: 12px !important; float: none !important; padding: 0 !important;
}

body #kboard-document .kboard-document-wrap .kboard-detail .detail-name::after {
    content: '' !important;
}

body #kboard-document .kboard-document-wrap .kboard-detail .detail-value {
    color: #475569 !important; font-size: 13px !important;
    font-weight: 600 !important; float: none !important; padding: 0 !important;
}

/* 카테고리 배지 */
body #kboard-document .kboard-document-wrap .detail-category1,
body #kboard-document .kboard-document-wrap .detail-category2 {
    padding: 3px 12px !important;
    background: rgba(99,102,241,0.12) !important; color: #6366f1 !important;
    border-radius: 20px !important; font-size: 11px !important;
    font-weight: 700 !important; border: none !important;
    float: none !important; line-height: 1.6 !important;
    letter-spacing: 0.02em !important;
}

body #kboard-document .kboard-document-wrap .detail-category1 .detail-name,
body #kboard-document .kboard-document-wrap .detail-category2 .detail-name { display: none !important; }

body #kboard-document .kboard-document-wrap .detail-category1 .detail-name::after,
body #kboard-document .kboard-document-wrap .detail-category2 .detail-name::after { content: '' !important; }

body #kboard-document .kboard-document-wrap .detail-category1 + .detail-attr::before,
body #kboard-document .kboard-document-wrap .detail-category2 + .detail-attr::before {
    content: '' !important; margin: 0 8px !important;
}

/* ─── 본문 ─── */
body #kboard-document .kboard-document-wrap .kboard-content {
    padding: 28px 20px !important;
    border-top: 1px solid #e8edf5 !important;
    border-bottom: 1px solid #e8edf5 !important;
    background: #ffffff !important;
    clear: both !important; float: none !important;
    min-height: auto !important; width: auto !important; box-sizing: border-box !important;
}

body #kboard-document .kboard-document-wrap .kboard-content .content-view {
    font-size: 15px !important; line-height: 1.85 !important;
    color: #334155 !important; word-break: keep-all !important;
    margin: 0 !important; padding: 0 !important;
}

body #kboard-document .kboard-document-wrap .kboard-content .content-view p { margin: 0 0 1.1em !important; }
body #kboard-document .kboard-document-wrap .kboard-content .content-view img {
    max-width: 100% !important; border-radius: 10px !important; height: auto !important;
}

/* ─── 좋아요/프린트 ─── */
body #kboard-document .kboard-document-wrap .kboard-document-action {
    display: flex !important; justify-content: space-between !important;
    align-items: center !important; padding: 12px 36px !important;
    background: #f8fafc !important; border-bottom: 1px solid #e8edf5 !important;
    overflow: visible !important; float: none !important; line-height: 1 !important;
}

body #kboard-document .kboard-document-wrap .kboard-document-action .left,
body #kboard-document .kboard-document-wrap .kboard-document-action .right {
    position: static !important; float: none !important;
    display: flex !important; gap: 8px !important;
}

body #kboard-document .kboard-document-wrap .kboard-button-action {
    display: inline-flex !important; align-items: center !important; gap: 5px !important;
    padding: 8px 16px !important; height: auto !important; line-height: 1 !important;
    border-radius: 9px !important; font-size: 13px !important; font-weight: 500 !important;
    cursor: pointer !important; border: 1.5px solid #e2e8f0 !important;
    background: #ffffff !important; color: #64748b !important;
    box-shadow: none !important; transition: all 0.2s !important;
    font-family: inherit !important; opacity: 1 !important;
}

body #kboard-document .kboard-document-wrap .kboard-button-like:hover { border-color: #fca5a5 !important; color: #ef4444 !important; background: #fff5f5 !important; opacity: 1 !important; }
body #kboard-document .kboard-document-wrap .kboard-button-unlike:hover { border-color: #fca5a5 !important; color: #f97316 !important; background: #fff7ed !important; opacity: 1 !important; }
body #kboard-document .kboard-document-wrap .kboard-button-print:hover { border-color: #93c5fd !important; color: #3b82f6 !important; background: #eff6ff !important; opacity: 1 !important; }

/* ─── 첨부파일 ─── */
body #kboard-document .kboard-document-wrap .kboard-attach {
    padding: 12px 36px !important; background: #f8fafc !important;
    border-bottom: 1px solid #e8edf5 !important; display: flex !important;
    flex-wrap: wrap !important; gap: 8px !important;
    float: none !important; width: auto !important; box-sizing: border-box !important;
}

body #kboard-document .kboard-document-wrap .kboard-button-download {
    display: inline-flex !important; align-items: center !important; gap: 6px !important;
    padding: 8px 16px !important; height: auto !important; line-height: 1 !important;
    background: #ffffff !important; border: 1.5px solid #6366f1 !important;
    color: #6366f1 !important; border-radius: 9px !important;
    font-size: 13px !important; font-weight: 500 !important;
    cursor: pointer !important; transition: all 0.2s !important; opacity: 1 !important;
}
body #kboard-document .kboard-document-wrap .kboard-button-download::before { content: '📎' !important; font-size: 14px !important; }
body #kboard-document .kboard-document-wrap .kboard-button-download:hover { background: #6366f1 !important; color: #fff !important; opacity: 1 !important; }

/* ─── 이전/다음 ─── */
body #kboard-document .kboard-document-navi { overflow: hidden !important; }
body #kboard-document .kboard-document-wrap .kboard-prev-document,
body #kboard-document .kboard-document-wrap .kboard-next-document { border-bottom: 1px solid #e8edf5 !important; }
body #kboard-document .kboard-document-wrap .kboard-prev-document:last-child { border-bottom: none !important; }

body #kboard-document .kboard-document-wrap .kboard-prev-document a,
body #kboard-document .kboard-document-wrap .kboard-next-document a {
    display: flex !important; align-items: center !important; gap: 12px !important;
    padding: 12px 36px !important; text-decoration: none !important;
    color: #64748b !important; font-size: 14px !important;
    transition: all 0.2s !important; border: none !important; box-shadow: none !important;
}
body #kboard-document .kboard-document-wrap .kboard-prev-document a:hover,
body #kboard-document .kboard-document-wrap .kboard-next-document a:hover {
    background: rgba(238,242,255,0.6) !important; color: #6366f1 !important;
}

body #kboard-document .kboard-document-wrap .navi-arrow {
    display: inline-flex !important; align-items: center !important;
    justify-content: center !important; min-width: 28px !important;
    width: 28px !important; height: 28px !important;
    background: #e8edf5 !important; border-radius: 50% !important;
    font-size: 13px !important; color: #64748b !important;
    flex-shrink: 0 !important; transition: all 0.2s !important; font-weight: bold !important;
}
body #kboard-document .kboard-document-wrap .kboard-prev-document a:hover .navi-arrow,
body #kboard-document .kboard-document-wrap .kboard-next-document a:hover .navi-arrow {
    background: linear-gradient(135deg, #3b82f6, #6366f1) !important; color: #fff !important;
}
body #kboard-document .kboard-document-wrap .navi-document-title {
    flex: 1 !important; overflow: hidden !important;
    text-overflow: ellipsis !important; white-space: nowrap !important; width: auto !important;
}

/* ─── 하단 컨트롤 ─── */
body #kboard-document .kboard-document-wrap .kboard-control {
    display: flex !important; justify-content: space-between !important;
    align-items: center !important; padding: 16px 36px !important;
    float: none !important; width: auto !important; box-sizing: border-box !important;
}
body #kboard-document .kboard-document-wrap .kboard-control .left,
body #kboard-document .kboard-document-wrap .kboard-control .right {
    position: static !important; float: none !important;
    display: flex !important; gap: 8px !important; width: auto !important; text-align: left !important;
}

body #kboard-document .kboard-document-wrap .kboard-control a.kboard-thumbnail-button-small,
body #kboard-document .kboard-document-wrap .kboard-control button.kboard-thumbnail-button-small {
    display: inline-flex !important; align-items: center !important;
    height: auto !important; line-height: 1 !important;
    padding: 9px 22px !important; border-radius: 9px !important;
    font-size: 14px !important; font-weight: 600 !important;
    background: #ffffff !important; border: 1.5px solid #d1d5db !important;
    color: #374151 !important; text-decoration: none !important;
    cursor: pointer !important; transition: all 0.2s !important;
    box-shadow: none !important; opacity: 1 !important;
    letter-spacing: 0 !important; font-family: inherit !important;
}
body #kboard-document .kboard-document-wrap .kboard-control a.kboard-thumbnail-button-small:hover,
body #kboard-document .kboard-document-wrap .kboard-control button.kboard-thumbnail-button-small:hover {
    background: #f1f5f9 !important; border-color: #9ca3af !important; opacity: 1 !important;
}

body #kboard-document .kboard-thumbnail-poweredby { display: none !important; }

/* ─── 반응형 ─── */
@media (max-width: 768px) {
    body #kboard-document { padding: 12px 10px !important; }
    body #kboard-document .kboard-document-wrap .kboard-title { padding: 22px 20px 18px !important; }
    body #kboard-document .kboard-document-wrap .kboard-title h1 { font-size: 18px !important; }
    body #kboard-document .kboard-document-wrap .kboard-content { padding: 22px 20px !important; }
    body #kboard-document .kboard-document-wrap .kboard-document-action,
    body #kboard-document .kboard-document-wrap .kboard-attach,
    body #kboard-document .kboard-document-wrap .kboard-control { padding: 12px 20px !important; }
    body #kboard-document .kboard-document-wrap .kboard-prev-document a,
    body #kboard-document .kboard-document-wrap .kboard-next-document a { padding: 11px 20px !important; }
}

/* ── 공지사항 최신글 (latest.php) ── */
#kboard-notice-latest {
    width: 100%;
}
#kboard-notice-latest .kboard-notice-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
#kboard-notice-latest .kboard-notice-item {
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    overflow: hidden;
    transition: transform 0.2s, box-shadow 0.2s;
}
#kboard-notice-latest .kboard-notice-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}
#kboard-notice-latest .kboard-notice-link {
    display: flex;
    text-decoration: none;
    color: inherit;
    padding: 16px;
    gap: 16px;
    align-items: stretch;
}
#kboard-notice-latest .kboard-notice-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    min-width: 60px;
    padding: 12px 4px;
    flex-shrink: 0;
}
#kboard-notice-latest .kboard-notice-day {
    font-size: 1.5rem;
    font-weight: 700;
    color: #6366f1;
    line-height: 1;
}
#kboard-notice-latest .kboard-notice-month {
    font-size: 0.75rem;
    color: #64748b;
    margin-top: 6px;
}
#kboard-notice-latest .kboard-notice-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
}
#kboard-notice-latest .kboard-notice-title-row {
    display: flex;
    align-items: center;
    gap: 8px;
}
#kboard-notice-latest .kboard-notice-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: #1e293b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color 0.15s;
}
#kboard-notice-latest .kboard-notice-link:hover .kboard-notice-title {
    color: #6366f1;
}
#kboard-notice-latest .kboard-notice-new {
    font-size: 0.6rem;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, #f97316, #ef4444);
    border-radius: 4px;
    padding: 2px 6px;
    flex-shrink: 0;
}
#kboard-notice-latest .kboard-notice-summary {
    font-size: 0.85rem;
    color: #64748b;
    line-height: 1.5;
    /* 2줄 제한 */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}
#kboard-notice-latest .kboard-notice-empty {
    padding: 30px 16px;
    text-align: center;
    color: #94a3b8;
    background: #f8fafc;
    border-radius: 12px;
    border: 1px dashed #e2e8f0;
}
