/**
 * 新闻资讯网站模板 - 页面特定样式表
 * 包含：首页、列表页、详情页的特定样式和响应式布局
 */

/* ==================== 页面布局 ==================== */
.page-wrapper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.page-main {
    flex: 1;
    padding: var(--spacing-lg) 0;
}

/* 两栏布局 */
.two-column-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: var(--spacing-xl);
}

.main-content {
    min-width: 0;
}

.sidebar {
    min-width: 0;
}

/* ==================== 首页样式 ==================== */
.hero-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid #0891b2;
}

/* 焦点图下方内容区 */
.featured-section {
    margin-bottom: var(--spacing-xl);
}

.featured-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-md);
}

/* 新闻区块 */
.news-section {
    margin-bottom: var(--spacing-xl);
}

.news-section-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--spacing-xl);
    align-items: start;
}

/* 左侧主要内容 */
.news-main .news-item:first-child {
    padding-top: 0;
}

/* 右侧栏目导航 - 标题时间列表式布局 */
.news-sidebar {
    display: flex;
    flex-direction: column;
}

.news-sidebar .section-header {
    margin-bottom: var(--spacing-md);
}

.sidebar-nav-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.sidebar-nav-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--bg-primary);
    border-bottom: 1px solid var(--border-light);
    transition: all var(--transition-fast);
    text-decoration: none;
}

.sidebar-nav-item:last-child {
    border-bottom: none;
}

.sidebar-nav-item:hover {
    background-color: var(--bg-secondary);
}

.sidebar-nav-item:hover .sidebar-nav-title {
    color: var(--primary-color);
}

.sidebar-nav-title {
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--text-primary);
    transition: color var(--transition-fast);
    flex: 1;
    margin-right: var(--spacing-md);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sidebar-nav-time {
    font-size: var(--font-size-xs);
    color: var(--text-tertiary);
    flex-shrink: 0;
}

/* 右侧推荐文章列表 - 与左侧新闻列表等高 */
.sidebar-article-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    overflow: hidden;
    height: 100%;
}

.sidebar-article-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--bg-primary);
    border-bottom: 1px solid var(--border-light);
    transition: all var(--transition-fast);
    text-decoration: none;
    flex: 1;
}

.sidebar-article-item:last-child {
    border-bottom: none;
}

.sidebar-article-item:hover {
    background-color: var(--bg-secondary);
}

.sidebar-article-item:hover .sidebar-article-title {
    color: var(--primary-color);
}

.sidebar-article-title {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--text-primary);
    transition: color var(--transition-fast);
    flex: 1;
    margin-right: var(--spacing-md);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: var(--line-height-tight);
    font-family: inherit;
}

.sidebar-article-item:hover .sidebar-article-title {
    color: var(--primary-color);
}

.sidebar-article-time {
    font-size: var(--font-size-xs);
    color: var(--text-tertiary);
    flex-shrink: 0;
    line-height: var(--line-height-tight);
}

/* 右侧栏目入口 */
.category-entries {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
}

.category-entry {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    background-color: var(--bg-secondary);
    border-radius: var(--radius-md);
    transition: all var(--transition-fast);
}

.category-entry:hover {
    background-color: var(--primary-color);
    color: #ffffff;
}

.category-entry:hover .category-entry-icon,
.category-entry:hover .category-entry-title,
.category-entry:hover .category-entry-count {
    color: #ffffff;
}

.category-entry-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(26, 115, 232, 0.1);
    color: var(--primary-color);
    border-radius: var(--radius-md);
    font-size: var(--font-size-lg);
}

.category-entry-info {
    flex: 1;
}

.category-entry-title {
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: var(--spacing-xs);
}

.category-entry-count {
    font-size: var(--font-size-xs);
    color: var(--text-tertiary);
}

/* 多栏目内容展示 */
.multi-column-section {
    margin-bottom: var(--spacing-xl);
}

.multi-column-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-lg);
}

.column-block {
    background-color: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.column-block-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    border-bottom: 1px solid var(--border-light);
}

.column-block-title {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--text-primary);
}

.column-block-body {
    padding: var(--spacing-md);
}

.column-block-body .news-item-text:first-child {
    padding-top: 0;
}

/* 图文卡片网格 */
.card-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-md);
}

/* ==================== 列表页样式 ==================== */
/* 筛选栏 */
.filter-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    background-color: var(--bg-secondary);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-md);
}

.filter-tabs {
    display: flex;
    gap: var(--spacing-xs);
}

.filter-tab {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
}

.filter-tab:hover,
.filter-tab.active {
    color: var(--primary-color);
    background-color: rgba(26, 115, 232, 0.1);
}

.filter-options {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.filter-select {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background-color: var(--bg-primary);
    color: var(--text-primary);
}

/* 文章列表 */
.article-list {
    background-color: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-md);
}

.article-list .news-item:first-child {
    padding-top: 0;
}

.article-list .news-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

/* 无图模式的文章项 */
.news-item.no-image .news-item-content {
    justify-content: flex-start;
}

.news-item.no-image .news-item-summary {
    margin-top: var(--spacing-sm);
}

/* ==================== 详情页样式 ==================== */
/* 文章头部 */
.article-header {
    margin-bottom: var(--spacing-lg);
}

.article-category-tag {
    display: inline-block;
    background: linear-gradient(135deg, #0891b2 0%, #06b6d4 100%);
    color: #ffffff;
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-size-sm);
    box-shadow: 0 2px 4px rgba(8, 145, 178, 0.25);
    border-radius: var(--radius-sm);
    margin-bottom: var(--spacing-md);
}

.article-title {
    font-size: var(--font-size-3xl);
    font-weight: 700;
    line-height: var(--line-height-tight);
    margin-bottom: var(--spacing-md);
    color: var(--text-primary);
}

.article-meta-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--border-light);
}

.article-meta-left {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.article-author {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.article-author-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
}

.article-author-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.article-author-info {
    display: flex;
    flex-direction: column;
}

.article-author-name {
    font-weight: 600;
    color: var(--text-primary);
}

.article-publish-time {
    font-size: var(--font-size-xs);
    color: var(--text-tertiary);
}

.article-meta-right {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.article-stats {
    display: flex;
    gap: var(--spacing-md);
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

.article-stats span {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

/* 文章内容 */
.article-content {
    font-size: var(--font-size-md);
    line-height: var(--line-height-relaxed);
    color: var(--text-primary);
}

.article-content p {
    margin-bottom: var(--spacing-lg);
    text-align: justify;
    overflow: hidden;
}

.article-content h2 {
    font-size: var(--font-size-xl);
    margin: var(--spacing-xl) 0 var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--border-light);
}

.article-content h3 {
    font-size: var(--font-size-lg);
    margin: var(--spacing-lg) 0 var(--spacing-md);
}

.article-content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    margin: 0 auto;
    object-fit: contain;
    box-sizing: border-box;
}

.article-content figcaption {
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    margin-top: var(--spacing-sm);
}

.article-content blockquote {
    border-left: 4px solid var(--primary-color);
    padding-left: var(--spacing-md);
    margin: var(--spacing-lg) 0;
    color: var(--text-secondary);
    font-style: italic;
}

.article-content ul,
.article-content ol {
    margin-bottom: var(--spacing-lg);
    padding-left: var(--spacing-lg);
}

.article-content ul {
    list-style: disc;
}

.article-content ol {
    list-style: decimal;
}

.article-content li {
    margin-bottom: var(--spacing-xs);
}

/* 图片画廊 */
.article-gallery {
    margin: var(--spacing-xl) 0;
}

.gallery-main {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--spacing-md);
}

.gallery-main img {
    width: 100%;
    height: auto;
    display: block;
}

/* 文章底部 */
.article-footer {
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--border-light);
}

.article-tags {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    flex-wrap: wrap;
}

.article-tags-label {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

.article-share {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    padding: var(--spacing-md) 0;
}

.article-declaration {
    background-color: var(--bg-secondary);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    margin-top: var(--spacing-lg);
}

.article-declaration-title {
    font-weight: 600;
    margin-bottom: var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.article-declaration p {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    margin-bottom: var(--spacing-xs);
}

/* 相关推荐 */
.related-articles {
    margin-top: var(--spacing-xl);
}

.related-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
}

/* 评论区 */
.comments-section {
    margin-top: var(--spacing-xl);
    background-color: var(--bg-primary);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-lg);
}

.comments-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
}

.comments-count {
    font-size: var(--font-size-lg);
    font-weight: 600;
}

.comments-sort {
    display: flex;
    gap: var(--spacing-md);
}

.comments-sort button {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

.comments-sort button.active {
    color: var(--primary-color);
    font-weight: 500;
}

.comment-form {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.comment-form-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}

.comment-form-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.comment-form-content {
    flex: 1;
}

.comment-form-textarea {
    width: 100%;
    padding: var(--spacing-md);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    resize: vertical;
    min-height: 100px;
    margin-bottom: var(--spacing-sm);
    font-family: inherit;
    font-size: var(--font-size-base);
}

.comment-form-textarea:focus {
    outline: none;
    border-color: var(--primary-color);
}

.comment-form-actions {
    display: flex;
    justify-content: flex-end;
}

.comments-list {
    border-top: 1px solid var(--border-light);
}

/* ==================== 响应式设计 ==================== */
/* 平板端 (768px - 1024px) */
@media (max-width: 1024px) {
    .two-column-layout {
        grid-template-columns: 1fr 280px;
        gap: var(--spacing-lg);
    }
    
    .featured-grid,
    .card-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .news-section-grid {
        grid-template-columns: 1fr;
    }
    
    .multi-column-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .related-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .footer-content {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* 移动端 (< 991px) */
@media (max-width: 991px) {
    :root {
        --container-padding: 12px;
    }
    
    /* 三层导航响应式 */
    .top-bar {
        display: none;
    }
    
    .header-middle {
        padding: 0;
        height: 56px;
        display: flex;
        align-items: center;
    }

    .header-middle-content {
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        height: 100%;
    }
    
    .header-middle .logo {
        font-size: 20px;
        height: 40px;
        display: flex;
        align-items: center;
    }
    
    .header-middle .logo i {
        font-size: 24px;
    }
    
    .header-search {
        display: none;
    }
    
    .nav-menu-main {
        display: none;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        background-color: var(--primary-color);
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        white-space: nowrap;
        padding: 0 var(--spacing-sm);
        box-shadow: var(--shadow-md);
        z-index: 1000;
    }
    
    .nav-menu-main.active {
        display: flex;
    }
    
    .nav-menu-main a {
        height: 48px;
        display: flex;
        align-items: center;
        padding: 0 var(--spacing-md);
        white-space: nowrap;
    }
    
    .nav-menu-main a:last-child {
        border-bottom: none;
    }
    
    /* 旧导航响应式兼容 */
    .nav-menu {
        display: none;
        position: absolute;
        top: 64px;
        left: 0;
        right: 0;
        background-color: var(--bg-primary);
        flex-direction: column;
        padding: var(--spacing-md);
        box-shadow: var(--shadow-md);
        gap: 0;
    }
    
    .nav-menu.active {
        display: flex;
    }
    
    .nav-menu a {
        padding: var(--spacing-md);
        border-bottom: 1px solid var(--border-light);
    }
    
    .nav-menu a:last-child {
        border-bottom: none;
    }
    
    .search-box {
        display: none;
    }
    
    .mobile-menu-btn {
        display: flex;
        width: 44px; /* 增加点击热区至 44px */
        height: 44px;
        padding: 10px;
        align-items: center;
        justify-content: center;
    }

    .main-nav-bar {
        height: 0;
        min-height: 0;
        padding: 0;
        overflow: visible;
    }
    
    .sub-nav {
        display: none;
    }
    
    /* 布局响应式 */
    .two-column-layout {
        grid-template-columns: 1fr;
    }
    
    .sidebar {
        order: 2;
    }
    
    /* 首页响应式 */
    .hero-section {
        grid-template-columns: 1fr;
    }
    
    .hero-carousel {
        height: 300px;
    }
    
    .carousel-title {
        font-size: var(--font-size-xl);
    }
    
    .carousel-summary {
        display: none;
    }
    
    .hero-sidebar {
        max-height: 300px;
    }
    
    .featured-grid,
    .card-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .multi-column-grid {
        grid-template-columns: 1fr;
    }
    
    .category-entries {
        grid-template-columns: repeat(2, 1fr);
    }

    /* 侧边栏推荐文章响应式 */
    .sidebar-article-list {
        border-radius: 0;
        border-left: none;
        border-right: none;
    }

    .sidebar-article-item {
        padding: var(--spacing-md);
    }

    .sidebar-article-title {
        font-size: var(--font-size-sm);
        margin-right: var(--spacing-sm);
    }

    .sidebar-article-time {
        font-size: 11px;
    }

    /* 列表页响应式 */
    .filter-bar {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .filter-tabs {
        overflow-x: auto;
        width: 100%;
        padding-bottom: var(--spacing-xs);
    }
    
    .news-item {
        flex-direction: column;
    }
    
    .news-item-image {
        flex: none;
        width: 100%;
        height: 180px;
    }
    
    /* 详情页响应式 */
    .article-title {
        font-size: var(--font-size-xl);
    }
    
    .article-meta-bar {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .related-grid {
        grid-template-columns: 1fr;
    }
    
    .article-share {
        flex-direction: column;
        align-items: flex-start;
    }
    
    /* 分页响应式 */
    .pagination {
        flex-wrap: wrap;
    }

    /* 文章图片溢出修复 */
    .article-content img {
        max-width: 100% !important;
        width: auto !important;
        height: auto !important;
    }

    /* 页脚响应式 */
    .footer-content {
        display: none;
    }
    
    .footer-bottom {
        flex-direction: column;
        text-align: center;
    }
}

/* 小屏手机 (< 480px) */
@media (max-width: 480px) {
    .featured-grid,
    .card-grid,
    .category-entries {
        grid-template-columns: 1fr;
    }
    
    .hero-carousel {
        height: 240px;
    }
    
    .carousel-control {
        width: 36px;
        height: 36px;
    }
    
    .article-title {
        font-size: var(--font-size-lg);
    }
    
    .comment-form {
        flex-direction: column;
    }
}

/* ==================== 打印样式 ==================== */
@media print {
    .top-bar,
    .main-header,
    .sub-nav,
    .sidebar,
    .hero-sidebar,
    .comments-section,
    .article-share,
    .footer {
        display: none !important;
    }
    
    .page-main {
        padding: 0;
    }
    
    .two-column-layout {
        grid-template-columns: 1fr;
    }
    
    .article-content {
        font-size: 12pt;
        line-height: 1.6;
    }
    
    .article-content a {
        text-decoration: underline;
    }
    
    .article-content a::after {
        content: " (" attr(href) ")";
        font-size: 10pt;
        color: #666;
    }
}
