/* ============================================================
   Article Card Component Styles
   ============================================================ */

.article-card {
  overflow: hidden;
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}

.article-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-2px);
}

/* ----- 封面图 ----- */
.article-card__image {
  overflow: hidden;
}

.ratio-16-9 {
  padding-top: 56.25%;   /* 16:9 比例 */
}

.article-card__cover-img {
  transition: transform var(--transition-slow);
}

.article-card:hover .article-card__cover-img {
  transform: scale(1.04);
}

/* ----- 内容区 ----- */
.article-card__body {
  flex: 1;
  padding: var(--space-md);
}

/* ----- 分类标签 ----- */
.article-card__tag {
  display: inline-block;
  padding: var(--space-xs) var(--space-sm);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-primary);
  background: var(--color-primary-light);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-sm);
}

/* ----- 标题 ----- */
.article-card__title {
  font-size: var(--text-base);
  font-weight: 600;
  line-height: 1.4;
  margin: 0 0 var(--space-sm) 0;
}

.article-card__link {
  color: var(--color-text-primary);
  transition: color var(--transition-fast);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.article-card__link:hover {
  color: var(--color-primary);
}

/* ----- 摘要 ----- */
.article-card__excerpt {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0 0 var(--space-md) 0;
}

/* ----- 底部元信息 ----- */
.article-card__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.article-card__date {
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}

.article-card__readmore {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-primary);
  transition: color var(--transition-fast);
}

.article-card__readmore:hover {
  color: var(--color-primary-hover);
}

/* ----- 响应式：移动端竖向排列 ----- */
@media (max-width: 767px) {
  .article-card {
    flex-direction: column;
  }

  .article-card__image {
    width: 100%;
  }
}
