/* ═══════════════════════════════════════════════════════
   KBoard Pro — 프론트엔드 스타일
   ═══════════════════════════════════════════════════════ */

.kboard-wrap { font-family: -apple-system, 'Malgun Gothic', sans-serif; max-width: 100%; }

/* ── 공통 버튼 ── */
.kboard-btn {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 6px 14px; border-radius: 4px; font-size: 13px;
    text-decoration: none; border: 1px solid #ddd; cursor: pointer;
    background: #fff; color: #333; transition: all .15s;
}
.kboard-btn:hover { background: #f5f5f5; text-decoration: none; }
.kboard-btn-primary { background: #2271b1; color: #fff !important; border-color: #2271b1; }
.kboard-btn-primary:hover { background: #135e96; }
.kboard-btn-write { background: #00a32a; color: #fff !important; border-color: #00a32a; }
.kboard-btn-write:hover { background: #007a1f; }
.kboard-btn-delete { background: #d63638; color: #fff !important; border-color: #d63638; }
.kboard-btn-reply { background: #8c8f94; color: #fff !important; border-color: #8c8f94; }

/* ── 검색 영역 ── */
.kboard-search-form { margin-bottom: 12px; }
.kboard-search-row { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.kboard-select { padding: 6px 8px; border: 1px solid #ddd; border-radius: 4px; }
.kboard-search-input { flex: 1; min-width: 160px; padding: 6px 10px; border: 1px solid #ddd; border-radius: 4px; }

/* ── 툴바 ── */
.kboard-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.kboard-total { color: #666; font-size: 13px; }

/* ── 목록 테이블 ── */
.kboard-list-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.kboard-list-table th {
    background: #f8f9fa; padding: 10px 8px;
    border-top: 2px solid #2271b1; border-bottom: 1px solid #ddd;
    text-align: center; font-weight: 600; color: #333;
}
.kboard-list-table td { padding: 9px 8px; border-bottom: 1px solid #eee; vertical-align: middle; }
.kboard-list-table tr:hover td { background: #f0f6fc; }
.kboard-notice-row td { background: #fffde7 !important; }
.kboard-notice-row:hover td { background: #fff9c4 !important; }

.kboard-num, .kboard-views, .kboard-comments { text-align: center; color: #666; }
.kboard-author, .kboard-date { text-align: center; color: #555; font-size: 13px; }

.kboard-post-link { color: #1a1a1a; text-decoration: none; }
.kboard-post-link:hover { color: #2271b1; text-decoration: underline; }
.kboard-comment-cnt { color: #2271b1; font-weight: 600; margin-left: 4px; }
.kboard-empty { text-align: center; padding: 40px !important; color: #999; }

.kboard-badge-notice {
    background: #d63638; color: #fff; font-size: 11px;
    padding: 2px 6px; border-radius: 3px; font-weight: 600;
}

/* ── 페이지네이션 ── */
.kboard-pagination { display: flex; justify-content: center; gap: 4px; margin-top: 16px; flex-wrap: wrap; }
.kboard-page-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border: 1px solid #ddd; border-radius: 4px;
    text-decoration: none; color: #333; font-size: 13px;
}
.kboard-page-btn:hover { background: #f0f6fc; border-color: #2271b1; }
.kboard-page-btn.active { background: #2271b1; color: #fff; border-color: #2271b1; }

/* ── 게시글 상세 ── */
.kboard-back-link { display: inline-block; margin-bottom: 12px; color: #666; text-decoration: none; font-size: 13px; }
.kboard-back-link:hover { color: #2271b1; }

.kboard-post-header { border-top: 2px solid #2271b1; border-bottom: 1px solid #eee; padding: 16px 0; margin-bottom: 20px; }
.kboard-post-title { font-size: 20px; font-weight: 700; margin: 0 0 10px; }
.kboard-post-meta { display: flex; gap: 16px; font-size: 13px; color: #666; flex-wrap: wrap; }
.kboard-post-content { min-height: 200px; line-height: 1.8; padding: 0 0 20px; border-bottom: 1px solid #eee; }

/* ── 첨부파일 ── */
.kboard-attachments { padding: 16px; background: #f8f9fa; border-radius: 6px; margin: 16px 0; }
.kboard-attachments h4 { margin: 0 0 10px; font-size: 14px; }
.kboard-attachments ul { list-style: none; margin: 0; padding: 0; }
.kboard-attachments li { padding: 5px 0; border-bottom: 1px solid #eee; display: flex; align-items: center; gap: 8px; }
.kboard-attach-link { color: #2271b1; text-decoration: none; }
.kboard-attach-link:hover { text-decoration: underline; }
.kboard-file-size { color: #999; font-size: 12px; }
.kboard-dl-count { color: #999; font-size: 12px; margin-left: auto; }

/* ── 답글 ── */
.kboard-replies { padding: 16px; background: #f0f6fc; border-radius: 6px; margin: 16px 0; }
.kboard-reply-item { padding: 12px; background: #fff; border-radius: 4px; margin-bottom: 8px; border-left: 3px solid #2271b1; }
.kboard-reply-meta { font-size: 12px; color: #666; margin-bottom: 6px; }
.kboard-reply-content { font-size: 14px; line-height: 1.6; }

/* ── 게시글 버튼 영역 ── */
.kboard-post-actions { display: flex; gap: 8px; flex-wrap: wrap; padding: 16px 0; border-bottom: 1px solid #eee; }
.kboard-post-nav { padding: 12px 0; font-size: 13px; }
.kboard-post-nav div { padding: 5px 0; border-bottom: 1px solid #f0f0f0; }
.kboard-post-nav a { color: #2271b1; text-decoration: none; }

/* ── 댓글 ── */
.kboard-comments-section { margin-top: 24px; }
.kboard-comments-section h3 { font-size: 16px; border-bottom: 1px solid #eee; padding-bottom: 8px; }
.kboard-comment { padding: 14px; border-bottom: 1px solid #f0f0f0; }
.kboard-child-comment { margin-left: 24px; background: #f8f9fa; border-radius: 4px; margin-top: 6px; }
.kboard-comment-meta { font-size: 12px; color: #666; margin-bottom: 6px; display: flex; align-items: center; gap: 8px; }
.kboard-comment-content { font-size: 14px; line-height: 1.6; }
.kboard-comment-delete { background: none; border: 1px solid #d63638; color: #d63638; font-size: 11px; padding: 2px 6px; border-radius: 3px; cursor: pointer; margin-left: auto; }
.kboard-reply-comment-btn { background: none; border: none; color: #2271b1; font-size: 12px; cursor: pointer; padding: 4px 0; }

/* ── 댓글 폼 ── */
.kboard-comment-form { background: #f8f9fa; padding: 16px; border-radius: 6px; margin-top: 16px; }
.kboard-comment-form h4 { margin: 0 0 12px; font-size: 14px; }
.kboard-comment-author-row { display: flex; gap: 8px; margin-bottom: 8px; }
.kboard-input { padding: 7px 10px; border: 1px solid #ddd; border-radius: 4px; font-size: 13px; }
.kboard-input-full { width: 100%; box-sizing: border-box; }
.kboard-input-sm { width: 130px; }
.kboard-textarea { width: 100%; padding: 8px 10px; border: 1px solid #ddd; border-radius: 4px; font-size: 13px; resize: vertical; box-sizing: border-box; }
.kboard-comment-options { display: flex; align-items: center; gap: 12px; margin-top: 8px; flex-wrap: wrap; }
.kboard-comment-options .kboard-btn { margin-left: auto; }

/* ── 글쓰기 폼 ── */
.kboard-form-title { font-size: 18px; margin-bottom: 16px; }
.kboard-form-row { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.kboard-form-row label:first-child { min-width: 70px; padding-top: 8px; font-weight: 600; font-size: 13px; color: #333; }
.kboard-form-title-row { flex-wrap: nowrap; }
.kboard-checkbox-label { display: flex; align-items: center; gap: 4px; font-size: 13px; cursor: pointer; padding-top: 8px; }

/* ── 파일 업로드 ── */
.kboard-file-input { display: none; }
.kboard-upload-label {
    display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px;
    border: 2px dashed #2271b1; border-radius: 6px; cursor: pointer;
    font-size: 13px; color: #2271b1; background: #f0f6fc;
}
.kboard-upload-label:hover { background: #e0edf8; }
.kboard-file-list { margin-top: 8px; }
.kboard-file-item { display: flex; align-items: center; gap: 8px; padding: 5px 8px; background: #fff; border: 1px solid #eee; border-radius: 4px; margin-bottom: 4px; font-size: 13px; }
.kboard-file-remove { background: none; border: none; color: #d63638; cursor: pointer; font-size: 14px; margin-left: auto; }

/* ── 폼 액션 버튼 ── */
.kboard-form-actions { display: flex; gap: 8px; justify-content: flex-end; padding-top: 12px; border-top: 1px solid #eee; margin-top: 16px; }

/* ── 비밀글 박스 ── */
.kboard-secret-box { text-align: center; padding: 40px; background: #f8f9fa; border-radius: 8px; }
.kboard-secret-box form { display: flex; gap: 8px; justify-content: center; margin-top: 16px; }

/* ── 에러 ── */
.kboard-error { color: #d63638; padding: 12px; background: #fce8e8; border-radius: 4px; }

/* ── 반응형 ── */
@media (max-width: 600px) {
    .kboard-list-table colgroup { display: none; }
    .kboard-list-table th:nth-child(n+3),
    .kboard-list-table td:nth-child(n+3) { display: none; }
    .kboard-form-row { flex-direction: column; }
    .kboard-form-row label:first-child { padding-top: 0; }
}
