/* ==================== MESSAGE BOARD ==================== */

/* Header */
.msgboard-header { text-align: center; margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--border); }
.msgboard-title { font-size: 24px; font-weight: 800; color: var(--text); margin: 0 0 6px; }
.msgboard-subtitle { font-size: 13px; color: var(--text-dim); margin: 0; }

/* Message list */
.msgboard-list { display: flex; flex-direction: column; gap: 2px; }
.msgboard-empty { text-align: center; padding: 48px 20px; color: var(--text-dim); font-size: 14px; line-height: 1.8; }

/* Message card (list item) */
.msgboard-card { display: flex; gap: 14px; padding: 16px 18px; border-radius: 8px; text-decoration: none; color: var(--text); transition: background 0.12s; border-bottom: 1px solid var(--border); }
.msgboard-card:hover { background: var(--bg-hover); }
.msgboard-card__left { flex-shrink: 0; }
.msgboard-card__avatar { width: 38px; height: 38px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #fff; }
.msgboard-card__body { flex: 1; min-width: 0; }
.msgboard-card__top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.msgboard-card__title { font-size: 15px; font-weight: 700; color: var(--text); margin: 0; }
.msgboard-card__preview { font-size: 13px; color: var(--text-dim); margin: 4px 0 0; line-height: 1.5; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.msgboard-card__meta { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-dim); margin-top: 6px; }
.msgboard-card__dot { opacity: 0.5; }
.msgboard-pin { font-size: 12px; }
.msgboard-cat { font-size: 10px; background: var(--accent-dim); color: var(--accent); padding: 1px 8px; border-radius: 9999px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.03em; }
.msgboard-comments { font-size: 11px; color: var(--accent); margin-left: auto; }

/* Single message post */
.msgboard-post { margin-bottom: 32px; }
.msgboard-post__header { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.msgboard-post__avatar { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; color: #fff; flex-shrink: 0; }
.msgboard-post__author { font-size: 14px; color: var(--text); }
.msgboard-post__date { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.msgboard-post__title { font-size: 22px; font-weight: 800; color: var(--text); margin: 0 0 16px; line-height: 1.3; }
.msgboard-post__content { font-size: 15px; color: var(--text-secondary); line-height: 1.7; }
.msgboard-post__content img { max-width: 100%; border-radius: 6px; margin: 8px 0; }
.msgboard-post__content a { color: var(--accent); }
.msgboard-post__content blockquote { border-left: 3px solid var(--accent); padding-left: 14px; margin: 12px 0; color: var(--text-dim); }

/* Comments section */
.msgboard-comments-section { border-top: 2px solid var(--border); padding-top: 24px; }
.msgboard-comments-title { font-size: 14px; font-weight: 700; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.04em; margin: 0 0 16px; }
.msgboard-comment { display: flex; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--border); }
.msgboard-comment:last-child { border-bottom: none; }
.msgboard-comment__avatar { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: #fff; flex-shrink: 0; }
.msgboard-comment__body { flex: 1; min-width: 0; }
.msgboard-comment__header { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.msgboard-comment__header strong { font-size: 13px; color: var(--text); }
.msgboard-comment__time { font-size: 11px; color: var(--text-dim); }
.msgboard-comment__actions { display: flex; gap: 2px; margin-left: auto; opacity: 0; transition: opacity 0.15s; }
.msgboard-comment:hover .msgboard-comment__actions { opacity: 1; }
.msgboard-comment__action { background: none; border: none; color: var(--text-dim); font-size: 13px; cursor: pointer; padding: 2px 5px; border-radius: 4px; transition: background 0.1s, color 0.1s; }
.msgboard-comment__action:hover { background: var(--bg-hover); color: var(--text); }
.msgboard-comment__action--del:hover { color: var(--red); background: var(--red-dim); }
.msgboard-comment__edited { font-size: 10px; color: var(--text-dim); font-style: italic; margin-left: 4px; }
.msgboard-comment__content { font-size: 14px; color: var(--text-secondary); line-height: 1.6; }
.msgboard-comment__content img { max-width: 100%; border-radius: 4px; }

/* Comment form */
.msgboard-comment-form { margin-top: 20px; }
.msgboard-comment-editor { border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: var(--bg); }
.msgboard-comment-editor trix-toolbar { position: static; background: var(--bg-card); border-bottom: 1px solid var(--border); border-radius: 8px 8px 0 0; padding: 6px 4px; }
.msgboard-comment-editor trix-toolbar .trix-button-group--file-tools { display: none; }
.msgboard-comment-editor trix-editor.trix-dark { min-height: 80px; max-height: 300px; overflow-y: auto; padding: 12px 14px; font-size: 14px; line-height: 1.5; background: var(--bg); color: var(--text); border: none; }

/* Modal editor — toolbar above, editor below, clear separation */
.msgboard-modal-editor { border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: var(--bg); }
.msgboard-modal-editor trix-toolbar { position: static; background: var(--bg-card); border-bottom: 1px solid var(--border); border-radius: 8px 8px 0 0; padding: 6px 4px; }
.msgboard-modal-editor trix-toolbar .trix-button-group--file-tools { display: none; }
.msgboard-modal-editor trix-editor.trix-dark { min-height: 200px; max-height: 500px; overflow-y: auto; padding: 14px 16px; font-size: 15px; line-height: 1.6; background: var(--bg); color: var(--text); border: none; }
