/* ============================================
   雨老爹 Blog - 前台主题：马卡龙绿
   清新自然的薄荷绿，宁静舒适
   ============================================ */
:root {
    --primary: #6CC08A;
    --primary-dark: #4CAF6A;
    --secondary: #A8E6CF;
    --gradient: linear-gradient(135deg, #6CC08A 0%, #A8E6CF 100%);
    --primary-gradient: linear-gradient(135deg, #6CC08A 0%, #A8E6CF 100%);
    --gradient-hover: linear-gradient(135deg, #4CAF6A 0%, #6CC08A 100%);
    --shadow-hover: 0 12px 28px rgba(108, 192, 138, 0.25);
    --primary-light: rgba(108, 192, 138, 0.08);
    --primary-shadow: rgba(108, 192, 138, 0.15);
}

/* ── 留言板美化（PC+移动端，使用主题变量） ── */

/* PC 端留言板头部 */
.pc-page .guestbook-header { text-align: center !important; padding: 50px 0 30px !important; }
.pc-page .guestbook-header h1 { font-size: 2.2rem !important; color: #1a1a2e !important; margin-bottom: 12px !important; font-weight: 700 !important; letter-spacing: .5px !important; }
.pc-page .guestbook-desc { color: #6b7280 !important; font-size: 1.05rem !important; max-width: 600px !important; margin: 0 auto !important; }

/* PC 端留言表单卡片 */
.pc-page .guestbook-form { background: #fff !important; border-radius: 16px !important; padding: 30px !important; margin-bottom: 36px !important; box-shadow: 0 2px 16px rgba(0,0,0,.04), 0 1px 4px rgba(0,0,0,.03) !important; border: 1px solid rgba(0,0,0,.04) !important; position: relative !important; }
.pc-page .guestbook-form::before { content: '' !important; position: absolute !important; top: 0 !important; left: 0 !important; right: 0 !important; height: 4px !important; background: var(--gradient) !important; border-radius: 4px 4px 0 0 !important; }
.pc-page .guestbook-form-row { display: grid !important; grid-template-columns: 1fr 1fr 1fr !important; gap: 14px !important; margin-bottom: 14px !important; }
.pc-page .guestbook-input, .pc-page .guestbook-textarea { padding: 12px 16px !important; border: 2px solid rgba(0,0,0,.06) !important; border-radius: 10px !important; font-size: .92rem !important; outline: none !important; transition: all .25s ease !important; background: #fafbfe !important; color: #333 !important; }
.pc-page .guestbook-input:focus, .pc-page .guestbook-textarea:focus { border-color: var(--primary) !important; box-shadow: 0 0 0 3px var(--primary-light) !important; }
.pc-page .guestbook-textarea-wrap { position: relative !important; }
.pc-page .guestbook-textarea { resize: vertical !important; min-height: 100px !important; }
.pc-page .emoji-bar { margin-top: 10px !important; position: relative !important; }
.pc-page .emoji-toggle { background: none !important; border: 1px solid #e0e4f0 !important; border-radius: 6px !important; padding: 5px 14px !important; cursor: pointer !important; font-size: .85rem !important; color: #666 !important; transition: all .2s !important; }
.pc-page .emoji-toggle:hover { background: var(--primary) !important; color: #fff !important; border-color: var(--primary) !important; }
.pc-page .emoji-picker { position: absolute !important; bottom: 100% !important; left: 0 !important; background: #fff !important; border: 1px solid #e0e4f0 !important; border-radius: 10px !important; padding: 12px !important; box-shadow: 0 4px 20px rgba(0,0,0,.1) !important; z-index: 99999 !important; width: 320px !important; overflow: visible !important; }
.pc-page .emoji-grid { display: grid !important; grid-template-columns: repeat(8, 1fr) !important; gap: 4px !important; }
.pc-page .emoji-item { display: flex !important; align-items: center !important; justify-content: center !important; width: 32px !important; height: 32px !important; cursor: pointer !important; border-radius: 6px !important; font-size: 1.2rem !important; transition: background .15s !important; }
.pc-page .emoji-item:hover { background: #f0f2ff !important; }
.pc-page .guestbook-form-actions { display: flex !important; align-items: center !important; gap: 12px !important; margin-top: 14px !important; }
.pc-page .guestbook-form-actions .btn-primary { padding: 12px 32px !important; font-size: .95rem !important; font-weight: 600 !important; border-radius: 10px !important; background: var(--gradient) !important; border: none !important; cursor: pointer !important; transition: all .25s ease !important; }
.pc-page .guestbook-form-actions .btn-primary:hover { transform: translateY(-2px) !important; box-shadow: 0 6px 20px var(--primary-shadow) !important; }

/* PC 端留言列表 - 完全参照 PC 端评论区卡片样式 */
.pc-page .guestbook-list { margin-top: 8px !important; }
.pc-page .message-item {
    padding: 22px 24px !important;
    margin-bottom: 16px !important;
    background: #fff !important;
    border-radius: 14px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.04) !important;
    border: 1px solid rgba(0,0,0,.04) !important;
    transition: all .25s ease !important;
    position: relative !important;
    overflow: hidden !important;
}
.pc-page .message-item::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: var(--gradient);
    opacity: 0;
    transition: opacity .25s ease;
}
.pc-page .message-item:last-child { margin-bottom: 0 !important; }
.pc-page .message-item:hover {
    box-shadow: 0 4px 20px rgba(0,0,0,.07) !important;
    transform: translateY(-2px) !important;
    border-color: rgba(0,0,0,.06) !important;
}
.pc-page .message-item:hover::before { opacity: 1; }

/* PC 端留言头部 */
.pc-page .message-header { display: flex !important; align-items: center !important; gap: 12px !important; margin-bottom: 12px !important; }
.pc-page .message-avatar { width: 44px !important; height: 44px !important; border-radius: 50% !important; background: var(--gradient) !important; display: flex !important; align-items: center !important; justify-content: center !important; color: #fff !important; font-size: .95rem !important; font-weight: 700 !important; flex-shrink: 0 !important; box-shadow: 0 2px 8px var(--primary-shadow) !important; transition: transform .3s ease !important; }
.pc-page .message-item:hover .message-avatar { transform: scale(1.08) !important; }
.pc-page .message-info { flex: 1 !important; display: flex !important; align-items: baseline !important; gap: 10px !important; flex-wrap: wrap !important; }
.pc-page .message-author { font-weight: 600 !important; color: #1a1a2e !important; font-size: 1rem !important; }
.pc-page .message-author a { color: inherit !important; text-decoration: none !important; transition: color .2s !important; }
.pc-page .message-author a:hover { color: var(--primary) !important; text-decoration: underline !important; }
.pc-page .message-author.admin { color: var(--primary) !important; }
.pc-page .message-time { font-size: .8rem !important; color: #9ca3b8 !important; margin-left: 2px !important; }
.pc-page .message-website { font-size: .82rem !important; color: var(--primary) !important; text-decoration: none !important; }
.pc-page .message-website:hover { text-decoration: underline !important; }

/* PC 端留言内容 */
.pc-page .message-content { padding-left: 56px !important; color: #4a5568 !important; font-size: .95rem !important; line-height: 1.75 !important; word-break: break-word !important; }
.pc-page .message-actions { padding-left: 56px !important; margin-top: 10px !important; }
.pc-page .message-reply-btn { background: none !important; border: none !important; color: var(--primary) !important; cursor: pointer !important; font-size: .84rem !important; padding: 4px 12px !important; border-radius: 6px !important; transition: all .2s ease !important; font-weight: 500 !important; }
.pc-page .message-reply-btn:hover { background: var(--primary-light) !important; transform: translateX(2px) !important; }

/* PC 端楼中楼回复 */
.pc-page .message-replies { margin-left: 56px !important; margin-top: 16px !important; padding: 20px 24px !important; border-left: 2px dashed rgba(102,126,234,.3) !important; background: linear-gradient(135deg, rgba(102,126,234,.04), rgba(102,126,234,.02)) !important; border-radius: 12px !important; }
.pc-page .message-replies .message-replies { margin-left: 14px !important; margin-top: 12px !important; padding: 16px 18px !important; background: rgba(0,0,0,.02) !important; }
.pc-page .message-reply-item { padding: 16px !important; border-radius: 10px !important; margin-bottom: 10px !important; background: #fff !important; border: 1px solid rgba(0,0,0,.04) !important; transition: all .2s ease !important; }
.pc-page .message-reply-item:last-child { margin-bottom: 0 !important; }
.pc-page .message-reply-item:hover { box-shadow: 0 2px 10px rgba(0,0,0,.06) !important; transform: translateX(4px) !important; }
.pc-page .message-reply-item .message-header { gap: 10px !important; margin-bottom: 8px !important; }
.pc-page .message-reply-item .message-avatar { width: 34px !important; height: 34px !important; font-size: .8rem !important; }
.pc-page .message-reply-item .message-author { font-size: .92rem !important; }
.pc-page .message-reply-item .message-content { padding-left: 44px !important; font-size: .92rem !important; line-height: 1.7 !important; }
.pc-page .message-reply-item .message-actions { padding-left: 44px !important; margin-top: 6px !important; }

/* PC 端管理员回复区域 */
.pc-page .message-reply { margin-left: 56px !important; margin-top: 16px !important; padding: 18px 20px !important; background: linear-gradient(135deg, rgba(102,126,234,.08), rgba(102,126,234,.04)) !important; border-radius: 12px !important; border-left: 3px solid var(--primary) !important; }
.pc-page .message-reply-label { font-size: .78rem !important; color: var(--primary) !important; font-weight: 600 !important; margin-bottom: 8px !important; display: flex !important; align-items: center !important; gap: 4px !important; }
.pc-page .message-reply-content { color: #4a5568 !important; font-size: .93rem !important; line-height: 1.7 !important; }
.pc-page .message-reply-time { font-size: .75rem !important; color: #9ca3b8 !important; margin-top: 8px !important; }

/* PC 端回复表单 */
.pc-page .message-reply-form { display: none !important; margin-left: 56px !important; margin-top: 10px !important; padding: 16px !important; background: #f8f9fc !important; border-radius: 10px !important; }
.pc-page .message-reply-form.active { display: block !important; }
.pc-page .message-reply-form textarea { width: 100% !important; padding: 12px !important; border: 2px solid #e0e4f0 !important; border-radius: 8px !important; font-size: .9rem !important; resize: vertical !important; outline: none !important; font-family: inherit !important; box-sizing: border-box !important; margin-bottom: 10px !important; background: #fff !important; }
.pc-page .message-reply-form textarea:focus { border-color: var(--primary) !important; box-shadow: 0 0 0 3px var(--primary-light) !important; }
.pc-page .message-reply-form-actions { display: flex !important; gap: 8px !important; align-items: center !important; }
.pc-page .message-reply-form .reply-msg { font-size: .82rem !important; }

/* PC 端回复中提示 */
.pc-page .replying-to-bar { display: none !important; padding: 10px 14px !important; background: #f7f8fc !important; border-radius: 8px !important; margin-bottom: 12px !important; font-size: .9rem !important; color: var(--primary) !important; }
.pc-page .replying-to-bar.active { display: block !important; }
.pc-page .replying-to-bar strong { color: var(--primary) !important; font-weight: 600 !important; }
.pc-page .replying-to-bar a { margin-left: 8px !important; color: #e74c3c !important; text-decoration: none !important; }

/* PC 端留言分页 */
.pc-page .comment-pagination { display: flex !important; align-items: center !important; justify-content: center !important; gap: 8px !important; margin-top: 28px !important; }
.pc-page .comment-pagination a, .pc-page .comment-pagination span { display: inline-flex !important; align-items: center !important; justify-content: center !important; min-width: 38px !important; height: 38px !important; padding: 0 12px !important; border-radius: 10px !important; font-size: .9rem !important; font-weight: 600 !important; text-decoration: none !important; transition: all .2s ease !important; color: #666 !important; background: #f5f6fa !important; border: 1px solid rgba(0,0,0,.04) !important; }
.pc-page .comment-pagination a:hover { background: var(--gradient) !important; color: #fff !important; border-color: transparent !important; transform: translateY(-2px) !important; box-shadow: 0 4px 12px var(--primary-shadow) !important; }
.pc-page .comment-pagination span.active { background: var(--gradient) !important; color: #fff !important; border-color: transparent !important; box-shadow: 0 4px 12px var(--primary-shadow) !important; }

/* PC 端空状态 & 关闭状态 */
.pc-page .loading-comments, .pc-page .no-comments { text-align: center !important; color: #9ca3b8 !important; padding: 48px 0 !important; font-size: .95rem !important; }
.pc-page .no-comments::before { content: '📭' !important; display: block !important; font-size: 3rem !important; margin-bottom: 12px !important; opacity: .5 !important; }
.pc-page .guestbook-closed { text-align: center !important; padding: 100px 20px !important; }
.pc-page .guestbook-closed-icon { font-size: 5rem !important; margin-bottom: 24px !important; opacity: .6 !important; }
.pc-page .guestbook-closed h2 { font-size: 1.6rem !important; color: #1a1a2e !important; margin-bottom: 12px !important; }
.pc-page .guestbook-closed p { color: #9ca3b8 !important; font-size: 1rem !important; }

/* 移动端留言板美化 */
@media (max-width: 768px) {
    .mobile-page .guestbook-header { padding: 30px 0 20px !important; }
    .mobile-page .guestbook-header h1 { font-size: 1.5rem !important; }
    .mobile-page .guestbook-desc { font-size: .9rem !important; }
    .mobile-page .guestbook-form {
        background: #fff !important;
        border-radius: 12px !important;
        padding: 18px !important;
        margin-bottom: 20px !important;
        box-shadow: 0 2px 12px rgba(0,0,0,.06) !important;
        border: 1px solid rgba(0,0,0,.05) !important;
        position: relative !important;
        overflow: visible !important;
        box-sizing: border-box !important;
        max-width: 100% !important;
    }
    .mobile-page .guestbook-form::before { content: '' !important; position: absolute !important; top: 0 !important; left: 0 !important; right: 0 !important; height: 3px !important; background: var(--gradient) !important; border-radius: 3px 3px 0 0 !important; }
    .mobile-page .guestbook-form-row { grid-template-columns: 1fr !important; gap: 10px !important; margin-bottom: 10px !important; }
    .mobile-page .guestbook-input, .mobile-page .guestbook-textarea { padding: 10px 12px !important; border: 2px solid rgba(0,0,0,.06) !important; border-radius: 8px !important; font-size: .9rem !important; background: #fafbfe !important; }
    .mobile-page .guestbook-input:focus, .mobile-page .guestbook-textarea:focus { border-color: var(--primary) !important; box-shadow: 0 0 0 3px var(--primary-light) !important; }
    .mobile-page .emoji-bar { margin-top: 6px !important; }
    .mobile-page .emoji-toggle { padding: 5px 12px !important; border-radius: 6px !important; font-size: .82rem !important; }
    .mobile-page .emoji-toggle:hover { background: var(--primary) !important; color: #fff !important; }
    .mobile-page .emoji-picker {
        width: 280px !important;
        left: 0 !important;
        bottom: 100% !important;
        margin-bottom: 0 !important;
        border-radius: 10px !important;
        box-shadow: 0 4px 20px rgba(0,0,0,.12) !important;
        max-width: calc(100vw - 40px) !important;
        overflow: visible !important;
        position: absolute !important;
        z-index: 99999 !important;
    }
    .mobile-page .emoji-grid { grid-template-columns: repeat(7, 1fr) !important; gap: 4px !important; }
    .mobile-page .emoji-item { width: 30px !important; height: 30px !important; font-size: 1.1rem !important; border-radius: 6px !important; }
    .mobile-page .emoji-item:hover { background: var(--primary-light) !important; }
    .mobile-page .guestbook-form-actions { margin-top: 10px !important; }
    .mobile-page .guestbook-form-actions .btn-primary { padding: 10px 24px !important; font-size: .9rem !important; border-radius: 8px !important; background: var(--gradient) !important; }
    .mobile-page .message-item {
        padding: 16px !important;
        margin-bottom: 12px !important;
        background: #fff !important;
        border-radius: 12px !important;
        box-shadow: 0 2px 10px rgba(0,0,0,.05) !important;
        border: 1px solid rgba(0,0,0,.04) !important;
        transition: all .2s ease !important;
        position: relative !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
        max-width: 100% !important;
    }
    .mobile-page .message-item::before {
        content: '' !important;
        position: absolute !important;
        left: 0 !important;
        top: 0 !important;
        bottom: 0 !important;
        width: 3px !important;
        background: var(--gradient) !important;
        opacity: 0 !important;
        transition: opacity .2s ease !important;
    }
    .mobile-page .message-item:last-child {
        margin-bottom: 0 !important;
    }
    .mobile-page .message-item:hover {
        box-shadow: 0 4px 16px rgba(0,0,0,.08) !important;
        transform: translateY(-1px) !important;
    }
    .mobile-page .message-item:hover::before {
        opacity: 1 !important;
    }
    .mobile-page .message-header { gap: 10px !important; margin-bottom: 10px !important; }
    .mobile-page .message-avatar { width: 40px !important; height: 40px !important; font-size: .88rem !important; }
    .mobile-page .message-author { font-size: .92rem !important; }
    .mobile-page .message-author.admin { color: var(--primary) !important; }
    .mobile-page .message-time { font-size: .75rem !important; color: #9ca3b8 !important; }
    .mobile-page .message-website { font-size: .8rem !important; color: var(--primary) !important; }
    .mobile-page .message-content, .mobile-page .message-actions, .mobile-page .message-replies { padding-left: 0 !important; margin-left: 0 !important; }
    .mobile-page .message-content { margin-top: 6px !important; font-size: .9rem !important; line-height: 1.65 !important; }
    .mobile-page .message-actions { margin-top: 8px !important; }
    .mobile-page .message-reply-btn { font-size: .8rem !important; padding: 3px 10px !important; border-radius: 5px !important; color: var(--primary) !important; }
    .mobile-page .message-reply-btn:hover { background: var(--primary-light) !important; }
    .mobile-page .message-replies { margin-top: 12px !important; padding: 14px 12px !important; border-left: 2px dashed rgba(102,126,234,.3) !important; background: linear-gradient(135deg, rgba(102,126,234,.04), rgba(102,126,234,.02)) !important; border-radius: 10px !important; }
    .mobile-page .message-replies .message-replies { margin-top: 10px !important; padding: 12px 10px !important; background: rgba(0,0,0,.02) !important; }
    .mobile-page .message-reply-item { padding: 12px !important; margin-bottom: 8px !important; border-radius: 8px !important; background: #fff !important; border: 1px solid rgba(0,0,0,.04) !important; }
    .mobile-page .message-reply-item .message-avatar { width: 32px !important; height: 32px !important; font-size: .78rem !important; }
    .mobile-page .message-reply-item .message-author { font-size: .88rem !important; }
    .mobile-page .message-reply-item .message-content { padding-left: 0 !important; margin-top: 6px !important; font-size: .88rem !important; }
    .mobile-page .message-reply-item .message-actions { padding-left: 0 !important; margin-top: 6px !important; }
    .mobile-page .message-reply { margin-top: 12px !important; padding: 16px !important; background: linear-gradient(135deg, rgba(102,126,234,.08), rgba(102,126,234,.04)) !important; border-radius: 10px !important; border-left: 3px solid var(--primary) !important; }
    .mobile-page .message-reply-label { font-size: .75rem !important; color: var(--primary) !important; margin-bottom: 6px !important; }
    .mobile-page .message-reply-content { font-size: .9rem !important; line-height: 1.65 !important; }
    .mobile-page .message-reply-time { font-size: .72rem !important; margin-top: 6px !important; }
    .mobile-page .message-reply-form { margin-top: 10px !important; padding: 14px !important; border-radius: 8px !important; }
    .mobile-page .message-reply-form textarea { padding: 10px !important; font-size: .88rem !important; margin-bottom: 8px !important; }
    .mobile-page .replying-to-bar { padding: 8px 12px !important; border-radius: 6px !important; font-size: .88rem !important; }
    .mobile-page .loading-comments, .mobile-page .no-comments { padding: 36px 0 !important; color: #9ca3b8 !important; }
    .mobile-page .comment-pagination { gap: 6px !important; margin-top: 18px !important; }
    .mobile-page .comment-pagination a, .mobile-page .comment-pagination span { min-width: 32px !important; height: 32px !important; font-size: .85rem !important; border-radius: 8px !important; }
    .mobile-page .comment-pagination a:hover { background: var(--gradient) !important; color: #fff !important; transform: translateY(-2px) !important; }
    .mobile-page .guestbook-closed { padding: 60px 20px !important; }
    .mobile-page .guestbook-closed-icon { font-size: 3.5rem !important; }
    .mobile-page .guestbook-closed h2 { font-size: 1.3rem !important; }
    .mobile-page .guestbook-closed p { font-size: .9rem !important; }
}

/* ── PC端评论区美化（使用主题变量，切换主题自动适配） ── */

/* 评论区域容器 */
.pc-page .comments-section {
    margin-top: 48px !important;
    padding-top: 36px !important;
    border-top: 1px solid rgba(0,0,0,.06) !important;
    position: relative;
}
.pc-page .comments-section::before {
    content: '';
    position: absolute;
    top: -1px; left: 0;
    width: 120px; height: 3px;
    background: var(--gradient);
    border-radius: 2px;
}

/* 评论标题 */
.pc-page .comments-title {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 1.35rem !important;
    color: #1a1a2e !important;
    margin-bottom: 28px !important;
    font-weight: 700 !important;
    letter-spacing: .5px !important;
}
.pc-page .comments-title svg { color: var(--primary) !important; transition: transform .3s ease; }
.pc-page .comments-title:hover svg { transform: rotate(-12deg) scale(1.1); }
.pc-page .comments-title #commentCount {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 28px; height: 28px; padding: 0 8px;
    background: var(--gradient); color: #fff;
    font-size: .82rem; font-weight: 700;
    border-radius: 14px; margin-left: 4px;
}

/* 评论表单卡片 */
.pc-page .comment-form {
    background: #fff !important;
    border-radius: 16px !important;
    padding: 28px !important;
    margin-bottom: 32px !important;
    box-shadow: 0 2px 16px rgba(0,0,0,.04), 0 1px 4px rgba(0,0,0,.03) !important;
    border: 1px solid rgba(0,0,0,.04) !important;
    position: relative !important; overflow: visible !important;
}
.pc-page .comment-form::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: var(--gradient);
}

/* 表单输入行 */
.pc-page .comment-form-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 14px !important; margin-bottom: 14px !important;
}

/* 输入框 */
.pc-page .comment-input, .pc-page .comment-textarea {
    padding: 12px 16px !important;
    border: 2px solid rgba(0,0,0,.06) !important;
    border-radius: 10px !important;
    font-size: .92rem !important; outline: none !important;
    transition: all .25s ease !important;
    background: #fafbfe !important; color: #333 !important;
}
.pc-page .comment-input:focus, .pc-page .comment-textarea:focus {
    border-color: var(--primary) !important;
    background: #fff !important;
    box-shadow: 0 0 0 4px var(--primary-light), 0 2px 8px var(--primary-shadow) !important;
}

/* 文本域 */
.pc-page .comment-textarea-wrap { position: relative !important; }
.pc-page .comment-textarea {
    width: 100% !important; min-height: 100px !important;
    resize: vertical !important; font-family: inherit !important;
    box-sizing: border-box !important; line-height: 1.6 !important;
}

/* 表情栏 */
.pc-page .emoji-bar { margin-top: 10px !important; }
.pc-page .emoji-bar-wrap { position: relative !important; }
.pc-page .emoji-toggle {
    background: #f5f6fa !important; border: 2px solid rgba(0,0,0,.05) !important;
    border-radius: 8px !important; padding: 6px 16px !important;
    cursor: pointer !important; font-size: .88rem !important;
    color: #666 !important; transition: all .25s ease !important;
    font-weight: 500 !important;
}
.pc-page .emoji-toggle:hover {
    background: var(--gradient) !important; color: #fff !important;
    border-color: transparent !important; transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px var(--primary-shadow) !important;
}

/* 表情选择器面板 */
.pc-page .emoji-picker {
    position: absolute !important; bottom: 100% !important; left: 0 !important;
    background: rgba(255,255,255,.96) !important;
    backdrop-filter: blur(12px) !important; -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(0,0,0,.06) !important;
    border-radius: 14px !important; padding: 16px !important;
    box-shadow: 0 8px 32px rgba(0,0,0,.15) !important;
    z-index: 99999 !important; width: 340px !important;
    overflow: visible !important;
}
.pc-page .emoji-grid { display: grid !important; grid-template-columns: repeat(8, 1fr) !important; gap: 4px !important; }
.pc-page .emoji-item {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; cursor: pointer; border-radius: 8px;
    font-size: 1.25rem; transition: all .15s ease;
}
.pc-page .emoji-item:hover { background: var(--primary-light) !important; transform: scale(1.25); }

/* 表单操作按钮 */
.pc-page .comment-form-actions {
    display: flex !important; align-items: center !important;
    gap: 14px !important; margin-top: 16px !important;
}
.pc-page .comment-form-actions .btn-primary {
    background: var(--gradient) !important; color: #fff !important;
    border: none !important; padding: 11px 32px !important;
    border-radius: 10px !important; font-size: .95rem !important;
    font-weight: 600 !important; cursor: pointer !important;
    transition: all .3s ease !important; letter-spacing: .3px !important;
}
.pc-page .comment-form-actions .btn-primary:hover {
    background: var(--gradient-hover) !important;
    transform: translateY(-2px) !important;
    box-shadow: var(--shadow-hover) !important;
}
.pc-page .comment-form-actions .btn-primary:active { transform: translateY(0) !important; }
.pc-page .comment-msg { font-size: .85rem !important; font-weight: 500 !important; }

/* 回复提示条 */
.pc-page #replyingTo {
    padding: 10px 16px !important; background: var(--primary-light) !important;
    border-radius: 10px !important; margin-bottom: 14px !important;
    font-size: .9rem !important; color: var(--primary) !important;
    font-weight: 500 !important; border-left: 3px solid var(--primary) !important;
}
.pc-page #replyingTo a { color: #e74c3c !important; text-decoration: none !important; font-weight: 600 !important; }
.pc-page #replyingTo a:hover { text-decoration: underline !important; }

/* 评论列表 */
.pc-page .comment-list { margin-top: 8px !important; }

/* 评论卡片 */
.pc-page .comment-item {
    padding: 22px 24px !important; margin-bottom: 16px !important;
    background: #fff !important; border-radius: 14px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.04) !important;
    border: 1px solid rgba(0,0,0,.04) !important;
    transition: all .25s ease !important;
    position: relative !important; overflow: hidden !important;
}
.pc-page .comment-item::before {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0;
    width: 4px; background: var(--gradient); opacity: 0;
    transition: opacity .25s ease;
}
.pc-page .comment-item:hover {
    box-shadow: 0 4px 20px rgba(0,0,0,.07) !important;
    transform: translateY(-2px) !important;
    border-color: rgba(0,0,0,.06) !important;
}
.pc-page .comment-item:hover::before { opacity: 1; }
.pc-page .comment-item:last-child { margin-bottom: 0 !important; }

/* 评论头部 */
.pc-page .comment-header {
    display: flex !important; align-items: center !important;
    gap: 12px !important; margin-bottom: 12px !important;
}

/* 头像 */
.pc-page .comment-avatar {
    width: 42px !important; height: 42px !important;
    border-radius: 50% !important; background: var(--gradient) !important;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: .9rem; font-weight: 700;
    flex-shrink: 0; transition: all .3s ease;
    box-shadow: 0 2px 8px var(--primary-shadow) !important;
    position: relative;
}
.pc-page .comment-item:hover .comment-avatar { transform: scale(1.08); }

/* 评论信息 */
.pc-page .comment-info {
    flex: 1 !important; display: flex !important;
    align-items: center !important; gap: 10px !important; flex-wrap: wrap !important;
}
.pc-page .comment-author { font-weight: 600 !important; color: #1a1a2e !important; font-size: .98rem !important; }
.pc-page .comment-author a { color: inherit !important; text-decoration: none !important; transition: color .2s; }
.pc-page .comment-author a:hover { color: var(--primary) !important; text-decoration: underline !important; }
.pc-page .comment-author.admin { color: var(--primary) !important; }
.pc-page .comment-time { font-size: .8rem !important; color: #9ca3b8 !important; margin-left: 2px !important; font-weight: 400 !important; }

/* 回复关系标签（楼中楼专用） */
.pc-page .reply-to-label {
    font-size: .75rem !important;
    color: #9ca3b8 !important;
    margin-bottom: 8px !important;
    margin-top: -4px !important;
    padding-left: 54px !important;
    line-height: 1.4 !important;
}
.pc-page .reply-to-label span {
    color: var(--primary) !important;
    font-weight: 700 !important;
    font-size: .78rem !important;
}

/* 管理员徽章 */
.pc-page .admin-badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px; background: var(--gradient);
    color: #fff; font-size: .7rem; border-radius: 6px;
    margin-left: 6px; vertical-align: middle;
    font-weight: 600; letter-spacing: .3px;
    box-shadow: 0 2px 6px var(--primary-shadow);
}

/* 评论内容 */
.pc-page .comment-content {
    padding-left: 54px !important; color: #4a5568 !important;
    font-size: .93rem !important; line-height: 1.75 !important;
    word-break: break-word !important;
}

/* 评论操作 */
.pc-page .comment-actions { padding-left: 54px !important; margin-top: 10px !important; }
.pc-page .comment-reply-btn {
    background: none !important; border: none !important;
    color: var(--primary) !important; cursor: pointer !important;
    font-size: .84rem !important; padding: 4px 12px !important;
    border-radius: 6px !important; transition: all .2s ease !important;
    font-weight: 500 !important;
}
.pc-page .comment-reply-btn:hover {
    background: var(--primary-light) !important;
    transform: translateX(2px) !important;
}

/* 楼中楼回复容器 - 视觉归组到主评论 */
.pc-page .comment-replies {
    margin-left: 68px !important;
    margin-top: 16px !important;
    margin-bottom: 24px !important;
    padding: 18px 20px !important;
    border-left: 2px dashed rgba(108,192,138,.3) !important;
    background: linear-gradient(135deg, rgba(108,192,138,.04), rgba(108,192,138,.02)) !important;
    border-radius: 12px !important;
    position: relative !important;
}
.pc-page .comment-replies .comment-replies {
    margin-left: 14px !important;
    margin-top: 12px !important;
    margin-bottom: 0 !important;
    padding: 14px 16px !important;
    background: rgba(0,0,0,.02) !important;
    border-left: 2px dashed rgba(108,192,138,.2) !important;
    border-radius: 10px !important;
}

/* 回复项 */
.pc-page .comment-reply-item {
    padding: 14px 16px !important; border-radius: 10px !important;
    margin-bottom: 10px !important; background: #fff !important;
    border: 1px solid rgba(0,0,0,.04) !important;
    transition: all .2s ease !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.03) !important;
}
.pc-page .comment-reply-item:last-child { margin-bottom: 0 !important; }
.pc-page .comment-reply-item:hover {
    box-shadow: 0 2px 10px rgba(0,0,0,.06) !important;
    transform: translateX(4px) !important;
}
.pc-page .comment-reply-item .comment-header { gap: 10px !important; margin-bottom: 8px !important; }
.pc-page .comment-reply-item .comment-avatar { width: 32px !important; height: 32px !important; font-size: .78rem !important; }
.pc-page .comment-reply-item .comment-author { font-size: .9rem !important; }
.pc-page .comment-reply-item .comment-content { padding-left: 42px !important; font-size: .9rem !important; line-height: 1.7 !important; }
.pc-page .comment-reply-item .comment-actions { padding-left: 42px !important; margin-top: 6px !important; }

/* 加载 & 空状态 */
.pc-page .loading-comments, .pc-page .no-comments {
    text-align: center !important; color: #9ca3b8 !important;
    padding: 48px 0 !important; font-size: .95rem !important; line-height: 1.8 !important;
}
.pc-page .no-comments::before {
    content: '💬'; display: block; font-size: 2.5rem;
    margin-bottom: 12px; opacity: .5;
}

/* 评论分页 */
.pc-page .comment-pagination {
    display: flex !important; align-items: center !important;
    justify-content: center !important; gap: 8px !important; margin-top: 24px !important;
}
.pc-page .comment-pagination a, .pc-page .comment-pagination span {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 36px; height: 36px; padding: 0 10px;
    border-radius: 10px; font-size: .88rem; font-weight: 600;
    text-decoration: none; transition: all .2s ease;
    color: #666; background: #f5f6fa;
    border: 1px solid rgba(0,0,0,.04);
}
.pc-page .comment-pagination a:hover {
    background: var(--gradient) !important; color: #fff !important;
    border-color: transparent !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px var(--primary-shadow) !important;
}
.pc-page .comment-pagination span.active {
    background: var(--gradient) !important; color: #fff !important;
    border-color: transparent !important;
    box-shadow: 0 4px 12px var(--primary-shadow) !important;
}

/* 移动端评论区美化 - 完全参照 PC 端标准 */
@media (max-width: 768px) {
    .mobile-page .comments-section {
        margin-top: 32px !important;
        padding-top: 24px !important;
        border-top: 1px solid rgba(0,0,0,.06) !important;
    }
    .mobile-page .comments-title {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        font-size: 1.15rem !important;
        color: #1a1a2e !important;
        margin-bottom: 20px !important;
        font-weight: 700 !important;
    }
    .mobile-page .comments-title svg {
        color: var(--primary) !important;
    }
    .mobile-page .comments-title #commentCount {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 24px !important;
        height: 24px !important;
        padding: 0 6px !important;
        background: var(--gradient) !important;
        color: #fff !important;
        font-size: .75rem !important;
        font-weight: 700 !important;
        border-radius: 12px !important;
    }
    .mobile-page .comment-form {
        background: #fff !important;
        border-radius: 14px !important;
        padding: 20px !important;
        margin-bottom: 24px !important;
        box-shadow: 0 2px 12px rgba(0,0,0,.06) !important;
        border: 1px solid rgba(0,0,0,.05) !important;
        position: relative !important;
        overflow: visible !important;
        box-sizing: border-box !important;
        max-width: 100% !important;
    }
    .mobile-page .comment-form::before {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        height: 3px !important;
        background: var(--gradient) !important;
        border-radius: 3px 3px 0 0 !important;
    }
    .mobile-page .comment-form-row {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        margin-bottom: 10px !important;
    }
    .mobile-page .comment-input, .mobile-page .comment-textarea {
        padding: 10px 12px !important;
        border: 2px solid rgba(0,0,0,.06) !important;
        border-radius: 8px !important;
        font-size: .9rem !important;
        outline: none !important;
        transition: all .2s ease !important;
        background: #fafbfe !important;
        color: #333 !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    .mobile-page .comment-input:focus, .mobile-page .comment-textarea:focus {
        border-color: var(--primary) !important;
        background: #fff !important;
        box-shadow: 0 0 0 3px var(--primary-light) !important;
    }
    .mobile-page .comment-textarea {
        resize: vertical !important;
        min-height: 90px !important;
        line-height: 1.6 !important;
        font-family: inherit !important;
    }
    .mobile-page .comment-textarea-wrap {
        position: relative !important;
    }
    .mobile-page .emoji-bar {
        margin-top: 8px !important;
        position: relative !important;
        overflow: visible !important;
    }
    .mobile-page .emoji-toggle {
        background: none !important;
        border: 1px solid #e0e4f0 !important;
        border-radius: 6px !important;
        padding: 5px 12px !important;
        cursor: pointer !important;
        font-size: .82rem !important;
        color: #666 !important;
        transition: all .2s !important;
    }
    .mobile-page .emoji-toggle:hover {
        background: var(--primary) !important;
        color: #fff !important;
        border-color: var(--primary) !important;
    }
    .mobile-page .emoji-picker {
        position: absolute !important;
        bottom: 100% !important;
        left: 0 !important;
        background: #fff !important;
        border: 1px solid #e0e4f0 !important;
        border-radius: 10px !important;
        padding: 12px !important;
        box-shadow: 0 4px 20px rgba(0,0,0,.12) !important;
        z-index: 99999 !important;
        width: 280px !important;
        max-width: calc(100vw - 40px) !important;
        overflow: visible !important;
        margin-bottom: 0 !important;
    }
    .mobile-page .emoji-grid {
        display: grid !important;
        grid-template-columns: repeat(7, 1fr) !important;
        gap: 4px !important;
    }
    .mobile-page .emoji-item {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 30px !important;
        height: 30px !important;
        cursor: pointer !important;
        border-radius: 6px !important;
        font-size: 1.1rem !important;
        transition: background .15s !important;
    }
    .mobile-page .emoji-item:hover {
        background: var(--primary-light) !important;
    }
    .mobile-page .comment-form-actions {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        margin-top: 12px !important;
    }
    .mobile-page .comment-form-actions .btn-primary {
        padding: 10px 24px !important;
        font-size: .9rem !important;
        font-weight: 600 !important;
        border-radius: 8px !important;
        background: var(--gradient) !important;
        border: none !important;
        cursor: pointer !important;
        transition: all .2s ease !important;
    }
    .mobile-page .comment-form-actions .btn-primary:hover {
        transform: translateY(-2px) !important;
        box-shadow: 0 4px 12px var(--primary-shadow) !important;
    }
    .mobile-page .comment-msg {
        font-size: .82rem !important;
    }
    .mobile-page .comment-list {
        margin-top: 10px !important;
    }
    .mobile-page .comment-item {
        padding: 16px !important;
        margin-bottom: 12px !important;
        background: #fff !important;
        border-radius: 12px !important;
        box-shadow: 0 2px 10px rgba(0,0,0,.05) !important;
        border: 1px solid rgba(0,0,0,.04) !important;
        transition: all .2s ease !important;
        position: relative !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
        max-width: 100% !important;
    }
    .mobile-page .comment-item::before {
        content: '' !important;
        position: absolute !important;
        left: 0 !important;
        top: 0 !important;
        bottom: 0 !important;
        width: 3px !important;
        background: var(--gradient) !important;
        opacity: 0 !important;
        transition: opacity .2s ease !important;
    }
    .mobile-page .comment-item:last-child {
        margin-bottom: 0 !important;
    }
    .mobile-page .comment-item:hover {
        box-shadow: 0 4px 16px rgba(0,0,0,.08) !important;
        transform: translateY(-1px) !important;
    }
    .mobile-page .comment-item:hover::before {
        opacity: 1 !important;
    }
    .mobile-page .comment-header {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        margin-bottom: 10px !important;
    }
    .mobile-page .comment-avatar {
        width: 40px !important;
        height: 40px !important;
        border-radius: 50% !important;
        background: var(--gradient) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: #fff !important;
        font-size: .88rem !important;
        font-weight: 700 !important;
        flex-shrink: 0 !important;
        box-shadow: 0 2px 6px var(--primary-shadow) !important;
    }
    .mobile-page .comment-info {
        flex: 1 !important;
        display: flex !important;
        align-items: baseline !important;
        gap: 8px !important;
        flex-wrap: wrap !important;
    }
    .mobile-page .comment-author {
        font-weight: 600 !important;
        color: #1a1a2e !important;
        font-size: .95rem !important;
    }
    .mobile-page .comment-author a {
        color: inherit !important;
        text-decoration: none !important;
        transition: color .2s !important;
    }
    .mobile-page .comment-author a:hover {
        color: var(--primary) !important;
        text-decoration: underline !important;
    }
    .mobile-page .comment-author.admin {
        color: var(--primary) !important;
    }
    .mobile-page .comment-time {
        font-size: .75rem !important;
        color: #9ca3b8 !important;
    }
    .mobile-page .admin-badge {
        display: inline-block !important;
        padding: 1px 5px !important;
        background: var(--gradient) !important;
        color: #fff !important;
        font-size: .65rem !important;
        border-radius: 4px !important;
        margin-left: 4px !important;
        vertical-align: middle !important;
    }
    .mobile-page .comment-content {
        color: #4a5568 !important;
        font-size: .92rem !important;
        line-height: 1.7 !important;
        word-break: break-word !important;
        margin-top: 6px !important;
    }
    .mobile-page .comment-actions {
        margin-top: 8px !important;
    }
    .mobile-page .comment-reply-btn {
        background: none !important;
        border: none !important;
        color: var(--primary) !important;
        cursor: pointer !important;
        font-size: .82rem !important;
        padding: 3px 10px !important;
        border-radius: 5px !important;
        transition: all .2s ease !important;
        font-weight: 500 !important;
    }
    .mobile-page .comment-reply-btn:hover {
        background: var(--primary-light) !important;
    }
    .mobile-page .comment-replies {
        margin-top: 12px !important;
        padding: 14px !important;
        border-left: 2px dashed rgba(108,192,138,.3) !important;
        background: linear-gradient(135deg, rgba(108,192,138,.04), rgba(108,192,138,.02)) !important;
        border-radius: 10px !important;
    }
    .mobile-page .comment-replies .comment-replies {
        margin-top: 10px !important;
        padding: 12px !important;
        background: rgba(0,0,0,.02) !important;
    }
    .mobile-page .comment-reply-item {
        padding: 12px !important;
        margin-bottom: 8px !important;
        border-radius: 8px !important;
        background: #fff !important;
        border: 1px solid rgba(0,0,0,.04) !important;
        transition: all .2s ease !important;
    }
    .mobile-page .comment-reply-item:last-child {
        margin-bottom: 0 !important;
    }
    .mobile-page .comment-reply-item .comment-header {
        gap: 8px !important;
        margin-bottom: 8px !important;
    }
    .mobile-page .comment-reply-item .comment-avatar {
        width: 32px !important;
        height: 32px !important;
        font-size: .78rem !important;
    }
    .mobile-page .comment-reply-item .comment-author {
        font-size: .9rem !important;
    }
    .mobile-page .comment-reply-item .comment-content {
        font-size: .9rem !important;
        line-height: 1.65 !important;
        margin-top: 6px !important;
    }
    .mobile-page .loading-comments, .mobile-page .no-comments {
        text-align: center !important;
        color: #9ca3b8 !important;
        padding: 40px 0 !important;
        font-size: .92rem !important;
    }
    .mobile-page .comment-pagination {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 6px !important;
        margin-top: 20px !important;
    }
    .mobile-page .comment-pagination a, .mobile-page .comment-pagination span {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 32px !important;
        height: 32px !important;
        padding: 0 8px !important;
        border-radius: 8px !important;
        font-size: .85rem !important;
        font-weight: 600 !important;
        text-decoration: none !important;
        transition: all .2s ease !important;
        color: #666 !important;
        background: #f5f6fa !important;
        border: 1px solid rgba(0,0,0,.04) !important;
    }
    .mobile-page .comment-pagination a:hover {
        background: var(--gradient) !important;
        color: #fff !important;
        border-color: transparent !important;
        transform: translateY(-2px) !important;
        box-shadow: 0 4px 12px var(--primary-shadow) !important;
    }
    .mobile-page .comment-pagination span.active {
        background: var(--gradient) !important;
        color: #fff !important;
        border-color: transparent !important;
        box-shadow: 0 4px 12px var(--primary-shadow) !important;
    }
    /* 回复提示条 - 移动端间距（不控制display，由JS控制显隐） */
    .mobile-page #replyingTo {
        padding: 10px 14px !important;
        background: var(--primary-light) !important;
        border-radius: 8px !important;
        margin-bottom: 16px !important;
        margin-top: 14px !important;
        font-size: .88rem !important;
        color: var(--primary) !important;
        font-weight: 500 !important;
        border-left: 3px solid var(--primary) !important;
    }
    .mobile-page #replyingTo a {
        color: #e74c3c !important;
        text-decoration: none !important;
        font-weight: 600 !important;
        margin-left: 8px !important;
    }
    .mobile-page #replyingTo a:hover {
        text-decoration: underline !important;
    }
}

/* 登录页样式覆盖 */
.login-container { background: var(--gradient) !important; }
.login-box { box-shadow: 0 20px 60px rgba(108,192,138,.3) !important; }
.login-title { color: var(--primary) !important; }
.login-input:focus { border-color: var(--primary) !important; box-shadow: 0 0 0 3px rgba(108,192,138,.1) !important; }
.login-btn { background: var(--gradient) !important; }
.login-btn:hover { background: var(--gradient-hover) !important; }
.login-links a { color: var(--primary) !important; }
