/* =========================
   Posts Search/List (Unified)
   ========================= */

.pagetitle {
  display: none;
}

.posts-page{ padding: 22px 0 60px; }

/* Filters */
.posts-filters{
  margin: 18px 0;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  border-radius: 18px;
  padding: 16px;
}

.filter-form{ display:block; }

.filter-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
  align-items:start;
}

.filter-row{
  display:flex;
  flex-direction:column;
  gap: 6px;
}

.filter-row-wide{ grid-column: 1 / -1; }

.filter-label{ font-size: 12px; opacity: .75; }

.filter-hint{
  margin: 4px 0 0;
  font-size: 11px;
  opacity: .55;
}

.filter-form input[type="search"],
.filter-form select{
  width: 100%;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.92);
  outline: none;
}

.filter-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

/* Tag multi select */
.tag-search{ margin-bottom: 10px; }

.tag-box{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  max-height: 220px;
  overflow:auto;
  padding: 10px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.14);
}

.tag-item{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  cursor:pointer;
  font-size: 12px;
  user-select:none;
}
.tag-item input{ accent-color: #22d3ee; }

/* Results */
.posts-count{
  font-size: 12px;
  opacity: .75;
  margin: 8px 0 12px;
}

.post-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}

.post-card{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  border-radius: 18px;
  overflow: hidden;
}

.post-card-link{
  display:block;
  text-decoration:none;
  color: inherit;
}

.post-thumb img{
  width: 100%;
  height: 180px;
  object-fit: cover;
  display:block;
}

.post-thumb-placeholder{
  height: 180px;
  background: linear-gradient(135deg, rgba(124,58,237,.25), rgba(34,211,238,.18));
}

.post-meta{ padding: 14px; }
.post-date{ font-size: 12px; opacity: .75; }
.post-title{ margin: 6px 0 8px; font-size: 16px; }
.post-excerpt{ margin: 0; opacity: .82; font-size: 13px; }

.post-tax{
  margin-top: 10px;
  font-size: 12px;
  opacity: .75;
  display:grid;
  gap: 6px;
}

/* Pagination */
.pagination ul{
  list-style:none;
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  padding: 0;
  margin: 18px 0 0;
}

.pagination a,
.pagination span{
  display:inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  text-decoration:none;
  color: rgba(255,255,255,.9);
  font-size: 12px;
}

.pagination .current{
  background: linear-gradient(135deg, rgba(124,58,237,.85), rgba(34,211,238,.55));
  border-color: transparent;
}

/* Ajax status + loading */
.ajax-status{ margin-top: 10px; font-size: 12px; opacity: .7; }

[data-result].is-loading{
  opacity: .6;
  pointer-events:none;
  filter: blur(.2px);
}

/* Responsive */
@media (max-width: 900px){
  .filter-grid{ grid-template-columns: 1fr; }
  .post-grid{ grid-template-columns: 1fr; }
  .post-thumb img,
  .post-thumb-placeholder{ height: 200px; }
}
