/* ==========================================================================
   comments.css - Comment Threads Styles
   Consumes design tokens from base.css
   ========================================================================== */

/* ─── Comments Section ────────────────────────────────────────────────── */
.comments-section {
    margin-top: var(--space-8);
    padding-top: var(--space-8);
    border-top: 1px solid var(--border-color);
}

/* ─── Comment Cards ───────────────────────────────────────────────────── */
.comment-card {
    padding: var(--space-4);
    margin-bottom: var(--space-3);
}
.comment-card--reply {
    margin-left: 1rem;
}

/* ─── Comment Card Header ─────────────────────────────────────────────── */
.comment-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
}
.comment-card__avatar-img {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}
.comment-card__avatar-initials {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: var(--text-sm);
    flex-shrink: 0;
}
.comment-card__author {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}
.comment-card__name {
    font-weight: 600;
    color: var(--text-color);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: var(--text-sm);
}
.comment-card__name:hover {
    text-decoration: underline;
}
.comment-card__date {
    font-size: var(--text-xs, 0.75rem);
    color: var(--text-muted);
}

/* ─── Comment Body ────────────────────────────────────────────────────── */
.comment-card__body {
    margin-top: var(--space-2);
    line-height: 1.5;
    color: var(--text-color);
    white-space: pre-wrap;
    word-break: break-word;
}

/* ─── Comment Footer ──────────────────────────────────────────────────── */
.comment-card__footer {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-top: var(--space-2);
}

/* ─── Like Button ─────────────────────────────────────────────────────── */
.comment-like-btn {
    background: none;
    border: none;
    padding: var(--space-1) var(--space-2);
    cursor: pointer;
    color: var(--text-muted);
    font-size: var(--text-sm);
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    transition: color var(--transition-speed);
    border-radius: var(--radius-sm);
}
.comment-like-btn:hover {
    color: var(--accent-color);
}
.comment-like-btn--active {
    color: var(--accent-color);
    background-color: rgba(var(--accent-rgb, 79, 70, 229), 0.08);
}
.comment-like-btn--active:hover {
    opacity: 0.8;
}
.comment-like-btn[data-processing="1"] {
    opacity: 0.5;
    pointer-events: none;
}

/* ─── Reply Button ────────────────────────────────────────────────────── */
.comment-reply-btn {
    background: none;
    border: none;
    padding: var(--space-1) var(--space-2);
    cursor: pointer;
    color: var(--text-muted);
    font-size: var(--text-sm);
    transition: color var(--transition-speed);
    border-radius: var(--radius-sm);
}
.comment-reply-btn:hover {
    color: var(--accent-color);
}

/* ─── Report Button ───────────────────────────────────────────────────── */
.comment-report-btn {
    background: none;
    border: none;
    padding: var(--space-1) var(--space-2);
    cursor: pointer;
    color: var(--text-muted);
    font-size: var(--text-sm);
    transition: color var(--transition-speed), opacity var(--transition-speed);
    border-radius: var(--radius-sm);
}
.comment-report-btn:hover {
    color: var(--danger-color, #dc3545);
}
.comment-report-btn--reported {
    color: var(--text-muted);
    opacity: 0.6;
    cursor: default;
}
.comment-report-btn:disabled {
    pointer-events: none;
}

/* ─── Reply Count ─────────────────────────────────────────────────────── */
.comment-reply-count {
    display: block;
    font-size: var(--text-xs, 0.75rem);
    color: var(--text-muted);
    margin-top: var(--space-1);
}

/* ─── Replies Container ───────────────────────────────────────────────── */
.comment-replies {
    margin-top: var(--space-2);
}

/* ─── Comment Form ────────────────────────────────────────────────────── */
.comment-form-container {
    margin-top: var(--space-6);
}
.comment-textarea {
    width: 100%;
    min-height: 80px;
    padding: var(--space-3);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--surface-primary);
    color: var(--text-color);
    font-family: inherit;
    font-size: var(--text-base);
    resize: vertical;
}
.comment-textarea:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background: var(--surface-secondary);
}
.comment-submit-btn {
    background-color: var(--accent-color);
    color: white;
    border: none;
    padding: var(--space-2) var(--space-5);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background-color var(--transition-speed);
    font-size: var(--text-sm);
    margin-top: var(--space-2);
}
.comment-submit-btn:hover {
    background-color: var(--accent-hover);
}
.comment-submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* ─── Character Counter ───────────────────────────────────────────────── */
.comment-char-counter {
    font-size: var(--text-xs, 0.75rem);
    color: var(--text-muted);
    margin-top: var(--space-1);
    min-height: 1.2em;
}
.comment-char-counter--warning {
    color: var(--danger-color, #dc3545);
}

/* ─── Form Error ──────────────────────────────────────────────────────── */
.comment-form__error {
    color: var(--danger-color, #dc3545);
    font-size: var(--text-sm);
    margin-top: var(--space-1);
    min-height: 1.2em;
}

/* ─── Inline Reply Form ───────────────────────────────────────────────── */
.comment-reply-form {
    margin-top: var(--space-2);
    margin-bottom: var(--space-2);
}
.comment-reply-textarea {
    width: 100%;
    min-height: 60px;
    padding: var(--space-2);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: var(--surface-primary);
    color: var(--text-color);
    font-family: inherit;
    font-size: var(--text-sm);
    resize: vertical;
}
.comment-reply-form__actions {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-2);
}
.comment-reply-submit-btn {
    background-color: var(--accent-color);
    color: white;
    border: none;
    padding: var(--space-1) var(--space-4);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: var(--text-sm);
    transition: background-color var(--transition-speed);
}
.comment-reply-submit-btn:hover {
    background-color: var(--accent-hover);
}
.comment-reply-submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}
.comment-reply-cancel-btn {
    background: none;
    border: 1px solid var(--border-color);
    padding: var(--space-1) var(--space-4);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: var(--text-sm);
    color: var(--text-muted);
    transition: background-color var(--transition-speed);
}
.comment-reply-cancel-btn:hover {
    background: var(--surface-secondary);
}
.comment-reply-form__error {
    color: var(--danger-color, #dc3545);
    font-size: var(--text-sm);
    margin-top: var(--space-1);
    min-height: 1.2em;
}

/* ─── Skeleton Loading ────────────────────────────────────────────────── */
.comments-skeleton {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.comments-skeleton__item {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-4);
}
.comments-skeleton__avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--surface-secondary);
    flex-shrink: 0;
    animation: comment-pulse 1.5s ease-in-out infinite;
}
.comments-skeleton__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.comments-skeleton__line {
    height: 12px;
    background: var(--surface-secondary);
    border-radius: var(--radius-sm);
    animation: comment-pulse 1.5s ease-in-out infinite;
}
.comments-skeleton__line--short {
    width: 40%;
}
.comments-skeleton__line--long {
    width: 80%;
}

@keyframes comment-pulse {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 0.8; }
}

/* ─── Empty State ─────────────────────────────────────────────────────── */
.comments-empty {
    text-align: center;
    padding: var(--space-8);
    color: var(--text-muted);
    font-size: var(--text-base);
    display: none;
}

/* ─── Responsive ──────────────────────────────────────────────────────── */
@media (max-width: 600px) {
    .comment-card__footer {
        flex-wrap: wrap;
    }
    .comment-reply-form__actions {
        flex-direction: column;
    }
    .comment-reply-submit-btn,
    .comment-reply-cancel-btn {
        width: 100%;
        text-align: center;
    }
}

/* ─── Dark Mode (prefers-color-scheme) ────────────────────────────────── */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .comment-card__body {
        color: var(--text-color);
    }
    :root:not([data-theme="light"]) .comment-textarea,
    :root:not([data-theme="light"]) .comment-reply-textarea {
        background: var(--surface-primary);
        border-color: var(--border-color);
        color: var(--text-color);
    }
    :root:not([data-theme="light"]) .comment-reply-cancel-btn {
        border-color: var(--border-color);
        color: var(--text-muted);
    }
    :root:not([data-theme="light"]) .comments-section {
        border-color: var(--border-color);
    }
    :root:not([data-theme="light"]) .comments-skeleton__avatar,
    :root:not([data-theme="light"]) .comments-skeleton__line {
        background: var(--surface-tertiary);
    }
}

/* ─── Dark Mode (explicit data-theme) ─────────────────────────────────── */
:root[data-theme="dark"] .comment-card__body {
    color: var(--text-color);
}
:root[data-theme="dark"] .comment-textarea,
:root[data-theme="dark"] .comment-reply-textarea {
    background: var(--surface-primary);
    border-color: var(--border-color);
    color: var(--text-color);
}
:root[data-theme="dark"] .comment-reply-cancel-btn {
    border-color: var(--border-color);
    color: var(--text-muted);
}
:root[data-theme="dark"] .comments-section {
    border-color: var(--border-color);
}
:root[data-theme="dark"] .comments-skeleton__avatar,
:root[data-theme="dark"] .comments-skeleton__line {
    background: var(--surface-tertiary);
}
