.forum-wrap { max-width: 1200px; margin: 0 auto; padding: 32px 20px }
.forum-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 32px }
.forum-header h1 { font-size: 28px; font-weight: 900; color: #fff; margin: 0; display: flex; align-items: center; gap: 12px; letter-spacing: -.5px }
.forum-header h1 small { font-size: 14px; font-weight: 500; color: rgba(255,255,255,.35); letter-spacing: 0 }
.forum-actions { display: flex; gap: 10px; flex-wrap: wrap }
.forum-actions .btn { padding: 10px 22px; font-size: 13px; border-radius: 12px; font-weight: 700; display: inline-flex; align-items: center; gap: 8px; transition: all .2s }

/* Stats Bar */
.forum-stat-bar { display: flex; gap: 0; padding: 0; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.06); border-radius: 16px; margin-bottom: 28px; overflow: hidden }
.forum-stat-item { flex: 1; display: flex; align-items: center; justify-content: center; gap: 10px; padding: 18px 16px; font-size: 13px; color: rgba(255,255,255,.4); border-right: 1px solid rgba(255,255,255,.04); position: relative }
.forum-stat-item:last-child { border-right: none }
.forum-stat-item .num { font-size: 20px; font-weight: 800; color: #fff; background: linear-gradient(135deg,#3b82f6,#8b5cf6); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text }

/* Categories Grid */
.forum-categories { display: grid; gap: 10px }
.forum-cat-card { background: linear-gradient(135deg, rgba(255,255,255,.03), rgba(255,255,255,.01)); border: 1px solid rgba(255,255,255,.06); border-radius: 16px; padding: 20px 24px; display: flex; align-items: center; gap: 20px; transition: all .25s cubic-bezier(.4,0,.2,1); text-decoration: none; position: relative; overflow: hidden }
.forum-cat-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: linear-gradient(135deg, rgba(37,99,235,.03), transparent); opacity: 0; transition: opacity .3s; pointer-events: none }
.forum-cat-card:hover { border-color: rgba(37,99,235,.25); background: rgba(37,99,235,.04); transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.15) }
.forum-cat-card:hover::before { opacity: 1 }
.forum-cat-icon { font-size: 36px; flex-shrink: 0; width: 52px; height: 52px; text-align: center; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.04); border-radius: 14px; border: 1px solid rgba(255,255,255,.06) }
.forum-cat-info { flex: 1; min-width: 0 }
.forum-cat-name { font-size: 17px; font-weight: 700; color: #fff; margin-bottom: 4px; transition: color .2s }
.forum-cat-card:hover .forum-cat-name { color: #60a5fa }
.forum-cat-desc { font-size: 13px; color: rgba(255,255,255,.4); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden }
.forum-cat-stats { text-align: center; flex-shrink: 0; min-width: 80px; padding: 8px 16px; background: rgba(255,255,255,.03); border-radius: 12px; border: 1px solid rgba(255,255,255,.04) }
.forum-cat-stats .num { font-size: 18px; font-weight: 800; color: #fff; display: block }
.forum-cat-stats .lbl { font-size: 11px; color: rgba(255,255,255,.35); font-weight: 600; text-transform: uppercase; letter-spacing: .5px }
.forum-cat-stats + .forum-cat-stats { margin-right: 8px }

/* Breadcrumb */
.forum-breadcrumb { display: flex; align-items: center; gap: 10px; font-size: 13px; color: rgba(255,255,255,.35); margin-bottom: 24px; flex-wrap: wrap; padding: 10px 16px; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.05); border-radius: 12px }
.forum-breadcrumb a { color: rgba(255,255,255,.5); text-decoration: none; transition: color .2s; font-weight: 500 }
.forum-breadcrumb a:hover { color: #60a5fa }
.forum-breadcrumb .sep { color: rgba(255,255,255,.15); font-weight: 700 }

/* Toolbar */
.forum-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 20px; padding: 14px 20px; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.06); border-radius: 14px }
.forum-toolbar .ft-left { display: flex; align-items: center; gap: 6px; flex-wrap: wrap }
.forum-toolbar .ft-right { display: flex; align-items: center; gap: 10px }
.forum-sort-btn { padding: 7px 16px; border-radius: 10px; font-size: 12px; font-weight: 600; background: transparent; color: rgba(255,255,255,.4); border: 1px solid rgba(255,255,255,.06); cursor: pointer; transition: all .2s; text-decoration: none }
.forum-sort-btn:hover { background: rgba(37,99,235,.1); color: #60a5fa; border-color: rgba(37,99,235,.2) }
.forum-sort-btn.active { background: rgba(37,99,235,.15); color: #60a5fa; border-color: rgba(37,99,235,.3); box-shadow: 0 0 20px rgba(37,99,235,.1) }

/* Thread List */
.forum-thread-list { background: rgba(255,255,255,.015); border: 1px solid rgba(255,255,255,.06); border-radius: 16px; overflow: hidden }
.forum-thread-row { display: flex; align-items: center; gap: 16px; padding: 16px 22px; text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.04); transition: all .15s; position: relative; cursor: pointer }
.forum-thread-row:last-child { border-bottom: none }
.forum-thread-row:hover { background: rgba(37,99,235,.04) }
.forum-thread-row:hover .forum-thread-title { color: #60a5fa }
.forum-thread-icon { font-size: 18px; flex-shrink: 0; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.04); border-radius: 10px; border: 1px solid rgba(255,255,255,.06) }
.forum-thread-main { flex: 1; min-width: 0 }
.forum-thread-top { display: flex; align-items: center; gap: 8px }
.forum-thread-title { font-size: 15px; font-weight: 600; color: #e2e8f0; transition: color .15s; line-height: 1.3; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis }
.forum-thread-row:hover .forum-thread-title { color: #60a5fa }
.forum-thread-top-meta { font-size: 12px; color: rgba(255,255,255,.35); display: flex; gap: 4px; align-items: center; flex-shrink: 0 }
.forum-thread-top-meta .ftm-sep { color: rgba(255,255,255,.15); font-weight: 300; user-select: none }
.forum-thread-author { font-size: 11px; color: rgba(255,255,255,.3); margin-top: 0; line-height: 1 }
.forum-thread-author a { color: rgba(255,255,255,.45); text-decoration: none; font-weight: 400 }
.forum-thread-author a:hover { color: #60a5fa }
.forum-thread-stats { flex-shrink: 0; text-align: center; min-width: 60px; padding: 6px 14px; background: rgba(255,255,255,.02); border-radius: 10px; border: 1px solid rgba(255,255,255,.04) }
.forum-thread-stats .num { font-weight: 800; color: #fff; font-size: 15px; display: block }
.forum-thread-stats .lbl { font-size: 10px; color: rgba(255,255,255,.3); font-weight: 600; text-transform: uppercase; letter-spacing: .5px }
.forum-thread-last { flex-shrink: 0; text-align: left; font-size: 11px; color: rgba(255,255,255,.3); min-width: 120px; direction: ltr; padding: 6px 12px; background: rgba(255,255,255,.015); border-radius: 8px }
.forum-thread-last .name { color: rgba(255,255,255,.5); font-weight: 600 }
.forum-thread-last .time { font-size: 10px }

/* Badges */
.forum-badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 20px; font-size: 10px; font-weight: 700; letter-spacing: .3px }
.forum-badge-solved { background: rgba(34,197,94,.12); color: #4ade80; border: 1px solid rgba(34,197,94,.25) }
.forum-badge-locked { background: rgba(239,68,68,.12); color: #f87171; border: 1px solid rgba(239,68,68,.25) }

/* Thread View */
.forum-thread-view { background: rgba(255,255,255,.015); border: 1px solid rgba(255,255,255,.06); border-radius: 18px; overflow: hidden; box-shadow: 0 4px 24px rgba(0,0,0,.08) }
.forum-thread-head { padding: 28px 32px; border-bottom: 1px solid rgba(255,255,255,.06); background: linear-gradient(180deg, rgba(37,99,235,.03), transparent) }
.forum-thread-head h1 { font-size: 24px; font-weight: 800; color: #fff; margin: 0 0 12px; line-height: 1.35; letter-spacing: -.3px }
.forum-thread-head .meta { font-size: 13px; color: rgba(255,255,255,.4); display: flex; gap: 20px; flex-wrap: wrap; align-items: center }
.forum-thread-head .meta a { color: #60a5fa; text-decoration: none; font-weight: 600 }
.forum-thread-head .meta a:hover { text-decoration: underline }

/* Posts */
.forum-post { display: flex; gap: 20px; padding: 24px 32px; border-bottom: 1px solid rgba(255,255,255,.04); transition: background .15s }
.forum-post:last-child { border-bottom: none }
.forum-post:hover { background: rgba(255,255,255,.005) }
.forum-post-solution { background: rgba(34,197,94,.025) !important; border-right: 3px solid #22c55e !important; position: relative }
.forum-post-solution:hover { background: rgba(34,197,94,.035) !important }
.forum-post-first { padding: 32px; border-bottom: none }
.forum-post-first .forum-post-body { width: 100% }
.forum-replies-header { display: flex; align-items: center; gap: 12px; padding: 16px 32px; border-top: 1px solid rgba(255,255,255,.06); border-bottom: 1px solid rgba(255,255,255,.04); background: rgba(255,255,255,.01) }
.forum-replies-count { font-size: 13px; font-weight: 700; color: rgba(255,255,255,.4); letter-spacing: .3px; text-transform: uppercase }
.forum-replies-section { border-top: 1px solid rgba(255,255,255,.06) }
.forum-post-sidebar { flex-shrink: 0; width: 130px; text-align: center }
.forum-post-avatar { width: 60px; height: 60px; border-radius: 50%; margin: 0 auto 10px; overflow: hidden; position: relative; box-shadow: 0 4px 14px rgba(0,0,0,.2) }
.forum-post-avatar img { width: 100%; height: 100%; object-fit: cover }
.forum-post-avatar .initials { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 22px; font-weight: 800; color: #fff }
.forum-post-author { font-size: 14px; font-weight: 700; color: #fff; text-decoration: none; display: block; transition: color .2s }
.forum-post-author:hover { color: #60a5fa }
.forum-post-role { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; padding: 2px 10px; border-radius: 20px; display: inline-block; margin-top: 4px }
.forum-post-role.admin { background: rgba(245,158,11,.12); color: #f59e0b }
.forum-post-role.user { background: rgba(37,99,235,.08); color: #60a5fa }
.forum-post-date { font-size: 11px; color: rgba(255,255,255,.3); margin-top: 4px }
.forum-post-body { flex: 1; min-width: 0 }
.forum-post-content { font-size: 15px; line-height: 1.85; color: #e2e8f0 }
.forum-post-content p { margin: 12px 0 }
.forum-post-content img { max-width: 100%; border-radius: 10px; margin: 12px 0; box-shadow: 0 4px 20px rgba(0,0,0,.15) }
.forum-post-content a { color: #60a5fa; text-decoration: underline; text-underline-offset: 2px }
.forum-post-content a:hover { color: #93bbfc }
.forum-post-content blockquote { border-right: 3px solid #3b82f6; padding: 12px 20px; margin: 16px 0; background: rgba(37,99,235,.04); border-radius: 12px; color: rgba(255,255,255,.6); font-style: italic }
.forum-post-content ul, .forum-post-content ol { padding-right: 24px; margin: 12px 0 }
.forum-post-content li { margin: 4px 0 }
.forum-post-content h1, .forum-post-content h2, .forum-post-content h3, .forum-post-content h4 { color: #fff; margin: 20px 0 10px; font-weight: 700 }
.forum-post-content h1 { font-size: 22px }
.forum-post-content h2 { font-size: 19px }
.forum-post-content h3 { font-size: 17px }
.forum-post-content h4 { font-size: 15px }
.forum-post-content pre { background: #0d1117; border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 20px; overflow-x: auto; direction: ltr; text-align: left; margin: 16px 0; font-size: 13px; line-height: 1.6 }
.forum-post-content code { font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace; font-size: 13px; color: #e6edf3 }
.forum-post-content p > code { background: rgba(37,99,235,.08); padding: 2px 8px; border-radius: 6px; font-size: 13px; color: #93bbfc }
.forum-post-content iframe { max-width: 100%; border-radius: 10px; margin: 12px 0; aspect-ratio: 16/9; width: 100%; border: none }
.forum-post-content table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 14px }
.forum-post-content th, .forum-post-content td { padding: 10px 14px; border: 1px solid rgba(255,255,255,.08); text-align: right }
.forum-post-content th { background: rgba(37,99,235,.06); font-weight: 700; color: #fff }
.forum-post-content hr { border: none; border-top: 1px solid rgba(255,255,255,.06); margin: 20px 0 }
.forum-post-footer { display: flex; align-items: center; gap: 8px; margin-top: 16px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.04); flex-wrap: wrap }
.forum-post-footer button, .forum-post-footer a { padding: 6px 14px; border-radius: 8px; font-size: 12px; font-weight: 600; border: none; cursor: pointer; transition: all .15s; text-decoration: none; display: inline-flex; align-items: center; gap: 5px }
.forum-btn-solve { background: rgba(34,197,94,.1); color: #4ade80 }
.forum-btn-solve:hover { background: rgba(34,197,94,.2) }
.forum-btn-delete { background: rgba(239,68,68,.1); color: #f87171 }
.forum-btn-delete:hover { background: rgba(239,68,68,.2) }
.forum-btn-edit { background: rgba(37,99,235,.1); color: #60a5fa }
.forum-btn-edit:hover { background: rgba(37,99,235,.2) }

/* Solved Badge in Post */
.forum-solved-badge { display: inline-flex; align-items: center; gap: 8px; padding: 8px 18px; border-radius: 12px; font-size: 13px; font-weight: 700; background: linear-gradient(135deg, rgba(34,197,94,.12), rgba(34,197,94,.06)); color: #4ade80; border: 1px solid rgba(34,197,94,.25); margin-bottom: 12px; box-shadow: 0 0 20px rgba(34,197,94,.06) }

/* Code Block */
.forum-code-block { position: relative; margin: 16px 0 }
.forum-code-block pre { padding-top: 44px !important }
.forum-copy-btn { position: absolute; top: 8px; right: 8px; padding: 5px 12px; background: rgba(255,255,255,.06); color: rgba(255,255,255,.6); border: 1px solid rgba(255,255,255,.08); border-radius: 8px; font-size: 11px; font-weight: 600; cursor: pointer; transition: all .2s; z-index: 1 }
.forum-copy-btn:hover { background: rgba(255,255,255,.1); color: #fff }
.forum-copy-btn.copied { background: rgba(34,197,94,.15); color: #4ade80; border-color: rgba(34,197,94,.25) }

/* Reply Box */
.forum-reply-box { padding: 28px 32px; border-top: 1px solid rgba(255,255,255,.06); background: linear-gradient(180deg, transparent, rgba(37,99,235,.02)) }
.forum-reply-box h3 { font-size: 17px; font-weight: 700; color: #fff; margin: 0 0 16px; display: flex; align-items: center; gap: 8px }

/* Hidden Link */
.forum-link-hidden { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: rgba(250,204,21,.06); border: 1px dashed rgba(250,204,21,.25); border-radius: 10px; color: #eab308; font-size: 13px; font-weight: 600; cursor: default; margin: 4px 0 }

/* Pagination */
.forum-pagination { display: flex; align-items: center; justify-content: center; gap: 4px; margin: 28px 0 }
.fp-btn { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; padding: 0 10px; border-radius: 10px; font-size: 13px; font-weight: 600; color: rgba(255,255,255,.4); background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); text-decoration: none; transition: all .2s }
.fp-btn:hover { background: rgba(37,99,235,.1); color: #60a5fa; border-color: rgba(37,99,235,.2) }
.fp-btn.active { background: linear-gradient(135deg, rgba(37,99,235,.2), rgba(37,99,235,.1)); color: #60a5fa; border-color: rgba(37,99,235,.3); box-shadow: 0 0 20px rgba(37,99,235,.08) }
.fp-dots { color: rgba(255,255,255,.2); font-size: 13px; padding: 0 6px }

/* Category Description Box */
.forum-cat-desc-box { padding: 16px 20px; background: rgba(37,99,235,.03); border: 1px solid rgba(37,99,235,.1); border-radius: 14px; font-size: 13px; color: rgba(255,255,255,.5); margin-bottom: 20px; line-height: 1.6 }

/* Create Page */
.forum-create-wrap { max-width: 860px; margin: 0 auto; padding: 8px 0 }
.forum-create-wrap h1 { font-size: 26px; font-weight: 800; color: #fff; margin-bottom: 24px; letter-spacing: -.3px }
.forum-form-group { margin-bottom: 20px }
.forum-form-group label { display: block; font-size: 13px; font-weight: 600; color: rgba(255,255,255,.7); margin-bottom: 8px }
.forum-form-group select, .forum-form-group input[type=text] { width: 100%; padding: 12px 16px; background: rgba(0,0,0,.3); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; color: #fff; font-size: 14px; transition: border-color .2s }
.forum-form-group select:focus, .forum-form-group input:focus { border-color: rgba(37,99,235,.4); outline: none; box-shadow: 0 0 0 3px rgba(37,99,235,.08) }

/* Empty State */
.forum-empty { text-align: center; padding: 60px 20px; color: rgba(255,255,255,.3); font-size: 15px; background: rgba(255,255,255,.015); border: 1px dashed rgba(255,255,255,.08); border-radius: 16px; margin: 20px 0 }

/* Recent Section */
.forum-section-title { font-size: 20px; font-weight: 800; color: #fff; margin: 0 0 18px; display: flex; align-items: center; gap: 10px; letter-spacing: -.3px }

/* Summernote Dark Overrides */
.note-editor { border-radius: 12px !important; overflow: hidden !important; border-color: rgba(255,255,255,.08) !important }
.note-editor .note-editable { color: #e2e8f0 !important; background: #0d1117 !important; min-height: 200px !important; padding: 20px !important }
.note-editor .note-toolbar { background: rgba(255,255,255,.03) !important; border-color: rgba(255,255,255,.06) !important; padding: 8px 12px !important }
.note-editor .note-btn { color: rgba(255,255,255,.6) !important; background: transparent !important; border: 1px solid transparent !important; border-radius: 8px !important; padding: 6px 10px !important; transition: all .15s !important }
.note-editor .note-btn:hover { background: rgba(255,255,255,.06) !important; color: #fff !important }
.note-editor .note-btn.active { background: rgba(37,99,235,.15) !important; color: #60a5fa !important }
.note-editor .note-dropdown-menu { background: #161b22 !important; border-color: rgba(255,255,255,.08) !important; border-radius: 12px !important; padding: 6px !important }
.note-editor .note-dropdown-item { color: rgba(255,255,255,.6) !important; border-radius: 8px !important; padding: 8px 14px !important }
.note-editor .note-dropdown-item:hover { background: rgba(37,99,235,.1) !important; color: #fff !important }
.note-editor .note-modal-content { background: #161b22 !important; color: #e2e8f0 !important; border-color: rgba(255,255,255,.08) !important; border-radius: 16px !important }
.note-editor .note-form-label { color: rgba(255,255,255,.7) !important; font-size: 13px !important }
.note-editor .note-input { background: #0d1117 !important; color: #fff !important; border-color: rgba(255,255,255,.08) !important; border-radius: 8px !important; padding: 10px 12px !important }
.note-editor .note-modal-header { border-color: rgba(255,255,255,.06) !important; background: rgba(255,255,255,.02) !important; padding: 16px 20px !important }
.note-editor .note-modal-header h4 { color: #fff !important; font-weight: 700 !important }
.note-editor .note-modal-footer { border-color: rgba(255,255,255,.06) !important; padding: 12px 20px !important }
.note-editor .note-btn-primary { background: #3b82f6 !important; border-color: #3b82f6 !important; color: #fff !important }
.note-editor .note-btn-primary:hover { background: #2563eb !important }
.note-group-select-from-files { display: none !important }
.note-editor .note-color-btn { border-color: rgba(255,255,255,.08) !important }
.note-editor .note-statusbar { background: rgba(255,255,255,.02) !important; border-color: rgba(255,255,255,.06) !important }
.note-editor .note-statusbar .note-resizebar { border-color: rgba(255,255,255,.06) !important }
.note-editor .note-status-output { color: rgba(255,255,255,.3) !important }
/* Summernote Modal Close Button */
.note-modal .note-modal-header { position: relative }
.note-modal .note-modal-header .note-modal-close-btn { position: absolute; top: 14px; right: 14px; width: 28px; height: 28px; border-radius: 50%; border: none; background: rgba(255,255,255,.06); color: rgba(255,255,255,.5); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .15s; z-index: 10; line-height: 1 }
.note-modal .note-modal-header .note-modal-close-btn:hover { background: rgba(239,68,68,.15); color: #f87171 }
[dir=rtl] .note-modal .note-modal-header .note-modal-close-btn { right: auto; left: 14px }

/* Admin Forum Page */
.forum-admin-wrap { max-width:1200px;margin:0 auto;padding:24px 16px }
.forum-admin-wrap h1 { font-size:24px;font-weight:800;color:#fff;margin-bottom:24px;letter-spacing:-.3px }
.forum-admin-card { background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.06); border-radius: 16px; padding: 20px; margin-bottom: 24px }
.forum-admin-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; flex-wrap: wrap; gap: 10px }
.forum-admin-card-header h2 { font-size: 18px; font-weight: 700; color: #fff; margin: 0 }
.forum-admin-table { width: 100%; font-size: 13px; border-collapse: collapse }
.forum-admin-table thead tr { border-bottom: 1px solid rgba(255,255,255,.06) }
.forum-admin-table th { padding: 10px 12px; text-align: right; color: rgba(255,255,255,.4); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px }
.forum-admin-table td { padding: 10px 12px; border-bottom: 1px solid rgba(255,255,255,.03); color: rgba(255,255,255,.7) }
.forum-admin-table td:first-child, .forum-admin-table th:first-child { padding-right: 16px }
.forum-admin-table tr:last-child td { border-bottom: none }
.forum-admin-table .cat-icon { font-size: 18px }
.forum-admin-table .cat-name { color: #e2e8f0; font-weight: 600 }
.forum-admin-table .cat-slug { font-family: monospace; font-size: 12px; color: rgba(255,255,255,.35) }
.forum-admin-table .status-active { color: #22c55e; font-weight: 600 }
.forum-admin-table .status-inactive { color: #ef4444; font-weight: 600 }
.forum-admin-add-form { display: none; background: rgba(0,0,0,.2); border: 1px solid rgba(255,255,255,.06); border-radius: 12px; padding: 16px; margin-bottom: 16px }
.forum-admin-add-form.show { display: block }
.forum-admin-form-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; margin-bottom: 8px }
.forum-admin-form-grid.double { grid-template-columns: 1fr 1fr }
.forum-admin-form-group label { font-size: 12px; color: rgba(255,255,255,.4); display: block; margin-bottom: 4px; font-weight: 600 }
.forum-admin-form-group input, .forum-admin-form-group textarea, .forum-admin-form-group select { width: 100%; padding: 8px 12px; background: rgba(0,0,0,.3); border: 1px solid rgba(255,255,255,.08); border-radius: 8px; color: #fff; font-size: 13px; transition: border-color .2s; box-sizing: border-box }
.forum-admin-form-group input:focus, .forum-admin-form-group textarea:focus { border-color: rgba(37,99,235,.4); outline: none; box-shadow: 0 0 0 3px rgba(37,99,235,.08) }
.forum-admin-form-group textarea { font-family: inherit; resize: vertical }
.forum-admin-form-group .checkbox-wrap { display: flex; align-items: center; gap: 8px; padding-top: 4px }
.forum-admin-form-group .checkbox-wrap input[type=checkbox] { width: auto }
.forum-admin-form-group .checkbox-wrap label { margin: 0; cursor: pointer }
.forum-admin-ban-form { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; padding: 14px; background: rgba(0,0,0,.2); border-radius: 12px; align-items: flex-end }
.forum-admin-ban-form .bf-group label { font-size: 11px; color: rgba(255,255,255,.4); display: block; margin-bottom: 2px; font-weight: 600 }
.forum-admin-ban-form .bf-group input { padding: 6px 10px; background: rgba(0,0,0,.3); border: 1px solid rgba(255,255,255,.08); border-radius: 6px; color: #fff; font-size: 12px }
.forum-admin-ban-form .bf-group input:focus { border-color: rgba(37,99,235,.4); outline: none }
.btn-ban { background: #ef4444; color: #fff; border: none; padding: 7px 18px; border-radius: 8px; font-weight: 700; font-size: 12px; cursor: pointer; transition: background .2s }
.btn-ban:hover { background: #dc2626 }
.btn-unban { background: transparent; border: 1px solid rgba(34,197,94,.2); color: #22c55e; padding: 5px 12px; border-radius: 6px; font-size: 11px; font-weight: 600; cursor: pointer; transition: all .15s }
.btn-unban:hover { background: rgba(34,197,94,.1) }
.forum-admin-modal { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,.7); z-index: 9999; align-items: center; justify-content: center; backdrop-filter: blur(4px) }
.forum-admin-modal.show { display: flex }
.forum-admin-modal-inner { background: #161b22; border: 1px solid rgba(255,255,255,.08); border-radius: 16px; padding: 28px; width: 90%; max-width: 600px; max-height: 90vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,.4) }
.forum-admin-modal-inner h3 { font-size: 18px; font-weight: 700; color: #fff; margin: 0 0 16px }
.forum-admin-modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px }
.forum-admin-modal-close { width: 32px; height: 32px; border-radius: 50%; border: 1px solid rgba(255,255,255,.08); background: transparent; color: rgba(255,255,255,.4); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .2s; font-size: 14px }
.forum-admin-modal-close:hover { background: rgba(255,255,255,.06); color: #fff }

/* Categories with children inside */
.forum-cat-card-parent { background: linear-gradient(135deg, rgba(255,255,255,.03), rgba(255,255,255,.01)); border: 1px solid rgba(255,255,255,.06); border-radius: 16px; margin-bottom: 10px; overflow: hidden; transition: all .25s cubic-bezier(.4,0,.2,1) }
.forum-cat-card-parent:hover { border-color: rgba(37,99,235,.2); box-shadow: 0 8px 30px rgba(0,0,0,.15) }
.forum-cat-card-link { display: flex; align-items: center; gap: 20px; padding: 20px 24px; text-decoration: none; position: relative }
.forum-cat-card-link .forum-cat-icon { font-size: 36px; flex-shrink: 0; width: 52px; height: 52px; text-align: center; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.04); border-radius: 14px; border: 1px solid rgba(255,255,255,.06) }
.forum-cat-card-link .forum-cat-info { flex: 1; min-width: 0 }
.forum-cat-card-link .forum-cat-name { font-size: 17px; font-weight: 700; color: #fff; margin-bottom: 4px; transition: color .2s }
.forum-cat-card-parent:hover .forum-cat-card-link .forum-cat-name { color: #60a5fa }
.forum-cat-card-link .forum-cat-desc { font-size: 13px; color: rgba(255,255,255,.4); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden }
.forum-cat-card-link .forum-cat-stats { flex-shrink: 0; text-align: center; min-width: 80px; padding: 8px 16px; background: rgba(255,255,255,.03); border-radius: 12px; border: 1px solid rgba(255,255,255,.04) }
.forum-cat-card-link .forum-cat-stats .num { font-size: 18px; font-weight: 800; color: #fff; display: block }
.forum-cat-card-link .forum-cat-stats .lbl { font-size: 11px; color: rgba(255,255,255,.35); font-weight: 600; text-transform: uppercase; letter-spacing: .5px }

.forum-cat-children { padding: 0 24px 16px; border-top: 1px solid rgba(255,255,255,.04); margin-top: 0; padding-top: 14px }

/* Sub-categories Compact Grid */
.forum-subcats { margin-bottom: 24px }
.forum-subcats-header { font-size: 11px; font-weight: 700; color: rgba(255,255,255,.25); text-transform: uppercase; letter-spacing: .8px; margin-bottom: 10px; padding: 0 4px }
.forum-subcats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 6px }
.forum-subcat-card { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.06); border-radius: 10px; text-decoration: none; transition: all .2s }
.forum-subcat-card:hover { background: rgba(37,99,235,.06); border-color: rgba(37,99,235,.2); transform: translateY(-1px) }
.forum-subcat-icon { flex-shrink: 0; font-size: 15px; width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.04); border-radius: 7px; border: 1px solid rgba(255,255,255,.05) }
.forum-subcat-info { flex: 1; min-width: 0 }
.forum-subcat-name { font-size: 12px; font-weight: 600; color: #e2e8f0; transition: color .2s; white-space: nowrap; overflow: hidden; text-overflow: ellipsis }
.forum-subcat-card:hover .forum-subcat-name { color: #60a5fa }
.forum-subcat-count { font-size: 11px; color: rgba(255,255,255,.3); white-space: nowrap }

/* Hidden Reply Block */
.forum-reply-block { display: flex; align-items: center; gap: 12px; padding: 16px 20px; background: rgba(255,255,255,.02); border: 1px dashed rgba(255,255,255,.12); border-radius: 12px; margin: 16px 0 }
.forum-reply-block .frb-icon { font-size: 22px; flex-shrink: 0; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: rgba(234,179,8,.08); border-radius: 10px }
.forum-reply-block .frb-text { font-size: 13px; color: rgba(255,255,255,.5); line-height: 1.5 }
.forum-reply-block a { color: #0ea5e9; text-decoration: underline }

/* Responsive */
@media (max-width: 768px) {
    .forum-wrap { padding: 20px 14px }
    .forum-post { flex-direction: column; padding: 18px 16px }
    .forum-post-sidebar { width: 100%; display: flex; align-items: center; gap: 12px; text-align: right; flex-wrap: wrap }
    .forum-post-avatar { margin: 0; width: 40px; height: 40px; font-size: 16px }
    .forum-post-avatar .initials { font-size: 16px }
    .forum-post-date { margin: 0 }
    .forum-thread-stats { display: none }
    .forum-thread-last { display: none }
    .forum-cat-stats { display: none }
    .forum-header h1 { font-size: 22px }
    .forum-stat-bar { flex-direction: column; gap: 0 }
    .forum-stat-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.04); padding: 14px }
    .forum-stat-item:last-child { border-bottom: none }
    .forum-thread-view .forum-thread-head { padding: 20px }
    .forum-thread-view .forum-post { padding: 20px }
    .forum-reply-box { padding: 20px }
}
