/* ============================================================
   ky_sport · article.css
   文章列表 + 文章详情 + 侧栏
   ============================================================ */

/* ============ 文章通用 ============ */
.kys-article-wrap { padding: 48px 0 80px; }
.kys-article-list { display: flex; flex-direction: column; gap: 20px; }

.kys-article-card {
  display: flex; gap: 20px; align-items: flex-start;
  background: #fff; border: 1px solid var(--kys-border);
  border-radius: var(--kys-radius);
  padding: 20px; color: var(--kys-text);
  transition: all .25s;
  text-decoration: none;
}
.kys-article-card:hover {
  border-color: rgba(var(--kys-primary-rgb),.3);
  box-shadow: var(--kys-shadow);
  transform: translateY(-2px);
  color: var(--kys-text);
}
.kys-article-card .kys-thumb {
  width: 160px; height: 110px; flex-shrink: 0;
  background: var(--kys-bg-2); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  font-size: 28px; color: var(--kys-muted);
}
.kys-article-card .kys-thumb img { width: 100%; height: 100%; object-fit: cover; }
.kys-article-card h3 { font-size: 17px; margin-bottom: 8px; line-height: 1.4; }
.kys-article-card .kys-desc {
  font-size: 14px; color: var(--kys-text-2); margin-bottom: 8px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.kys-article-card .kys-meta { font-size: 13px; color: var(--kys-muted); }

/* ============ 文章详情 ============ */
.kys-article-detail { background: #fff; border-radius: var(--kys-radius); padding: 36px; border: 1px solid var(--kys-border); }
.kys-article-detail h1 { font-size: clamp(22px, 3vw, 32px); margin-bottom: 16px; }
.kys-article-meta {
  display: flex; flex-wrap: wrap; gap: 16px;
  font-size: 14px; color: var(--kys-text-2);
  padding-bottom: 20px; margin-bottom: 24px;
  border-bottom: 1px solid var(--kys-border);
}
.kys-article-meta i { margin-right: 4px; }
.kys-article-content { font-size: 16px; line-height: 1.8; }
.kys-article-content p { margin-bottom: 16px; }
.kys-article-content img { border-radius: 8px; margin: 12px 0; }
.kys-article-content h2, .kys-article-content h3 { margin-top: 28px; margin-bottom: 12px; }
.kys-article-content blockquote {
  border-left: 4px solid var(--kys-primary);
  padding: 16px 20px; margin: 20px 0;
  background: var(--kys-bg-2); border-radius: 0 8px 8px 0;
  color: var(--kys-text-2);
}
.kys-article-content pre {
  background: #1e1e1e; color: #d4d4d4;
  padding: 20px; border-radius: 8px;
  overflow-x: auto; font-size: 14px;
}
.kys-article-content table { width: 100%; border-collapse: collapse; margin: 16px 0; }
.kys-article-content th, .kys-article-content td {
  padding: 10px 14px; border: 1px solid var(--kys-border); text-align: left;
}
.kys-article-content th { background: var(--kys-bg-2); font-weight: 600; }

/* ============ 侧栏 ============ */
.kys-side-card {
  background: #fff; border: 1px solid var(--kys-border);
  border-radius: var(--kys-radius);
  padding: 24px; margin-bottom: 20px;
}
.kys-side-card h5 { font-size: 16px; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 2px solid var(--kys-primary); }
.kys-side-card ul { list-style: none; padding: 0; margin: 0; }
.kys-side-card ul li { padding: 8px 0; border-bottom: 1px dashed var(--kys-border); }
.kys-side-card ul li:last-child { border-bottom: none; }
.kys-side-card ul li a { color: var(--kys-text-2); font-size: 14px; transition: color .2s; display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kys-side-card ul li a:hover { color: var(--kys-primary); }

/* MOBILE ENHANCED - article */
@media (max-width: 991.98px) {
  .kys-article-card .kys-thumb { width: 120px; height: 85px; }
  .kys-article-detail { padding: 24px; }
}
@media (max-width: 768px) {
  .kys-article-card { flex-direction: column; }
  .kys-article-card .kys-thumb { width: 100%; height: 180px; }
  .kys-article-detail { padding: 20px; }
  .kys-article-meta { gap: 10px; font-size: 13px; }
}
@media (max-width: 480px) {
  .kys-article-wrap { padding: 24px 0 48px; }
  .kys-article-detail { padding: 16px; }
}
