/* Comment threads — works on speaker_profile.php and inside any portal panel. */
.cm-thread { display: flex; flex-direction: column; gap: 1rem; }
.cm-empty {
    color: #999; font-family: 'IBM Plex Mono', monospace; font-size: 0.7rem;
    letter-spacing: 0.5px; padding: 0.6rem 0;
}
.cm-empty a { color: #e63328; }
.cm-row { display: flex; gap: 0.85rem; align-items: flex-start; }
.cm-row.cm-reply { margin-left: 3rem; }
.cm-avatar { flex: 0 0 38px; }
.cm-avatar img { width: 38px; height: 38px; object-fit: cover; border-radius: 50%; display: block; }
.cm-avatar-fallback {
    width: 38px; height: 38px; border-radius: 50%;
    background: #1c1c24; border: 1px solid #2a2a35; color: #999;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Bebas Neue', sans-serif; font-size: 1rem;
}
.cm-body { flex: 1; min-width: 0; }
.cm-meta {
    display: flex; gap: 0.55rem; align-items: baseline; flex-wrap: wrap;
    margin-bottom: 0.25rem; font-size: 0.75rem;
}
.cm-author-name { color: #f0f0f0; font-weight: 500; text-decoration: none; }
.cm-author-name:hover { color: #e63328; }
.cm-badge {
    font-family: 'IBM Plex Mono', monospace; font-size: 0.55rem;
    letter-spacing: 1.2px; text-transform: uppercase;
    padding: 0.1rem 0.4rem; border: 1px solid currentColor;
}
.cm-badge-speaker { color: #e63328; }
.cm-badge-admin { color: #f59e0b; }
.cm-time, .cm-edited {
    font-family: 'IBM Plex Mono', monospace; font-size: 0.6rem;
    color: #666; letter-spacing: 0.3px;
}
.cm-text {
    color: #c0c0c0; font-size: 0.9rem; line-height: 1.6;
    word-wrap: break-word;
}
.cm-text p { margin: 0 0 0.5rem; }
.cm-text p:last-child { margin-bottom: 0; }
.cm-text code {
    background: rgba(255,255,255,0.06); border: 1px solid #2a2a35;
    padding: 0.05rem 0.3rem; font-family: 'IBM Plex Mono', monospace;
    font-size: 0.85em;
}
.cm-text a { color: #e63328; }
.cm-text strong { color: #f0f0f0; }

.cm-deleted .cm-text {
    color: #666; font-style: italic;
}

.cm-actions {
    display: flex; gap: 0.6rem; margin-top: 0.4rem; flex-wrap: wrap;
}
.cm-link {
    background: none; border: none; padding: 0; cursor: pointer;
    color: #888; font-family: 'IBM Plex Mono', monospace;
    font-size: 0.6rem; letter-spacing: 0.5px;
    text-transform: uppercase;
}
.cm-link:hover { color: #f0f0f0; }
.cm-action-delete:hover { color: #e63328; }

.cm-form {
    margin-top: 0.4rem; display: flex; flex-direction: column; gap: 0.4rem;
}
.cm-input {
    width: 100%; padding: 0.6rem 0.75rem;
    background: #15151c; border: 1px solid #2a2a35; color: #f0f0f0;
    font-family: 'IBM Plex Sans', sans-serif; font-size: 0.85rem;
    line-height: 1.5; resize: vertical; box-sizing: border-box;
}
.cm-input:focus { outline: none; border-color: #e63328; }
.cm-form-bar {
    display: flex; justify-content: space-between; align-items: center; gap: 0.6rem;
}
.cm-form-msg {
    font-family: 'IBM Plex Mono', monospace; font-size: 0.65rem;
    color: #e63328; min-height: 1em;
}
.cm-btn {
    background: transparent; border: 1px solid #2a2a35; color: #f0f0f0;
    padding: 0.4rem 0.85rem; cursor: pointer;
    font-family: 'IBM Plex Mono', monospace; font-size: 0.65rem;
    letter-spacing: 1.2px; text-transform: uppercase;
}
.cm-btn:hover { border-color: #999; }
.cm-btn-primary { background: #e63328; border-color: #e63328; }
.cm-btn-primary:hover { background: #c5251c; border-color: #c5251c; }
.cm-btn:disabled { opacity: 0.5; cursor: not-allowed; }
