/* Forum Plugin Styles - Gekapselt in #bwForum */

/* Layout-Klassen werden nicht mehr benötigt - Layout erfolgt über Tailwind CSS Grid-System */

#bwForum .forum-container {
      padding: 20px;
}

#bwForum .avatar {
      flex-shrink: 0;
}

#bwForum .topic-content,
#bwForum .reply-content {
      line-height: 1.6;
      word-wrap: break-word;
      color: var(--bw-txt);
}

#bwForum .like-btn {
      transition: all 0.3s ease;
}

#bwForum .like-btn:hover {
      transform: scale(1.1);
}

#bwForum .like-count {
      margin-left: 5px;
      font-weight: bold;
}

/* ============================================
   Sub-Forum Cards (Kategorien-Übersicht)
   ============================================ */

.forum-subforum-card {
      display: block;
      padding: 1rem;
      border-radius: 0.5rem;
      background-color: var(--bw-card-bg);
      border: 1px solid var(--bw-border-medium);
      transition: all 0.25s ease;
      cursor: pointer;
}

.forum-subforum-card:hover {
      border-color: var(--bw-element-primary);
      box-shadow: 0 4px 16px rgba(var(--bw-element-primary-rgb), 0.2);
      transform: translateY(-2px);
}

/* Sub-Forum Icon (Sidebar klein) */
.forum-subforum-icon {
      width: 36px;
      height: 36px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.875rem;
      color: #fff;
      flex-shrink: 0;
}

/* Sub-Forum Icon (Kategorien-Karten groß) */
.forum-subforum-icon-lg {
      width: 48px;
      height: 48px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.125rem;
      color: #fff;
      flex-shrink: 0;
}

/* Sub-Forum Icon (Header klein) */
.forum-subforum-icon-sm {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.75rem;
      color: #fff;
      flex-shrink: 0;
}

/* Gradient-Varianten für Sub-Forum Icons */
.forum-gradient-blue {
      background: linear-gradient(135deg, #3b82f6, #1d4ed8);
}
.forum-gradient-purple {
      background: linear-gradient(135deg, #8b5cf6, #6d28d9);
}
.forum-gradient-green {
      background: linear-gradient(135deg, #10b981, #047857);
}
.forum-gradient-orange {
      background: linear-gradient(135deg, #f59e0b, #d97706);
}
.forum-gradient-pink {
      background: linear-gradient(135deg, #ec4899, #be185d);
}
.forum-gradient-teal {
      background: linear-gradient(135deg, #14b8a6, #0d9488);
}

/* Stat Badge (Kategorien) */
.forum-stat-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      padding: 0.25rem 0.5rem;
      font-size: 0.75rem;
      border-radius: 9999px;
      background-color: rgba(var(--bw-element-primary-rgb), 0.15);
      color: var(--bw-element-primary);
      font-weight: 500;
}

/* Stat Pill (Sidebar) */
.forum-stat-pill {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      padding: 0.125rem 0.5rem;
      font-size: 0.6875rem;
      border-radius: 9999px;
      background-color: rgba(var(--bw-element-primary-rgb), 0.1);
      color: var(--bw-text-muted);
}

/* ============================================
   Topic Cards (Themen-Liste)
   ============================================ */

.forum-topic-card {
      padding: 1rem;
      border-radius: 0.5rem;
      background-color: var(--bw-card-bg);
      border: 1px solid var(--bw-border-medium);
      transition: all 0.2s ease;
}

.forum-topic-card:hover {
      border-color: var(--bw-element-primary);
      background-color: var(--bw-tbl-hover);
}

.forum-topic-pinned {
      border-left: 3px solid #f59e0b;
}

/* Vote/Reply Counter */
.forum-topic-votes {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      min-width: 56px;
      padding: 0.25rem;
      border-radius: 0.375rem;
      background-color: rgba(var(--bw-element-primary-rgb), 0.08);
      flex-shrink: 0;
}

.forum-vote-count {
      font-size: 1.25rem;
      font-weight: 700;
      color: var(--bw-element-primary);
      line-height: 1;
}

/* Pin & Lock Badges */
.forum-pin-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      padding: 0.125rem 0.5rem;
      font-size: 0.6875rem;
      border-radius: 0.25rem;
      background-color: rgba(245, 158, 11, 0.2);
      color: #f59e0b;
      font-weight: 600;
}

.forum-lock-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      padding: 0.125rem 0.5rem;
      font-size: 0.6875rem;
      border-radius: 0.25rem;
      background-color: rgba(239, 68, 68, 0.2);
      color: #ef4444;
      font-weight: 600;
}

/* Mini Avatar (Topic List) */
.forum-avatar-xs {
      width: 20px;
      height: 20px;
      border-radius: 50%;
      background-color: var(--bw-element-primary);
      color: #fff;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-size: 0.625rem;
      font-weight: 700;
      flex-shrink: 0;
}

/* ============================================
   Top Poster Widget (Leaderboard)
   ============================================ */

.forum-poster-item {
      transition: background-color 0.2s ease;
}

.forum-poster-item:hover {
      background-color: var(--bw-tbl-hover);
}

/* Rank Badge */
.forum-rank-badge {
      width: 24px;
      height: 24px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.6875rem;
      font-weight: 700;
      background-color: rgba(var(--bw-element-primary-rgb), 0.15);
      color: var(--bw-text-muted);
      flex-shrink: 0;
}

.forum-rank-gold {
      background: linear-gradient(135deg, #f59e0b, #d97706);
      color: #fff;
}

.forum-rank-silver {
      background: linear-gradient(135deg, #9ca3af, #6b7280);
      color: #fff;
}

.forum-rank-bronze {
      background: linear-gradient(135deg, #d97706, #92400e);
      color: #fff;
}

/* Poster Avatar */
.forum-poster-avatar {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      background-color: var(--bw-element-primary);
      color: #fff;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 0.75rem;
      font-weight: 700;
      flex-shrink: 0;
}

/* ============================================
   Sub-Forum Item (Sidebar)
   ============================================ */

.forum-subforum-item {
      transition: background-color 0.2s ease;
}

.forum-subforum-item:hover {
      background-color: var(--bw-tbl-hover);
}

/* ============================================
   Top Posts Widget
   ============================================ */

.forum-toppost-item {
      transition: background-color 0.2s ease;
}

.forum-toppost-item:hover {
      background-color: var(--bw-tbl-hover);
}

/* ============================================
   Bestehende Styles (Card, List, Table, etc.)
   ============================================ */
#bwForum .card {
      background-color: var(--bw-card-bg) !important;
      border-color: var(--bw-border-medium) !important;
      color: var(--bw-txt);
      transition: box-shadow 0.3s ease;
      width: 100% !important;
      min-height: unset;
}

#bwForum .card:hover {
      box-shadow: 0 0.5rem 1rem rgba(var(--bw-element-primary-rgb), 0.3) !important;
}

#bwForum .card-body {
      background-color: var(--bw-card-bg);
      color: var(--bw-txt);
}

#bwForum .card-footer {
      background-color: var(--bw-card-bg-light) !important;
      border-top: 1px solid var(--bw-border-medium) !important;
      color: var(--bw-text-muted);
}

/* List Group Styles */
#bwForum .list-group-item {
      background-color: var(--bw-card-bg) !important;
      border-color: var(--bw-border-medium) !important;
      color: var(--bw-txt) !important;
}

#bwForum .list-group-item-action:hover {
      background-color: var(--bw-bg-light) !important;
      color: var(--bw-txt) !important;
}

#bwForum .list-group-item h5 {
      color: var(--bw-txt);
}

#bwForum .list-group-item p {
      color: var(--bw-text-muted) !important;
}

/* Table Styles */
#bwForum .table {
      color: var(--bw-txt);
      background-color: transparent;
}

#bwForum .table thead {
      background-color: var(--bw-tbl-bg) !important;
      color: var(--bw-txt);
      border-color: var(--bw-border-medium) !important;
}

#bwForum .table thead th {
      color: var(--bw-txt) !important;
      border-color: var(--bw-border-medium) !important;
}

#bwForum .table tbody tr {
      background-color: var(--bw-card-bg);
      border-color: var(--bw-border-medium) !important;
}

#bwForum .table tbody tr:hover {
      background-color: var(--bw-tbl-hover) !important;
}

#bwForum .table tbody td {
      border-color: var(--bw-border-medium) !important;
}

#bwForum .table-light {
      background-color: var(--bw-tbl-bg) !important;
      color: var(--bw-txt) !important;
}

#bwForum .table-warning {
      background-color: rgba(255, 193, 7, 0.15) !important;
      color: var(--bw-txt) !important;
      border-color: var(--bw-border-medium) !important;
}

#bwForum .table-warning:hover {
      background-color: rgba(255, 193, 7, 0.25) !important;
}

/* Badges */
#bwForum .badge.bg-primary {
      background-color: var(--bw-element-primary) !important;
      color: var(--bw-white);
}

#bwForum .badge.bg-secondary {
      background-color: var(--bw-mono) !important;
      color: var(--bw-white);
}

/* Avatar */
#bwForum .avatar.bg-primary {
      background-color: var(--bw-element-primary) !important;
}

#bwForum .avatar.bg-secondary {
      background-color: var(--bw-mono) !important;
}

/* Breadcrumb */
#bwForum .breadcrumb {
      background-color: transparent;
      padding: 0;
}

#bwForum .breadcrumb-item a {
      color: var(--bw-element-primary);
      text-decoration: none;
}

#bwForum .breadcrumb-item a:hover {
      color: var(--bw-element-primary-hover);
}

#bwForum .breadcrumb-item.active {
      color: var(--bw-text-muted);
}

#bwForum .breadcrumb-item + .breadcrumb-item::before {
      content: '›';
      font-size: 1.2em;
      color: var(--bw-text-muted);
      position: relative;
      top: -4px;
}

/* Text Colors */
#bwForum .text-muted {
      color: var(--bw-text-muted) !important;
}

#bwForum h2,
#bwForum h4,
#bwForum h5,
#bwForum h6 {
      color: var(--bw-txt);
}

/* Forms */
#bwForum .form-label {
      color: var(--bw-txt);
}

#bwForum .form-control {
      background-color: var(--bw-input-bg);
      border-color: var(--bw-border-medium);
      color: var(--bw-txt);
}

#bwForum .form-control:focus {
      background-color: var(--bw-input-bg);
      border-color: var(--bw-element-primary);
      color: var(--bw-txt);
      box-shadow: 0 0 0 0.25rem rgba(var(--bw-element-primary-rgb), 0.25);
}

/* Alerts */
#bwForum .alert-info {
      background-color: rgba(var(--bw-element-primary-rgb), 0.1);
      border-color: rgba(var(--bw-element-primary-rgb), 0.2);
      color: var(--bw-txt);
}

#bwForum .alert-warning {
      background-color: rgba(var(--bw-notification-warning), 0.1);
      border-color: var(--bw-notification-warning);
      color: var(--bw-txt);
}

/* Modal Styles */
#newTopicModal .modal-content {
      background-color: var(--bw-card-bg);
      border-color: var(--bw-border-medium);
      color: var(--bw-txt);
}

#newTopicModal .modal-header {
      background-color: var(--bw-card-bg);
      border-bottom: 1px solid var(--bw-border-medium);
      color: var(--bw-txt);
}

#newTopicModal .modal-body {
      background-color: var(--bw-card-bg);
      color: var(--bw-txt);
}

#newTopicModal .modal-footer {
      background-color: var(--bw-card-bg);
      border-top: 1px solid var(--bw-border-medium);
}

#newTopicModal .modal-title {
      color: var(--bw-txt);
}

#newTopicModal .btn-close {
      filter: invert(1);
}

#newTopicModal .form-label {
      color: var(--bw-txt);
}

#newTopicModal .form-control {
      background-color: var(--bw-input-bg);
      border-color: var(--bw-border-medium);
      color: var(--bw-txt);
}

#newTopicModal .form-control:focus {
      background-color: var(--bw-input-bg);
      border-color: var(--bw-element-primary);
      color: var(--bw-txt);
      box-shadow: 0 0 0 0.25rem rgba(var(--bw-element-primary-rgb), 0.25);
}

@media (max-width: 768px) {
      #bwForum .avatar {
            width: 40px !important;
            height: 40px !important;
            font-size: 18px !important;
      }

      #bwForum .d-flex.mb-3 {
            flex-direction: column;
            align-items: flex-start !important;
      }

      #bwForum .like-btn {
            margin-top: 10px;
      }
}
