/**
 * ForumX Plugin Styles
 * Version: 1.0.0
 */

/* FontAwesome CDN - fallback if not loaded */
@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css');

:root {
    /* Base Colors - WCAG AA compliant */
    --fx-bg: #ffffff;
    --fx-fg: #1a1a1a;                    /* Enhanced contrast from #333333 */
    --fx-accent: #b7d0db;                /* Requested accent color */
    --fx-accent-dark: #9fbcc9;           /* Darker shade of accent */
    --fx-accent-light: #4f94cd;          /* New lighter accent */
    --fx-success: #00602d;               /* WCAG AA compliant green */
    --fx-warning: #b7d0db;               /* Custom color - replacing orange */
    --fx-danger: #cc0000;                /* WCAG AA compliant red */
    --fx-info: #0073aa;                  /* Same as accent for consistency */
    
    /* Neutral Colors */
    --fx-border: #d0d0d0;                /* Enhanced from #e0e0e0 */
    --fx-light: #f6f7f8;                 /* Softer than #f8f9fa */
    --fx-muted: #5a5a5a;                 /* Enhanced contrast from #666666 */
    --fx-subtle: #8c8c8c;                /* For less important text */
    
    /* Interactive States */
    --fx-hover-bg: rgba(0, 115, 170, 0.1);
    --fx-active-bg: rgba(0, 115, 170, 0.2);
    --fx-focus-outline: #0073aa;
    --fx-focus-shadow: rgba(0, 115, 170, 0.4);
    
    /* Gradients */
    --fx-gradient-1: linear-gradient(135deg, #0073aa 0%, #005177 100%);
    --fx-gradient-2: linear-gradient(135deg, #f6f7f8 0%, #e8eaed 100%);
    --fx-gradient-hover: linear-gradient(135deg, #005177 0%, #003d5c 100%);
    
    /* Shadows */
    --fx-shadow-subtle: 0 1px 3px rgba(0, 0, 0, 0.12);
    --fx-shadow-medium: 0 4px 12px rgba(0, 0, 0, 0.15);
    --fx-shadow-strong: 0 8px 25px rgba(0, 0, 0, 0.2);
    --fx-shadow-focus: 0 0 0 3px rgba(0, 115, 170, 0.3);
    
    /* Card Styles */
    --fx-card-bg: #ffffff;
    --fx-card-border: 1px solid var(--fx-border);
    --fx-card-radius: 12px;
    --fx-card-padding: 20px;
    --fx-card-shadow: var(--fx-shadow-subtle);
    --fx-card-shadow-hover: var(--fx-shadow-medium);
    
    /* Typography */
    --fx-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    --fx-font-size-xs: 0.75rem;         /* 12px */
    --fx-font-size-sm: 0.875rem;        /* 14px */
    --fx-font-size-base: 1rem;          /* 16px */
    --fx-font-size-lg: 1.125rem;        /* 18px */
    --fx-font-size-xl: 1.25rem;         /* 20px */
    --fx-font-size-2xl: 1.5rem;         /* 24px */
    --fx-line-height-tight: 1.25;
    --fx-line-height-normal: 1.5;
    --fx-line-height-relaxed: 1.75;
    
    /* Spacing */
    --fx-space-xs: 0.25rem;             /* 4px */
    --fx-space-sm: 0.5rem;              /* 8px */
    --fx-space-md: 1rem;                /* 16px */
    --fx-space-lg: 1.5rem;              /* 24px */
    --fx-space-xl: 2rem;                /* 32px */
    --fx-space-2xl: 3rem;               /* 48px */
    
    /* Transitions */
    --fx-transition-fast: 0.15s ease-out;
    --fx-transition-normal: 0.2s ease-out;
    --fx-transition-slow: 0.3s ease-out;
    
    /* Focus styles */
    --fx-focus-ring: 0 0 0 3px var(--fx-accent-a11y);
    --fx-focus-offset: 2px;
    
    /* Breakpoints for reference */
    --fx-breakpoint-sm: 576px;
    --fx-breakpoint-md: 768px;
    --fx-breakpoint-lg: 992px;
    --fx-breakpoint-xl: 1200px;
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* Card component */
.fx-card {
    background: var(--fx-card-bg);
    border-radius: var(--fx-card-radius);
    padding: var(--fx-card-padding);
    box-shadow: var(--fx-card-shadow);
    border: var(--fx-card-border);
    transition: var(--fx-transition-normal);
}

.fx-card:hover {
    box-shadow: var(--fx-card-shadow-hover);
    transform: translateY(-1px);
}

/* Focus styles for interactive elements */
.fx-card:focus-visible,
.forumx:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
a:focus-visible {
    outline: 2px solid var(--fx-accent-a11y);
    outline-offset: var(--fx-focus-offset);
    box-shadow: var(--fx-focus-ring);
}

.forumx {
    background: var(--fx-card-bg);
    color: var(--fx-text-primary);
    font-family: var(--fx-font-family);
    font-size: var(--fx-font-size-base);
    line-height: var(--fx-line-height-normal);
}


.forumx-container {
    max-width: 100%;
    margin: 0 auto;
}

.forumx-container .forumx {
    width: 100%;
    box-sizing: border-box;
}

/* Screen reader only utility class */
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Removed excessive URL hiding rules for clarity and maintainability */

/* ForumX Feed Styles */
.forumx-feed {
    background: transparent;
    padding: var(--fx-card-padding);
    margin: var(--fx-space-lg) 0;
    box-shadow: none;
    border: none;
    border-radius: var(--fx-card-radius);
}

/* Reddit-like post card styling */
.forumx-post,
.forumx-dashboard-post {
    background: var(--fx-card-bg);
    border: var(--fx-card-border);
    border-radius: var(--fx-card-radius);
    box-shadow: var(--fx-card-shadow);
    padding: 16px;
    margin: 12px 0;
}

.forumx-post:hover,
.forumx-dashboard-post:hover {
    box-shadow: var(--fx-card-shadow-hover);
}

.forumx-post-voting .forumx-vote-btn,
.forumx-post-voting .forumx-vote-btn-reddit {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.forumx-vote-score,
.forumx-vote-score-reddit {
    font-weight: 600;
    min-width: 28px;
    text-align: center;
}

.forumx-share-btn,
.forumx-report-btn,
.forumx-post-delete-btn,
.forumx-btn {
    border-radius: 8px;
    padding: 6px 10px;
    transition: background var(--fx-transition-fast), color var(--fx-transition-fast), box-shadow var(--fx-transition-fast);
}

.forumx-share-btn:hover,
.forumx-report-btn:hover,
.forumx-post-delete-btn:hover,
.forumx-btn:hover {
    background: var(--fx-hover-bg);
}

/* Feed content scrollable area */
.forumx-feed-content {
    max-height: 800px;
    overflow-y: auto;
    padding-right: 8px;
    scrollbar-width: thin;
    scrollbar-color: var(--fx-border) transparent;
}

/* Custom scrollbar for webkit browsers */
.forumx-feed-content::-webkit-scrollbar {
    width: 8px;
}

.forumx-feed-content::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}

.forumx-feed-content::-webkit-scrollbar-thumb {
    background: var(--fx-border);
    border-radius: 4px;
    transition: background 0.2s ease;
}

.forumx-feed-content::-webkit-scrollbar-thumb:hover {
    background: var(--fx-accent);
}

.forumx-feed-header {
    margin-bottom: 25px;
    padding-bottom: 15px;
    border-bottom: 2px solid #e0e0e0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
}

/* Feed Filter Buttons */
.forumx-feed-filters {
    display: flex;
    gap: 8px;
    align-items: center;
}

.forumx-filter-btn {
    background: transparent;
    border: 2px solid var(--fx-border);
    border-radius: 8px;
    padding: 8px 16px;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 500;
    color: var(--fx-muted);
}

.forumx-filter-btn:hover {
    border-color: var(--fx-accent);
    background: rgba(0, 115, 170, 0.1);
    color: var(--fx-accent);
}

.forumx-filter-btn.active {
    background: var(--fx-accent);
    border-color: var(--fx-accent);
    color: white;
}

.forumx-filter-btn .dashicons {
    font-size: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.forumx-feed-header h2 {
    margin: 0 0 8px 0;
    font-size: var(--fx-font-size-2xl);
    color: var(--fx-text-primary);
    font-weight: 700;
    line-height: var(--fx-line-height-tight);
}

.forumx-feed-meta {
    font-size: var(--fx-font-size-sm);
    color: var(--fx-text-secondary);
    font-weight: 500;
}

.forumx-post {
    background: var(--fx-card-bg);
    border: var(--fx-card-border);
    border-radius: var(--fx-card-radius);
    margin-bottom: var(--fx-space-lg);
    padding: var(--fx-card-padding);
    box-shadow: var(--fx-card-shadow);
    transition: var(--fx-transition-normal);
}

.forumx-post:hover {
    box-shadow: var(--fx-card-shadow-hover);
    transform: translateY(-1px);
    border-color: var(--fx-border-focus);
}

.forumx-post:focus-within {
    border-color: var(--fx-accent-a11y);
    box-shadow: var(--fx-focus-ring);
    outline: none;
}

.forumx-post-header {
    margin-bottom: 15px;
}

.forumx-post-title {
    margin: 0 0 var(--fx-space-sm) 0;
    font-size: var(--fx-font-size-xl);
    line-height: var(--fx-line-height-tight);
    font-weight: 600;
}

.forumx-post-title a {
    color: var(--fx-text-primary);
    text-decoration: none;
    transition: var(--fx-transition-normal);
}

.forumx-post-title a:hover {
    color: var(--fx-accent);
    text-decoration: underline;
}

.forumx-post-title a:focus-visible {
    color: var(--fx-accent);
    text-decoration: underline;
    outline: 2px solid var(--fx-accent-a11y);
    outline-offset: var(--fx-focus-offset);
}

.forumx-post-community {
    font-size: var(--fx-font-size-sm);
    color: var(--fx-text-secondary);
    display: flex;
    align-items: center;
    gap: 6px;
}

.forumx-post-community .forumx-community-icon,
.forumx-post-community .forumx-community-icon.fa {
    border-radius: 50%;
    object-fit: cover;
}

.forumx-community-label strong {
    color: var(--fx-accent);
    font-weight: 600;
}

.forumx-post-excerpt {
    margin: var(--fx-space-md) 0;
    color: var(--fx-text-secondary);
    line-height: var(--fx-line-height-relaxed);
}

/* Post Meta - Right aligned in footer */
.forumx-post-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--fx-space-lg);
    align-items: center;
    margin-left: auto;
    text-align: right;
}

.forumx-meta-label {
    font-weight: 500;
}

.forumx-author-name {
    color: var(--fx-accent);
    font-weight: 600;
}

.forumx-comment-count {
    font-weight: 500;
}

.forumx-post-time {
    color: var(--fx-muted);
    font-size: var(--fx-font-size-xs);
    font-weight: 400;
}

.forumx-no-posts {
    text-align: center;
    color: var(--fx-text-secondary);
    font-style: italic;
    padding: var(--fx-space-2xl) var(--fx-space-lg);
}

/* ForumX Thread Styles */
.forumx-thread {
    background: none;
    padding: 0;
    margin: 0;
    border: none;
    box-shadow: none;
}

.forumx-thread-header {
    margin-bottom: 30px;
    padding-bottom: 15px;
    border-bottom: 2px solid #e0e0e0;
}

.forumx-breadcrumb {
    font-size: var(--fx-font-size-sm);
    color: var(--fx-text-secondary);
}

.forumx-breadcrumb-community {
    color: var(--fx-accent);
    font-weight: 600;
}

.forumx-breadcrumb-separator {
    margin: 0 8px;
}

.forumx-breadcrumb-current {
    color: var(--fx-text-primary);
    font-weight: 500;
}

.forumx-main-post {
    background: var(--fx-card-bg);
    border: var(--fx-card-border);
    border-radius: var(--fx-card-radius);
    padding: var(--fx-space-2xl);
    margin-bottom: var(--fx-space-2xl);
    box-shadow: var(--fx-card-shadow);
}

.forumx-thread-title {
    margin: 0 0 var(--fx-space-lg) 0;
    font-size: 1.75rem;
    line-height: var(--fx-line-height-tight);
    color: var(--fx-text-primary);
    font-weight: 700;
}

.forumx-main-post .forumx-post-meta {
    margin-bottom: 20px;
    padding-bottom: 20px;
}

.forumx-post-content {
    line-height: var(--fx-line-height-relaxed);
    color: var(--fx-text-primary);
}

.forumx-post-content h1,
.forumx-post-content h2,
.forumx-post-content h3,
.forumx-post-content h4,
.forumx-post-content h5,
.forumx-post-content h6 {
    color: var(--fx-text-primary);
    margin-top: 1.5em;
    margin-bottom: 0.5em;
    font-weight: 600;
}

.forumx-post-content p {
    margin-bottom: 1em;
}

.forumx-post-content ul,
.forumx-post-content ol {
    margin: 1em 0;
    padding-left: 2em;
}

.forumx-post-content blockquote {
    margin: 1.5em 0;
    padding: var(--fx-space-md) var(--fx-space-lg);
    background: var(--fx-surface-light);
    border-left: 4px solid var(--fx-accent);
    border-radius: 0 var(--fx-card-radius) var(--fx-card-radius) 0;
    color: var(--fx-text-secondary);
    font-style: italic;
}

.forumx-comments {
    margin-top: 40px;
}

/* Error Styles */
.forumx-error {
    background-color: #ffebee;
    color: #c62828;
    border: 2px solid #ef5350;
    padding: 15px;
    border-radius: var(--fx-border-radius);
    font-weight: 500;
    text-align: center;
}

/* Focus Indicators (Accessibility) */
.forumx a:focus,
.forumx button:focus,
.forumx input:focus-visible,
.forumx textarea:focus-visible,
.forumx select:focus-visible {
    outline: 2px solid var(--fx-accent-a11y);
    outline-offset: var(--fx-focus-offset);
    box-shadow: var(--fx-focus-ring);
}

.forumx [tabindex="0"]:focus-visible {
    outline: 2px solid var(--fx-accent-a11y);
    outline-offset: var(--fx-focus-offset);
    box-shadow: var(--fx-focus-ring);
}

/* High Contrast Support */
@media (prefers-contrast: high) {
    .forumx-post {
        border-color: #000000;
    }
    
    .forumx-post-title a {
        color: #000000;
    }
    
    .forumx-post-title a:hover,
    .forumx-post-title a:focus {
        color: #000000;
        background-color: #ffff00;
    }
    
    .forumx-meta-label,
    .forumx-author-name,
    .forumx-community-label strong {
        color: #000000;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    .forumx,
    .forumx-post,
    .forumx-post-title a {
        transition: none;
    }
}

/* Report Button Styles */
.forumx-post-actions {
    margin-left: auto;
}

.forumx-report-btn,
.forumx-post-delete-btn {
    background: rgba(183, 208, 219, 0.12);
    border: 1px solid rgba(183, 208, 219, 0.25);
    color: #e5e7eb;
    font-size: 12px;
    cursor: pointer;
    padding: 6px 10px;
    border-radius: 20px;
    transition: all 0.2s ease;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-weight: 500;
    text-decoration: none;
}

.forumx-report-btn:hover:not(:disabled),
.forumx-post-delete-btn:hover:not(:disabled) {
    color: #b7d0db;
    background: rgba(183, 208, 219, 0.2);
    border-color: rgba(183, 208, 219, 0.45);
    transform: translateY(-1px);
}

.forumx-report-btn:disabled,
.forumx-post-delete-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    color: rgba(229, 229, 229, 0.7);
    background: rgba(183, 208, 219, 0.08);
    border-color: rgba(183, 208, 219, 0.25);
}

.forumx-report-btn .fa,
.forumx-report-btn .dashicons,
.forumx-post-delete-btn .dashicons {
    font-size: 12px;
    width: 12px;
    height: 12px;
}

.forumx-report-text {
    font-size: 11px;
    font-weight: 500;
    color: #b7d0db;
}

/* Report Modal Styles */
.forumx-report-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 10000;
    padding: var(--fx-space-lg);
    box-sizing: border-box;
    backdrop-filter: blur(4px);
    animation: fadeIn 0.3s ease-out;
}

.forumx-report-modal.active {
    display: flex;
}

.forumx-report-modal-content {
    background: var(--fx-card-bg);
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    max-width: 480px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    animation: slideInScale 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    border: 1px solid var(--fx-border);
}

@keyframes slideInScale {
    from {
        opacity: 0;
        transform: scale(0.8) translateY(40px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.forumx-report-modal-header {
    padding: 24px 30px 20px;
    border-bottom: 1px solid var(--fx-border);
    background: linear-gradient(135deg, #ff5252 0%, #e53e3e 100%);
    border-radius: 16px 16px 0 0;
    color: white;
    position: relative;
}

.forumx-report-modal-title {
    margin: 0;
    font-size: 20px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 12px;
}

.forumx-report-modal-title .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    opacity: 0.9;
}

.forumx-report-modal-close {
    position: absolute;
    top: 20px;
    right: 24px;
    background: rgba(255, 255, 255, 0.2);
    border: none;
    color: white;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    font-size: 18px;
}

.forumx-report-modal-close:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: scale(1.1);
}

.forumx-report-modal-body {
    padding: 30px;
}

.forumx-report-form-group {
    margin-bottom: 24px;
}

.forumx-report-form-group label {
    display: block;
    margin-bottom: 10px;
    font-weight: 600;
    color: var(--fx-fg);
    font-size: 15px;
}

.forumx-report-form-group .required {
    color: #dc3545;
    margin-left: 3px;
}

.forumx-report-select {
    width: 100%;
    padding: 12px 16px;
    border: 2px solid var(--fx-border);
    border-radius: 10px;
    font-size: 15px;
    font-family: inherit;
    background: var(--fx-card-bg);
    color: var(--fx-fg);
    transition: all 0.3s ease;
    cursor: pointer;
    box-sizing: border-box;
}

.forumx-report-select:focus {
    outline: none;
    border-color: #ff5252;
    box-shadow: 0 0 0 3px rgba(255, 82, 82, 0.1);
    transform: translateY(-1px);
}

.forumx-report-textarea {
    width: 100%;
    min-height: 100px;
    padding: 12px 16px;
    border: 2px solid var(--fx-border);
    border-radius: 10px;
    font-size: 15px;
    font-family: inherit;
    background: var(--fx-card-bg);
    color: var(--fx-fg);
    resize: vertical;
    transition: all 0.3s ease;
    box-sizing: border-box;
    line-height: 1.5;
}

.forumx-report-textarea:focus {
    outline: none;
    border-color: #ff5252;
    box-shadow: 0 0 0 3px rgba(255, 82, 82, 0.1);
    transform: translateY(-1px);
}

.forumx-report-textarea::placeholder {
    color: var(--fx-muted);
    opacity: 0.7;
}

.forumx-report-warning {
    background: linear-gradient(135deg, #f0f7f8 0%, #e8f3f5 100%);
    border: 1px solid #b7d0db;
    border-radius: 8px;
    padding: 12px 16px;
    margin: 20px 0;
    font-size: 13px;
    color: #b7d0db;
    line-height: 1.4;
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.forumx-report-warning .dashicons {
    color: #b7d0db;
    font-size: 16px;
    width: 16px;
    height: 16px;
    margin-top: 1px;
    flex-shrink: 0;
}

.forumx-report-modal-footer {
    padding: 20px 30px 30px;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    border-top: 1px solid var(--fx-border);
    background: var(--fx-light);
    border-radius: 0 0 16px 16px;
}

.forumx-report-submit-btn,
.forumx-report-cancel-btn {
    padding: 12px 24px;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    border: 2px solid;
    min-width: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.forumx-report-submit-btn {
    background: linear-gradient(135deg, #ff5252 0%, #e53e3e 100%);
    color: white;
    border-color: #ff5252;
}

.forumx-report-submit-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, #e53e3e 0%, #c62828 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(255, 82, 82, 0.3);
}

.forumx-report-submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.forumx-report-submit-btn.loading {
    position: relative;
}

.forumx-report-submit-btn.loading::after {
    content: '';
    position: absolute;
    right: 8px;
    width: 16px;
    height: 16px;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.forumx-report-cancel-btn {
    background: transparent;
    color: var(--fx-muted);
    border-color: var(--fx-border);
}

.forumx-report-cancel-btn:hover {
    background: var(--fx-light);
    color: var(--fx-fg);
    border-color: var(--fx-muted);
    transform: translateY(-1px);
}

/* Responsive adjustments for report modal */
@media (max-width: 600px) {
    .forumx-report-modal {
        padding: var(--fx-space-md);
    }
    
    .forumx-report-modal-content {
        max-width: 100%;
        border-radius: 12px;
    }
    
    .forumx-report-modal-header {
        padding: 20px 24px 16px;
        border-radius: 12px 12px 0 0;
    }
    
    .forumx-report-modal-title {
        font-size: 18px;
    }
    
    .forumx-report-modal-body {
        padding: 24px 20px;
    }
    
    .forumx-report-modal-footer {
        padding: 16px 20px 20px;
        flex-direction: column-reverse;
        border-radius: 0 0 12px 12px;
    }
    
    .forumx-report-submit-btn,
    .forumx-report-cancel-btn {
        width: 100%;
        justify-content: center;
    }
}

/* High contrast support for modal */
@media (prefers-contrast: high) {
    .forumx-report-modal-header {
        background: #dc3545;
    }
    
    .forumx-report-select,
    .forumx-report-textarea {
        border-color: #000000;
    }
    
    .forumx-report-submit-btn {
        background: #dc3545;
        border-color: #dc3545;
    }
}

/* Reduced motion support for modal */
@media (prefers-reduced-motion: reduce) {
    .forumx-report-modal,
    .forumx-report-modal-content {
        animation: none;
    }
    
    .forumx-report-modal-content {
        transform: none;
    }
    
    .forumx-report-select:focus,
    .forumx-report-textarea:focus {
        transform: none;
    }
}

/* Post meta styling moved to line 254 */

/* Elementor Widget Styles */
.forumx-elementor-widget {
    width: 100%;
}

.forumx-elementor-widget .forumx-feed {
    background: none;
    padding: 0;
    margin: 0;
    border: none;
    box-shadow: none;
}

.forumx-elementor-widget .forumx-feed-header {
    margin-bottom: 20px;
}

.forumx-elementor-widget .forumx-post {
    margin-bottom: 20px;
}

/* Elementor Editor Styles */
.elementor-editor-active .forumx-elementor-widget {
    min-height: 100px;
}

.elementor-forumx-preview {
    background: #f8f9fa;
    border: 2px dashed #dee2e6;
    padding: 20px;
    text-align: center;
    border-radius: 8px;
}

.elementor-forumx-preview h3 {
    margin-top: 0;
    color: #007cba;
    font-size: 18px;
}

.forumx-preview-settings {
    background: #ffffff;
    border: 1px solid #dee2e6;
    border-radius: 4px;
    padding: 15px;
    margin: 15px 0;
    text-align: left;
}

.forumx-preview-settings p {
    margin: 5px 0;
    font-size: 14px;
}

.forumx-preview-note {
    font-size: 12px;
    color: #666;
    margin-top: 10px;
}

/* Responsive Design */
@media (max-width: 768px) {
    .forumx-post {
        padding: 15px;
        margin-bottom: 15px;
    }
    
    .forumx-main-post {
        padding: 20px;
    }
    
    .forumx-thread-title {
        font-size: 1.5rem;
    }
    
    .forumx-post-footer {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    
    .forumx-post-meta {
        margin-left: 0;
        text-align: left;
        justify-content: space-between;
    }
    
    .forumx-post-voting {
        justify-content: center;
        padding: 8px 0;
        border-top: 1px solid var(--fx-border);
        margin-top: 8px;
    }
}

/* Post Footer Layout */
.forumx-post-footer {
    padding-top: var(--fx-space-md);
    border-top: 1px solid var(--fx-border);
    font-size: var(--fx-font-size-sm);
    color: var(--fx-text-secondary);
}

/* Post Interactions Row */
.forumx-post-interactions {
    display: flex;
    align-items: center;
    gap: var(--fx-space-lg);
    margin-bottom: var(--fx-space-sm);
    padding-bottom: var(--fx-space-sm);
    border-bottom: 1px solid rgba(0, 115, 170, 0.1);
}

/* Voting Styles - Repositioned */
.forumx-post-voting {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

/* Post Stats */
.forumx-post-stats {
    display: flex;
    align-items: center;
    gap: var(--fx-space-md);
}

.forumx-comments-indicator {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--fx-muted);
    font-size: var(--fx-font-size-sm);
}

.forumx-comments-indicator .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

/* Share Button */
.forumx-post-share {
    margin-left: auto;
}

.forumx-share-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1px solid var(--fx-border);
    color: var(--fx-muted);
    padding: 8px 12px;
    border-radius: 20px;
    font-size: var(--fx-font-size-xs);
    font-weight: 500;
    cursor: pointer;
    transition: var(--fx-transition-normal);
    min-height: 32px;
}

.forumx-share-btn:hover {
    color: var(--fx-accent);
    border-color: var(--fx-accent);
    background: rgba(0, 115, 170, 0.05);
    transform: translateY(-1px);
}

.forumx-share-btn .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

.forumx-share-text {
    font-weight: 500;
}

/* Mobile compact actions */
@media (max-width: 480px) {
  .forumx-share-text { display: none; }
  .forumx-share-btn { padding: 8px; min-width: 36px; }
  .forumx-comments-text { display: none; }
  .forumx-post-interactions { flex-wrap: wrap; gap: 10px; }
}

.forumx-vote-btn {
    background: #f8f8f8;
    border: 1px solid #ddd;
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: var(--fx-transition);
    color: #666;
}

.forumx-vote-btn:hover {
    background: #e8e8e8;
    border-color: #ccc;
    transform: translateY(-1px);
}

.forumx-vote-btn:active {
    transform: translateY(0);
}

.forumx-vote-btn.active {
    background: var(--fx-bg);
    border-color: var(--fx-bg-hover);
    color: var(--fx-fg);
}

.forumx-vote-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.forumx-vote-btn.loading {
    position: relative;
}

.forumx-vote-btn.loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 16px;
    height: 16px;
    margin: -8px 0 0 -8px;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.forumx-vote-score {
    font-weight: 600;
    color: #333;
    min-width: 30px;
    text-align: center;
    font-size: 14px;
}

.forumx-vote-up.active {
    background: var(--fx-accent);
    border-color: var(--fx-accent-hover);
}

.forumx-vote-down.active {
    background: #dc3545;
    border-color: #c82333;
}

/* Loading Styles */
.forumx-loading {
    text-align: center;
    padding: 40px 20px;
    color: #666;
    font-style: italic;
}

.forumx-loading .dashicons {
    animation: spin 1s linear infinite;
    margin-right: 8px;
}

/* Vote Messages */
.forumx-vote-message,
.forumx-vote-error {
    margin: 10px 0;
    padding: 8px 12px;
    border-radius: 4px;
    font-size: 14px;
    line-height: 1.4;
}

.forumx-login-required {
    background: #e1f5fe;
    color: #0277bd;
    border: 1px solid #b3e5fc;
}

.forumx-login-required a {
    color: #0277bd;
    text-decoration: underline;
}

.forumx-login-required a:hover {
    color: #01579b;
}

.forumx-vote-error {
    background: #ffebee;
    color: #c62828;
    border: 1px solid #ffcdd2;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* Create Post Form Styles */
.forumx-create-container {
    max-width: 800px;
    margin: 20px auto;
    background: #ffffff;
    border: 1px solid #e0e0e0;
    border-radius: var(--fx-border-radius);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.forumx-create-header {
    padding: 20px 30px;
    border-bottom: 1px solid #e0e0e0;
    background: #f8f9fa;
    border-radius: var(--fx-border-radius) var(--fx-border-radius) 0 0;
}

.forumx-create-header h2 {
    margin: 0;
    color: #333;
    font-size: 1.5rem;
}

.forumx-create-form {
    padding: 30px;
}

.forumx-form-group {
    margin-bottom: 20px;
}

.forumx-form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: #333;
    font-size: 14px;
}

.forumx-form-group .required {
    color: #dc3545;
}

.forumx-form-group input[type="text"],
.forumx-form-group textarea,
.forumx-form-group select {
    width: 100%;
    padding: 12px 15px;
    border: 2px solid #e0e0e0;
    border-radius: 6px;
    font-size: 14px;
    font-family: inherit;
    transition: var(--fx-transition);
    box-sizing: border-box;
}

.forumx-form-group input[type="text"]:focus,
.forumx-form-group textarea:focus,
.forumx-form-group select:focus {
    outline: none;
    border-color: var(--fx-bg);
    box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
}

.forumx-form-group input[type="text"]:invalid,
.forumx-form-group textarea:invalid,
.forumx-form-group select:invalid {
    border-color: #dc3545;
}

.forumx-form-group textarea {
    min-height: 120px;
    resize: vertical;
    line-height: 1.5;
}

.forumx-field-help {
    margin-top: 6px;
    font-size: 13px;
    color: #666;
    line-height: 1.4;
}

.forumx-form-actions {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px solid #e0e0e0;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.forumx-submit-btn,
.forumx-cancel-btn {
    padding: 12px 24px;
    border: 2px solid;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--fx-transition);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 120px;
}

.forumx-submit-btn {
    background: var(--fx-bg);
    color: var(--fx-fg);
    border-color: var(--fx-bg);
}

.forumx-submit-btn:hover:not(:disabled) {
    background: var(--fx-bg-hover);
    border-color: var(--fx-bg-hover);
    transform: translateY(-1px);
}

.forumx-submit-btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.forumx-submit-btn.loading {
    position: relative;
}

.forumx-submit-btn.loading::after {
    content: '';
    position: absolute;
    right: 8px;
    width: 16px;
    height: 16px;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.forumx-cancel-btn {
    background: transparent;
    color: #666;
    border-color: #ddd;
}

.forumx-cancel-btn:hover:not(:disabled) {
    background: #f8f9fa;
    color: #333;
    border-color: #ccc;
}

.forumx-messages {
    margin-top: 20px;
}

.forumx-message {
    padding: 15px 20px;
    border-radius: 6px;
    margin-bottom: 15px;
    border: 1px solid;
}

.forumx-message.forumx-error {
    background: #ffebee;
    color: #c62828;
    border-color: #ffcdd2;
}

.forumx-message.forumx-success {
    background: #e8f5e8;
    color: #2e7d32;
    border-color: #c8e6c9;
}

.forumx-message h4 {
    margin: 0 0 8px 0;
    font-size: 16px;
}

.forumx-message ul {
    margin: 8px 0 0 20px;
    padding: 0;
}

.forumx-message li {
    margin-bottom: 4px;
}

.forumx-view-post-btn {
    display: inline-block;
    padding: 8px 16px;
    background: var(--fx-accent);
    color: white;
    text-decoration: none;
    border-radius: 4px;
    font-weight: 500;
    margin-top: 8px;
    transition: var(--fx-transition);
}

.forumx-view-post-btn:hover {
    background: var(--fx-accent-hover);
    color: white;
    text-decoration: none;
}

/* ForumX Message Styles */
.forumx-message {
    padding: 12px 16px;
    margin: 15px 0;
    border-radius: 6px;
    border: 1px solid;
    font-size: 14px;
    line-height: 1.4;
}

.forumx-message.forumx-error {
    background: #ffebee;
    color: #c62828;
    border-color: #ffcdd2;
}

.forumx-message.forumx-success {
    background: #e8f5e8;
    color: #2e7d32;
    border-color: #c8e6c9;
}

.forumx-message.forumx-info {
    background: #e1f5fe;
    color: #0277bd;
    border-color: #b3e5fc;
}

/* User Info Styles */
.forumx-user-info {
    max-width: 450px;
    margin: 20px auto;
    padding: 20px;
    background: #e8f5e8;
    color: #2e7d32;
    border: 1px solid #c8e6c9;
    border-radius: var(--fx-border-radius);
    text-align: center;
}

.forumx-user-info p {
    margin: 8px 0;
}

.forumx-user-info a {
    color: #1b5e20;
    text-decoration: none;
    font-weight: 500;
}

.forumx-user-info a:hover {
    color: #0d4613;
    text-decoration: underline;
}

.forumx-logout-btn {
    padding: 8px 16px;
    background: #dc3545;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: var(--fx-transition);
}

.forumx-logout-btn:hover:not(:disabled) {
    background: #c82333;
}

.forumx-logout-btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

/* Authentication Form Styles */
.forumx-login-container,
.forumx-register-container {
    max-width: 400px;
    margin: 20px auto;
    background: #ffffff;
    border: 1px solid #e0e0e0;
    border-radius: var(--fx-border-radius);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.forumx-auth-header {
    padding: 20px 30px;
    border-bottom: 1px solid #e0e0e0;
    background: #f8f9fa;
    border-radius: var(--fx-border-radius) var(--fx-border-radius) 0 0;
    text-align: center;
}

.forumx-auth-header h2 {
    margin: 0;
    color: #333;
    font-size: 1.5rem;
}

.forumx-auth-form {
    padding: 30px;
}

.forumx-checkbox-group {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

.forumx-checkbox-group label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    cursor: pointer;
    font-weight: normal;
}

.forumx-checkbox-group input[type="checkbox"] {
    margin: 0;
    width: auto;
    min-width: 16px;
    height: 16px;
    margin-top: 2px;
}

.forumx-checkbox-label {
    font-size: 14px;
    line-height: 1.4;
    color: #333;
}

.forumx-auth-links {
    padding: 20px 30px;
    border-top: 1px solid #e0e0e0;
    background: #fafafa;
    border-radius: 0 0 var(--fx-border-radius) var(--fx-border-radius);
    text-align: center;
}

.forumx-auth-links p {
    margin: 8px 0;
    font-size: 14px;
    color: #666;
}

.forumx-auth-links a {
    color: var(--fx-bg);
    text-decoration: none;
    font-weight: 500;
}

.forumx-auth-links a:hover {
    color: var(--fx-bg-hover);
    text-decoration: underline;
}

.forumx-user-info {
    max-width: 400px;
    margin: 20px auto;
    padding: 20px;
    background: #e8f5e8;
    color: #2e7d32;
    border: 1px solid #c8e6c9;
    border-radius: var(--fx-border-radius);
    text-align: center;
}

.forumx-user-info p {
    margin: 8px 0;
}

.forumx-user-info a {
    color: #1b5e20;
    text-decoration: none;
    font-weight: 500;
}

.forumx-user-info a:hover {
    color: #0d4613;
    text-decoration: underline;
}

/* Responsive Authentication Forms */
@media (max-width: 768px) {
    .forumx-login-container,
    .forumx-register-container {
        max-width: 100%;
        margin: 10px;
        border-radius: 0;
    }
    
    .forumx-auth-form {
        padding: 20px;
    }
    
    .forumx-auth-header,
    .forumx-auth-links {
        padding: 15px 20px;
    }
    
    .forumx-user-info {
        max-width: 100%;
        margin: 10px;
        border-radius: 0;
    }
}

/* Print Styles */
@media print {
    .forumx-post,
    .forumx-main-post {
        border: 1px solid #000000;
        box-shadow: none;
    }
    
    .forumx-post-title a,
    .forumx-author-name,
    .forumx-community-label strong {
        color: #000000 !important;
    }
    
    .forumx-post-voting,
    .forumx-loading {
        display: none;
    }
}

/* Unified Authentication Interface */
.forumx-auth-container {
    max-width: 450px;
    margin: 30px auto;
    background: var(--fx-bg);
    border: 1px solid var(--fx-border);
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 124, 186, 0.1);
    overflow: hidden;
    position: relative;
}

.forumx-auth-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--fx-accent), var(--fx-accent-dark));
}

.forumx-auth-toggle {
    display: flex;
    background: var(--fx-light);
    position: relative;
}

.forumx-tab-btn {
    flex: 1;
    padding: 18px 20px;
    border: none;
    background: transparent;
    color: #9ca3af;
    cursor: pointer;
    font-size: 16px;
    font-weight: 600;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    border-radius: 0;
}

.forumx-tab-btn.active {
    color: #0f172a;
    background: #b7d0db;
    transform: translateY(-1px);
}

.forumx-tab-btn.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 60%;
    height: 3px;
    background: linear-gradient(90deg, #8fb8c9, #b7d0db);
    border-radius: 2px 2px 0 0;
}

.forumx-tab-btn:hover:not(.active) {
    color: #e5e7eb;
    background: rgba(183, 208, 219, 0.12);
}

.forumx-auth-panel {
    display: none;
    padding: 30px;
    animation: fadeIn 0.3s ease-in;
}

.forumx-auth-panel.active {
    display: block;
}

.forumx-auth-form .forumx-form-group {
    margin-bottom: 24px;
}

.forumx-auth-form label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: var(--fx-fg);
    font-size: 14px;
}

.forumx-auth-form .required {
    color: #dc3545;
}

.forumx-auth-form input[type="text"],
.forumx-auth-form input[type="email"],
.forumx-auth-form input[type="password"] {
    width: 100%;
    padding: 14px 16px;
    border: 2px solid var(--fx-border);
    border-radius: 8px;
    font-size: 15px;
    font-family: inherit;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-sizing: border-box;
    background: var(--fx-bg);
}

.forumx-auth-form input:focus {
    outline: none;
    border-color: var(--fx-accent);
    box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
    transform: translateY(-1px);
}

.forumx-auth-form input:valid {
    border-color: #28a745;
}

.forumx-field-help {
    margin-top: 6px;
    font-size: 13px;
    color: var(--fx-muted);
    line-height: 1.4;
}

.forumx-auth-form .forumx-form-actions {
    margin-top: 30px;
}

.forumx-auth-form .forumx-submit-btn {
    width: 100%;
    padding: 14px 20px;
    background: linear-gradient(135deg, #c7deeb, #b7d0db);
    color: #102029;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.forumx-auth-form .forumx-submit-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(183, 208, 219, 0.35);
}

.forumx-auth-form .forumx-submit-btn:active {
    transform: translateY(0);
}

.forumx-auth-form .forumx-submit-btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.forumx-auth-form .forumx-submit-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.5s;
}

.forumx-auth-form .forumx-submit-btn:hover:not(:disabled)::before {
    left: 100%;
}

.forumx-auth-links {
    text-align: center;
    margin-top: 25px;
    padding-top: 20px;
    border-top: 1px solid var(--fx-border);
}

.forumx-auth-links p {
    margin: 0;
    color: var(--fx-muted);
    font-size: 14px;
}

/* --- Unified Auth Modal Theme --- */
#forumx-auth-modal .forumx-modal-content {
    background: #212121;
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #f5f5f5;
}

#forumx-auth-modal .forumx-modal-header {
    border-color: #2f2f2f;
}

#forumx-auth-modal .forumx-modal-body {
    color: #f5f5f5;
}

#forumx-auth-modal .forumx-modal-title,
#forumx-auth-modal .forumx-auth-context {
    color: #b7d0db;
}

#forumx-auth-modal .forumx-auth-container {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    overflow: hidden;
}

#forumx-auth-modal .forumx-auth-toggle {
    background: #2a2a2a;
    border-bottom: 1px solid #333333;
}

#forumx-auth-modal .forumx-auth-panel {
    background: transparent;
}

#forumx-auth-modal label {
    color: #e5e5e5;
}

#forumx-auth-modal .forumx-form-help,
#forumx-auth-modal .forumx-form-link {
    color: #cbd5f5;
}

#forumx-auth-modal input,
#forumx-auth-modal select,
#forumx-auth-modal textarea {
    background: #2c2c2c;
    border: 1px solid #3d3d3d;
    color: #ffffff;
}

#forumx-auth-modal input::placeholder,
#forumx-auth-modal textarea::placeholder {
    color: #9ca3af;
}

#forumx-auth-modal .forumx-submit-btn {
    background: linear-gradient(135deg, #c7deeb, #b7d0db);
    color: #102029;
    border: none;
}

#forumx-auth-modal .forumx-submit-btn:hover:not(:disabled) {
    box-shadow: 0 6px 16px rgba(183, 208, 219, 0.35);
}

#forumx-auth-modal .forumx-message {
    background: rgba(183, 208, 219, 0.08);
    border: 1px solid rgba(183, 208, 219, 0.25);
    color: #f8fafc;
}

#forumx-auth-modal .forumx-message.forumx-error {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.18);
    color: #fefefe;
}

#forumx-auth-modal .forumx-message.forumx-success {
    background: rgba(183, 208, 219, 0.12);
    border-color: rgba(183, 208, 219, 0.35);
    color: #e7f2f8;
}

#forumx-auth-modal .forumx-tab-btn.active {
    color: #102029;
    background: #b7d0db;
}

#forumx-auth-modal .forumx-tab-btn:hover:not(.active) {
    color: #f5f5f5;
    background: rgba(183, 208, 219, 0.12);
}

#forumx-auth-modal .forumx-auth-loading {
    color: #e5e5e5;
}

/* Password reveal toggle */
.forumx-password-field {
    position: relative;
    display: flex;
    align-items: center;
}

.forumx-password-field input[type="password"],
.forumx-password-field input[type="text"] {
    padding-right: 44px;
}

.forumx-password-toggle {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: 1px solid rgba(183, 208, 219, 0.25);
    border-radius: 50%;
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #d1d5db;
    transition: all 0.2s ease;
}

.forumx-password-toggle:hover,
.forumx-password-toggle:focus {
    background: rgba(183, 208, 219, 0.12);
    border-color: rgba(183, 208, 219, 0.45);
    color: #f9fafb;
}

.forumx-eye-icon {
    font-size: 16px;
    line-height: 1;
}

/* Auth dependent visibility helper */
[data-auth-visible][hidden] {
    display: none !important;
}

.forumx-auth-required,
.forumx-login-prompt-section,
.forumx-login-prompt-card,
.forumx-comment-login-required {
    background: #212121;
    border: 1px solid #2f2f2f;
    border-radius: 12px;
    color: #f5f5f5;
    padding: 24px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
}

.forumx-login-prompt-section .forumx-login-prompt h3,
.forumx-auth-required h3 {
    color: #b7d0db;
}

.forumx-login-prompt-section .forumx-login-prompt p,
.forumx-auth-required p,
.forumx-comment-login-required p {
    color: rgba(229, 229, 229, 0.85);
}

.forumx-login-prompt-section .forumx-btn-primary,
.forumx-auth-required .forumx-btn-primary,
.forumx-comment-login-required .forumx-btn-primary {
    background: #b7d0db;
    color: #102029;
    border: 1px solid rgba(183, 208, 219, 0.45);
    padding: 10px 22px;
    border-radius: 999px;
}

.forumx-login-prompt-section .forumx-btn-primary:hover,
.forumx-auth-required .forumx-btn-primary:hover,
.forumx-comment-login-required .forumx-btn-primary:hover {
    background: #c7deeb;
}

.forumx-login-prompt-section .forumx-login-prompt .dashicons,
.forumx-auth-required .dashicons {
    color: #102029;
}

/* Ensure headings inside modal use accent color */
#forumx-auth-modal h3,
#forumx-auth-modal h4,
#forumx-auth-modal h5 {
    color: #b7d0db;
}

.forumx-auth-links a {
    color: var(--fx-accent);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s ease;
}

.forumx-auth-links a:hover {
    color: var(--fx-accent-dark);
    text-decoration: underline;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Dark Mode for Authentication - ALWAYS Dark Gray */
/* Force dark theme for ALL auth containers */
.forumx-auth-container {
    background: #2A2A2A !important;
    border: 1px solid #3a3a3a !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5) !important;
    color: #ffffff !important;
}

/* Force dark styling for ALL auth elements - no .forumx-dark prefix needed */
.forumx-auth-toggle {
    background: #1f1f1f !important;
}

.forumx-tab-btn {
    color: #e5e7eb !important;
    background: transparent !important;
}

.forumx-tab-btn.active {
    color: var(--fx-accent, #b7d0db) !important;
    background: rgba(255, 255, 255, 0.06) !important;
}

.forumx-tab-btn:hover:not(.active) {
    color: #ffffff !important;
    background: rgba(255, 255, 255, 0.08) !important;
}

.forumx-auth-form label {
    color: #e5e7eb !important;
}

.forumx-auth-form input[type="text"],
.forumx-auth-form input[type="email"],
.forumx-auth-form input[type="password"],
.forumx-auth-form input[type="checkbox"] {
    background: #111827 !important;
    border: 1px solid #374151 !important;
    color: #e5e7eb !important;
}

.forumx-auth-form input:focus {
    border-color: var(--fx-accent, #b7d0db) !important;
    box-shadow: 0 0 0 3px rgba(183, 208, 219, 0.1) !important;
}

.forumx-auth-form input::placeholder {
    color: #9ca3af !important;
}

.forumx-auth-form .forumx-submit-btn,
.forumx-submit-btn {
    background: var(--fx-accent, #b7d0db) !important;
    color: #0b1b24 !important;
    border: 1px solid var(--fx-accent, #b7d0db) !important;
}

.forumx-auth-form .forumx-submit-btn:hover,
.forumx-submit-btn:hover {
    background: var(--fx-accent, #b7d0db) !important;
    opacity: 0.9 !important;
}

.forumx-auth-links a {
    color: var(--fx-accent, #b7d0db) !important;
}

.forumx-auth-links p {
    color: #e5e7eb !important;
}

.forumx-field-help {
    color: #9ca3af !important;
}

/* Force dark styling for checkbox labels and remember me section */
.forumx-auth-form .forumx-checkbox-group {
    color: #e5e7eb !important;
}

.forumx-auth-form .forumx-checkbox-group label {
    color: #e5e7eb !important;
}

/* Password visibility toggle styling */
.forumx-password-wrapper {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}

.forumx-password-wrapper input[type="password"],
.forumx-password-wrapper input[type="text"] {
    flex: 1 !important;
    padding-right: 45px !important;
}

.forumx-password-toggle {
    position: absolute !important;
    right: 12px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    padding: 4px !important;
    border-radius: 4px !important;
    color: #9ca3af !important;
    font-size: 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 28px !important;
    height: 28px !important;
    transition: all 0.2s ease !important;
}

.forumx-password-toggle:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: #e5e7eb !important;
}

.forumx-password-toggle:focus {
    outline: 2px solid var(--fx-accent, #b7d0db) !important;
    outline-offset: 2px !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

.forumx-password-toggle:active {
    transform: translateY(-50%) scale(0.95) !important;
}

.forumx-eye-icon {
    pointer-events: none !important;
    line-height: 1 !important;
}

/* Profile Page Styling - Dark Mode */
.forumx-profile-page {
    padding: 80px 0 40px 0;
    background: transparent;
    min-height: 70vh;
}

.forumx-profile-container {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px;
    background: #2A2A2A !important;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.forumx-profile-header {
    text-align: center;
    margin-bottom: 40px;
    background: transparent !important;
}

.forumx-profile-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: #ffffff !important;
    margin-bottom: 10px;
}

.forumx-profile-subtitle {
    font-size: 1.1rem;
    color: #e5e7eb !important;
    margin: 0;
}

.forumx-profile-content {
    display: block;
}

.forumx-profile-main {
    display: flex;
    flex-direction: column;
    gap: 30px;
    width: 100%;
}

.forumx-profile-image-section,
.forumx-profile-info-section,
.forumx-profile-logout-section {
    background: #1f1f1f !important;
    border: 1px solid #3a3a3a !important;
    border-radius: 12px;
    padding: 30px;
}

.forumx-profile-image-section h2,
.forumx-profile-info-section h2 {
    font-size: 1.5rem;
    font-weight: 600;
    color: #ffffff !important;
    margin-bottom: 20px;
    border-bottom: 2px solid var(--fx-accent, #b7d0db);
    padding-bottom: 10px;
}

.forumx-profile-image-wrapper {
    display: flex;
    align-items: center;
    gap: 30px;
}

.forumx-profile-image-display {
    flex-shrink: 0;
}

.forumx-profile-avatar {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--fx-accent);
    box-shadow: 0 4px 12px rgba(0, 124, 186, 0.2);
}

.forumx-profile-avatar-placeholder {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: #3a3a3a;
    border: 3px solid #4a4a4a;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    color: #9ca3af;
}

.forumx-profile-image-upload {
    flex: 1;
}

#forumx-profile-image-input {
    display: none;
}

.forumx-file-upload-btn {
    display: inline-block;
    padding: 12px 24px;
    background: #3a3a3a !important;
    border: 2px dashed #4a4a4a !important;
    border-radius: 8px;
    color: #ffffff !important;
    cursor: pointer;
    font-weight: 500;
    margin-bottom: 15px;
    transition: all 0.3s ease;
}

.forumx-file-upload-btn:hover {
    border-color: var(--fx-accent, #b7d0db) !important;
    background: rgba(183, 208, 219, 0.1) !important;
    color: var(--fx-accent, #b7d0db) !important;
}

.forumx-profile-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 25px;
}

.forumx-profile-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.forumx-profile-field label {
    font-weight: 600;
    color: #9ca3af !important;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.forumx-profile-value {
    font-size: 1.1rem;
    color: #ffffff !important;
    font-weight: 500;
}

.forumx-status-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.9rem;
    font-weight: 600;
}

.forumx-status-active {
    background: rgba(34, 197, 94, 0.1);
    color: #22c55e;
}

/* Profile Logout Section */
.forumx-profile-logout-section {
    text-align: center;
    margin-top: 20px;
}

.forumx-btn {
    display: inline-block;
    padding: 12px 24px;
    border-radius: 8px;
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: all 0.3s ease;
    border: none;
    cursor: pointer;
    font-size: 1rem;
}

.forumx-btn-logout {
    background: #dc3545;
    color: #ffffff;
    border: 1px solid #dc3545;
    min-width: 200px;
}

.forumx-btn-logout:hover {
    background: #c82333;
    border-color: #bd2130;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(220, 53, 69, 0.3);
}

.forumx-btn-delete {
    background: #6c757d;
    color: #ffffff;
    border: 1px solid #6c757d;
    min-width: 200px;
    margin-top: 15px;
}

.forumx-btn-delete:hover {
    background: #dc3545;
    border-color: #dc3545;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(220, 53, 69, 0.3);
}

/* Delete Account Confirmation Modal */
.forumx-delete-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.forumx-delete-modal.show {
    opacity: 1;
    visibility: visible;
}

.forumx-delete-modal-content {
    background: #2A2A2A;
    border-radius: 12px;
    padding: 30px;
    max-width: 500px;
    width: 90%;
    text-align: center;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
    border: 1px solid #3a3a3a;
}

.forumx-delete-modal h3 {
    color: #dc3545;
    font-size: 1.5rem;
    margin-bottom: 20px;
    font-weight: 700;
}

.forumx-delete-modal p {
    color: #e5e7eb;
    font-size: 1.1rem;
    line-height: 1.6;
    margin-bottom: 25px;
}

.forumx-delete-modal-actions {
    display: flex;
    gap: 15px;
    justify-content: center;
}

.forumx-btn-confirm-delete {
    background: #dc3545;
    color: #ffffff;
    border: 1px solid #dc3545;
    padding: 12px 30px;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
}

.forumx-btn-confirm-delete:hover {
    background: #c82333;
    border-color: #bd2130;
    transform: translateY(-2px);
}

.forumx-btn-cancel-delete {
    background: #6c757d;
    color: #ffffff;
    border: 1px solid #6c757d;
    padding: 12px 30px;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
}

.forumx-btn-cancel-delete:hover {
    background: #5a6268;
    border-color: #545b62;
    transform: translateY(-2px);
}

/* Responsive Design */
@media (max-width: 768px) {
    .forumx-profile-page {
        padding: 40px 0 20px 0;
    }
    
    .forumx-profile-container {
        margin: 0 20px;
        padding: 30px 20px;
    }
    
    .forumx-profile-image-wrapper {
        flex-direction: column;
        text-align: center;
        gap: 20px;
    }
    
    .forumx-profile-info-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .forumx-profile-title {
        font-size: 2rem;
    }
    
    .forumx-btn-logout,
    .forumx-btn-delete {
        min-width: 100%;
    }
}

/* Message styling for profile image upload */
.forumx-message {
    padding: 12px 16px;
    border-radius: 6px;
    margin: 10px 0;
    font-weight: 500;
    border-left: 4px solid;
}

.forumx-message-success {
    background: rgba(34, 197, 94, 0.1);
    color: #22c55e;
    border-left-color: #22c55e;
}

.forumx-message-error {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
    border-left-color: #ef4444;
}

.forumx-message-info {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
    border-left-color: #3b82f6;
}

/* User Avatar Styling */
.forumx-user-avatar,
.forumx-author-avatar,
.forumx-community-author-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--fx-border);
    margin-right: 8px;
    flex-shrink: 0;
}

.forumx-user-avatar.forumx-forumx-avatar {
    width: 40px;
    height: 40px;
    margin-right: 12px;
}

.forumx-avatar-initial,
.forumx-avatar-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--fx-light);
    color: var(--fx-muted);
    font-weight: 600;
    font-size: 14px;
    border: 2px solid var(--fx-border);
}

.forumx-author-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.forumx-comment-form-header {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.forumx-dark .forumx-auth-container {
    background: #2A2A2A !important;
    border: 1px solid #3a3a3a !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5) !important;
}

.forumx-dark .forumx-auth-container::before {
    background: linear-gradient(90deg, var(--fx-accent, #b7d0db), var(--fx-accent, #b7d0db));
}

.forumx-dark .forumx-tab-btn {
    color: #e5e7eb;
    background: transparent;
    border-bottom: 2px solid transparent;
}

.forumx-dark .forumx-tab-btn.active {
    color: var(--fx-accent, #b7d0db);
    background: rgba(255, 255, 255, 0.06);
    border-bottom: 2px solid var(--fx-accent, #b7d0db);
}

.forumx-dark .forumx-tab-btn:hover:not(.active) {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
}

.forumx-dark .forumx-auth-form label {
    color: #e5e7eb;
}

.forumx-dark .forumx-auth-form input {
    background: #111827;
    border: 1px solid #374151;
    color: #e5e7eb;
}

.forumx-dark .forumx-auth-form input:focus {
    border-color: var(--fx-accent, #b7d0db);
    box-shadow: 0 0 0 3px rgba(183, 208, 219, 0.1);
}

.forumx-dark .forumx-auth-form input::placeholder {
    color: #9ca3af;
}

.forumx-dark .forumx-submit-btn {
    background: var(--fx-accent, #b7d0db);
    color: #0b1b24;
    border: 1px solid var(--fx-accent, #b7d0db);
}

.forumx-dark .forumx-submit-btn:hover {
    background: var(--fx-accent, #b7d0db);
    opacity: 0.9;
}

.forumx-dark .forumx-field-help {
    color: #9ca3af;
}

.forumx-dark .forumx-auth-links a {
    color: var(--fx-accent, #b7d0db);
}

.forumx-dark .forumx-user-info {
    background: rgba(42,42,42,0.92);
    border: 1px solid #3a3a3a;
    color: #e5e7eb;
}

.forumx-dark .forumx-logout-btn {
    background: var(--fx-accent, #b7d0db);
    color: #0b1b24;
    border: 1px solid var(--fx-accent, #b7d0db);
}

/* Responsive adjustments for unified auth */
@media (max-width: 600px) {
    .forumx-auth-container {
        margin: 15px;
        border-radius: 8px;
    }
    
    .forumx-auth-panel {
        padding: 20px;
    }
    
    .forumx-tab-btn {
        padding: 12px 15px;
        font-size: 14px;
    }
}

/* Profile Interface */
.forumx-profile-container {
    max-width: 600px;
    margin: 30px auto;
    background: var(--fx-bg);
    border: 1px solid var(--fx-border);
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 124, 186, 0.1);
    overflow: hidden;
    position: relative;
}

.forumx-profile-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--fx-accent), var(--fx-accent-dark));
}

.forumx-profile-header {
    display: flex;
    align-items: center;
    padding: 30px;
    background: var(--fx-light);
}

.forumx-profile-avatar {
    margin-right: 20px;
    flex-shrink: 0;
}

.forumx-profile-avatar img {
    border-radius: 50%;
    border: 4px solid var(--fx-accent);
    width: 80px !important;
    height: 80px !important;
    box-shadow: 0 4px 12px rgba(0, 124, 186, 0.2);
}

.forumx-profile-info {
    flex: 1;
}

.forumx-profile-name {
    margin: 0 0 12px 0;
    font-size: 24px;
    font-weight: 700;
    color: var(--fx-fg);
}

.forumx-profile-meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.forumx-profile-email {
    color: var(--fx-accent);
    font-weight: 600;
    font-size: 15px;
}

.forumx-profile-joined,
.forumx-profile-last-login {
    color: var(--fx-muted);
    font-size: 14px;
}

.forumx-profile-actions {
    padding: 20px 30px;
    border-top: 1px solid var(--fx-border);
    text-align: center;
}

.forumx-profile-links {
    padding: 15px 30px;
    border-top: 1px solid var(--fx-border);
    background: var(--fx-light);
    text-align: center;
}

.forumx-profile-links p {
    margin: 0;
    font-size: 14px;
}

.forumx-profile-links a {
    color: var(--fx-accent);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s ease;
}

.forumx-profile-links a:hover {
    color: var(--fx-accent-dark);
    text-decoration: underline;
}

.forumx-profile-nav {
    display: flex;
    background: var(--fx-light);
    border-bottom: 1px solid var(--fx-border);
}

.forumx-profile-tab-btn {
    flex: 1;
    padding: 15px 20px;
    border: none;
    background: transparent;
    color: var(--fx-muted);
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    transition: all 0.3s ease;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.forumx-profile-tab-btn.active {
    color: var(--fx-accent);
    background: var(--fx-bg);
}

.forumx-profile-tab-btn.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--fx-accent);
}

.forumx-profile-tab-btn:hover:not(.active) {
    color: var(--fx-fg);
    background: var(--fx-light);
}

.forumx-tab-count {
    background: var(--fx-accent);
    color: white;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    min-width: 20px;
    text-align: center;
}

.forumx-profile-tab-btn:not(.active) .forumx-tab-count {
    background: var(--fx-muted);
}

.forumx-profile-panel {
    display: none;
    padding: 30px;
}

.forumx-profile-panel.active {
    display: block;
}

.forumx-profile-section-header {
    margin-bottom: 25px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--fx-border);
}

.forumx-profile-section-header h3 {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
    color: var(--fx-fg);
}

.forumx-profile-posts-list,
.forumx-profile-votes-list {
    min-height: 200px;
}

.forumx-profile-item {
    padding: 20px;
    border: 1px solid var(--fx-border);
    border-radius: 8px;
    margin-bottom: 15px;
    background: var(--fx-bg);
    transition: all 0.3s ease;
}

.forumx-profile-item:hover {
    border-color: var(--fx-accent);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.forumx-profile-item-title {
    margin: 0 0 10px 0;
    font-size: 18px;
    font-weight: 600;
}

.forumx-profile-item-title a {
    color: var(--fx-fg);
    text-decoration: none;
}

.forumx-profile-item-title a:hover {
    color: var(--fx-accent);
}

.forumx-profile-item-meta {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 10px;
    font-size: 14px;
    color: var(--fx-muted);
}

.forumx-profile-community {
    color: var(--fx-accent);
    font-weight: 500;
}

.forumx-profile-vote-indicator {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
}

.forumx-profile-vote-indicator.upvote {
    background: rgba(34, 197, 94, 0.1);
    color: #22c55e;
}

.forumx-profile-vote-indicator.downvote {
    background: rgba(239, 68, 68, 0.1);
    color: #ef4444;
}

.forumx-profile-item-excerpt {
    color: var(--fx-muted);
    line-height: 1.5;
    margin: 0;
}

.forumx-profile-empty {
    text-align: center;
    padding: 50px 20px;
    color: var(--fx-muted);
}

.forumx-profile-empty h4 {
    margin: 0 0 10px 0;
    font-size: 18px;
    color: var(--fx-fg);
}

.forumx-profile-empty p {
    margin: 0;
}

/* Responsive adjustments for profile */
@media (max-width: 600px) {
    .forumx-profile-container {
        margin: 15px;
        border-radius: 8px;
    }
    
    .forumx-profile-header {
        flex-direction: column;
        text-align: center;
        padding: 20px;
    }
    
    .forumx-profile-avatar {
        margin: 0 0 15px 0;
    }
    
    .forumx-profile-meta {
        align-items: center;
    }
    
    .forumx-profile-panel {
        padding: 20px;
    }
    
    .forumx-profile-tab-btn {
        padding: 12px 15px;
        font-size: 14px;
        flex-direction: column;
        gap: 4px;
    }
    
    .forumx-profile-item {
        padding: 15px;
    }
    
    .forumx-profile-item-meta {
        flex-wrap: wrap;
        gap: 10px;
    }
}
/* Modal body scroll prevention */
body.modal-open {
    overflow: hidden;
    height: 100vh;
}

/* Comments Section Styles */
.forumx-comments-section {
    margin-top: var(--fx-space-xl);
    border-top: 1px solid var(--fx-border);
    padding-top: var(--fx-space-xl);
}

.forumx-comments-loading {
    text-align: center;
    padding: var(--fx-space-lg);
    color: var(--fx-muted);
    font-style: italic;
}

.forumx-comments-loading .dashicons {
    animation: spin 1s linear infinite;
    margin-right: 8px;
}

.forumx-comments-error {
    text-align: center;
    padding: var(--fx-space-lg);
    background: #ffebee;
    color: #c62828;
    border: 1px solid #ffcdd2;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.forumx-comments-empty {
    text-align: center;
    padding: var(--fx-space-2xl) var(--fx-space-lg);
    color: var(--fx-muted);
}

.forumx-comments-empty h4 {
    margin: 0 0 var(--fx-space-sm) 0;
    font-size: var(--fx-font-size-lg);
    color: var(--fx-fg);
}

.forumx-comments-empty p {
    margin: 0;
    font-size: var(--fx-font-size-sm);
}

.forumx-comments-title {
    margin: 0 0 var(--fx-space-lg) 0;
    font-size: var(--fx-font-size-xl);
    font-weight: 600;
    color: var(--fx-fg);
    border-bottom: 2px solid var(--fx-accent);
    padding-bottom: var(--fx-space-sm);
}

/* Individual Comment Styles */
.forumx-comment {
    margin-bottom: var(--fx-space-lg);
}

.forumx-comment-card {
    background: var(--fx-card-bg);
    border: 1px solid var(--fx-border);
    border-radius: 12px;
    padding: var(--fx-space-lg);
    box-shadow: var(--fx-shadow-subtle);
    transition: var(--fx-transition-normal);
    position: relative;
}

.forumx-comment-card:hover {
    border-color: var(--fx-accent);
    box-shadow: var(--fx-shadow-medium);
}

.forumx-comment-card::before {
    content: '';
    position: absolute;
    left: -2px;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--fx-accent);
    border-radius: 2px;
    opacity: 0;
    transition: opacity var(--fx-transition-normal);
}

.forumx-comment-card:hover::before {
    opacity: 1;
}

.forumx-comment-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--fx-space-md);
}

.forumx-comment-author {
    display: flex;
    align-items: center;
    gap: var(--fx-space-sm);
}

.forumx-comment-author-name {
    font-weight: 600;
    color: var(--fx-accent);
    font-size: var(--fx-font-size-sm);
}

.forumx-comment-time {
    font-size: var(--fx-font-size-xs);
    color: var(--fx-muted);
    font-weight: 400;
}

.forumx-comment-actions {
    display: flex;
    gap: var(--fx-space-xs);
}

.forumx-comment-delete-btn {
    background: none;
    border: none;
    color: var(--fx-muted);
    cursor: pointer;
    padding: var(--fx-space-xs);
    border-radius: 4px;
    transition: var(--fx-transition-normal);
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    min-height: 32px;
}

.forumx-comment-delete-btn:hover {
    color: #dc3545;
    background: rgba(220, 53, 69, 0.1);
    transform: scale(1.1);
}

.forumx-comment-delete-btn .dashicons {
    font-size: 14px;
    width: 14px;
    height: 14px;
}

.forumx-comment-content {
    line-height: var(--fx-line-height-relaxed);
    color: var(--fx-fg);
    margin-bottom: var(--fx-space-md);
}

.forumx-comment-content p {
    margin: 0 0 1em 0;
}

.forumx-comment-content p:last-child {
    margin-bottom: 0;
}

.forumx-comment-footer {
    display: flex;
    align-items: center;
    gap: var(--fx-space-sm);
}

.forumx-comment-reply-btn {
    background: none;
    border: 1px solid var(--fx-border);
    color: var(--fx-muted);
    cursor: pointer;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: var(--fx-font-size-xs);
    transition: var(--fx-transition-normal);
    display: flex;
    align-items: center;
    gap: 4px;
    font-weight: 500;
}

.forumx-comment-reply-btn:hover {
    color: var(--fx-accent);
    border-color: var(--fx-accent);
    background: rgba(0, 115, 170, 0.05);
    transform: translateY(-1px);
}

.forumx-comment-reply-btn .dashicons {
    font-size: 12px;
    width: 12px;
    height: 12px;
}

.forumx-comment-reply-form {
    margin-top: var(--fx-space-md);
    padding-top: var(--fx-space-md);
    border-top: 1px solid var(--fx-border);
}

/* Comment Form Styles */
.forumx-comment-form-container {
    margin-top: var(--fx-space-xl);
}

.forumx-comment-form {
    background: var(--fx-card-bg);
    border: 1px solid var(--fx-border);
    border-radius: 12px;
    padding: var(--fx-space-lg);
}

.forumx-comment-form-group {
    margin-bottom: var(--fx-space-md);
}

.forumx-comment-textarea {
    width: 100%;
    min-height: 100px;
    padding: var(--fx-space-md);
    border: 2px solid var(--fx-border);
    border-radius: 8px;
    font-size: var(--fx-font-size-base);
    font-family: inherit;
    line-height: var(--fx-line-height-normal);
    resize: vertical;
    transition: var(--fx-transition-normal);
    box-sizing: border-box;
}

.forumx-comment-textarea:focus {
    outline: none;
    border-color: var(--fx-accent);
    box-shadow: 0 0 0 3px rgba(0, 115, 170, 0.1);
}

.forumx-comment-textarea::placeholder {
    color: var(--fx-muted);
    opacity: 0.7;
}

.forumx-comment-form-actions {
    display: flex;
    gap: var(--fx-space-sm);
    justify-content: flex-end;
    align-items: center;
}

.forumx-comment-submit-btn,
.forumx-comment-cancel-btn {
    padding: 10px 20px;
    border-radius: 8px;
    font-size: var(--fx-font-size-sm);
    font-weight: 600;
    cursor: pointer;
    transition: var(--fx-transition-normal);
    border: 2px solid;
    display: flex;
    align-items: center;
    gap: 6px;
    min-height: 40px;
}

.forumx-comment-submit-btn {
    background: linear-gradient(135deg, var(--fx-accent), var(--fx-accent-dark));
    color: white;
    border-color: var(--fx-accent);
}

.forumx-comment-submit-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, var(--fx-accent-dark), #003d5c);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 115, 170, 0.3);
}

.forumx-comment-submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.forumx-comment-submit-btn.loading {
    position: relative;
}

.forumx-comment-submit-btn.loading::after {
    content: '';
    position: absolute;
    right: 8px;
    width: 16px;
    height: 16px;
    border: 2px solid transparent;
    border-top: 2px solid currentColor;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

.forumx-comment-cancel-btn {
    background: transparent;
    color: var(--fx-muted);
    border-color: var(--fx-border);
}

.forumx-comment-cancel-btn:hover {
    background: var(--fx-light);
    color: var(--fx-fg);
    border-color: var(--fx-muted);
    transform: translateY(-1px);
}

.forumx-comment-form-help {
    margin-top: var(--fx-space-sm);
    font-size: var(--fx-font-size-xs);
    color: var(--fx-muted);
    text-align: right;
}

.forumx-comment-login-required {
    text-align: center;
    padding: var(--fx-space-lg);
    background: #e1f5fe;
    color: #0277bd;
    border: 1px solid #b3e5fc;
    border-radius: 8px;
}

.forumx-comment-login-required p {
    margin: 0 0 var(--fx-space-sm) 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.forumx-login-link {
    display: inline-block;
    padding: 8px 16px;
    background: var(--fx-accent);
    color: white;
    text-decoration: none;
    border-radius: 6px;
    font-weight: 500;
    transition: var(--fx-transition-normal);
}

.forumx-login-link:hover {
    background: var(--fx-accent-dark);
    color: white;
    text-decoration: none;
    transform: translateY(-1px);
}

/* Reply Indentation */
.forumx-comment[style*="margin-left: 20px"] .forumx-comment-card {
    border-left: 3px solid rgba(0, 115, 170, 0.2);
}

.forumx-comment[style*="margin-left: 40px"] .forumx-comment-card {
    border-left: 3px solid rgba(0, 115, 170, 0.4);
}

.forumx-comment[style*="margin-left: 60px"] .forumx-comment-card {
    border-left: 3px solid rgba(0, 115, 170, 0.6);
}

/* Responsive Comments */
@media (max-width: 768px) {
    .forumx-comments-section {
        padding-top: var(--fx-space-lg);
        margin-top: var(--fx-space-lg);
    }
    
    .forumx-comment {
        margin-left: 0 !important; /* Remove indentation on mobile */
    }
    
    .forumx-comment-card {
        padding: var(--fx-space-md);
    }
    
    .forumx-comment-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--fx-space-xs);
    }
    
    .forumx-comment-actions {
        align-self: flex-end;
    }
    
    .forumx-comment-form-actions {
        flex-direction: column-reverse;
        gap: var(--fx-space-sm);
    }
    
    .forumx-comment-submit-btn,
    .forumx-comment-cancel-btn {
        width: 100%;
        justify-content: center;
    }
    
    .forumx-comment-form-help {
        text-align: center;
    }
}

/* High Contrast Support for Comments */
@media (prefers-contrast: high) {
    .forumx-comment-card {
        border-color: #000000;
    }
    
    .forumx-comment-author-name {
        color: #000000;
    }
    
    .forumx-comment-submit-btn {
        background: #0073aa;
        border-color: #0073aa;
    }
}

/* Reduced Motion Support for Comments */
@media (prefers-reduced-motion: reduce) {
    .forumx-comment-card,
    .forumx-comment-reply-btn,
    .forumx-comment-submit-btn,
    .forumx-comment-cancel-btn {
        transition: none;
        transform: none;
    }
    
    .forumx-comment-card:hover,
    .forumx-comment-reply-btn:hover,
    .forumx-comment-submit-btn:hover:not(:disabled),
    .forumx-comment-cancel-btn:hover {
        transform: none;
    }
}

/* Share Modal Styles */
.forumx-share-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.6);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 10000;
    padding: var(--fx-space-lg);
    box-sizing: border-box;
    backdrop-filter: blur(4px);
    animation: fadeIn 0.3s ease-out;
}

.forumx-share-modal.active {
    display: flex;
}

.forumx-share-modal-content {
    background: var(--fx-card-bg);
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    max-width: 480px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    animation: slideInScale 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    border: 1px solid var(--fx-border);
}

.forumx-share-modal-header {
    padding: 24px 30px 20px;
    border-bottom: 1px solid var(--fx-border);
    background: linear-gradient(135deg, var(--fx-accent) 0%, var(--fx-accent-dark) 100%);
    border-radius: 16px 16px 0 0;
    color: white;
    position: relative;
}

.forumx-share-modal-title {
    margin: 0;
    font-size: 20px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 12px;
}

.forumx-share-modal-title .dashicons {
    font-size: 24px;
    width: 24px;
    height: 24px;
    opacity: 0.9;
}

.forumx-share-modal-close {
    position: absolute;
    top: 20px;
    right: 24px;
    background: rgba(255, 255, 255, 0.2);
    border: none;
    color: white;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    font-size: 18px;
}

.forumx-share-modal-close:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: scale(1.1);
}

.forumx-share-modal-body {
    padding: 30px;
}

.forumx-share-link-section {
    margin-bottom: 30px;
}

.forumx-share-label {
    display: block;
    margin-bottom: 10px;
    font-weight: 600;
    color: var(--fx-fg);
    font-size: 15px;
}

.forumx-share-copy-container {
    display: flex;
    gap: 8px;
    align-items: stretch;
}

.forumx-copy-link-input {
    flex: 1;
    padding: 12px 16px;
    border: 2px solid var(--fx-border);
    border-radius: 8px;
    font-size: 14px;
    font-family: monospace;
    background: var(--fx-light);
    color: var(--fx-fg);
    transition: all 0.3s ease;
}

.forumx-copy-link-input:focus {
    outline: none;
    border-color: var(--fx-accent);
    box-shadow: 0 0 0 3px rgba(0, 115, 170, 0.1);
}

.forumx-copy-btn {
    padding: 12px 16px;
    background: var(--fx-accent);
    color: white;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 500;
    min-width: 100px;
    justify-content: center;
}

.forumx-copy-btn:hover:not(.copied) {
    background: var(--fx-accent-dark);
    transform: translateY(-1px);
}

.forumx-copy-btn.copied {
    background: #4caf50;
}

.forumx-share-social-section {
    margin-bottom: 20px;
}

.forumx-share-social-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-top: 15px;
}

.forumx-social-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    border: 2px solid var(--fx-border);
    border-radius: 10px;
    text-decoration: none;
    color: var(--fx-fg);
    background: var(--fx-card-bg);
    font-weight: 500;
    transition: all 0.3s ease;
    cursor: pointer;
    min-height: 48px;
}

.forumx-social-btn:hover {
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.forumx-social-twitter:hover {
    background: #1da1f2;
    color: white;
    border-color: #1da1f2;
}

.forumx-social-facebook:hover {
    background: #1877f2;
    color: white;
    border-color: #1877f2;
}

.forumx-social-linkedin:hover {
    background: #0a66c2;
    color: white;
    border-color: #0a66c2;
}

.forumx-social-copy:hover {
    background: var(--fx-accent);
    color: white;
    border-color: var(--fx-accent);
}

.forumx-social-btn .dashicons {
    font-size: 18px;
    width: 18px;
    height: 18px;
}

.forumx-share-native-section {
    margin-bottom: 20px;
    text-align: center;
}

.forumx-native-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    background: linear-gradient(135deg, var(--fx-accent), var(--fx-accent-dark));
    color: white;
    border: none;
    border-radius: 25px;
    cursor: pointer;
    font-weight: 600;
    transition: all 0.3s ease;
}

.forumx-native-share-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 115, 170, 0.3);
}

.forumx-share-modal-footer {
    padding: 20px 30px 30px;
    border-top: 1px solid var(--fx-border);
    background: var(--fx-light);
    border-radius: 0 0 16px 16px;
    text-align: center;
}

.forumx-share-close-btn {
    padding: 12px 24px;
    background: transparent;
    color: var(--fx-muted);
    border: 2px solid var(--fx-border);
    border-radius: 8px;
    cursor: pointer;
    font-weight: 500;
    transition: all 0.3s ease;
    min-width: 120px;
}

.forumx-share-close-btn:hover {
    background: var(--fx-light);
    color: var(--fx-fg);
    border-color: var(--fx-muted);
    transform: translateY(-1px);
}

/* Responsive Share Modal */
@media (max-width: 600px) {
    .forumx-share-modal {
        padding: var(--fx-space-md);
    }
    
    .forumx-share-modal-content {
        max-width: 100%;
        border-radius: 12px;
    }
    
    .forumx-share-modal-header {
        padding: 20px 24px 16px;
        border-radius: 12px 12px 0 0;
    }
    
    .forumx-share-modal-title {
        font-size: 18px;
    }
    
    .forumx-share-modal-body {
        padding: 24px 20px;
    }
    
    .forumx-share-copy-container {
        flex-direction: column;
    }
    
    .forumx-copy-btn {
        min-width: 100%;
    }
    
    .forumx-share-social-buttons {
        grid-template-columns: 1fr;
    }
    
    .forumx-share-modal-footer {
        padding: 16px 20px 20px;
        border-radius: 0 0 12px 12px;
    }
    
    .forumx-share-close-btn {
        width: 100%;
    }
}

/* High Contrast Support for Share Modal */
@media (prefers-contrast: high) {
    .forumx-share-modal-header {
        background: var(--fx-accent);
    }
    
    .forumx-copy-link-input,
    .forumx-social-btn {
        border-color: #000000;
    }
    
    .forumx-copy-btn {
        background: var(--fx-accent);
        border: 2px solid #000000;
    }
}

/* Reduced Motion Support for Share Modal */
@media (prefers-reduced-motion: reduce) {
    .forumx-share-modal,
    .forumx-share-modal-content,
    .forumx-copy-btn,
    .forumx-social-btn,
    .forumx-native-share-btn,
    .forumx-share-close-btn {
        animation: none;
        transition: none;
        transform: none;
    }
    
    .forumx-copy-btn:hover,
    .forumx-social-btn:hover,
    .forumx-native-share-btn:hover,
    .forumx-share-close-btn:hover {
        transform: none;
    }
}

/* =============================================================================
   DASHBOARD LAYOUT
   ============================================================================= */

/* Dashboard Container */
.forumx-dashboard {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    background: transparent;
    color: #e5edf1;
}

/* Dashboard Header */
.forumx-dashboard-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.forumx-dashboard-title {
    margin: 0;
}

/* "Zum Profil" button style (scoped to dashboard header) */
.forumx-dashboard-header .button-link {
    display: inline-block;
    background: #b7d0db;
    color: #1a1a1a;
    padding: 13px 20px;
    margin: 0; /* align with H1 on same line */
    border-radius: 12px;
    text-decoration: none;
    font-weight: bold;
    font-size: 18px;
    transition: all 0.3s ease;
    border: 2px solid transparent;
    cursor: pointer;
}

.forumx-dashboard-header .button-link:hover {
    background: #1a1a1a;
    color: #b7d0db;
    text-decoration: none;
}

.forumx-dashboard-header .button-link:focus {
    outline: none;
    background: #1a1a1a;
    color: #b7d0db;
    box-shadow: 0 0 0 3px #b7d0db;
    text-decoration: none;
}

/* Popular Posts Section */
.forumx-dashboard-popular {
    margin-bottom: 40px;
}

.forumx-section-title {
    font-size: 24px;
    font-weight: 600;
    color: #e5edf1;
    margin: 0 0 20px 0;
    border-bottom: 2px solid var(--fx-accent);
    padding-bottom: 10px;
}

/* Popular Posts Carousel */
.forumx-popular-carousel {
    position: relative;
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 20px;
}

.forumx-popular-posts {
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    flex: 1;
    gap: 20px;
    padding-bottom: 4px; /* room for scrollbar */
    margin-top: 10px;
    scrollbar-width: thin; /* Firefox */
    scrollbar-color: var(--fx-accent) transparent; /* Firefox */
}

.forumx-popular-posts::-webkit-scrollbar { height: 6px; }
.forumx-popular-posts::-webkit-scrollbar-track { background: transparent; }
.forumx-popular-posts::-webkit-scrollbar-thumb { background: var(--fx-accent); border-radius: 4px; }
.forumx-popular-posts::-webkit-scrollbar-thumb:hover { background: var(--fx-accent-dark); }

.forumx-popular-posts .forumx-popular-card {
    flex: 0 0 calc((100% - 40px) / 3);
    min-width: 280px;
    position: relative;
    display: block;
    scroll-snap-align: start;
}

.forumx-carousel-nav {
    background: var(--fx-accent);
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    cursor: pointer;
    transition: all 0.2s ease;
    z-index: 10;
    flex-shrink: 0;
}

.forumx-carousel-nav:hover {
    background: var(--fx-accent-dark);
    transform: scale(1.05);
}

.forumx-carousel-nav:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.forumx-carousel-nav .dashicons {
    font-size: 18px;
}

/* Popular Post Cards */
.forumx-popular-card {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    cursor: pointer;
    min-height: 180px;
    background: #0f172a;
}

.forumx-popular-card:hover { transform: translateY(-2px); box-shadow: 0 6px 22px rgba(0,0,0,0.15); }

.forumx-card-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.forumx-card-gradient { position:absolute; inset:0; background: linear-gradient(to top, rgba(0,0,0,0.6), rgba(0,0,0,0.0) 60%); }
.forumx-card-fallback-gradient { position:absolute; inset:0; background: linear-gradient(135deg, #b7d0db 0%, #9bc4d0 100%); }
.forumx-card-overlay { position:absolute; left:12px; bottom:12px; right:12px; color:#fff; z-index:2; }
.forumx-carousel-title { margin:0 0 6px 0; font-size:18px; font-weight:700; line-height:1.25; color:#fff !important; text-shadow: 0 2px 4px rgba(0,0,0,0.8) !important; }
.forumx-carousel-community { display:flex; align-items:center; gap:8px; font-size:13px; color:#fff !important; text-shadow: 0 1px 2px rgba(0,0,0,0.7) !important; }
.forumx-carousel-community .forumx-community-icon { width:24px; height:24px; border-radius:50%; object-fit:cover; }
.forumx-carousel-community .forumx-community-icon.fa { width:24px; height:24px; border-radius:50%; background:#b7d0db; color:#0b1b24; display:inline-flex; align-items:center; justify-content:center; font-size:11px; }
.forumx-popular-card.no-image .forumx-carousel-title { color:#fff !important; text-shadow: 0 2px 4px rgba(0,0,0,0.8) !important; }
.forumx-popular-card.no-image .forumx-carousel-community { color:#fff !important; text-shadow: 0 1px 2px rgba(0,0,0,0.7) !important; }

.forumx-card-fallback {
    background: linear-gradient(135deg, #b7d0db 0%, #9bc4d0 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.forumx-card-fallback::after {
    content: "📰";
    font-size: 3rem;
    opacity: 0.7;
}

.forumx-card-content {
    padding: 16px;
}

.forumx-card-community {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
    font-size: 12px;
    color: #787c82;
    font-weight: 500;
}

.forumx-community-icon {
    width: 16px;
    height: 16px;
    border-radius: 50%;
}

.forumx-community-name {
    font-weight: 600;
    color: #1c1c1c;
}

.forumx-card-title {
    margin: 0 0 12px 0;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.3;
}

.forumx-card-title a {
    color: #1a1a1b;
    text-decoration: none;
    transition: color 0.2s ease;
}

.forumx-card-title a:hover {
    color: #b7d0db;
}

.forumx-card-excerpt {
    font-size: 14px;
    line-height: 1.4;
    color: #7c7c83;
    margin-bottom: 12px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.forumx-card-meta {
    display: flex;
    align-items: center;
    gap: 16px;
    font-size: 12px;
    color: #787c82;
}

.forumx-card-score,
.forumx-card-comments {
    display: flex;
    align-items: center;
    gap: 4px;
}

.forumx-card-score .dashicons,
.forumx-card-comments .dashicons {
    width: 14px;
    height: 14px;
    font-size: 14px;
}

/* Dashboard Main Layout */
.forumx-dashboard-main {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 30px;
}

/* Dashboard Feed */
.forumx-dashboard-feed {
    background: #ffffff;
    border: 1px solid #ccc;
    border-radius: 12px;
    overflow: hidden;
}

.forumx-dashboard .forumx-feed-header {
    background: #f8f9fa;
    padding: 16px 20px;
    border-bottom: 1px solid #edeff1;
}

.forumx-dashboard .forumx-feed-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1b;
}

/* Dashboard Posts */
.forumx-dashboard-post {
    border-bottom: 1px solid #edeff1;
    padding: 16px 20px;
    transition: background-color 0.2s ease;
    cursor: pointer;
}

.forumx-dashboard-post:last-child {
    border-bottom: none;
}

.forumx-dashboard-post:hover {
    background: #111827;
}

.forumx-dashboard-post-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.forumx-post-author-info {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #787c82;
}

.forumx-post-author {
    font-weight: 600;
    color: #e5edf1;
}

.forumx-post-community {
    color: #b7d0db;
    font-weight: 500;
}

.forumx-post-report-action .forumx-report-btn-small,
.forumx-post-report-action .forumx-post-delete-btn {
    padding: 4px 8px;
    font-size: 11px;
    border-radius: 12px;
    background: rgba(183, 208, 219, 0.12);
    border: 1px solid rgba(183, 208, 219, 0.25);
    color: #e5e7eb;
    transition: all 0.2s ease;
}

.forumx-post-report-action .forumx-report-btn-small:hover,
.forumx-post-report-action .forumx-post-delete-btn:hover {
    background: rgba(183, 208, 219, 0.2);
    border-color: rgba(183, 208, 219, 0.45);
    color: #b7d0db;
    transform: translateY(-1px);
}

@media (max-width: 768px) {
    .forumx-report-text {
        display: none;
    }
    
    .forumx-report-btn {
        padding: 6px 8px;
        border-radius: 16px;
    }
}

/* Responsive tweaks for dashboard */
@media (max-width: 900px) {
    .forumx-dashboard-main {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .forumx-dashboard-sidebar {
        position: static;
        top: auto;
    }
}

.forumx-dashboard-post-title {
    margin: 0 0 12px 0;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.3;
}

.forumx-dashboard-post-title a {
    color: #e5edf1;
    text-decoration: none;
    transition: color 0.2s ease;
}

.forumx-dashboard-post-title a:hover {
    color: var(--fx-accent);
}

.forumx-dashboard-post-body {
    margin-bottom: 12px;
}

.forumx-post-image {
    margin-bottom: 12px;
    border-radius: 8px;
    overflow: hidden;
}

.forumx-post-image img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    object-fit: cover;
    display: block;
}

/* Feed image optimization */
.forumx-feed .forumx-post-image {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: 12px;
    background: #f5f5f5; /* Neutral background for portrait images */
    min-height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.forumx-feed .forumx-post-image img {
    width: 100%;
    height: auto;
    max-height: 400px;
    object-fit: contain; /* Keep proportions, show full image */
    object-position: center;
    border-radius: 12px;
}

/* Landscape images - full width cover */
.forumx-feed .forumx-post-image.landscape {
    min-height: 250px;
    max-height: 300px;
}

.forumx-feed .forumx-post-image.landscape img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Fill width completely */
}

/* Portrait images - proportional with neutral background */
.forumx-feed .forumx-post-image.portrait {
    background: #e8e9ea; /* Slightly darker neutral background */
    min-height: 350px;
    max-height: 400px;
}

.forumx-feed .forumx-post-image.portrait img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain; /* Keep proportions, fill sides with background */
}

.forumx-post-text {
    font-size: 14px;
    line-height: 1.5;
    color: #d1d5db;
    word-break: break-word;
    overflow-wrap: anywhere;
}

.forumx-dashboard-post-footer {
    margin-top: 12px;
}

.forumx-comments-toggle {
    background: none;
    border: none;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 12px;
    color: #9ca3af;
    transition: all 0.2s ease;
    cursor: pointer;
}

.forumx-comments-toggle:hover,
.forumx-comments-toggle.active {
    background: rgba(183, 208, 219, 0.15);
    color: #e5edf1;
}

.forumx-comments-toggle .dashicons {
    width: 14px;
    height: 14px;
    font-size: 14px;
}

/* Dashboard Sidebar */
.forumx-dashboard-sidebar {
    background: #0f172a;
    border: 1px solid #1f2937;
    border-radius: 12px;
    padding: 20px;
    height: fit-content;
    position: sticky;
    top: 20px;
}

.forumx-widget-title {
    margin: 0 0 16px 0;
    font-size: 24px; /* align with all H2 */
    font-weight: 700;
    color: #e5edf1;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--fx-accent);
}

.forumx-communities-list {
    margin-bottom: 20px;
}

.forumx-community-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    margin-bottom: 4px;
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
    transition: all 0.2s ease;
}

.forumx-community-item:hover {
    background: rgba(183, 208, 219, 0.08);
    text-decoration: none;
}

.forumx-community-item .forumx-community-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

/* Fallback font-awesome icon should be centered inside a circle */
.forumx-community-item .forumx-community-icon.fa,
.forumx-community-item i.forumx-community-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #2f2f2f;
    color: var(--fx-accent);
}

.forumx-community-info {
    flex: 1;
    min-width: 0;
}

.forumx-community-name {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #e5edf1;
    margin-bottom: 2px;
}

.forumx-community-description {
    display: block;
    font-size: 12px;
    color: #787c82;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.forumx-community-count {
    font-size: 12px;
    color: #9ca3af;
    background: rgba(183, 208, 219, 0.12);
    padding: 2px 6px;
    border-radius: 10px;
    font-weight: 500;
    flex-shrink: 0;
}

.forumx-create-community-btn {
    width: 100%;
    padding: 12px 16px;
    background: #b7d0db;
    color: #0b1b24; /* dark text for contrast on light accent */
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.forumx-create-community-btn:hover {
    background: #9fbcc9; /* slightly darker accent */
    transform: translateY(-1px);
}

.forumx-create-community-btn .dashicons {
    width: 16px;
    height: 16px;
    font-size: 16px;
}

/* Community Creation Modal */
.forumx-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.forumx-modal.active {
    opacity: 1;
    visibility: visible;
}

.forumx-modal-content {
    background: #212121;
    color: #f5f5f5;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    width: 90%;
    max-width: 600px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.6);
    transform: translateY(-20px);
    transition: transform 0.3s ease;
}

.forumx-modal.active .forumx-modal-content {
    transform: translateY(0);
}

.forumx-modal-header {
    padding: 20px 24px;
    border-bottom: 1px solid #303030;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.forumx-modal-title {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
    color: #b7d0db;
    display: flex;
    align-items: center;
    gap: 10px;
}

.forumx-modal-close {
    background: none;
    border: none;
    font-size: 18px;
    cursor: pointer;
    padding: 8px;
    border-radius: 50%;
    transition: background 0.2s ease;
    color: #d1d5db;
}

.forumx-modal-close:hover {
    background: rgba(183, 208, 219, 0.15);
    color: #ffffff;
}

.forumx-modal-body {
    padding: 24px;
    color: #f5f5f5;
}

.forumx-form-group {
    margin-bottom: 20px;
}

.forumx-form-row {
    display: flex;
    gap: 16px;
}

.forumx-form-half {
    flex: 1;
}

.forumx-form label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #e5edf1;
    margin-bottom: 6px;
}

.forumx-form input,
.forumx-form textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #374151;
    border-radius: 6px;
    font-size: 14px;
    transition: border-color 0.2s ease;
    font-family: inherit;
    background: #111827;
    color: #e5edf1;
}

.forumx-form input:focus,
.forumx-form textarea:focus {
    outline: none;
    border-color: var(--fx-accent);
    box-shadow: 0 0 0 2px rgba(183, 208, 219, 0.2);
}

.forumx-form-help {
    display: block;
    font-size: 12px;
    color: #9ca3af;
    margin-top: 4px;
}

.required {
    color: var(--fx-accent);
}

.forumx-modal-footer {
    padding: 20px 24px;
    border-top: 1px solid #1f2937;
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

.forumx-btn {
    padding: 10px 20px;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 8px;
}

.forumx-btn-primary {
    background: #b7d0db;
    color: #102029;
    border: 1px solid rgba(183, 208, 219, 0.65);
}

.forumx-btn-primary:hover {
    background: #c7deeb;
}

.forumx-btn-secondary {
    background: #f0f0f0;
    color: #1c1c1c;
    border: 1px solid #ccc;
}

.forumx-btn-secondary:hover {
    background: #e0e0e0;
}

.forumx-btn:disabled,
.forumx-btn.loading {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Empty States */
.forumx-no-posts,
.forumx-no-communities {
    text-align: center;
    padding: 40px 20px;
    color: #787c82;
    font-style: italic;
}

/* Responsive Design */
@media (max-width: 768px) {
    .forumx-dashboard {
        padding: 16px;
    }
    
    .forumx-dashboard-main {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    
    .forumx-dashboard-sidebar {
        order: -1;
        position: static;
    }
    
    .forumx-popular-posts {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    
    .forumx-card-content {
        padding: 12px;
    }
    
    .forumx-dashboard-post {
        padding: 12px 16px;
    }
    
    .forumx-post-author-info {
        flex-wrap: wrap;
        gap: 4px;
    }
    
    .forumx-form-row {
        flex-direction: column;
        gap: 12px;
    }
    
    .forumx-modal-content {
        margin: 20px;
        width: auto;
    }
    
    .forumx-modal-header,
    .forumx-modal-body,
    .forumx-modal-footer {
        padding: 16px;
    }
}

@media (max-width: 480px) {
    .forumx-dashboard {
        padding: 12px;
    }
    
    .forumx-section-title {
        font-size: 20px;
    }
    
    .forumx-dashboard-post-title {
        font-size: 16px;
    }
    
    .forumx-modal-title {
        font-size: 18px;
    }
}

/* Dark Mode Support */
@media (prefers-color-scheme: dark) {
    .forumx-dashboard {
        background: #1a1a1b;
        color: #d7dadc;
    }
    
    .forumx-popular-card,
    .forumx-dashboard-feed,
    .forumx-dashboard-sidebar {
        background: #1a1a1b;
        border-color: #343536;
    }
    
    .forumx-section-title,
    .forumx-feed-title,
    .forumx-widget-title {
        color: #d7dadc;
    }
    
    .forumx-dashboard-post:hover {
        background: #272729;
    }
    
    .forumx-modal-content {
        background: #1a1a1b;
        color: #d7dadc;
    }
    
    .forumx-form input,
    .forumx-form textarea {
        background: #272729;
        border-color: #343536;
        color: #d7dadc;
    }
}

/* =============================================================================
   COMMUNITY PAGE
   ============================================================================= */

/* Community Header */
.forumx-community-page:not(.forumx-dark) .forumx-community-header {
    background: #ffffff;
    border: 1px solid #ccc;
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 20px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.forumx-community-banner {
    height: 200px;
    background-size: cover;
    background-position: center;
    background-color: #f8f9fa;
    position: relative;
}

.forumx-community-banner::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 60px;
    background: linear-gradient(to top, rgba(0,0,0,0.3), transparent);
}

.forumx-community-info {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    padding: 20px 24px;
    position: relative;
}

.forumx-community-avatar {
    flex-shrink: 0;
    margin-top: -60px;
    z-index: 2;
    position: relative;
}

.forumx-community-icon,
.forumx-community-icon-fallback {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 4px solid #ffffff;
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.forumx-community-icon-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    color: #b7d0db;
}

.forumx-community-details {
    flex: 1;
    min-width: 0;
}

.forumx-community-title {
    margin: 0 0 8px 0;
    font-size: 28px;
    font-weight: 700;
    color: #1a1a1b;
    line-height: 1.2;
}

.forumx-community-description {
    margin: 0 0 12px 0;
    font-size: 16px;
    line-height: 1.5;
    color: #7c7c83;
}

.forumx-community-stats {
    display: flex;
    gap: 20px;
    font-size: 14px;
    color: #787c82;
}

.forumx-community-post-count {
    font-weight: 600;
}

.forumx-community-actions {
    flex-shrink: 0;
    align-self: flex-start;
}

.forumx-create-post-btn {
    padding: 12px 24px;
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
}

/* Community Feed Controls */
.forumx-community-page:not(.forumx-dark) .forumx-feed-controls {
    background: #ffffff;
    border: 1px solid #ccc;
    border-radius: 12px;
    padding: 16px 20px;
    margin-bottom: 20px;
}

.forumx-sort-buttons {
    display: flex;
    gap: 8px;
}

.forumx-sort-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: none;
    border: 1px solid #edeff1;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    color: #787c82;
    cursor: pointer;
    transition: all 0.2s ease;
}

.forumx-sort-btn:hover {
    background: #f8f9fa;
    border-color: #ccc;
    color: #1c1c1c;
}

.forumx-sort-btn.active {
    background: #b7d0db;
    border-color: #b7d0db;
    color: white;
}

.forumx-sort-btn .dashicons {
    width: 16px;
    height: 16px;
    font-size: 16px;
}

/* Community Feed */
.forumx-community-page:not(.forumx-dark) .forumx-community-feed {
    background: #ffffff;
    border: 1px solid #ccc;
    border-radius: 12px;
    overflow: hidden;
}

/* =============================================================================
   SINGLE POST PAGE
   ============================================================================= */

.forumx-single-post-page {
    max-width: 1000px;
    margin: 0 auto;
    padding: 48px 20px 20px; /* more top spacing from site header */
}

.forumx-single-post-main {
    margin-bottom: 40px;
}

/* Single Post */
.forumx-single-post {
    background: #ffffff;
    border: 1px solid #ccc;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.forumx-single-post-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    background: #f8f9fa;
    border-bottom: 1px solid #edeff1;
}

.forumx-single-post-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 14px;
}

.forumx-single-post-meta .forumx-post-community {
    background: #b7d0db;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-weight: 600;
    font-size: 12px;
}

.forumx-single-post-meta .forumx-post-author {
    font-weight: 600;
    color: #1c1c1c;
}

.forumx-single-post-meta .forumx-post-time {
    color: #787c82;
}

.forumx-single-post-content {
    padding: 24px;
}

.forumx-single-post-title {
    margin: 0 0 20px 0;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.3;
    color: #1a1a1b;
}

.forumx-single-post-image {
    margin-bottom: 20px;
    border-radius: 8px;
    overflow: hidden;
}

.forumx-single-post-image img {
    width: 100%;
    height: auto;
    max-height: 500px;
    object-fit: cover;
}

.forumx-single-post-body {
    font-size: 16px;
    line-height: 1.6;
    color: #1c1c1c;
}

.forumx-single-post-body h1,
.forumx-single-post-body h2,
.forumx-single-post-body h3,
.forumx-single-post-body h4,
.forumx-single-post-body h5,
.forumx-single-post-body h6 {
    margin-top: 24px;
    margin-bottom: 12px;
    color: #1a1a1b;
}

.forumx-single-post-body p {
    margin-bottom: 16px;
}

.forumx-single-post-body ul,
.forumx-single-post-body ol {
    margin-bottom: 16px;
    padding-left: 20px;
}

.forumx-single-post-body blockquote {
    margin: 16px 0;
    padding: 16px 20px;
    background: #f8f9fa;
    border-left: 4px solid #b7d0db;
    font-style: italic;
}

.forumx-single-post-body code {
    background: #f1f1f1;
    padding: 2px 4px;
    border-radius: 3px;
    font-size: 0.9em;
}

.forumx-single-post-body pre {
    background: #f8f9fa;
    padding: 16px;
    border-radius: 6px;
    overflow-x: auto;
    margin-bottom: 16px;
}

.forumx-single-post-footer {
    padding: 20px 24px;
    border-top: 1px solid #edeff1;
    background: #f8f9fa;
}

.forumx-single-post-footer .forumx-post-interactions {
    justify-content: flex-start;
    gap: 20px;
}

.forumx-single-post-footer .forumx-post-voting {
    gap: 8px;
}

.forumx-single-post-footer .forumx-vote-btn {
    padding: 8px 12px;
    border-radius: 6px;
}

.forumx-single-post-footer .forumx-vote-score {
    font-weight: 700;
    font-size: 16px;
    color: #1c1c1c;
    min-width: 40px;
    text-align: center;
}

/* Comments Section */
.forumx-comments-section {
    margin-top: 24px;
    padding: 24px;
    border-top: 1px solid #edeff1;
}

.forumx-comments-title {
    margin: 0 0 20px 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1b;
}

/* Related Posts */
.forumx-related-posts {
    background: #ffffff;
    border: 1px solid #ccc;
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.forumx-related-title {
    margin: 0 0 20px 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1b;
    padding-bottom: 12px;
    border-bottom: 2px solid #b7d0db;
}

.forumx-related-posts-container {
    display: grid;
    gap: 16px;
}

.forumx-related-post {
    border: 1px solid #edeff1;
    border-radius: 8px;
    overflow: hidden;
    transition: all 0.2s ease;
}

.forumx-related-post:hover {
    border-color: #ccc;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.forumx-related-post-link {
    display: flex;
    gap: 12px;
    padding: 12px;
    text-decoration: none;
    color: inherit;
}

.forumx-related-post-link:hover {
    text-decoration: none;
}

.forumx-related-post-image {
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    border-radius: 6px;
    overflow: hidden;
}

.forumx-related-post-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.forumx-related-post-content {
    flex: 1;
    min-width: 0;
}

.forumx-related-post-title {
    margin: 0 0 6px 0;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
    color: #1c1c1c;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.forumx-related-post-meta {
    display: flex;
    gap: 8px;
    font-size: 12px;
    color: #787c82;
}

.forumx-related-post-author {
    font-weight: 500;
}

/* Responsive Design for Community and Single Post Pages */
@media (max-width: 768px) {
    .forumx-community-page,
    .forumx-single-post-page {
        padding: 16px;
    }
    
    .forumx-community-header {
        margin-bottom: 16px;
    }
    
    .forumx-community-banner {
        height: 120px;
    }
    
    .forumx-community-info {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 16px;
        padding: 16px;
    }
    
    .forumx-community-avatar {
        margin-top: -40px;
    }
    
    .forumx-community-icon,
    .forumx-community-icon-fallback {
        width: 60px;
        height: 60px;
        border-width: 3px;
    }
    
    .forumx-community-icon-fallback {
        font-size: 24px;
    }
    
    .forumx-community-title {
        font-size: 24px;
    }
    
    .forumx-community-details {
        text-align: center;
    }
    
    .forumx-feed-controls {
        padding: 12px 16px;
    }
    
    .forumx-sort-buttons {
        flex-wrap: wrap;
        justify-content: center;
    }
    
    .forumx-sort-btn {
        padding: 6px 12px;
        font-size: 12px;
    }
    
    .forumx-single-post-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding: 12px 16px;
    }
    
    .forumx-single-post-meta {
        flex-wrap: wrap;
        gap: 8px;
    }
    
    .forumx-single-post-content {
        padding: 16px;
    }
    
    .forumx-single-post-title {
        font-size: 20px;
    }
    
    .forumx-single-post-footer {
        padding: 16px;
    }
    
    .forumx-comments-section {
        padding: 16px;
    }
    
    .forumx-related-posts {
        padding: 16px;
    }
    
    .forumx-related-post-link {
        padding: 8px;
    }
}

@media (max-width: 480px) {
    .forumx-community-info {
        padding: 12px;
    }
    
    .forumx-community-title {
        font-size: 20px;
    }
    
    .forumx-community-description {
        font-size: 14px;
    }
    
    .forumx-create-post-btn {
        padding: 10px 16px;
        font-size: 12px;
    }
    
    .forumx-single-post-title {
        font-size: 18px;
    }
    
    .forumx-single-post-body {
        font-size: 15px;
    }
}

/* Dark Mode Support for Community and Single Post Pages */
@media (prefers-color-scheme: dark) {
    .forumx-community-header,
    .forumx-single-post,
    .forumx-related-posts,
    .forumx-feed-controls {
        background: #1a1a1b;
        border-color: #343536;
    }
    
    .forumx-community-title,
    .forumx-single-post-title,
    .forumx-related-title,
    .forumx-comments-title {
        color: #d7dadc;
    }
    
    .forumx-community-description {
        color: #818384;
    }
    
    .forumx-single-post-header,
    .forumx-single-post-footer {
        background: #272729;
        border-color: #343536;
    }
    
    .forumx-single-post-body {
        color: #d7dadc;
    }
    
    .forumx-single-post-body h1,
    .forumx-single-post-body h2,
    .forumx-single-post-body h3,
    .forumx-single-post-body h4,
    .forumx-single-post-body h5,
    .forumx-single-post-body h6 {
        color: #d7dadc;
    }
    
    .forumx-related-post {
        background: #272729;
        border-color: #343536;
    }
    
    .forumx-related-post-title {
        color: #d7dadc;
    }
    
    .forumx-sort-btn {
        border-color: #343536;
        color: #818384;
    }
    
    .forumx-sort-btn:hover {
        background: #272729;
        border-color: #818384;
        color: #d7dadc;
    }
}

/* =============================================================================
   CAROUSEL COMPONENT
   ============================================================================= */

/* Carousel Container */
.forumx-carousel {
    position: relative;
    width: 100%;
    margin: 20px 0;
}

.forumx-carousel-container {
    position: relative;
    display: flex;
    align-items: center;
    background: transparent;
}

.forumx-carousel-track-container {
    flex: 1;
    overflow: hidden;
    border-radius: 16px;
    position: relative;
    margin: 0 60px; /* Space for navigation buttons */
}

.forumx-carousel-track {
    display: flex;
    transition: transform 0.3s ease;
    width: 400%; /* 4 slides */
    height: auto;
    align-items: stretch;
}

.forumx-popular-card {
    min-width: 25%; /* 100% / 4 slides */
    max-width: 25%;
    flex: 0 0 25%;
    cursor: pointer;
    background: #ffffff;
    margin: 0 8px;
    box-sizing: border-box;
    height: 100%;
    display: flex;
    flex-direction: column;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    margin: 0 10px;
}

.forumx-popular-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
}

.forumx-card-image {
    height: 200px;
    background-size: cover;
    background-position: center;
    position: relative;
}

/* Karussell images: full cover without links */
.forumx-popular-posts .forumx-card-image-cover {
    height: 160px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    cursor: pointer;
}

.forumx-popular-posts .forumx-card-image-cover::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.3) 70%, rgba(0,0,0,0.7) 100%);
    z-index: 1;
}

.forumx-card-image::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(to top, rgba(0,0,0,0.7), transparent);
}

.forumx-card-fallback {
    background: linear-gradient(135deg, #b7d0db 0%, #9bc4d0 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.forumx-card-fallback::before {
    content: "📰";
    font-size: 3rem;
    opacity: 0.8;
    z-index: 1;
    position: relative;
}

/* Card content should be positioned normally for carousel */
.forumx-popular-posts .forumx-card-content {
    position: relative;
    padding: 16px;
    color: #1c1c1c;
    background: white;
}

/* Only apply absolute positioning to cards with image backgrounds */
.forumx-card-image + .forumx-card-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 20px;
    color: white;
    z-index: 2;
    background: linear-gradient(transparent, rgba(0,0,0,0.8));
}

.forumx-card-community {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
    font-size: 12px;
    opacity: 0.9;
}

.forumx-community-icon {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,0.8);
}

.forumx-community-icon.fa {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #b7d0db;
    color: #0b1b24;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    border: 2px solid rgba(255,255,255,0.8);
}

.forumx-community-name {
    font-weight: 600;
    text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}

.forumx-card-title {
    margin: 0 0 8px 0;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.3;
    text-shadow: 0 1px 2px rgba(0,0,0,0.7);
}

.forumx-card-title a {
    color: white;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.forumx-card-title a:hover {
    opacity: 0.9;
}

.forumx-card-excerpt {
    font-size: 13px;
    line-height: 1.4;
    opacity: 0.9;
    text-shadow: 0 1px 2px rgba(0,0,0,0.5);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 10px;
}

.forumx-card-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 11px;
    opacity: 0.8;
}

.forumx-card-score,
.forumx-card-comments {
    display: flex;
    align-items: center;
    gap: 4px;
}

.forumx-card-score .dashicons,
.forumx-card-comments .dashicons {
    width: 12px;
    height: 12px;
    font-size: 12px;
}

/* Carousel Navigation Buttons */
.forumx-carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.95);
    border: none;
    border-radius: 50%;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: all 0.2s ease;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
}

.forumx-carousel-btn:hover {
    background: rgba(255, 255, 255, 1);
    transform: translateY(-50%) scale(1.05);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.forumx-carousel-btn:active {
    transform: translateY(-50%) scale(0.95);
}

.forumx-carousel-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    transform: translateY(-50%) scale(1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.forumx-carousel-btn .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
    color: #333;
}

.forumx-carousel-prev {
    left: -24px;
}

.forumx-carousel-next {
    right: -24px;
}

/* Carousel Indicators */
.forumx-carousel-indicators {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 20px;
}

.forumx-carousel-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: rgba(0, 0, 0, 0.3);
    cursor: pointer;
    transition: all 0.2s ease;
}

.forumx-carousel-indicator.active,
.forumx-carousel-indicator:hover {
    background: #b7d0db;
    transform: scale(1.2);
}

/* Responsive Design for Carousel */
@media (max-width: 1024px) {
    .forumx-carousel-track {
        width: 200%; /* Show 2 slides on tablets */
    }
    
    .forumx-popular-card {
        min-width: 50%;
        max-width: 50%;
        flex: 0 0 50%;
    }
}

@media (max-width: 768px) {
    .forumx-carousel-track-container {
        margin: 0 50px; /* Less margin on mobile */
    }
    
    .forumx-carousel-track {
        width: 100%; /* Show 1 slide on mobile */
    }
    
    .forumx-popular-card {
        min-width: 100%;
        max-width: 100%;
        flex: 0 0 100%;
        margin: 0 4px;
    }
    
    .forumx-carousel-btn {
        width: 40px;
        height: 40px;
    }
    
    .forumx-carousel-btn .dashicons {
        font-size: 16px;
        width: 16px;
        height: 16px;
    }
    
    .forumx-carousel-prev {
        left: -20px;
    }
    
    .forumx-carousel-next {
        right: -20px;
    }
    
    .forumx-card-image {
        height: 160px;
    }
    
    .forumx-card-content {
        padding: 16px;
    }
    
    .forumx-card-title {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .forumx-carousel-prev {
        left: 5px;
    }
    
    .forumx-carousel-next {
        right: 5px;
    }
    
    .forumx-carousel-btn {
        background: rgba(0, 0, 0, 0.7);
    }
    
    .forumx-carousel-btn .dashicons {
        color: white;
    }
}

/* Fix community icon sizing globally */
.forumx-community-icon {
    width: 24px;
    height: 24px;
    object-fit: cover;
    border-radius: 50%;
}

.forumx-community-icon.fa {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: #b7d0db;
    color: #0b1b24;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
}

/* Single Community Template Styles */
.forumx-single-community-wrapper {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

.forumx-community-header {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    margin-bottom: 30px;
}

.forumx-community-banner {
    height: 200px;
    overflow: hidden;
}

.forumx-community-banner-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.forumx-community-info {
    padding: 20px;
    display: flex;
    gap: 20px;
    align-items: flex-start;
}

.forumx-community-icon-large {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    font-size: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--fx-light);
    color: var(--fx-muted);
    flex-shrink: 0;
}

.forumx-community-meta {
    flex: 1;
}

.forumx-community-title {
    margin: 0 0 10px 0;
    font-size: 28px;
    font-weight: 700;
    color: var(--fx-fg);
}

.forumx-community-description {
    color: var(--fx-muted);
    margin: 0 0 15px 0;
    font-size: 16px;
    line-height: 1.5;
}

.forumx-community-stats {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
    font-size: 14px;
    color: var(--fx-muted);
}

.forumx-create-post-btn,
.forumx-login-btn {
    background: var(--fx-accent);
    color: white;
    border: none;
    padding: 12px 24px;
    border-radius: 25px;
    font-weight: 600;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.forumx-create-post-btn:hover,
.forumx-login-btn:hover {
    background: var(--fx-accent-dark);
    transform: translateY(-1px);
}

/* Single Post Template Styles */
.forumx-single-post-wrapper {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
}

.forumx-single-post {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    margin-bottom: 30px;
}

.forumx-post-header {
    padding: 30px;
    border-bottom: 1px solid var(--fx-border);
}

.forumx-post-community-info {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 15px;
}

.forumx-community-link {
    color: var(--fx-accent);
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
}

.forumx-community-link:hover {
    text-decoration: underline;
}

.forumx-post-title {
    margin: 0 0 20px 0;
    font-size: 32px;
    font-weight: 700;
    line-height: 1.3;
    color: var(--fx-fg);
}

.forumx-post-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.forumx-author-info {
    display: flex;
    align-items: center;
    gap: 12px;
}

.forumx-author-details {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.forumx-author-name {
    font-weight: 600;
    color: var(--fx-fg);
    font-size: 14px;
}

.forumx-post-date {
    color: var(--fx-muted);
    font-size: 12px;
}

.forumx-post-actions {
    display: flex;
    align-items: center;
    gap: 15px;
}

.forumx-vote-section {
    display: flex;
    align-items: center;
    gap: 8px;
}

.forumx-vote-btn {
    background: none;
    border: 1px solid var(--fx-border);
    width: 32px;
    height: 32px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.forumx-vote-btn:hover {
    background: var(--fx-light);
    border-color: var(--fx-accent);
}

.forumx-upvote:hover {
    color: var(--fx-success);
}

.forumx-downvote:hover {
    color: var(--fx-danger);
}

/* Active vote button states */
.forumx-vote-btn.active.forumx-vote-up {
    background: var(--fx-success);
    color: white;
    border-color: var(--fx-success);
}

.forumx-vote-btn.active.forumx-vote-down {
    background: var(--fx-danger);
    color: white;
    border-color: var(--fx-danger);
}

.forumx-vote-btn.active:hover {
    opacity: 0.8;
}

.forumx-vote-score {
    font-weight: 600;
    font-size: 14px;
    min-width: 30px;
    text-align: center;
}

.forumx-post-content {
    padding: 30px;
}

.forumx-post-image {
    margin-bottom: 20px;
}

.forumx-post-image img {
    width: 100%;
    height: auto;
    border-radius: 8px;
}

.forumx-post-body {
    font-size: 16px;
    line-height: 1.6;
    color: var(--fx-fg);
}

.forumx-post-body p {
    margin-bottom: 16px;
}

.forumx-post-footer {
    padding: 20px 30px;
    border-top: 1px solid var(--fx-border);
    background: var(--fx-light);
}

.forumx-post-tags {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.forumx-tag {
    background: var(--fx-accent);
    color: white;
    padding: 4px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 500;
}

/* Comments Wrapper */
.forumx-comments-wrapper {
    background: white;
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.forumx-comments-title {
    margin: 0 0 20px 0;
    font-size: 20px;
    font-weight: 700;
}

.forumx-comment-respond {
    margin-bottom: 30px;
}

.forumx-comment-form {
    background: var(--fx-light);
    padding: 20px;
    border-radius: 8px;
}

.forumx-comment-form-field {
    margin-bottom: 15px;
}

.forumx-comment-label {
    display: block;
    margin-bottom: 5px;
    font-weight: 600;
    color: var(--fx-fg);
}

.forumx-comment-form textarea {
    width: 100%;
    min-height: 100px;
    padding: 12px;
    border: 1px solid var(--fx-border);
    border-radius: 6px;
    font-family: inherit;
    resize: vertical;
}

.forumx-comment {
    padding: 20px 0;
    border-bottom: 1px solid var(--fx-border);
}

.forumx-comment:last-child {
    border-bottom: none;
}

.forumx-comment-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

.forumx-comment-avatar {
    border-radius: 50%;
}

.forumx-comment-meta {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.forumx-comment-author {
    font-weight: 600;
    color: var(--fx-fg);
    font-size: 14px;
}

.forumx-comment-date {
    color: var(--fx-muted);
    font-size: 12px;
}

.forumx-comment-content {
    margin-left: 52px;
    margin-bottom: 10px;
    color: var(--fx-fg);
    line-height: 1.5;
}

.forumx-comment-actions {
    margin-left: 52px;
}

.forumx-comment-reply {
    color: var(--fx-accent);
    text-decoration: none;
    font-size: 12px;
    font-weight: 600;
}

.forumx-comment-reply:hover {
    text-decoration: underline;
}

/* Community Posts */
.forumx-community-posts {
    background: white;
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.forumx-community-post-item {
    padding: 20px 0;
    border-bottom: 1px solid var(--fx-border);
}

.forumx-community-post-item:last-child {
    border-bottom: none;
}

.forumx-post-title a {
    color: var(--fx-fg);
    text-decoration: none;
    font-size: 18px;
    font-weight: 600;
}

.forumx-post-title a:hover {
    color: var(--fx-accent);
}

.forumx-post-excerpt {
    margin: 10px 0 15px 0;
    color: var(--fx-muted);
    line-height: 1.5;
}

.forumx-read-more {
    color: var(--fx-accent);
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
}

.forumx-read-more:hover {
    text-decoration: underline;
}

/* Related Posts */
.forumx-related-posts {
    background: white;
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.forumx-related-posts h3 {
    margin: 0 0 20px 0;
    font-size: 20px;
    font-weight: 700;
}

.forumx-related-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
}

.forumx-related-post {
    padding: 15px;
    background: var(--fx-light);
    border-radius: 8px;
}

.forumx-related-post h4 {
    margin: 0 0 8px 0;
    font-size: 16px;
}

.forumx-related-post h4 a {
    color: var(--fx-fg);
    text-decoration: none;
}

.forumx-related-post h4 a:hover {
    color: var(--fx-accent);
}

.forumx-related-post-meta {
    font-size: 12px;
    color: var(--fx-muted);
    display: flex;
    gap: 10px;
}

/* No Posts Message */
.forumx-no-posts {
    text-align: center;
    padding: 40px 20px;
    color: var(--fx-muted);
    background: white;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

/* Responsive Design */
@media (max-width: 768px) {
    .forumx-single-community-wrapper,
    .forumx-single-post-wrapper {
        padding: 10px;
    }
    
    .forumx-community-info {
        flex-direction: column;
        text-align: center;
    }
    
    .forumx-community-icon-large {
        margin: 0 auto;
    }
    
    .forumx-post-meta {
        flex-direction: column;
        gap: 15px;
        align-items: flex-start;
    }
    
    .forumx-post-actions {
        order: -1;
    }
    
    .forumx-post-title {
        font-size: 24px;
    }
    
    .forumx-comment-content,
    .forumx-comment-actions {
        margin-left: 0;
        margin-top: 10px;
    }
}

/* Community links in post meta */
.forumx-post-community a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s ease;
}

.forumx-post-community a:hover {
    border-bottom-color: var(--fx-accent);
    color: var(--fx-accent);
}


/* Dashboard Background Transparency */
.forumx-dashboard {
    background: transparent;
}

.forumx-dashboard > * {
    background: transparent;
}

/* Keep cards with proper backgrounds */
.forumx-dashboard:not(.forumx-dark) .forumx-popular-card,
.forumx-dashboard:not(.forumx-dark) .forumx-dashboard-feed,
.forumx-dashboard:not(.forumx-dark) .forumx-dashboard-sidebar,
.forumx-dashboard:not(.forumx-dark) .forumx-feed-controls,
.forumx-dashboard:not(.forumx-dark) .forumx-dashboard-post {
    background: #ffffff;
}

/* =============================================================================
   DEFENSIVE CSS FOR COMPLIANZ/ADBLOCK COMPATIBILITY
   ============================================================================= */

/* Prevent layout breaks when cookie blocker CSS is blocked */
.cmplz-blocked,
.cmplz-consent-banner,
.cmplz-cookiebanner,
[class*="cookie"],
[class*="gdpr"] {
    /* Fallback styles if third-party CSS is blocked */
    position: relative !important;
    z-index: 999999 !important;
}

/* Ensure ForumX layout is not affected by missing external CSS */
.forumx {
    /* Reset any potential interference */
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

/* Prevent adblock from breaking ForumX styling */
.forumx-dashboard,
.forumx-community-page,
.forumx-single-post-page {
    /* Ensure core layout remains intact */
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Fallback for blocked external resources */
@supports not (display: contents) {
    /* Graceful degradation for older browsers */
    .forumx-carousel {
        display: block;
    }
    
    .forumx-carousel-track {
        display: block;
    }
    
    .forumx-popular-card {
        display: block;
        margin-bottom: 20px;
    }
}

/* Prevent cookie consent interference with forum modals */
.forumx-modal {
    z-index: 1000000 !important; /* Higher than most cookie banners */
}

/* Ensure forum content is readable even with cookie overlays */
.forumx-dashboard {
    position: relative;
    z-index: 1;
}

/* Defensive loading states */
.forumx-loading {
    display: inline-block;
    min-height: 20px;
    /* Ensure loading text is visible even if external fonts fail */
    font-family: system-ui, -apple-system, sans-serif;
}

/* Error handling for blocked resources */
.forumx-error {
    background: #ffebee !important;
    color: #c62828 !important;
    padding: 12px 16px !important;
    border-radius: 4px !important;
    font-family: system-ui, -apple-system, sans-serif !important;
    border: 1px solid #ef5350 !important;
}

/* Ensure buttons remain functional */
.forumx-btn,
.forumx-vote-btn,
.forumx-report-btn,
.forumx-share-btn {
    cursor: pointer !important;
    user-select: none !important;
    /* Prevent accidental text selection on buttons */
}

/* Removed over-aggressive dashicons fallbacks that produced wrong glyphs */
html body .forumx-dashboard {
    background: transparent !important;
}

body .forumx-dashboard:not(.forumx-dark) .forumx-popular-card,
html body .forumx-dashboard:not(.forumx-dark) .forumx-popular-card,
body .forumx-dashboard:not(.forumx-dark) .forumx-dashboard-feed,
html body .forumx-dashboard:not(.forumx-dark) .forumx-dashboard-feed,
body .forumx-dashboard:not(.forumx-dark) .forumx-dashboard-sidebar,
html body .forumx-dashboard:not(.forumx-dark) .forumx-dashboard-sidebar {
    background: #ffffff !important;
}


/* ================================
   COMMUNITY PAGE STYLES
   ================================ */

/* Community Page Container */
.forumx-community-page {
    max-width: 1200px;
    margin: 0 auto;
    background-color: #DAE0E6;
    min-height: 100vh;
}

/* Community Header */
.forumx-community-header {
    background: transparent;
    border-bottom: 1px solid #EDEFF1;
    margin-bottom: 20px;
}

.forumx-community-banner {
    height: 200px;
    background: none;
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
}

.forumx-community-banner-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 60px;
    background: linear-gradient(transparent, rgba(0,0,0,0.3));
}

.forumx-community-info-wrapper {
    padding: 0 20px;
    background: #ffffff;
}

.forumx-community-info {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding: 20px 0;
    max-width: 100%;
}

.forumx-community-identity {
    display: flex;
    align-items: flex-end;
    gap: 16px;
    flex: 1;
}

.forumx-community-avatar {
    margin-top: -40px;
    z-index: 2;
    position: relative;
}

.forumx-community-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 4px solid #ffffff;
    background: #ffffff;
    object-fit: cover;
}

.forumx-community-icon-fallback {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 4px solid #ffffff;
    background: linear-gradient(135deg, #b7d0db, #9bc4d0);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
}

.forumx-community-details {
    flex: 1;
    min-width: 0;
}

.forumx-community-title {
    margin: 0 0 8px 0;
    font-size: 28px;
    font-weight: 700;
    color: #1A1A1B;
    line-height: 1.2;
}

.forumx-community-description {
    margin: 0 0 12px 0;
    color: #7C7C83;
    font-size: 16px;
    line-height: 1.4;
}

/* Ensure long community descriptions wrap in header area */
.forumx-community-title-content .forumx-community-description {
    white-space: normal;            /* allow multi-line */
    overflow-wrap: anywhere;        /* break long words/URLs */
    word-wrap: break-word;          /* legacy support */
    text-overflow: clip;            /* no ellipsis */
    overflow: visible;              /* let text expand the container */
}

.forumx-community-stats {
    display: flex;
    gap: 24px;
    align-items: center;
    flex-wrap: wrap;
}

.forumx-stat {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: #7C7C83;
}

.forumx-stat strong {
    color: #1A1A1B;
    font-weight: 600;
}

.forumx-online-indicator {
    width: 8px;
    height: 8px;
    background: #46D160;
    border-radius: 50%;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% { opacity: 1; }
    50% { opacity: 0.5; }
    100% { opacity: 1; }
}

.forumx-community-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-shrink: 0;
}

/* Community Navigation */
.forumx-community-nav {
    background: #ffffff;
    border-bottom: 1px solid #EDEFF1;
    margin-bottom: 20px;
    position: sticky;
    top: 60px;
    z-index: 10;
}

.forumx-nav-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.forumx-nav-tabs {
    display: flex;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.forumx-nav-tab {
    background: none;
    border: none;
    padding: 16px 24px;
    color: #7C7C83;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: 3px solid transparent;
    transition: all 0.2s ease;
}

.forumx-nav-tab:hover {
    color: #1A1A1B;
    background-color: #F8F9FA;
}

.forumx-nav-tab.active {
    color: #0079D3;
    border-bottom-color: #0079D3;
}

.forumx-nav-tab .dashicons {
    width: 16px;
    height: 16px;
    font-size: 16px;
}

.forumx-nav-controls {
    display: flex;
    align-items: center;
    gap: 16px;
}

.forumx-sort-select {
    padding: 8px 12px;
    border: 1px solid #EDEFF1;
    border-radius: 20px;
    background: #ffffff;
    color: #1A1A1B;
    font-size: 14px;
    cursor: pointer;
}

/* Community Content Layout */
.forumx-community-content {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 20px;
    padding: 0 20px;
    max-width: 1200px;
    margin: 0 auto;
}

.forumx-community-main {
    min-width: 0;
}

.forumx-tab-panel {
    background: transparent;
}

/* Community Feed */
.forumx-community-feed { background: transparent; }
.forumx-community-page:not(.forumx-dark) .forumx-community-feed .forumx-feed-content .forumx-dashboard-post { background: #ffffff; border: 1px solid #EDEFF1; border-radius: 8px; margin-bottom: 10px; transition: all 0.2s ease; }
.forumx-community-page:not(.forumx-dark) .forumx-community-feed .forumx-dashboard-post:hover { border-color: #878A8C; }

/* Community Sidebar */
.forumx-community-sidebar {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.forumx-sidebar-widget {
    background: #ffffff;
    border: 1px solid #EDEFF1;
    border-radius: 8px;
    overflow: hidden;
}

.forumx-widget-title {
    background: #F8F9FA;
    padding: 12px 16px;
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: #1A1A1B;
    border-bottom: 1px solid #EDEFF1;
}

.forumx-widget-content {
    padding: 16px;
}

.forumx-widget-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    margin-bottom: 12px;
}

.forumx-widget-stats {
    display: flex;
    gap: 20px;
    margin: 12px 0;
}

.forumx-stat-item {
    text-align: center;
}

.forumx-stat-number {
    display: block;
    font-size: 18px;
    font-weight: 700;
    color: #1A1A1B;
    line-height: 1;
}

.forumx-stat-label {
    display: block;
    font-size: 12px;
    color: #7C7C83;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 4px;
}

.forumx-widget-description p {
    margin: 0;
    font-size: 14px;
    color: #7C7C83;
    line-height: 1.4;
}

/* About Tab Content */
.forumx-community-about {
    background: #ffffff;
    border: 1px solid #EDEFF1;
    border-radius: 8px;
    padding: 20px;
}

.forumx-about-section {
    margin-bottom: 24px;
}

.forumx-about-section:last-child {
    margin-bottom: 0;
}

.forumx-about-section h3 {
    margin: 0 0 12px 0;
    font-size: 16px;
    font-weight: 600;
    color: #1A1A1B;
}

.forumx-about-section p {
    margin: 0;
    color: #7C7C83;
    line-height: 1.5;
}

.forumx-community-rules {
    color: #7C7C83;
    line-height: 1.5;
}

/* Buttons */
.forumx-btn-primary {
    background: #0079D3;
    color: #ffffff;
    border: 1px solid #0079D3;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.forumx-btn-primary:hover {
    background: #0060A8;
    border-color: #0060A8;
    color: #ffffff;
}

.forumx-btn-secondary {
    background: transparent;
    color: #0079D3;
    border: 1px solid #0079D3;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    transition: all 0.2s ease;
}

.forumx-btn-secondary:hover {
    background: #0079D3;
    color: #ffffff;
}

.forumx-create-post-btn .dashicons {
    width: 16px;
    height: 16px;
    font-size: 16px;
}

/* Loading States */
.forumx-loading-small {
    padding: 20px;
    text-align: center;
    color: #7C7C83;
    font-size: 14px;
}

/* Modal Styles */
.forumx-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.forumx-modal-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    cursor: pointer;
}

.forumx-modal-container {
    position: relative;
    max-width: 600px;
    width: 100%;
    max-height: 90vh;
    overflow: auto;
    z-index: 1001;
}

.forumx-modal-content {
    background: #ffffff;
    border-radius: 8px;
    padding: 24px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

/* Strong dark overrides for ForumX creation modals to prevent white flash */
#forumx-create-post-modal .forumx-modal-content,
#forumx-create-community-modal .forumx-modal-content {
    background: rgba(42,42,42,0.85) !important;
    border: 1px solid #3a3a3a !important;
    -webkit-backdrop-filter: blur(8px) saturate(140%);
    backdrop-filter: blur(8px) saturate(140%);
    color: #e5e7eb;
}

/* Ensure post modal overlays everything consistently */
#forumx-create-post-modal { z-index: 10000 !important; }

/* Single Community: Create-post button text + icon must be black */
.forumx-community-page .forumx-create-post-btn.forumx-create-community-btn {
    color: #000 !important;
    background: #b7d0db; /* keep dashboard accent */
}
.forumx-community-page .forumx-create-post-btn.forumx-create-community-btn .dashicons {
    color: #000 !important;
}

/* Single Community: Highlight posts count under description (dark theme) */
.forumx-community-page.forumx-dark .forumx-community-stats .forumx-stat {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid #3a3a3a;
    padding: 4px 10px;
    border-radius: 999px;
    font-weight: 700;
}
.forumx-community-page.forumx-dark .forumx-community-stats .forumx-stat strong {
    color: #ffffff;
}

/* Similar Communities: bigger theme label for accessibility */
.forumx-similar-community-item .forumx-theme-tag {
    font-size: 13px !important;
    padding: 4px 10px !important;
    border-radius: 12px;
}
#forumx-create-post-modal .forumx-modal-header,
#forumx-create-community-modal .forumx-modal-header { border-bottom: 1px solid #1f2937; }
#forumx-create-post-modal .forumx-modal-footer,
#forumx-create-community-modal .forumx-modal-footer { border-top: 1px solid #1f2937; }
#forumx-create-post-modal label,
#forumx-create-community-modal label { color:#ffffff; font-weight:700; }
#forumx-create-post-modal input,
#forumx-create-post-modal textarea,
#forumx-create-post-modal select,
#forumx-create-community-modal input,
#forumx-create-community-modal textarea,
#forumx-create-community-modal select {
    background:#1a1a1a; color:#ffffff; border:1px solid #374151; border-radius:8px;
}
#forumx-create-post-modal input::placeholder,
#forumx-create-post-modal textarea::placeholder,
#forumx-create-community-modal input::placeholder,
#forumx-create-community-modal textarea::placeholder { color:#9ca3af; }
#forumx-create-post-modal input:focus,
#forumx-create-post-modal textarea:focus,
#forumx-create-community-modal input:focus,
#forumx-create-community-modal textarea:focus {
    outline:none; border-color: var(--fx-accent); box-shadow: 0 0 0 3px rgba(183,208,219,.2);
}
#forumx-create-post-modal .forumx-btn-primary,
#forumx-create-community-modal .forumx-btn-primary { background: var(--fx-accent); color:#0b1b24; border:1px solid var(--fx-accent); }
#forumx-create-post-modal .forumx-btn-secondary,
#forumx-create-community-modal .forumx-btn-secondary { background:#2a2a2a; color:#ffffff; border:1px solid #3a3a3a; }
#forumx-create-post-modal .forumx-upload-button,
#forumx-create-community-modal .forumx-upload-button { background:#111827; border:1px solid #374151; color:#e5e7eb; }
#forumx-create-post-modal .forumx-upload-button:hover,
#forumx-create-community-modal .forumx-upload-button:hover { background:#0b1220; border-color: var(--fx-accent); color: var(--fx-accent); }

/* ================================
   RESPONSIVE DESIGN
   ================================ */

@media (max-width: 1024px) {
    .forumx-community-content {
        grid-template-columns: 1fr 280px;
        gap: 16px;
    }
    
    .forumx-nav-container {
        padding: 0 16px;
    }
    
    .forumx-community-info-wrapper {
        padding: 0 16px;
    }
}

@media (max-width: 768px) {
    .forumx-community-page {
        margin-top: 80px;
    }
    
    .forumx-community-content {
        grid-template-columns: 1fr;
        gap: 16px;
        padding: 0 16px;
    }
    
    .forumx-community-sidebar {
        order: -1;
    }
    
    .forumx-community-info {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }
    
    .forumx-community-identity {
        flex-direction: column;
        align-items: flex-start;
        text-align: left;
        width: 100%;
    }
    
    .forumx-community-title-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
        width: 100%;
    }
    
    .forumx-community-title-content {
        width: 100%;
    }
    
    .forumx-community-description {
        word-wrap: break-word;
        overflow-wrap: break-word;
        white-space: normal;
        width: 100%;
    }
    
    .forumx-community-avatar {
        margin-top: -60px;
    }
    
    .forumx-community-actions {
        width: 100%;
        justify-content: center;
    }
    
    .forumx-community-banner {
        height: 120px;
    }
    
    .forumx-community-title {
        font-size: 24px;
    }
    
    .forumx-community-stats {
        justify-content: center;
    }
    
    .forumx-nav-tabs {
        flex: 1;
    }
    
    .forumx-nav-tab {
        padding: 12px 16px;
        font-size: 13px;
    }
    
    .forumx-nav-controls {
        display: none;
    }
    
    .forumx-modal {
        padding: 10px;
    }
    
    .forumx-modal-content {
        padding: 16px;
    }
}

@media (max-width: 480px) {
    .forumx-community-info-wrapper {
        padding: 0 12px;
    }
    
    .forumx-nav-container {
        padding: 0 12px;
    }
    
    .forumx-community-content {
        padding: 0 12px;
    }
    
    .forumx-community-actions {
        flex-direction: column;
        gap: 8px;
    }
    
    .forumx-btn-primary,
    .forumx-btn-secondary {
        width: 100%;
        justify-content: center;
    }
    
    .forumx-nav-tab {
        padding: 12px 8px;
        font-size: 12px;
    }
    
    .forumx-widget-stats {
        justify-content: space-around;
    }
}

/* Screen Reader Support */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ========================================
   MODERNES SINGLE POST DESIGN
   ======================================== */

/* Main Container */
.forumx-single-post-page {
    background: transparent;
    min-height: 100vh;
    padding: 80px 0 40px 0;
}

.forumx-container {
    max-width: 768px;
    margin: 0 auto;
    padding: 0 16px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Post Card - Modernes Design */
.forumx-post-card {
    background: white;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

/* Post Header */
.forumx-post-header {
    padding: 16px 20px 12px 20px;
    border-bottom: 1px solid #f0f0f0;
}

.forumx-post-meta {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.forumx-community-link-container {
    display: flex;
    align-items: center;
}

.forumx-community-link {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #1a1a1b;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
    transition: color 0.2s ease;
}

.forumx-community-link:hover {
    color: #0079d3;
}

.forumx-community-icon {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.forumx-community-icon-default {
    background: linear-gradient(135deg, #0079d3, #005ba1);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
}

.forumx-community-name {
    color: inherit;
}

.forumx-post-details {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #787c7e;
}

.forumx-post-author,
.forumx-post-time {
    color: #787c7e;
}

/* Post Content */
.forumx-post-content {
    padding: 0 20px 16px 20px;
}

.forumx-post-title {
    font-size: 20px;
    font-weight: 600;
    line-height: 1.4;
    color: #1a1a1b;
    margin: 0 0 16px 0;
    word-wrap: break-word;
}

.forumx-post-media {
    margin: 0 0 16px 0;
    border-radius: 8px;
    overflow: hidden;
}

.forumx-post-image {
    width: 100%;
    height: auto;
    max-height: 500px;
    object-fit: cover;
    display: block;
}

.forumx-post-text {
    font-size: 16px;
    line-height: 1.6;
    color: #1a1a1b;
    word-break: break-word;
    overflow-wrap: anywhere;
}

.forumx-post-text p {
    margin: 0 0 16px 0;
}

.forumx-post-text p:last-child {
    margin-bottom: 0;
}

/* Post Actions */
.forumx-post-actions {
    padding: 8px 12px;
    background: #f8f9fa;
    border-top: 1px solid #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.forumx-voting-section {
    display: flex;
    align-items: center;
    background: white;
    border-radius: 20px;
    padding: 4px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    border: 1px solid #e5e5e5;
}

.forumx-vote-btn {
    background: none;
    border: none;
    padding: 6px 8px;
    cursor: pointer;
    color: #878a8c;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    transition: all 0.2s ease;
    min-width: 32px;
    height: 32px;
}

.forumx-vote-btn:hover {
    background: #f8f9fa;
}

.forumx-vote-up:hover,
.forumx-vote-up.active {
    color: #b7d0db;
    background: #f0f7f8;
}

.forumx-vote-down:hover,
.forumx-vote-down.active {
    color: #7193ff;
    background: #f0f3ff;
}

.forumx-vote-score {
    padding: 0 8px;
    font-weight: 700;
    font-size: 14px;
    color: #1a1a1b;
    min-width: 32px;
    text-align: center;
}

.forumx-action-buttons {
    display: flex;
    align-items: center;
    gap: 4px;
}

.forumx-action-btn {
    background: none;
    border: none;
    padding: 8px 12px;
    color: #878a8c;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    border-radius: 20px;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.forumx-action-btn:hover {
    background: #f8f9fa;
    color: #1a1a1b;
}

.forumx-comments-count {
    font-weight: 700;
}

/* Comments Section */
.forumx-comments-section {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Comment Form Card */
.forumx-comment-form-card,
.forumx-login-prompt-card {
    background: #212121;
    border-radius: 12px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
    border: 1px solid #2f2f2f;
    overflow: hidden;
    color: #f5f5f5;
}

.forumx-comment-form-header {
    padding: 16px 20px 12px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid #2f2f2f;
}

.forumx-user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.forumx-comment-as {
    font-size: 12px;
    color: #cbd5f5;
}

.forumx-comment-form {
    padding: 0 20px 16px 20px;
}

.forumx-comment-input-wrapper {
    margin-bottom: 12px;
}

.forumx-comment-textarea {
    width: 100%;
    min-height: 120px;
    padding: 16px;
    border: 1px solid #3d3d3d;
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    resize: vertical;
    background: #2c2c2c;
    color: #f5f5f5;
    transition: all 0.2s ease;
    box-sizing: border-box;
}

.forumx-comment-textarea:focus {
    outline: none;
    border-color: #b7d0db;
    background: #2f2f2f;
    box-shadow: 0 0 0 1px rgba(183, 208, 219, 0.2);
}

.forumx-comment-form-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.forumx-comment-helper-text {
    color: rgba(229, 229, 229, 0.75);
    font-size: 11px;
}

.forumx-comment-form-actions {
    display: flex;
    gap: 8px;
}

/* Login Prompt */
.forumx-login-prompt {
    padding: 32px;
    text-align: center;
}

.forumx-login-prompt h3 {
    margin: 0 0 8px 0;
    color: #1a1a1b;
    font-size: 18px;
    font-weight: 600;
}

.forumx-login-prompt p {
    margin: 0 0 20px 0;
    color: #787c7e;
    font-size: 14px;
}

/* Button Styles */
.forumx-btn {
    padding: 8px 16px;
    border: none;
    border-radius: 20px;
    font-weight: 700;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
}

@media (max-width: 600px) {
    .forumx-btn {
        white-space: normal;
        flex-wrap: wrap;
        justify-content: center;
        text-align: center;
        max-width: 100%;
    }

    .forumx-create-post-btn {
        white-space: normal;
    }

    .forumx-dashboard-sidebar .forumx-community-item,
    .forumx-communities-list .forumx-community-item {
        justify-content: center;
        text-align: center;
    }

    .forumx-dashboard-sidebar .forumx-community-info,
    .forumx-communities-list .forumx-community-info {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .forumx-dashboard-sidebar .forumx-community-name,
    .forumx-dashboard-sidebar .forumx-community-count,
    .forumx-communities-list .forumx-community-name,
    .forumx-communities-list .forumx-community-count {
        text-align: center;
    }
}

.forumx-btn-primary {
    background: var(--fx-accent);
    color: #0b1b24;
}

.forumx-btn-primary:hover {
    background: var(--fx-accent-dark);
    transform: translateY(-1px);
}

.forumx-btn-primary:disabled {
    background: #ccc;
    cursor: not-allowed;
    transform: none;
}

/* Comments List Card */
.forumx-comments-list-card {
    background: white;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(0, 0, 0, 0.05);
    overflow: hidden;
}

/* =============================================================================
   FORUMX DASHBOARD DARK THEME (scoped)
   ============================================================================= */
.forumx h2 { font-size: 24px; font-weight: 700; line-height: 1.25; }
.forumx h3 { font-size: 18px; font-weight: 600; line-height: 1.25; }
.forumx-dashboard.forumx-dark {
    color: #e5edf1;
}

.forumx-dashboard.forumx-dark .forumx-section-title,
.forumx-dashboard.forumx-dark .forumx-feed-title,
.forumx-dashboard.forumx-dark .forumx-widget-title {
    color: var(--fx-accent);
    border-bottom-color: var(--fx-accent);
}

/* Glass surfaces */
.forumx-dashboard.forumx-dark .forumx-dashboard-feed,
.forumx-dashboard.forumx-dark .forumx-dashboard-sidebar,
.forumx-dashboard.forumx-dark .forumx-dashboard-post,
.forumx-dashboard.forumx-dark .forumx-popular-card,
.forumx-dashboard.forumx-dark .forumx-modal-content,
.forumx-dashboard.forumx-dark .forumx-feed-header {
    background: rgba(42, 42, 42, 0.92); /* #2a2a2a glass */
    -webkit-backdrop-filter: saturate(140%) blur(8px);
    backdrop-filter: saturate(140%) blur(8px);
    border: 1px solid #3a3a3a;
}

.forumx-dashboard.forumx-dark .forumx-dashboard-post:hover {
    background: rgba(255, 255, 255, 0.06); /* subtle elevation, not color shift */
}

.forumx-dashboard.forumx-dark .forumx-feed-header {
    border-bottom-color: #3a3a3a;
}

.forumx-dashboard.forumx-dark .forumx-dashboard-post-title a {
    color: var(--fx-accent);
}

.forumx-dashboard.forumx-dark .forumx-dashboard-post,
.forumx-dashboard.forumx-dark .forumx-post-text,
.forumx-dashboard.forumx-dark .forumx-post-text p,
.forumx-dashboard.forumx-dark .forumx-post-text li {
    color: #e5e7eb;
}
.forumx-dashboard.forumx-dark .forumx-post-text a { color: var(--fx-accent); }
.forumx-dashboard.forumx-dark .forumx-post-author-info,
.forumx-dashboard.forumx-dark .forumx-community-description,
.forumx-dashboard.forumx-dark .forumx-community-count,
.forumx-dashboard.forumx-dark .forumx-comments-toggle {
    color: #ffffff;
}

.forumx-dashboard.forumx-dark .forumx-comments-toggle:hover,
.forumx-dashboard.forumx-dark .forumx-comments-toggle.active {
    background: rgba(183, 208, 219, 0.15);
    color: #e5edf1;
}

.forumx-dashboard.forumx-dark .forumx-vote-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: #d1d5db;
}

/* Sidebar community item hover */
.forumx-dashboard.forumx-dark .forumx-community-item:hover {
    background: rgba(183, 208, 219, 0.08);
}

/* Sidebar widget & title in dark */
.forumx-dashboard.forumx-dark .forumx-sidebar-widget {
    background: #2a2a2a;
    border-color: #3a3a3a;
}
.forumx-dashboard.forumx-dark .forumx-widget-title {
    background: transparent;
    border-bottom-color: #3a3a3a;
    color: var(--fx-accent);
}

/* Focus styles for accessibility */
.forumx-dashboard.forumx-dark a:focus-visible,
.forumx-dashboard.forumx-dark button:focus-visible,
.forumx-dashboard.forumx-dark [role="button"]:focus-visible,
.forumx-dashboard.forumx-dark [role="link"]:focus-visible,
.forumx-single-post-page.forumx-dark a:focus-visible,
.forumx-single-post-page.forumx-dark button:focus-visible,
.forumx-single-post-page.forumx-dark [role="button"]:focus-visible,
.forumx-single-post-page.forumx-dark [role="link"]:focus-visible,
.forumx-community-page.forumx-dark a:focus-visible,
.forumx-community-page.forumx-dark button:focus-visible,
.forumx-community-page.forumx-dark [role="button"]:focus-visible,
.forumx-community-page.forumx-dark [role="link"]:focus-visible {
    outline: 2px solid var(--fx-accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 3px rgba(183, 208, 219, 0.3);
    border-radius: 6px;
}

/* Carousel cards: keep overlay text readable in dark */
.forumx-dashboard.forumx-dark .forumx-popular-card.no-image .forumx-carousel-title {
    color: var(--fx-accent);
}
.forumx-dashboard.forumx-dark .forumx-popular-card.no-image .forumx-carousel-community {
    color: #9ca3af;
}


.forumx-comments-header {
    padding: 16px 20px;
    border-bottom: 1px solid #f0f0f0;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.forumx-comments-title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #1a1a1b;
    display: flex;
    align-items: center;
    gap: 8px;
}

.forumx-comments-total {
    color: #787c7e;
    font-weight: 400;
}

.forumx-comments-sort {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #787c7e;
}

.forumx-comments-sort-select {
    padding: 4px 8px;
    border: 1px solid #e5e5e5;
    border-radius: 4px;
    font-size: 12px;
    background: white;
    color: #1a1a1b;
}

.forumx-comments-container {
    min-height: 60px;
    display: flex;
    flex-direction: column;
}

.forumx-comments-loading {
    padding: 40px 20px;
    text-align: center;
    color: #787c7e;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}

.forumx-loading-spinner {
    width: 20px;
    height: 20px;
    border: 2px solid #e5e5e5;
    border-top: 2px solid #0079d3;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Individual Comments */
.forumx-comment {
    padding: 16px 20px;
    border-bottom: 1px solid #f0f0f0;
}

.forumx-comment:last-child {
    border-bottom: none;
}

.forumx-comment-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.forumx-comment-avatar {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.forumx-comment-author {
    font-weight: 700;
    font-size: 12px;
    color: #1a1a1b;
}

.forumx-comment-time {
    font-size: 12px;
    color: #787c7e;
}

.forumx-comment-body {
    margin-bottom: 8px;
    font-size: 14px;
    line-height: 1.6;
    color: #1a1a1b;
}

.forumx-comment-actions {
    display: flex;
    gap: 12px;
}

.forumx-comment-action-btn {
    background: none;
    border: none;
    color: #787c7e;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    padding: 2px 4px;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.forumx-comment-action-btn:hover {
    background: #f8f9fa;
    color: #1a1a1b;
}

/* Nested Comments */
.forumx-comment-replies {
    margin-left: 32px;
    border-left: 2px solid #f0f0f0;
    padding-left: 16px;
    margin-top: 8px;
}

/* Related Posts Card */
.forumx-related-posts-card {
    background: white;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(0, 0, 0, 0.05);
    overflow: hidden;
}

.forumx-related-posts-header {
    padding: 16px 20px;
    border-bottom: 1px solid #f0f0f0;
}

.forumx-related-posts-title {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--fx-accent, #b7d0db);
}

.forumx-related-posts-list {
    padding: 0;
}

.forumx-related-post {
    padding: 16px 20px;
    border-bottom: 1px solid #f0f0f0;
    transition: background-color 0.2s ease;
    min-height: 140px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.forumx-related-post:hover {
    background: #f8f9fa;
}

.forumx-related-post:last-child {
    border-bottom: none;
}

.forumx-related-top {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: #787c7e;
    margin-bottom: 4px;
}

.forumx-related-community-icon {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.forumx-related-community-icon-fallback {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--fx-accent, #b7d0db);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #0b1b24;
    font-size: 11px;
    flex-shrink: 0;
}

.forumx-related-community {
    color: #1a1a1b;
    font-weight: 700;
}

.forumx-meta-separator {
    color: #787c7e;
}

.forumx-related-post-title {
    margin: 0 0 6px 0;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.3;
}

.forumx-related-post-title a {
    color: var(--fx-accent, #b7d0db);
    text-decoration: none;
    transition: color 0.2s ease;
}

.forumx-related-post-title a:hover {
    color: var(--fx-accent, #b7d0db);
    opacity: 0.8;
}

.forumx-related-post-stats {
    font-size: 11px;
    color: #787c7e;
    display: flex;
    align-items: center;
    gap: 6px;
}

.forumx-no-related-posts {
    padding: 24px 20px;
    text-align: center;
    color: #787c7e;
    font-style: italic;
}

/* Success/Error Messages */
.forumx-success-message {
    position: fixed;
    top: 20px;
    right: 20px;
    background: #4caf50;
    color: white;
    padding: 12px 20px;
    border-radius: 8px;
    z-index: 1000;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 4px 12px rgba(76, 175, 80, 0.3);
}

.forumx-error-message {
    position: fixed;
    top: 20px;
    right: 20px;
    background: #f44336;
    color: white;
    padding: 12px 20px;
    border-radius: 8px;
    z-index: 1000;
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 4px 12px rgba(244, 67, 54, 0.3);
}

/* Mobile Responsiveness */
@media (max-width: 768px) {
    .forumx-single-post-page {
        padding: 60px 0 20px 0;
    }
    
    .forumx-container {
        padding: 0 12px;
        gap: 12px;
    }
    
    .forumx-post-card,
    .forumx-comment-form-card,
    .forumx-login-prompt-card,
    .forumx-comments-list-card,
    .forumx-related-posts-card {
        border-radius: 8px;
    }
    
    .forumx-post-title {
        font-size: 18px;
    }
    
    .forumx-post-content,
    .forumx-comment-form-header,
    .forumx-comment-form,
    .forumx-comments-header {
        padding-left: 16px;
        padding-right: 16px;
    }
    
    .forumx-comment-replies {
        margin-left: 16px;
        padding-left: 12px;
    }
    
    .forumx-comment-textarea {
        min-height: 100px;
        padding: 12px;
    }
    
    .forumx-action-buttons {
        flex-wrap: wrap;
        gap: 2px;
    }
    
    .forumx-action-btn {
        padding: 6px 8px;
        font-size: 11px;
    }
}

@media (max-width: 480px) {
    .forumx-comments-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    
    .forumx-comment-form-footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    
    .forumx-post-actions {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
    
    .forumx-voting-section {
        align-self: flex-start;
    }
}
/* Back button on single post page */
.forumx-post-wrapper { position: relative; }
.forumx-back-btn {
    position: absolute;
    top: 0;
    left: -52px;
    z-index: 10000;
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--fx-border);
    box-shadow: var(--fx-shadow-subtle);
    color: #1a1a1a;
}

.forumx-back-btn:hover {
    background: var(--fx-hover-bg);
}

/* Threaded comments (Reddit-like) */
.forumx-comments-container.forumx-threaded {
    margin-top: 8px;
}

.forumx-threaded .forumx-comment {
    position: relative;
    padding: 8px 0 8px 0;
}

.forumx-threaded .forumx-comment-card {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0 8px 8px 8px;
}

.forumx-threaded .forumx-comment + .forumx-comment {
    border-top: 1px solid #f1f5f9;
}

/* Indentation using inline margin-left from JS + connector line */
.forumx-threaded .forumx-comment[style*="margin-left:"] {
    border-left: 2px solid #e5e7eb;
    padding-left: 16px;
}

.forumx-comment-actions {
    display: flex;
    gap: 16px;
    align-items: center;
    margin-top: 6px;
}

.forumx-comment-action-btn {
    background: none;
    border: none;
    color: #6b7280;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 6px;
    border-radius: 6px;
    cursor: pointer;
}

.forumx-comment-action-btn:hover { background: #f3f4f6; color: #111827; }

.forumx-comment-voting .forumx-vote-btn.active { color: #ff4500; background: #fff2e6; border-radius: 6px; }
/* Post page wrapper widths */
.forumx-post-wrapper {
    max-width: 920px;
    margin: 50px auto 0; /* top spacing 50px as requested */
    padding: 0 16px;
}

@media (max-width: 1199px) {
    .forumx-post-wrapper { max-width: 720px; }
}

@media (max-width: 768px) {
    .forumx-post-wrapper { max-width: 100%; padding: 0 12px; }
    .forumx-back-btn { position: static; margin-bottom: 8px; }
}

/* Post meta row */
.forumx-post-header-compact { margin-top: 40px; margin-bottom: 0; }
.forumx-post-header-compact .forumx-header-meta {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    max-width: 680px;
}

.forumx-community-avatar-lg { flex: 0 0 auto; }
.forumx-community-icon-lg { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; display: block; }
.forumx-community-icon-lg.fa { width: 40px; height: 40px; border-radius: 50%; background: #b7d0db; color: #0b1b24; display: flex; align-items: center; justify-content: center; font-size: 18px; border: 1px solid #3a3a3a; }
.forumx-community-icon-fallback-lg { width: 40px; height: 40px; border-radius: 50%; background: #b7d0db; color: #fff; display:flex; align-items:center; justify-content:center; font-weight:700; }

.forumx-post-header .forumx-community-info { display:none; }
.forumx-meta-text { display:flex; flex-direction:column; gap: 2px; }
.forumx-community-row { display:flex; align-items:center; gap:6px; color:#6b7280; font-size:13px; }
.forumx-community-row .forumx-community-name { color:#111827; font-weight:600; }
.forumx-author-row { color:#6b7280; font-size:13px; }
.forumx-dot { color:#9ca3af; }

.forumx-post-header .forumx-community-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: #374151;
}

.forumx-post-header .forumx-post-time { color: #9ca3af; }

/* Action chips under post */
.forumx-post-actions-reddit {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
}

.forumx-voting-section-reddit {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: 1px solid var(--fx-border);
    background: #fff;
    border-radius: 999px;
    padding: 4px 6px;
}

.forumx-action-btn-reddit {
    border: 1px solid var(--fx-border);
    background: #fff;
    border-radius: 999px;
    padding: 6px 10px;
    color: #374151;
}

.forumx-action-btn-reddit:hover { background: var(--fx-hover-bg); }

/* Comment composer: lighter */
.forumx-comment-form-section {
    background: #212121;
    border: 1px solid #2f2f2f;
    border-radius: 12px;
    padding: 20px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
    color: #f5f5f5;
}
.forumx-login-prompt-section { background: transparent; border-top: 1px solid #f1f5f9; }

/* Threaded comments density tweaks */
.forumx-threaded .forumx-comment { padding: 8px 0; }
.forumx-threaded .forumx-comment[style*="margin-left:"] { border-left: 2px solid #e5e7eb; padding-left: 16px; }
.forumx-comment-actions { margin-top: 4px; }
.forumx-post-card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}
.forumx-dashboard.forumx-dark .forumx-share-btn {
    color: #ffffff;
    border-color: #ffffff;
    background: transparent;
}
.forumx-dashboard.forumx-dark .forumx-share-btn:hover {
    color: #ffffff;
    border-color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
}

.forumx-dashboard.forumx-dark .forumx-post-report-action .forumx-report-btn-small {
    background: transparent;
    border-color: #ffffff;
    color: #ffffff;
}
.forumx-dashboard.forumx-dark .forumx-post-report-action .forumx-report-btn-small:hover {
    background: rgba(220, 53, 69, 0.15);
    border-color: #dc3545;
    color: #ffffff;
}

.forumx-dashboard.forumx-dark .forumx-vote-btn,
.forumx-dashboard.forumx-dark .forumx-vote-btn .dashicons {
    color: #ffffff;
}
.forumx-dashboard.forumx-dark .forumx-vote-score,
.forumx-dashboard.forumx-dark .forumx-vote-score-reddit {
    color: #ffffff;
}
.forumx-dashboard.forumx-dark .forumx-vote-btn.active.forumx-vote-up {
    background: var(--fx-accent);
    color: #0b1b24; /* dark text on light accent */
}

.forumx-dashboard.forumx-dark .forumx-post-time,
.forumx-dashboard.forumx-dark .forumx-post-author-info { color: #e5e7eb; }

.forumx-dashboard.forumx-dark .forumx-community-item .forumx-community-name,
.forumx-dashboard.forumx-dark .forumx-community-item:hover .forumx-community-name,
.forumx-dashboard.forumx-dark .forumx-community-item .forumx-community-count {
    color: #ffffff;
}
.forumx-dashboard.forumx-dark .forumx-filter-btn {
    color: #ffffff;
    border-color: #3a3a3a;
    background: transparent;
}
.forumx-dashboard.forumx-dark .forumx-filter-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #ffffff;
    border-color: var(--fx-accent);
}
.forumx-dashboard.forumx-dark .forumx-filter-btn.active {
    background: var(--fx-accent);
    border-color: var(--fx-accent);
    color: #0b1b24; /* black/dark text on light accent */
}
/* Auth overlay for create community */
.forumx-auth-overlay { position:absolute; inset:0; background: rgba(0,0,0,0.6); display:flex; align-items:center; justify-content:center; z-index: 100; }
.forumx-auth-overlay-content { background:#2a2a2a; color:#fff; border:1px solid #3a3a3a; border-radius:12px; padding:20px; text-align:center; max-width: 420px; }
.forumx-auth-overlay-actions { display:flex; gap:10px; justify-content:center; margin-top:12px; }

/* Sidebar mobile collapse */
.forumx-communities-toggle-wrap { display: none; }
@media (max-width: 768px) {
  .forumx-communities-widget { position: relative; }
  .forumx-communities-list { max-height: 64px; overflow: hidden; }
  .forumx-communities-widget.expanded .forumx-communities-list { max-height: none; }
  .forumx-communities-toggle-wrap { margin-top: 8px; display: block; }
  .forumx-dashboard-sidebar { padding: 12px; }
  .forumx-communities-list .forumx-community-item { 
    min-height: 48px; 
    display: flex;
    align-items: center;
    gap: 12px;
  }
  
  .forumx-communities-list .forumx-community-item .forumx-community-icon,
  .forumx-communities-list .forumx-community-item .forumx-community-icon.fa {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  
  .forumx-post-submit-btn {
    white-space: normal;
    word-wrap: break-word;
    line-height: 1.3;
    min-height: 44px;
    padding: 8px 12px;
  }
}


/* Checkbox styling for auth forms */
.forumx-checkbox-group {
    margin-bottom: 16px !important;
}

.forumx-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    cursor: pointer;
    font-size: 14px;
    line-height: 1.4;
}

.forumx-checkbox-label input[type="checkbox"] {
    margin: 0;
    flex-shrink: 0;
    margin-top: 2px;
}

.forumx-checkbox-text {
    flex-grow: 1;
}

.forumx-dark .forumx-checkbox-label {
    color: #e5e7eb;
}

.forumx-dark .forumx-checkbox-label input[type="checkbox"] {
    accent-color: var(--fx-accent, #b7d0db);
}


/* Auth info styling for popup modals */
.forumx-auth-info {
    background: rgba(183, 208, 219, 0.1);
    border: 1px solid var(--fx-accent, #b7d0db);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 20px;
}

.forumx-auth-info p {
    margin: 0 0 8px 0;
    color: var(--fx-fg, #1f2937);
}

.forumx-auth-info p:last-child {
    margin-bottom: 0;
}

.forumx-dark .forumx-auth-info {
    background: rgba(183, 208, 219, 0.05);
    border-color: var(--fx-accent, #b7d0db);
}

.forumx-dark .forumx-auth-info p {
    color: #e5e7eb;
}

/* Alt Text Field Styling - Dark Design */
.forumx-alt-text-container {
    margin-top: 12px;
    padding: 12px;
    background: #2a2a2a;
    border-radius: 8px;
    border: 1px solid #3a3a3a;
}

.forumx-alt-text-container label {
    display: block;
    margin-bottom: 6px;
    font-weight: 600;
    color: #e5e7eb;
    font-size: 14px;
}

.forumx-alt-text-container input[type="text"] {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid #d1d5db;
    border-radius: 6px;
    font-size: 14px;
    transition: border-color 0.2s;
}

.forumx-alt-text-container input[type="text"]:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.forumx-alt-text-container input[type="text"]:disabled {
    background: #f3f4f6;
    color: #9ca3af;
    cursor: not-allowed;
    border-color: #e5e7eb;
}

.forumx-alt-text-info {
    display: block;
    margin-top: 6px;
    color: #d1d5db;
    font-size: 12px;
    line-height: 1.4;
}

.forumx-alt-char-counter {
    margin-top: 4px;
    text-align: right;
    color: #d1d5db;
    font-size: 12px;
}

.forumx-alt-char-counter .current {
    font-weight: 600;
    color: #f3f4f6;
}

/* Remove duplicate dark mode styles since we now use dark design as default */

/* Profile Page Button Styling */
.forumx-profile-navigation {
    text-align: center;
    margin: 20px 0;
}

.forumx-profile-navigation .button-link {
    display: inline-block;
    background: #B7D0DB !important;
    color: #1a1a1a !important;
    font-size: 1.2rem;
    padding: 16px 30px;
    margin: 0;
    border-radius: 12px;
    text-decoration: none !important;
    font-weight: bold;
    transition: all 0.3s ease;
    border: 2px solid transparent;
    cursor: pointer;
}

.forumx-profile-navigation .button-link:hover {
    background: #1a1a1a !important;
    color: #b7d0db !important;
    text-decoration: none !important;
}

.forumx-profile-navigation .button-link:focus {
    outline: none;
    background: #1a1a1a !important;
    color: #b7d0db !important;
    box-shadow: 0 0 0 3px #b7d0db;
    text-decoration: none !important;
}

.forumx-profile-navigation .button-link:active {
    background: #A3BDC9 !important;
    color: #1a1a1a !important;
    text-decoration: none !important;
}

.back-link-wrapper {
    margin-top: 40px;
}

.back-link {
    display: inline-block;
    font-size: 1rem;
    padding: 13px 20px;
    margin-bottom: 30px;
    background: #b7d0db;
    color: #1a1a1a;
    border-radius: 12px;
    text-decoration: none;
    font-weight: bold;
    transition: background 0.3s ease;
}

.back-link:hover {
    background: #1a1a1a;
    color: #b7d0db;
}

.back-link:focus {
    outline: none;
    background: #1a1a1a;
    color: #b7d0db;
    box-shadow: 0 0 0 3px #b7d0db;
}
.forumx-comment-access {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .forumx-single-post-page {
        padding: 60px 0 20px;
    }

    .forumx-container {
        padding: 0 12px;
        gap: 12px;
    }

    .forumx-post-card,
    .forumx-comment-form-section,
    .forumx-login-prompt-section,
    .forumx-comments-list-card,
    .forumx-related-posts-card {
        border-radius: 10px;
        padding-left: 16px;
        padding-right: 16px;
    }

    .forumx-comment-form,
    .forumx-comment-form-header,
    .forumx-comments-header {
        padding-left: 0;
        padding-right: 0;
    }

    .forumx-comment-textarea {
        min-height: 100px;
        padding: 12px;
    }

    .forumx-comment-form-footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }

    .forumx-action-buttons {
        flex-wrap: wrap;
        gap: 6px;
    }
}

@media (max-width: 480px) {
    .forumx-comments-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .forumx-post-actions {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }

    .forumx-voting-section {
        align-self: flex-start;
    }

    .forumx-login-prompt {
        padding: 24px 20px;
    }
}
