/* 资讯列表页正文（母版已含全局与页头页尾） */
.page-header { background: var(--white); padding: 22px 0; margin-bottom: 26px; box-shadow: var(--shadow); }
.page-title-container { display: flex; justify-content: space-between; align-items: center; gap: 14px; }
.page-header .breadcrumb { color: var(--mid); font-size: 14px; }
.page-header .breadcrumb a { color: var(--primary); text-decoration: none; }
.page-header .breadcrumb a:hover { text-decoration: underline; }
.page-header .breadcrumb strong { font-size: 16px; color: var(--primary); }
.total-count { font-size: 14px; color: var(--mid); }
.total-count strong { color: var(--primary); }

.main-content { display: flex; gap: 26px; padding-bottom: 38px; }
.content-left { flex: 2.5; }
.content-right { flex: 1; }

.list-controls { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 18px; background: var(--white); padding: 16px 18px; border-radius: var(--radius); box-shadow: var(--shadow); }
.controls-left { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.qbox { display: flex; align-items: center; gap: 8px; }
.qbox input { width: 240px; padding: 8px 12px; border: 1px solid #ddd; border-radius: var(--radius); font-size: 14px; }
.qbox input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 2px rgba(233,67,115,0.15); }
.btn-mini { padding: 8px 12px; font-size: 13px; border-radius: var(--radius); border: 1px solid var(--primary); background: var(--primary-bg); color: var(--primary); cursor: pointer; transition: var(--tr); }
.btn-mini:hover { background: var(--primary); color: #fff; }
.sort-options { display: flex; align-items: center; gap: 10px; }
.sort-options label { font-weight: 600; font-size: 14px; }
.sort-options select { padding: 8px 12px; border-radius: var(--radius); border: 1px solid #ddd; background: #fff; font-size: 14px; cursor: pointer; }

.article-list { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; margin-bottom: 18px; }
.list-item { display: flex; gap: 18px; padding: 18px; border-bottom: 1px solid #eee; transition: var(--tr); text-decoration: none; color: inherit; }
.list-item:hover { background: var(--primary-bg); }
.item-image { width: 200px; height: 140px; border-radius: 8px; object-fit: cover; flex-shrink: 0; background: #fafafa; border: 1px solid #eee; }
.item-image-ph { width: 200px; height: 140px; border-radius: 8px; flex-shrink: 0; background: linear-gradient(135deg,#fde8ef,#f9c5d1); border: 1px solid #eee; display: flex; align-items: center; justify-content: center; color: var(--primary); font-size: 28px; }
.item-content { flex: 1; min-width: 0; display: flex; flex-direction: column; justify-content: center; }
.item-title { font-weight: 700; font-size: 18px; margin-bottom: 10px; line-height: 1.45; color: var(--dark); }
.item-excerpt { color: var(--mid); margin-bottom: 12px; line-height: 1.65; font-size: 14px; }
.item-meta { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.item-info { display: flex; gap: 16px; font-size: 12px; color: var(--mid); flex-wrap: wrap; }
.item-date, .item-author, .item-category { display: flex; align-items: center; gap: 5px; }
.item-category { background: var(--primary-bg); color: var(--primary); padding: 3px 10px; border-radius: 20px; border: 1px solid rgba(233,67,115,0.2); }
.item-views { font-size: 12px; color: var(--mid); white-space: nowrap; }

.no-data { padding: 24px 18px; text-align: center; color: var(--mid); font-size: 13px; }

.sidebar { display: flex; flex-direction: column; gap: 18px; }
.sidebar-widget { background: var(--white); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; }
.widget-title { padding: 14px 16px; background: var(--primary); color: #fff; font-size: 15px; font-weight: 700; display: flex; align-items: center; gap: 8px; }
.widget-title.recommended { background: var(--accent-orange); }
.widget-title.popular { background: var(--accent-red); }
.widget-item { display: flex; padding: 14px 16px; border-bottom: 1px solid #eee; transition: var(--tr); text-decoration: none; color: inherit; }
.widget-item:hover { background: var(--primary-bg); }
.widget-item:last-child { border-bottom: none; }
.widget-rank { width: 24px; height: 24px; background: var(--primary-bg); color: var(--primary); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; margin-right: 12px; flex-shrink: 0; }
.widget-content { flex: 1; min-width: 0; }
.widget-item-title { font-weight: 600; font-size: 13px; line-height: 1.45; margin-bottom: 6px; color: var(--dark); }
.widget-meta { display: flex; justify-content: space-between; font-size: 12px; color: var(--mid); gap: 10px; }

.pagination { display: flex; justify-content: center; align-items: center; margin-top: 28px; }
.pagination-list { display: flex; list-style: none; gap: 8px; flex-wrap: wrap; }
.pagination-item { min-width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius); background: #fff; border: 1px solid #ddd; transition: var(--tr); }
.pagination-item a, .pagination-item span { text-decoration: none; color: var(--dark); width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; padding: 0 10px; white-space: nowrap; }
.pagination-item:hover { border-color: var(--primary); background: var(--primary-bg); }
.pagination-item.active { background: var(--primary); border-color: var(--primary); }
.pagination-item.active a { color: #fff; }
.pagination-item.disabled { opacity: .55; pointer-events: none; }
.pagination-prev, .pagination-next { min-width: 92px; }

@media (max-width: 992px) {
    .main-content { flex-direction: column; }
    .content-left, .content-right { width: 100%; }
    .list-item { flex-direction: column; }
    .item-image, .item-image-ph { width: 100%; height: 200px; }
}
@media (max-width: 768px) {
    .list-controls { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 576px) {
    .qbox input { width: 200px; }
}
