
/* ============================================
   Header组件
   ============================================ */
.header {
  background-color: var(--color__bg--primary);
  border-bottom: 1px solid var(--color__border--secondary);
}

.header__top {
  background-color: var(--color__bg--tertiary);
  border-bottom: 1px solid var(--color__border--secondary);
  height: var(--space--10);
  line-height: var(--space--10);
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
}

.header__top-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header__top-left {
  display: flex;
  align-items: center;
  gap: var(--space--4);
}

.header__top-right {
  display: flex;
  align-items: center;
  gap: var(--space--4);
}

.header__logo-section {
  padding: var(--space--4) 0;
}

.header__logo-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header__logo {
  display: flex;
  align-items: center;
}

.header__logo-link {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.header__logo-img {
  height: 50px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  transition: transform var(--effect__transition--fast);
}

.header__logo-link:hover .header__logo-img {
  transform: scale(1.02);
}

/* Logo响应式适配 */
@media (max-width: 1199px) {
  .header__logo-img {
    height: 45px;
  }
}

@media (max-width: 991px) {
  .header__logo-img {
    height: 40px;
  }
}

@media (max-width: 575px) {
  .header__logo-img {
    height: 32px;
  }
}

/* 保留原有text和subtitle样式（兼容其他页面） */
.header__logo-text {
  font-size: var(--font__size--2xl);
  font-weight: var(--font__weight--bold);
  color: var(--color__primary);
}

.header__logo-subtitle {
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
}

.header__search {
  display: flex;
  align-items: center;
  gap: var(--space--2);
}

.header__search-input {
  width: 200px;
  padding: var(--space--2) var(--space--3);
  border: 1px solid var(--color__border--primary);
  border-radius: var(--effect__radius--sm);
  font-size: var(--font__size--sm);
}

.header__search-btn {
  padding: var(--space--2) var(--space--3);
  background-color: var(--color__primary);
  color: var(--color__text--white);
  border-radius: var(--effect__radius--sm);
  font-size: var(--font__size--sm);
  display: flex;
  align-items: center;
  gap: var(--space--1);
}

/* ============================================
   Navigation组件
   ============================================ */
.nav {
  background-color: var(--color__primary);
}

.nav__list {
  display: flex;
  align-items: center;
  gap: var(--space--1);
}

.nav__item {
  position: relative;
}

.nav__link {
  display: block;
  padding: var(--space--3) var(--space--4);
  color: var(--color__text--white);
  font-size: var(--font__size--base);
  font-weight: var(--font__weight--medium);
  transition: background-color var(--effect__transition--fast);
}

.nav__link:hover,
.nav__link--active {
  background-color: var(--color__primary--dark);
}

.nav__mobile-toggle {
  display: none;
  padding: var(--space--3);
  color: var(--color__text--white);
  font-size: var(--font__size--lg);
}

/* 桌面端：隐藏移动端导航元素 */
@media (min-width: 992px) {
  .header__logo-inner .nav__mobile-toggle {
    display: none;
  }
  
  .nav--mobile {
    display: none;
  }
}

@media (max-width: 991px) {
  /* 隐藏桌面端导航栏 */
  .nav--desktop {
    display: none;
  }
  
  /* 显示移动端汉堡菜单 */
  .nav__mobile-toggle {
    display: flex;
  }
  
  /* 隐藏Logo副标题和搜索框 */
  .header__logo-subtitle,
  .header__search {
    display: none;
  }
  
  /* Logo区域布局调整 */
  .header__logo-section {
    padding: var(--space--3) 0;
  }
  
  .header__logo-inner {
    position: relative;
  }
  
  /* 汉堡菜单移到Logo区域右侧 */
  .header__logo-inner .nav__mobile-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space--2);
    color: var(--color__primary);
    font-size: var(--font__size--xl);
    background: none;
    border: none;
    cursor: pointer;
  }
  
  /* 移动端导航菜单 - 下拉形式 */
  .nav--mobile {
    display: block;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--color__primary);
    z-index: var(--z-index--dropdown);
  }
  
  .nav--mobile .nav__list {
    display: none;
    flex-direction: column;
    gap: 0;
  }
  
  .nav--mobile .nav__list--open {
    display: flex;
  }
  
  .nav--mobile .nav__link {
    padding: var(--space--3) var(--space--4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
}
/* ============================================
   Section组件
   ============================================ */
.section {
  padding: var(--space--6) 0;
  overflow: hidden;
}

.section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space--4);
  padding-bottom: var(--space--3);
  border-bottom: 2px solid var(--color__border--secondary);
}

.section__title {
  font-size: var(--font__size--lg);
  font-weight: var(--font__weight--bold);
  color: var(--color__text--primary);
  display: flex;
  align-items: center;
  gap: var(--space--2);
}

.section__title::before {
  content: "";
  width: 4px;
  height: 20px;
  background-color: var(--color__primary);
  border-radius: var(--effect__radius--sm);
}

.section__more {
  font-size: var(--font__size--sm);
  color: var(--color__text--tertiary);
  display: flex;
  align-items: center;
  gap: var(--space--1);
  transition: color var(--effect__transition--fast);
}

.section__more:hover {
  color: var(--color__primary);
}

/* ============================================
   Card组件 - 新闻卡片
   ============================================ */
.card {
  background-color: var(--color__bg--primary);
  border-radius: var(--effect__radius--md);
  overflow: hidden;
  transition: box-shadow var(--effect__transition--normal);
}

.card:hover {
  box-shadow: var(--effect__shadow--md);
}

.card__image {
  position: relative;
  overflow: hidden;
}

.card__image--4-3::before {
  content: "";
  display: block;
  padding-top: 75%;
}

.card__image--16-9::before {
  content: "";
  display: block;
  padding-top: 56.25%;
}

.card__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--effect__transition--normal);
}

.card:hover .card__img {
  transform: scale(1.05);
}

.card__content {
  padding: var(--space--4);
}

.card__title {
  font-size: var(--font__size--base);
  font-weight: var(--font__weight--semibold);
  line-height: var(--line-height--tight);
  margin-bottom: var(--space--2);
  color: var(--color__text--primary);
}

.card__title a:hover {
  color: var(--color__primary);
}

.card__desc {
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
  line-height: var(--line-height--relaxed);
}

.card__meta {
  display: flex;
  align-items: center;
  gap: var(--space--3);
  margin-top: var(--space--3);
  font-size: var(--font__size--xs);
  color: var(--color__text--tertiary);
}

.card__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space--1);
}

/* ============================================
   News List组件 - 纯文本列表（带序号）
   ============================================ */
.news-list {
  display: flex;
  flex-direction: column;
  gap: var(--space--3);
}

.news-list__item {
  display: flex;
  align-items: center;
  gap: var(--space--3);
}

.news-list__number {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color__bg--secondary);
  border-radius: var(--effect__radius--full);
  font-size: var(--font__size--xs);
  font-weight: var(--font__weight--semibold);
  color: var(--color__text--secondary);
}

.news-list__number--top-1 {
  background-color: var(--color__primary);
  color: var(--color__text--white);
}

.news-list__number--top-2 {
  background-color: var(--color__accent--orange);
  color: var(--color__text--white);
}

.news-list__number--top-3 {
  background-color: var(--color__accent--green);
  color: var(--color__text--white);
}

.news-list__title {
  flex: 1;
  min-width: 0;
  font-size: var(--font__size--sm);
  line-height: var(--line-height--normal);
  color: var(--color__text--primary);
  overflow: hidden;
}

.news-list__title a {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.news-list__title a:hover {
  color: var(--color__primary);
}

/* ============================================
   News Item组件 - 左图右文列表
   ============================================ */
.news-item {
  display: flex;
  gap: var(--space--4);
  padding: var(--space--4) 0;
  border-bottom: 1px solid var(--color__border--secondary);
  min-width: 0;
  overflow: hidden;
}

.news-item__image {
  flex-shrink: 0;
  width: 160px;
  position: relative;
  overflow: hidden;
  border-radius: var(--effect__radius--sm);
}

.news-item__image::before {
  content: "";
  display: block;
  padding-top: 75%;
}

.news-item__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-item__content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.news-item__title {
  font-size: var(--font__size--md);
  font-weight: var(--font__weight--semibold);
  line-height: var(--line-height--tight);
  margin-bottom: var(--space--2);
  min-width: 0;
}

.news-item__title a {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.news-item__title a:hover {
  color: var(--color__primary);
}

.news-item__desc {
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
  line-height: var(--line-height--relaxed);
  margin-bottom: var(--space--3);
}

.news-item__meta {
  display: flex;
  align-items: center;
  gap: var(--space--4);
  margin-top: auto;
  font-size: var(--font__size--xs);
  color: var(--color__text--tertiary);
}

.news-item__category {
  padding: var(--space--1) var(--space--2);
  background-color: var(--color__bg--secondary);
  border-radius: var(--effect__radius--sm);
  color: var(--color__primary);
}

.news-item__actions {
  display: flex;
  align-items: center;
  gap: var(--space--3);
  margin-left: auto;
}

.news-item__action {
  display: flex;
  align-items: center;
  gap: var(--space--1);
  color: var(--color__text--tertiary);
  transition: color var(--effect__transition--fast);
}

.news-item__action:hover {
  color: var(--color__primary);
}

@media (max-width: 767px) {
  .news-item {
    flex-direction: column;
    gap: var(--space--3);
  }
  
  .news-item__image {
    width: 100%;
  }
}

/* ============================================
   Mixed Module组件 - 混合模块（头图+列表）
   ============================================ */
.mixed-module {
  overflow: hidden;
}

.mixed-module__featured {
  margin-bottom: var(--space--4);
}

.mixed-module__featured-image {
  position: relative;
  overflow: hidden;
  border-radius: var(--effect__radius--md);
  margin-bottom: var(--space--3);
}

.mixed-module__featured-image::before {
  content: "";
  display: block;
  padding-top: 56.25%;
}

.mixed-module__featured-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mixed-module__featured-title {
  font-size: var(--font__size--md);
  font-weight: var(--font__weight--semibold);
  line-height: var(--line-height--tight);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mixed-module__featured-title a {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mixed-module__featured-title a:hover {
  color: var(--color__primary);
}

/* 混合模块头图网格布局 */
.mixed-module__featured-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space--4);
  margin-bottom: var(--space--4);
}

.mixed-module__featured-grid .mixed-module__featured {
  margin-bottom: 0;
  min-width: 0;
  overflow: hidden;
}

.mixed-module__featured-grid .mixed-module__featured-title {
  min-width: 0;
}

@media (max-width: 575px) {
  .mixed-module__featured-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================
   Breadcrumb组件 - 面包屑导航
   ============================================ */
.breadcrumb {
  padding: var(--space--3) 0;
  background-color: var(--color__bg--secondary);
}

.breadcrumb__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space--2);
}

.breadcrumb__item {
  display: flex;
  align-items: center;
  gap: var(--space--2);
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
}

.breadcrumb__item:not(:last-child)::after {
  content: ">";
  color: var(--color__text--tertiary);
}

.breadcrumb__link:hover {
  color: var(--color__primary);
}

.breadcrumb__item--current {
  color: var(--color__text--primary);
}

/* ============================================
   Article组件 - 文章内容
   ============================================ */
.article__header {
  margin-bottom: var(--space--6);
}

.article__title {
  font-size: var(--font__size--2xl);
  font-weight: var(--font__weight--bold);
  line-height: var(--line-height--tight);
  margin-bottom: var(--space--4);
  color: var(--color__text--primary);
}

.article__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space--4);
  padding: var(--space--3) 0;
  border-bottom: 1px solid var(--color__border--secondary);
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
}

.article__meta-item {
  display: flex;
  align-items: center;
  gap: var(--space--1);
}

.article__share {
  display: flex;
  align-items: center;
  gap: var(--space--2);
  margin-left: auto;
}

.article__share-label {
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
}

.article__share-list {
  display: flex;
  gap: var(--space--2);
}

.article__share-btn {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--effect__radius--sm);
  background-color: var(--color__bg--secondary);
  color: var(--color__text--secondary);
  transition: all var(--effect__transition--fast);
}

.article__share-btn:hover {
  background-color: var(--color__primary);
  color: var(--color__text--white);
}

.article__content {
  font-size: var(--font__size--base);
  line-height: var(--line-height--relaxed);
  color: var(--color__text--primary);
}

.article__content p {
  margin-bottom: var(--space--4);
  text-indent: 2em;
  overflow: hidden;
}

.article__content p:first-child {
  text-indent: 0;
}

.article__content img {
  max-width: 100%;
  width: auto;
  height: auto;
  margin: var(--space--4) auto;
  border-radius: var(--effect__radius--sm);
  object-fit: contain;
}

.article__tags {
  margin-top: var(--space--6);
  padding-top: var(--space--4);
  border-top: 1px solid var(--color__border--secondary);
}

.article__tags-label {
  font-size: var(--font__size--sm);
  font-weight: var(--font__weight--semibold);
  color: var(--color__text--primary);
  margin-bottom: var(--space--2);
}

.article__tags-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space--2);
}

.article__tag {
  padding: var(--space--1) var(--space--3);
  background-color: var(--color__bg--secondary);
  border-radius: var(--effect__radius--sm);
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
  transition: all var(--effect__transition--fast);
}

.article__tag:hover {
  background-color: var(--color__primary);
  color: var(--color__text--white);
}

/* ============================================
   Pagination组件 - 分页（仅使用允许的选择器）
   ============================================ */
.pagination {
  display: flex;
  justify-content: center;
  padding: var(--space--6) 0;
}

.pagination ul {
  display: flex;
  align-items: center;
  gap: var(--space--2);
}

.pagination li {
  display: flex;
}

.pagination li a,
.pagination li span {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 var(--space--3);
  border-radius: var(--effect__radius--sm);
  font-size: var(--font__size--sm);
  transition: all var(--effect__transition--fast);
}

.pagination li a {
  background-color: var(--color__bg--secondary);
  color: var(--color__text--primary);
}

.pagination li a:hover {
  background-color: var(--color__primary);
  color: var(--color__text--white);
}

.pagination li span {
  background-color: var(--color__primary);
  color: var(--color__text--white);
}

.pagination li:first-child a,
.pagination li:last-child a {
  padding: 0 var(--space--4);
}

/* ============================================
   Sidebar组件 - 侧边栏
   ============================================ */
.sidebar {
  width: var(--sidebar--width);
  flex-shrink: 0;
}

.sidebar__widget {
  margin-bottom: var(--space--6);
  background-color: var(--color__bg--primary);
  border-radius: var(--effect__radius--md);
  padding: var(--space--4);
  border: 1px solid var(--color__border--secondary);
}

.sidebar__widget-title {
  font-size: var(--font__size--md);
  font-weight: var(--font__weight--bold);
  margin-bottom: var(--space--4);
  padding-bottom: var(--space--3);
  border-bottom: 2px solid var(--color__primary);
  display: flex;
  align-items: center;
  gap: var(--space--2);
}

.sidebar__widget-content {
  display: flex;
  flex-direction: column;
  gap: var(--space--3);
}

@media (max-width: 991px) {
  .sidebar {
    display: none;
  }
  
  .article__content img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
  }
}

/* ============================================
   Footer组件 - 页脚
   ============================================ */
.footer {
  background-color: var(--color__bg--dark);
  color: var(--color__text--white);
  padding: var(--space--5) 0 var(--space--1);
}

.footer__top {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space--6);
  margin-bottom: var(--space--6);
}

.footer__column-title {
  font-size: var(--font__size--base);
  font-weight: var(--font__weight--semibold);
  margin-bottom: var(--space--4);
  color: var(--color__text--white);
}

.footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--space--2);
}

.footer__link {
  font-size: var(--font__size--sm);
  color: rgba(255, 255, 255, 0.7);
  transition: color var(--effect__transition--fast);
}

.footer__link:hover {
  color: var(--color__text--white);
}

.footer__bottom {
  padding-top: var(--space--6);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  text-align: center;
}

.footer__copyright {
  font-size: var(--font__size--sm);
  color: rgba(255, 255, 255, 0.5);
}

@media (max-width: 991px) {
  .footer__top {
    display: none;
  }
  
  .footer__bottom {
    padding-top: var(--space--3);
    border-top: none;
  }
  
  .footer {
    padding: var(--space--3) 0;
  }
}

/* ============================================
   Tag Cloud组件 - 标签云
   ============================================ */
.tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space--2);
}

.tag-cloud__item {
  padding: var(--space--1) var(--space--3);
  background-color: var(--color__bg--secondary);
  border-radius: var(--effect__radius--sm);
  font-size: var(--font__size--sm);
  color: var(--color__text--secondary);
  transition: all var(--effect__transition--fast);
}

.tag-cloud__item:hover {
  background-color: var(--color__primary);
  color: var(--color__text--white);
}

/* ============================================
   Main Layout组件 - 主内容区布局
   ============================================ */
.main-layout {
  display: flex;
  gap: var(--space--6);
}

.main-layout__content {
  flex: 1;
  min-width: 0;
}

@media (max-width: 991px) {
  .main-layout {
    flex-direction: column;
  }
}
