/* WP Forum v3 — ktopredki.ru */
:root {
  --wpf-bg:       #faf8f5;
  --wpf-surface:  #ffffff;
  --wpf-border:   #e8e2d9;
  --wpf-border2:  #d4cdc2;
  --wpf-accent:   #8B1A2B;
  --wpf-accent2:  #b02235;
  --wpf-text:     #2a2118;
  --wpf-muted:    #8c8278;
  --wpf-nick-bg:  rgba(139,26,43,.07);
  --wpf-nick-col: #8B1A2B;
  --wpf-radius:   10px;
}

.wpf-wrap { max-width: 760px; margin: 0 auto; font-family: inherit; color: var(--wpf-text); }

.wpf-header { display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-bottom:20px;margin-bottom:24px;border-bottom:2px solid var(--wpf-border); }
.wpf-title  { font-size:22px;font-weight:700;margin:0 0 4px;font-family:inherit; }
.wpf-subtitle { font-size:14px;color:var(--wpf-muted);margin:0; }
.wpf-sort-tabs { display:flex;gap:6px;align-items:center; }
.wpf-sort-btn svg { vertical-align: middle; margin-right: 3px; margin-top: -2px; }
.wpf-sort-btn { background:none;border:1px solid var(--wpf-border2);color:var(--wpf-muted);font-size:13px;padding:7px 16px;border-radius:100px;cursor:pointer;font-family:inherit;transition:all .2s; }
.wpf-sort-btn.active, .wpf-sort-btn:hover { border-color:var(--wpf-accent);color:var(--wpf-accent);background:rgba(139,26,43,.06); }

/* ---- Avatar ---- */
.wpf-avatar {
  width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0;
  background-color: var(--wpf-surface);
  background-size: cover; background-position: center;
  border: 1.5px solid var(--wpf-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; font-weight: 700; color: var(--wpf-accent);
  user-select: none;
}

/* ---- Compose ---- */
.wpf-compose {
  background: var(--wpf-surface);
  border: 1.5px solid var(--wpf-border);
  border-radius: 14px;
  margin-bottom: 24px;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.wpf-compose.is-open {
  border-color: var(--wpf-border2);
  box-shadow: 0 2px 12px rgba(0,0,0,.08);
}

/* Однострочный */
.wpf-compose-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; cursor: text;
}
.wpf-compose-inline {
  flex: 1; border: 1.5px solid var(--wpf-border); border-radius: 100px;
  padding: 9px 18px; font-size: 14px; font-family: inherit;
  color: var(--wpf-muted); background: var(--wpf-bg);
  cursor: text; outline: none;
  transition: border-color .2s;
}
.wpf-compose-row:hover .wpf-compose-inline { border-color: var(--wpf-border2); }

/* Развёрнутый */
.wpf-compose-full { display: none; }
.wpf-compose.is-open .wpf-compose-row  { display: none; }
.wpf-compose.is-open .wpf-compose-full { display: block; animation: wpfExpand .18s ease; }
@keyframes wpfExpand {
  from { opacity:0; transform:translateY(-4px); }
  to   { opacity:1; transform:translateY(0); }
}

.wpf-compose-fullrow {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 14px 14px 0;
}
.wpf-compose-inputs { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.wpf-compose-loggedin {
  font-size: 13px; font-weight: 700; color: var(--wpf-accent);
}
.wpf-nick-input {
  border: none; border-bottom: 1.5px solid var(--wpf-border);
  outline: none; background: none; padding: 4px 0;
  font-size: 13px; font-weight: 700; font-family: inherit;
  color: var(--wpf-accent); width: 100%;
  transition: border-color .2s;
}
.wpf-nick-input:focus { border-color: var(--wpf-accent); }
.wpf-nick-input::placeholder { color: var(--wpf-muted); font-weight: 400; }

#wpf-text, .wpf-compose-full textarea {
  border: none; outline: none; resize: none; background: none;
  font-size: 15px; line-height: 1.7; font-family: inherit;
  color: var(--wpf-text); width: 100%; min-height: 72px;
  padding: 4px 0;
}
#wpf-text::placeholder { color: var(--wpf-muted); }

.wpf-compose-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px 12px; margin-top: 6px;
  border-top: 1px solid var(--wpf-border);
}
.wpf-compose-actions { display: flex; gap: 8px; align-items: center; }
.wpf-char-count { font-size: 12px; color: var(--wpf-muted); }
.wpf-char-count.warn { color: var(--wpf-accent); }

.wpf-btn-post {
  background: var(--wpf-accent); color: #fff; border: none;
  border-radius: 8px; font-size: 13px; font-weight: 600;
  font-family: inherit; padding: 9px 22px; cursor: pointer;
  transition: background .2s, transform .1s;
}
.wpf-btn-post:hover   { background: var(--wpf-accent2); }
.wpf-btn-post:active  { transform: scale(.97); }
.wpf-btn-post:disabled { opacity: .4; cursor: default; }

.wpf-btn-cancel {
  background: none; border: none;
  color: var(--wpf-muted); font-size: 13px;
  font-family: inherit; padding: 6px 10px; cursor: pointer;
  transition: color .15s; border-radius: 6px;
}
.wpf-btn-cancel:hover { color: var(--wpf-text); background: rgba(0,0,0,.04); }

/* reply textarea */
#wpf-reply-text {
  width: 100%; border: none; outline: none; resize: none; background: none;
  font-size: 15px; line-height: 1.65; font-family: inherit;
  color: var(--wpf-text); min-height: 80px;
}
#wpf-reply-text::placeholder { color: var(--wpf-muted); }

.wpf-notice { border-radius:var(--wpf-radius);padding:12px 16px;font-size:14px;margin-bottom:14px; }
.wpf-success { background:#f0f7f0;border:1px solid #b8ddb8;color:#2d6a2d; }
.wpf-error   { background:#fdf0f1;border:1px solid #e8b8bc;color:var(--wpf-accent); }

.wpf-new-banner { background:var(--wpf-accent);color:#fff;text-align:center;padding:10px;border-radius:var(--wpf-radius);margin-bottom:14px;cursor:pointer;font-size:13px;animation:wpfSlide .3s ease;user-select:none; }
.wpf-new-banner:hover { background:var(--wpf-accent2); }
@keyframes wpfSlide { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }

.wpf-post-card { background:var(--wpf-surface);border:1px solid var(--wpf-border);border-radius:var(--wpf-radius);margin-bottom:10px;box-shadow:0 1px 3px rgba(0,0,0,.04);overflow:hidden;transition:border-color .2s,box-shadow .2s;animation:wpfFade .3s ease; }
.wpf-post-card:hover { border-color:var(--wpf-border2);box-shadow:0 3px 10px rgba(0,0,0,.08); }
@keyframes wpfFade { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.wpf-post-body { padding:16px 16px 12px;cursor:pointer; }
.wpf-post-body:hover .wpf-post-text { color:#000; }
.wpf-nick { display:inline-block;font-size:12px;font-weight:600;color:var(--wpf-nick-col);background:var(--wpf-nick-bg);border-radius:4px;padding:2px 8px;margin-bottom:9px; }
.wpf-nick.mine { background:rgba(176,100,20,.09);color:#8a4a10; }
.wpf-post-text { color:var(--wpf-text);word-break:break-word;white-space:pre-wrap;line-height:1.65;margin-bottom:12px;font-size:15px;transition:color .15s; }
.wpf-post-meta { display:flex;align-items:center;gap:10px;font-size:13px;color:var(--wpf-muted); }
.wpf-time { font-size:12px; }

.wpf-like-btn, .wpf-comments-btn, .wpf-delete-btn { display:flex;align-items:center;gap:5px;background:none;border:none;color:var(--wpf-muted);font-family:inherit;font-size:13px;cursor:pointer;padding:3px 8px 3px 4px;border-radius:6px;transition:color .2s,background .2s; }
.wpf-like-btn:hover   { background:rgba(139,26,43,.08);color:var(--wpf-accent); }
.wpf-like-btn.liked   { color:var(--wpf-accent); }
.wpf-comments-btn:hover { background:rgba(42,125,225,.08);color:#2a7de1; }
.wpf-comments-btn.open  { color:#2a7de1; }
.wpf-delete-btn { margin-left:auto; }
.wpf-delete-btn:hover { background:rgba(139,26,43,.08);color:var(--wpf-accent); }

/* permalink */
.wpf-permalink { font-size:12px;color:var(--wpf-muted);text-decoration:none;padding:3px 6px;border-radius:4px; }
.wpf-permalink:hover { color:var(--wpf-accent); }

.wpf-comments { display:none; border-top:1px solid var(--wpf-border); background:var(--wpf-bg); animation:wpfFade .2s ease; }
.wpf-comments.open { display:block; }
.wpf-comments-list { padding:10px 14px 2px; display:flex; flex-direction:column; gap:8px; }
.wpf-empty-comments { padding:12px 14px; font-size:13px; color:var(--wpf-muted); }

/* Элемент комментария */
.wpf-comment-item { display:flex; gap:9px; animation:wpfFade .2s ease; }
.wpf-comment-item-body { flex:1; min-width:0; }
.wpf-comment-bubble {
  background:var(--wpf-surface); border:1px solid var(--wpf-border);
  border-radius:0 10px 10px 10px; padding:8px 12px;
  font-size:13px; line-height:1.5; color:var(--wpf-text);
  word-break:break-word; white-space:pre-wrap;
}
.wpf-comment-nick {
  display:inline-block; font-size:11px; font-weight:700;
  color:var(--wpf-nick-col); margin-bottom:4px;
}
.wpf-comment-nick.mine { color:#8a4a10; }
.wpf-comment-meta { display:flex; align-items:center; gap:8px; font-size:11px; color:var(--wpf-muted); margin-top:4px; padding-left:2px; }

/* Маленький аватар */
.wpf-comment-av-wrap { flex-shrink:0; padding-top:2px; }
.wpf-av-sm {
  width:30px; height:30px; border-radius:50%;
  background:var(--wpf-surface); border:1.5px solid var(--wpf-border);
  background-size:cover; background-position:center;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; color:var(--wpf-accent); user-select:none;
}

/* Форма комментария */
.wpf-comment-compose {
  padding: 10px 14px 12px;
  border-top: 1px solid var(--wpf-border);
}

/* Закрытое */
.wpf-ccompose-collapsed {
  display: flex; align-items: center; gap: 10px; cursor: text;
}
.wpf-ccompose-hint {
  flex: 1; background: var(--wpf-surface);
  border: 1.5px solid var(--wpf-border);
  border-radius: 100px; padding: 7px 16px;
  font-size: 13px; color: var(--wpf-muted);
  transition: border-color .2s;
}
.wpf-ccompose-collapsed:hover .wpf-ccompose-hint { border-color: var(--wpf-border2); }

/* Открытое */
.wpf-ccompose-expanded { display: none; animation: wpfExpand .15s ease; }
.wpf-comment-compose-inner {
  display: flex; gap: 0; align-items: flex-start;
  background: var(--wpf-surface);
  border: 1.5px solid var(--wpf-border);
  border-radius: 12px; overflow: hidden;
  transition: border-color .2s;
}
.wpf-comment-compose-inner:focus-within { border-color: var(--wpf-border2); }
.wpf-comment-av {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  background: var(--wpf-surface); border: 1.5px solid var(--wpf-border);
  margin: 9px 0 9px 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; color: var(--wpf-accent); user-select: none;
}
.wpf-comment-fields { flex:1; display:flex; flex-direction:column; min-width:0; }
.wpf-comment-nick-input {
  border: none; outline: none; background: none;
  font-size: 12px; font-weight: 700; font-family: inherit;
  color: var(--wpf-accent); padding: 8px 12px 0; width: 100%;
}
.wpf-comment-nick-input::placeholder { color:var(--wpf-muted); font-weight:400; }
.wpf-comment-fields textarea {
  border: none; outline: none; resize: none; background: none;
  font-size: 13px; line-height: 1.55; font-family: inherit;
  color: var(--wpf-text); width: 100%; min-height: 36px;
  padding: 7px 12px;
}
.wpf-comment-fields textarea::placeholder { color:var(--wpf-muted); }
.wpf-comment-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 8px;
}
.wpf-comment-footer-left { display:flex; align-items:center; gap:10px; }
.wpf-comment-chars { font-size:11px; color:var(--wpf-muted); }
.wpf-ccompose-cancel {
  background: none; border: none; font-size: 12px; font-family: inherit;
  color: var(--wpf-muted); cursor: pointer; padding: 6px 8px; border-radius: 6px;
  transition: color .15s;
}
.wpf-ccompose-cancel:hover { color: var(--wpf-text); }
.wpf-btn-comment {
  background: var(--wpf-accent); color: #fff; border: none;
  border-radius: 8px; font-size: 12px; font-weight: 600;
  font-family: inherit; padding: 7px 18px; cursor: pointer;
  transition: background .2s;
}
.wpf-btn-comment:hover { background: var(--wpf-accent2); }
.wpf-btn-comment:disabled { opacity:.4; cursor:default; }

.wpf-loader { display:flex;align-items:center;justify-content:center;gap:10px;padding:30px;color:var(--wpf-muted);font-size:13px; }
.wpf-spinner { width:20px;height:20px;border:2px solid var(--wpf-border2);border-top-color:var(--wpf-accent);border-radius:50%;animation:wpfSpin .6s linear infinite;flex-shrink:0; }
@keyframes wpfSpin { to{transform:rotate(360deg)} }

@media(max-width:600px) {
  .wpf-header { flex-direction:column; }
  .wpf-nick-row { flex-wrap:wrap; }
  .wpf-nick-input { width:100%; }
}

/* Single page */
.wpf-single { max-width:760px; margin:30px auto; padding:0 16px; }
.wpf-single-back { margin-bottom:16px; }
.wpf-single-back a { color:var(--wpf-muted); font-size:13px; text-decoration:none; }
.wpf-single-back a:hover { color:var(--wpf-accent); }

/* ---- Single page ---- */
.wpf-single .wpf-post-card { cursor:default; }
.wpf-single .wpf-post-body { cursor:default; }
.wpf-single .wpf-post-body:hover .wpf-post-text { color:var(--wpf-text); }

/* Миниатюра фото в посте */
.wpf-single .wpf-post-image {
  max-height:260px; cursor:zoom-in;
  border-radius:8px; overflow:hidden; margin:8px 0 4px;
}
.wpf-single .wpf-post-image img {
  width:100%; max-height:260px; object-fit:cover; display:block;
}

/* Комментарии на single — секция с фоном, вплотную к карточке поста */
.wpf-single .wpf-post-card { margin-bottom: 0; border-radius: var(--wpf-radius) var(--wpf-radius) 0 0; border-bottom: none; }
.wpf-single-comments {
  background: var(--wpf-bg);
  border: 1px solid var(--wpf-border);
  border-top: none;
  border-radius: 0 0 var(--wpf-radius) var(--wpf-radius);
  padding: 12px 14px 14px;
  display: flex; flex-direction: column; gap: 8px;
  margin-bottom: 10px;
}
/* .wpf-single-comments .wpf-comment-item — без карточки, как в ленте */
/* Форма ответа — тот же фон, без лишних отступов */
.wpf-single-compose { margin-top: 4px; }

/* Форма на single — такая же как на главной, без переопределений */
.wpf-single-compose {
  margin-top: 8px;
}

.wpf-replies-heading { display:none; }
.wpf-empty-single { padding:14px 16px; font-size:13px; color:var(--wpf-muted); background:var(--wpf-surface); border:1px solid var(--wpf-border); border-radius:12px 12px 0 0; }
.wpf-replies-count { font-weight:400; }

/* ---- Image upload ---- */
.wpf-compose-tools { display:flex; align-items:center; gap:12px; }
.wpf-attach-btn {
  display:flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:50%; cursor:pointer;
  color:var(--wpf-muted); transition:color .2s, background .2s;
}
.wpf-attach-btn:hover { color:var(--wpf-accent); background:var(--wpf-nick-bg); }

.wpf-image-preview {
  position:relative; margin:0 14px 10px;
  border-radius:10px; overflow:hidden;
  border:1px solid var(--wpf-border);
  max-height:260px;
}
.wpf-image-preview img {
  width:100%; max-height:260px; object-fit:cover; display:block;
}
.wpf-image-remove {
  position:absolute; top:8px; right:8px;
  background:rgba(0,0,0,.55); color:#fff; border:none;
  width:26px; height:26px; border-radius:50%; cursor:pointer;
  font-size:12px; display:flex; align-items:center; justify-content:center;
  transition:background .2s;
}
.wpf-image-remove:hover { background:rgba(0,0,0,.8); }

/* Фото в карточке */
.wpf-post-image {
  margin:8px 0 4px; border-radius:8px; overflow:hidden;
  max-height:260px; cursor:zoom-in;
}
.wpf-post-image img {
  width:100%; max-height:260px; object-fit:cover; display:block;
  border-radius:8px; transition:opacity .2s;
}
.wpf-post-image img:hover { opacity:.93; }

/* Фото в комментарии */
.wpf-comment-image {
  margin:6px 0 2px; border-radius:6px; overflow:hidden;
  max-height:200px; cursor:zoom-in;
}
.wpf-comment-image img {
  width:100%; max-height:200px; object-fit:cover; display:block;
  border-radius:6px; transition:opacity .2s;
}
.wpf-comment-image img:hover { opacity:.93; }

/* Модальное окно просмотра фото */
.wpf-lightbox {
  position:fixed; inset:0; z-index:99999;
  background:rgba(0,0,0,.85); backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center;
  cursor:zoom-out; animation:wpfLbIn .18s ease;
}
@keyframes wpfLbIn { from{opacity:0} to{opacity:1} }
.wpf-lightbox img {
  max-width:92vw; max-height:92vh;
  border-radius:8px; box-shadow:0 8px 40px rgba(0,0,0,.6);
  cursor:default; object-fit:contain;
  animation:wpfLbScale .2s ease;
}
@keyframes wpfLbScale { from{transform:scale(.95)} to{transform:scale(1)} }
.wpf-lightbox-close {
  position:fixed; top:16px; right:20px;
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.15); border:none; color:#fff;
  font-size:18px; cursor:pointer; display:flex;
  align-items:center; justify-content:center;
  transition:background .2s;
}
.wpf-lightbox-close:hover { background:rgba(255,255,255,.3); }

/* Кнопка прикрепления фото в комментарии */
.wpf-comment-attach { display:flex; align-items:center; gap:10px; margin-top:6px; }
.wpf-comment-attach-btn {
  display:flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:50%; cursor:pointer;
  color:var(--wpf-muted); transition:color .2s, background .2s; flex-shrink:0;
}
.wpf-comment-attach-btn:hover { color:var(--wpf-accent); background:var(--wpf-nick-bg); }
.wpf-comment-img-preview {
  position:relative; border-radius:6px; overflow:hidden;
  width:60px; height:60px; flex-shrink:0;
}
.wpf-comment-img-preview img { width:100%; height:100%; object-fit:cover; display:block; }
.wpf-comment-img-remove {
  position:absolute; top:2px; right:2px;
  background:rgba(0,0,0,.6); color:#fff; border:none;
  width:18px; height:18px; border-radius:50%; cursor:pointer;
  font-size:10px; display:flex; align-items:center; justify-content:center;
}

.wpf-comment-nick-input {
  display: block; width: 100%;
  border: none; border-bottom: 1px solid var(--wpf-border);
  outline: none; background: none;
  font-size: 12px; font-weight: 600; font-family: inherit;
  color: var(--wpf-accent); padding: 6px 14px 6px;
  transition: border-color .2s;
}
.wpf-comment-nick-input:focus { border-color: var(--wpf-border2); }
.wpf-comment-nick-input::placeholder { color: var(--wpf-muted); font-weight: 400; }

/* Аватар в карточке поста */
.wpf-post-author { display:flex; align-items:center; gap:10px; margin-bottom:10px; padding:0 2px; }
.wpf-post-av {
  width:36px; height:36px; border-radius:50%; flex-shrink:0;
  background:var(--wpf-surface); border:1.5px solid var(--wpf-border);
  background-size:cover; background-position:center;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; color:var(--wpf-accent); user-select:none;
}
.wpf-post-av.has-img { font-size:0; border:none; background-color:transparent; }

/* Форма всегда открыта — убираем стили закрытого состояния */
.wpf-compose { border:1.5px solid var(--wpf-border); border-radius:14px; background:var(--wpf-surface); overflow:hidden; }


/* ---- Галерея фото в посте ---- */
.wpf-post-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px; margin: 8px 0 4px;
}
.wpf-gallery-thumb {
  height: 90px; border-radius: 6px; overflow: hidden;
  cursor: zoom-in;
}
.wpf-gallery-thumb img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: opacity .2s;
}
.wpf-gallery-thumb img:hover { opacity: .88; }

/* 1 фото — полная ширина */
.wpf-post-gallery:has(.wpf-gallery-thumb:only-child) {
  grid-template-columns: 1fr;
}
.wpf-post-gallery:has(.wpf-gallery-thumb:only-child) .wpf-gallery-thumb {
  height: 240px;
}

/* 2 фото — по половине */
.wpf-post-gallery:has(.wpf-gallery-thumb:nth-child(2)):not(:has(.wpf-gallery-thumb:nth-child(3))) {
  grid-template-columns: repeat(2, 1fr);
}
.wpf-post-gallery:has(.wpf-gallery-thumb:nth-child(2)):not(:has(.wpf-gallery-thumb:nth-child(3))) .wpf-gallery-thumb {
  height: 160px;
}

/* 3 фото — 3 в ряд */
.wpf-post-gallery:has(.wpf-gallery-thumb:nth-child(3)):not(:has(.wpf-gallery-thumb:nth-child(4))) {
  grid-template-columns: repeat(3, 1fr);
}

/* Превью нескольких фото в форме */
.wpf-images-preview {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 0 14px 10px;
}
.wpf-img-thumb {
  position: relative; width: 72px; height: 72px;
  border-radius: 8px; overflow: hidden; flex-shrink: 0;
}
.wpf-img-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.wpf-img-thumb-rm {
  position: absolute; top: 3px; right: 3px;
  width: 18px; height: 18px; border-radius: 50%;
  background: rgba(0,0,0,.6); color: #fff; border: none;
  font-size: 10px; cursor: pointer; display: flex;
  align-items: center; justify-content: center;
}

.wpf-comment-nick-logged {
  font-size: 12px; font-weight: 700; color: var(--wpf-accent);
  padding: 8px 12px 0;
}

.wpf-new-replies-banner {
  margin: 0 14px 8px;
  padding: 8px 12px;
  background: var(--wpf-accent-light, #f5e6e8);
  color: var(--wpf-accent);
  border: 1px solid var(--wpf-accent);
  border-radius: 8px;
  font-size: 13px;
  cursor: pointer;
  text-align: center;
  transition: background .2s;
}
.wpf-new-replies-banner:hover { background: var(--wpf-accent); color: #fff; }

/* Поиск */
.wpf-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.wpf-search-icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  color: var(--wpf-muted);
}
.wpf-search-input {
  flex: 1;
  min-width: 0;
  box-sizing: border-box;
  padding: 9px 36px 9px 12px;
  border: 1px solid var(--wpf-border);
  border-radius: var(--wpf-radius);
  background: var(--wpf-surface);
  font-family: inherit;
  font-size: 14px;
  color: var(--wpf-text);
  transition: border-color .2s, box-shadow .2s;
}
.wpf-search-input:focus {
  outline: none;
  border-color: var(--wpf-accent);
  box-shadow: 0 0 0 3px rgba(139,26,43,.1);
}
.wpf-search-input::placeholder { color: var(--wpf-muted); }
.wpf-search-clear {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  display: none;
  align-items: center;
  justify-content: center;
  width: 20px; height: 20px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--wpf-muted);
  font-size: 13px;
  border-radius: 50%;
  transition: background .2s, color .2s;
}
.wpf-search-clear:hover { background: var(--wpf-border); color: var(--wpf-text); }
.wpf-empty-search {
  text-align: center;
  padding: 40px 20px;
  color: var(--wpf-muted);
  font-size: 14px;
}

/* Список тем [forum_topics] */
.wpf-topics { font-family: inherit; }
.wpf-topics-list { list-style: none; margin: 0; padding: 0; }
.wpf-topics-item {
  border-bottom: 1px solid var(--wpf-border);
}
.wpf-topics-item:last-child { border-bottom: none; }
.wpf-topics-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 11px 4px;
  text-decoration: none;
  color: var(--wpf-text);
  transition: color .2s;
}
.wpf-topics-link:hover .wpf-topics-title { color: var(--wpf-accent); }
.wpf-topics-title {
  flex: 1;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  transition: color .2s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wpf-topics-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  font-size: 12px;
  color: var(--wpf-muted);
}
.wpf-topics-author { color: var(--wpf-nick-col); font-weight: 600; }
.wpf-topics-stat {
  display: flex;
  align-items: center;
  gap: 3px;
}
.wpf-topics-stat svg { opacity: .6; }
.wpf-topics-date { white-space: nowrap; }
.wpf-topics-empty { color: var(--wpf-muted); font-size: 14px; }
