/* jokbo 스킨 - et-jokbo CSS 변수 사용 */

.jkb-board { font-family: 'Pretendard Variable', Pretendard, sans-serif; color: #333; }

/* 툴바 */
.jkb-board-toolbar {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; margin-bottom: 14px; flex-wrap: wrap;
}
.jkb-toolbar-right { display: flex; align-items: center; gap: 8px; }
.jkb-cats { display: flex; gap: 6px; flex-wrap: wrap; }
.jkb-cat {
    padding: 5px 14px; border-radius: 20px; font-size: 13px;
    color: #666; border: 1px solid #ddd; text-decoration: none; transition: all .15s;
}
.jkb-cat:hover, .jkb-cat.active {
    background: var(--primary, #0d2b52); color: #fff; border-color: var(--primary, #0d2b52);
}
.jkb-search { display: flex; gap: 4px; }
.jkb-search input {
    padding: 7px 12px; border: 1px solid #ddd; border-radius: 6px;
    font-size: 13px; width: 180px; outline: none;
}
.jkb-search input:focus { border-color: var(--primary, #0d2b52); }
.jkb-search button {
    padding: 7px 12px; background: var(--primary, #0d2b52); color: #fff;
    border: none; border-radius: 6px; cursor: pointer;
}

/* 버튼 */
.jkb-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 8px 16px; font-size: 14px; font-weight: 500;
    border-radius: 6px; cursor: pointer; text-decoration: none;
    border: none; transition: all .15s;
}
.jkb-btn--primary { background: var(--primary, #0d2b52); color: #fff; }
.jkb-btn--primary:hover { background: var(--primary-light, #1a3f6f); color: #fff; }
.jkb-btn--outline { background: #fff; color: #555; border: 1px solid #ddd; }
.jkb-btn--outline:hover { background: #f5f5f5; color: #333; }
.jkb-btn--danger-ghost { background: transparent; color: #dc2626; border: 1px solid #dc2626; }
.jkb-btn--danger-ghost:hover { background: rgba(220,38,38,.08); }
.jkb-btn--sm { padding: 5px 12px; font-size: 13px; }

/* 테이블 */
.jkb-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.jkb-table th {
    padding: 10px 12px; text-align: left; font-weight: 600; color: #555;
    border-bottom: 2px solid var(--primary, #0d2b52);
    background: #f8f9fa; white-space: nowrap;
}
.jkb-table td { padding: 12px; border-bottom: 1px solid #eee; vertical-align: middle; }
.jkb-row { transition: background .12s; }
.jkb-row:hover { background: #f9f9f9; }
.jkb-row--notice { background: #fffbf0; }
.jkb-row--notice:hover { background: #fff7e0; }
.jkb-col-num { width: 60px; text-align: center; color: #999; font-size: 13px; }
.jkb-col-author { width: 100px; color: #666; font-size: 13px; white-space: nowrap; }
.jkb-col-date { width: 100px; color: #999; font-size: 13px; white-space: nowrap; }
.jkb-col-views { width: 60px; text-align: center; color: #999; font-size: 13px; }
.jkb-title-link { color: #333; text-decoration: none; font-weight: 500; }
.jkb-title-link:hover { color: var(--primary, #0d2b52); }
.jkb-cnt { color: var(--accent, #3b82f6); font-size: 12px; font-weight: 600; margin-left: 3px; }
.jkb-empty { text-align: center; padding: 48px 12px; color: #999; }
.jkb-badge-notice {
    display: inline-block; padding: 2px 8px; background: var(--primary, #0d2b52);
    color: #fff; font-size: 11px; border-radius: 4px; font-weight: 600;
}
.jkb-badge-cat {
    display: inline-block; padding: 2px 8px; background: var(--secondary, #b4975a);
    color: #fff; font-size: 11px; border-radius: 4px;
}
.jkb-file-badge { font-size: 12px; color: var(--accent, #3b82f6); }

/* 페이징 */
.jkb-paging { display: flex; justify-content: center; gap: 4px; margin-top: 24px; }
.jkb-page-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 34px; height: 34px; border-radius: 6px; font-size: 13px;
    color: #555; text-decoration: none; border: 1px solid #ddd; transition: all .12s;
}
.jkb-page-btn:hover { background: #f5f5f5; }
.jkb-page-btn.active { background: var(--primary, #0d2b52); color: #fff; border-color: var(--primary, #0d2b52); }

/* 상세보기 */
.jkb-view-header {
    padding-bottom: 20px; border-bottom: 2px solid var(--primary, #0d2b52); margin-bottom: 24px;
}
.jkb-view-title { font-size: 22px; font-weight: 700; color: #1a1a1a; margin: 0 0 12px; line-height: 1.4; }
.jkb-view-meta { display: flex; flex-wrap: wrap; gap: 16px; font-size: 13px; color: #888; }
.jkb-view-meta span { display: flex; align-items: center; gap: 5px; }
.jkb-view-badges { display: flex; gap: 6px; margin-bottom: 10px; }
.jkb-view-actions { display: flex; gap: 8px; margin-top: 14px; }
.jkb-view-content {
    min-height: 200px; font-size: 15px; line-height: 1.8; color: #333;
    padding: 24px 0; border-bottom: 1px solid #eee;
}
.jkb-view-content p { margin: 0 0 1em; }
.jkb-view-content img { max-width: 100%; height: auto; border-radius: 6px; }
.jkb-view-attachments { padding: 16px 0; border-bottom: 1px solid #eee; }
.jkb-view-attachments h4 { font-size: 14px; font-weight: 600; margin: 0 0 10px; }
.jkb-view-attachments ul { list-style: none; padding: 0; margin: 0; }
.jkb-view-attachments li { margin-bottom: 6px; }
.jkb-view-attachments a { font-size: 14px; color: var(--accent, #3b82f6); display: inline-flex; align-items: center; gap: 5px; }
.jkb-view-nav { margin: 20px 0; border: 1px solid #eee; border-radius: 8px; overflow: hidden; }
.jkb-nav-item { display: flex; align-items: center; gap: 16px; padding: 11px 16px; border-bottom: 1px solid #eee; font-size: 14px; }
.jkb-nav-item:last-child { border-bottom: none; }
.jkb-nav-label { flex-shrink: 0; width: 50px; color: #999; font-size: 12px; }
.jkb-nav-link { color: #333; text-decoration: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.jkb-nav-link:hover { color: var(--primary, #0d2b52); }
.jkb-view-footer { margin-top: 16px; }

/* 댓글 */
.jkb-comments { margin-top: 32px; padding-top: 24px; border-top: 1px solid #eee; }
.jkb-comments-title { font-size: 16px; font-weight: 700; margin: 0 0 20px; }
.jkb-comment-list { list-style: none; padding: 0; margin: 0 0 20px; }
.jkb-comment-item { padding: 14px 0; border-bottom: 1px solid #f2f2f2; }
.jkb-comment-item:last-child { border-bottom: none; }
.jkb-comment-header { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.jkb-comment-author { font-size: 14px; font-weight: 600; color: #333; }
.jkb-comment-date { font-size: 12px; color: #aaa; flex: 1; }
.jkb-comment-del-btn {
    background: none; border: none; cursor: pointer; color: #ccc;
    font-size: 12px; padding: 2px 4px; margin-left: auto;
}
.jkb-comment-del-btn:hover { color: #dc2626; }
.jkb-comment-content { font-size: 14px; color: #444; line-height: 1.6; margin: 0; }
.jkb-comment-form { border-top: 1px solid #eee; padding-top: 18px; }
.jkb-comment-textarea {
    width: 100%; padding: 10px; border: 1px solid #ddd; border-radius: 6px;
    font-size: 14px; resize: vertical; outline: none; box-sizing: border-box;
    font-family: inherit;
}
.jkb-comment-textarea:focus { border-color: var(--primary, #0d2b52); }
.jkb-comment-form-footer { display: flex; justify-content: flex-end; margin-top: 8px; }
.jkb-login-notice { font-size: 14px; color: #888; margin-top: 16px; }
.jkb-login-notice a { color: var(--primary, #0d2b52); text-decoration: underline; }

/* 글쓰기 */
.jkb-write-title { font-size: 20px; font-weight: 700; margin: 0 0 24px; padding-bottom: 14px; border-bottom: 2px solid var(--primary, #0d2b52); }
.jkb-write-form { max-width: 860px; }
.jkb-field { margin-bottom: 20px; }
.jkb-field label { display: block; font-size: 14px; font-weight: 600; color: #333; margin-bottom: 7px; }
.req { color: #dc2626; }
.jkb-input {
    width: 100%; padding: 9px 13px; border: 1px solid #ddd; border-radius: 6px;
    font-size: 14px; outline: none; transition: border .15s; box-sizing: border-box; font-family: inherit;
}
.jkb-input:focus { border-color: var(--primary, #0d2b52); }
.jkb-select { height: 38px; }
.jkb-file-input { font-size: 14px; }
.jkb-field-hint { font-size: 12px; color: #999; margin: 5px 0 0; }
.jkb-write-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 28px; padding-top: 20px; border-top: 1px solid #eee; }
.jkb-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* TipTap 에디터 */
.jkb-editor-wrap { border: 1px solid #ddd; border-radius: 6px; overflow: hidden; }
.jkb-editor-wrap:focus-within { border-color: var(--primary, #0d2b52); }
.jkb-editor-toolbar {
    display: flex; align-items: center; gap: 2px; padding: 8px 10px;
    background: #f8f9fa; border-bottom: 1px solid #eee; flex-wrap: wrap;
}
.jkb-editor-toolbar button {
    width: 30px; height: 28px; border: none; background: none; cursor: pointer;
    border-radius: 4px; color: #555; font-size: 13px; transition: all .12s;
    display: flex; align-items: center; justify-content: center;
}
.jkb-editor-toolbar button:hover { background: #e9ecef; color: #1a1a1a; }
.jkb-editor-toolbar button.is-active { background: var(--primary, #0d2b52); color: #fff; }
.jkb-sep { width: 1px; height: 20px; background: #ddd; margin: 0 4px; }
.jkb-editor-body {
    min-height: 320px; padding: 14px; font-size: 15px; line-height: 1.7; outline: none;
}
.jkb-editor-body--sm { min-height: 180px; }
.jkb-editor-body .ProseMirror { outline: none; min-height: inherit; }
.jkb-editor-body p { margin: 0 0 .8em; }
.jkb-editor-body p:last-child { margin-bottom: 0; }
.jkb-editor-body ul, .jkb-editor-body ol { padding-left: 1.5em; margin: 0 0 .8em; }
.jkb-editor-body blockquote { border-left: 3px solid var(--primary, #0d2b52); padding-left: 14px; color: #666; margin: 0 0 .8em; }
.jkb-editor-body pre { background: #f1f3f4; padding: 12px; border-radius: 4px; overflow-x: auto; font-size: 13px; }
.jkb-editor-body img { max-width: 100%; border-radius: 4px; }
.jkb-editor-body a { color: var(--accent, #3b82f6); text-decoration: underline; }
.jkb-editor-body p.is-editor-empty:first-child::before {
    content: attr(data-placeholder); color: #aaa; pointer-events: none; float: left; height: 0;
}
.jkb-msg { color: #888; padding: 20px; text-align: center; }

@media (max-width: 640px) {
    .jkb-table { display: block; overflow-x: auto; }
    .jkb-col-author, .jkb-col-views { display: none; }
    .jkb-board-toolbar { flex-direction: column; align-items: stretch; }
    .jkb-search input { width: 100%; }
    .jkb-view-title { font-size: 18px; }
}
