/* =============================================
   喵彩 — 專欄（Blog）& 文章（Article）
   ============================================= */

/* ── 共用 Content padding ──────────────────── */

#screen-blog-list .content,
#screen-article .content {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--content-pad) var(--sp-10);
}

/* ══════════════════════════════════════════
   BLOG LIST — 專欄列表
   ══════════════════════════════════════════ */

.blog-header {
  padding: var(--sp-2) 0 var(--sp-5);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: var(--sp-5);
}

.blog-header-sub {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
}

/* ── 文章卡片列表 ── */

.blog-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.blog-card {
  position: relative;
  background: var(--bg-surface);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  cursor: pointer;
  transition:
    border-color var(--dur-fast),
    background   var(--dur-fast),
    transform    var(--dur-fast);
  outline: none;
  overflow: hidden;
}

.blog-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px;
  height: 100%;
  background: linear-gradient(180deg, #3B82F6 0%, #6366F1 100%);
  border-radius: var(--r-lg) 0 0 var(--r-lg);
  opacity: 0;
  transition: opacity var(--dur-fast);
}
/* 有 big_lotto / power_lottery / nba / mlb 子元素時換色條顏色 */
.blog-card:has(.blog-card-cat[data-cat="big_lotto"])::before {
  background: linear-gradient(180deg, #FFD700 0%, #F59E0B 100%);
}
.blog-card:has(.blog-card-cat[data-cat="power_lottery"])::before {
  background: linear-gradient(180deg, #FF4D6D 0%, #BE123C 100%);
}
.blog-card:has(.blog-card-cat[data-cat="nba"])::before {
  background: linear-gradient(180deg, #FB923C 0%, #EA580C 100%);
}
.blog-card:has(.blog-card-cat[data-cat="mlb"])::before {
  background: linear-gradient(180deg, #4ADE80 0%, #16A34A 100%);
}

.blog-card:hover,
.blog-card:focus-visible {
  border-color: rgba(99, 102, 241, 0.35);
  background: var(--bg-raised);
  transform: translateY(-1px);
}

.blog-card:hover::before,
.blog-card:focus-visible::before {
  opacity: 1;
}

/* ── 卡片 meta 行（分類 + 日期） ── */

.blog-card-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
}

.blog-card-cat {
  font-size: 11px;
  font-weight: var(--weight-bold);
  letter-spacing: 0.06em;
  border-radius: var(--r-full);
  padding: 2px 9px;
  /* 預設：今彩539 / 通用（靛藍） */
  color: #6366F1;
  background: rgba(99, 102, 241, 0.12);
  border: 1px solid rgba(99, 102, 241, 0.25);
}
/* 大樂透（金） */
.blog-card-cat[data-cat="big_lotto"] {
  color: var(--lotto-gold);
  background: var(--lotto-gold-dim);
  border-color: var(--lotto-gold-border);
}
/* 威力彩（紅） */
.blog-card-cat[data-cat="power_lottery"] {
  color: var(--power-red);
  background: var(--power-red-dim);
  border-color: var(--power-red-border);
}
/* NBA（橘） */
.blog-card-cat[data-cat="nba"] {
  color: #FB923C;
  background: rgba(251, 146, 60, 0.12);
  border-color: rgba(251, 146, 60, 0.3);
}
/* MLB（綠） */
.blog-card-cat[data-cat="mlb"] {
  color: #4ADE80;
  background: rgba(74, 222, 128, 0.10);
  border-color: rgba(74, 222, 128, 0.28);
}

.blog-card-date {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-family: var(--font-num);
}

/* ── 卡片標題 ── */

.blog-card-title {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  line-height: 1.4;
  margin-bottom: var(--sp-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── 摘要 ── */

.blog-card-excerpt {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: var(--sp-3);
}

/* ── 閱讀全文 CTA ── */

.blog-card-read {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  color: #818CF8;
  letter-spacing: 0.02em;
  transition: color var(--dur-fast), gap var(--dur-fast);
}

.blog-card:hover .blog-card-read {
  color: #A5B4FC;
  gap: 7px;
}

/* ── Skeleton ── */

.blog-card--skeleton {
  cursor: default;
  pointer-events: none;
}
.blog-card--skeleton::before { display: none; }

.sk-line {
  height: 12px;
  background: linear-gradient(90deg,
    rgba(255,255,255,0.05) 25%,
    rgba(255,255,255,0.10) 50%,
    rgba(255,255,255,0.05) 75%);
  background-size: 400% 100%;
  border-radius: var(--r-sm);
  margin-bottom: var(--sp-2);
  animation: sk-shimmer 1.4s ease-in-out infinite;
}
.sk-line--xs  { width: 30%; }
.sk-line--sm  { width: 45%; }
.sk-line--md  { width: 70%; }
.sk-line--lg  { width: 85%; }
.sk-line--xl  { width: 100%; height: 18px; }

@keyframes sk-shimmer {
  0%   { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

/* ── Empty / Error State ── */

.blog-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-4);
  padding: var(--sp-16) var(--sp-4);
  color: var(--text-muted);
  text-align: center;
}

.blog-empty-icon {
  font-size: 48px;
  line-height: 1;
}

.blog-empty p {
  font-size: var(--text-sm);
  line-height: 1.6;
}

/* ══════════════════════════════════════════
   ARTICLE — 文章詳情頁
   ══════════════════════════════════════════ */

.article-body {
  max-width: 680px;
  margin: 0 auto;
}

/* ── 文章 meta（分類 + 日期） ── */

.article-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

/* ── 文章正文 ── */

.article-content {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--text-secondary);
}

.article-content h1,
.article-content h2,
.article-content h3 {
  color: var(--text-primary);
  font-weight: var(--weight-bold);
  line-height: 1.4;
  margin: var(--sp-8) 0 var(--sp-3);
}

.article-content h1 { font-size: var(--text-2xl); }
.article-content h2 { font-size: var(--text-xl); }
.article-content h3 {
  font-size: var(--text-lg);
  color: var(--text-secondary);
}

.article-content p {
  margin-bottom: var(--sp-4);
}

.article-content ul,
.article-content ol {
  padding-left: var(--sp-6);
  margin-bottom: var(--sp-4);
}

.article-content li {
  margin-bottom: var(--sp-1);
  line-height: 1.7;
}

.article-content strong {
  color: var(--text-primary);
  font-weight: var(--weight-bold);
}

.article-content em {
  color: #818CF8;
  font-style: normal;
}

.article-content blockquote {
  border-left: 3px solid rgba(99,102,241,0.5);
  background: rgba(99,102,241,0.06);
  padding: var(--sp-3) var(--sp-4);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  margin: var(--sp-5) 0;
  color: var(--text-secondary);
  font-style: italic;
}

.article-content table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--sp-5) 0;
  font-size: var(--text-sm);
}

.article-content th,
.article-content td {
  padding: var(--sp-2) var(--sp-3);
  text-align: left;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.article-content th {
  color: var(--text-muted);
  font-weight: var(--weight-bold);
  font-size: var(--text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--bg-raised);
}

.article-content tr:hover td {
  background: rgba(255,255,255,0.02);
}

/* ── Page header 返回按鈕（blog-list + article） ── */

.article-header-back {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 12px;
  border-radius: var(--r-md);
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--text-secondary);
  background: var(--bg-raised);
  border: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  transition:
    color        var(--dur-fast),
    background   var(--dur-fast),
    border-color var(--dur-fast);
  flex-shrink: 0;
}

.article-header-back:hover {
  color: var(--text-primary);
  background: var(--bg-overlay);
  border-color: rgba(255,255,255,0.15);
}

/* ── 文章 footer（返回 + 前往分析） ── */

.article-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-top: var(--sp-10);
  padding-top: var(--sp-6);
  border-top: 1px solid rgba(255,255,255,0.07);
}

.article-back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-md);
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--text-secondary);
  background: var(--bg-raised);
  border: 1px solid rgba(255,255,255,0.08);
  cursor: pointer;
  transition:
    color        var(--dur-fast),
    background   var(--dur-fast),
    border-color var(--dur-fast);
  text-decoration: none;
}

.article-back-link:hover {
  color: var(--text-primary);
  background: var(--bg-overlay);
  border-color: rgba(255,255,255,0.15);
}

.article-jcai-link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-5);
  border-radius: var(--r-md);
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: #fff;
  background: linear-gradient(135deg, #6366F1 0%, #4F46E5 100%);
  border: 1px solid rgba(99,102,241,0.4);
  cursor: pointer;
  transition:
    opacity      var(--dur-fast),
    transform    var(--dur-fast);
  text-decoration: none;
}

.article-jcai-link:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

@media (max-width: 400px) {
  .article-footer {
    flex-direction: column;
    align-items: stretch;
  }
  .article-back-link,
  .article-jcai-link {
    justify-content: center;
  }
}

/* ══════════════════════════════════════════
   HOME BLOG INLINE WIDGET
   首頁底部最新文章卡片
   ══════════════════════════════════════════ */

.home-blog-section {
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid rgba(255,255,255,0.06);
}

.home-section-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--sp-4);
}

.blog-inline-card {
  background: var(--bg-surface);
  border: 1px solid rgba(99,102,241,0.2);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5);
  cursor: pointer;
  transition:
    border-color var(--dur-fast),
    background   var(--dur-fast);
  outline: none;
  position: relative;
  overflow: hidden;
}

.blog-inline-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(99,102,241,0.04) 0%, transparent 60%);
  pointer-events: none;
}

.blog-inline-card:hover,
.blog-inline-card:focus-visible {
  border-color: rgba(99,102,241,0.45);
  background: var(--bg-raised);
}

.blog-inline-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
}

.blog-inline-title {
  font-size: var(--text-base);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  line-height: 1.4;
  margin-bottom: var(--sp-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-inline-excerpt {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: var(--sp-3);
}

.blog-inline-card .blog-card-read {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  color: #818CF8;
  letter-spacing: 0.02em;
}

.home-blog-more {
  display: block;
  width: 100%;
  margin-top: var(--sp-3);
  padding: var(--sp-3);
  background: none;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: var(--r-md);
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--text-muted);
  cursor: pointer;
  text-align: center;
  transition:
    border-color var(--dur-fast),
    color        var(--dur-fast),
    background   var(--dur-fast);
}

.home-blog-more:hover {
  border-color: rgba(99,102,241,0.35);
  color: #A5B4FC;
  background: rgba(99,102,241,0.05);
}
