/**
 * 文章內容樣式
 * 專為技術文章、教學文件設計
 */

/* ==================== 容器與版面 ==================== */
.article {
  max-width: 100%;
  margin: 0;
  padding: 0;
  line-height: 1.8;
  font-size: 1.05rem;
}

/* ==================== 標題系統 ==================== */
.article h1 {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 3px solid var(--bs-success);
  color: var(--bs-emphasis-color);
  line-height: 1.3;
}

.article.article-preview h1 {
  /* 使用 color-mix() 函式將基底顏色混合 30% 的黑色 */
  border-bottom: 3px solid color-mix(in srgb, var(--bs-danger) 70%, black 30%);
}

.article h2 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-top: 3rem;
  margin-bottom: 1.25rem;
  padding-left: 1rem;
  border-left: 4px solid var(--bs-success);
  color: var(--bs-emphasis-color);
}

.article.article-preview h2 {
  border-left: 4px solid color-mix(in srgb, var(--bs-danger) 70%, black 30%);
}

.article h3 {
  font-size: 1.2rem;
  font-weight: 600;
  margin-top: 2rem;
  margin-bottom: 1rem;
  color: var(--bs-body-color);
}

/* ==================== 段落與文字 ==================== */
.article p {
  margin-bottom: 1.25rem;
  color: var(--bs-body-color);
  text-align: justify;
}

.article strong {
  font-weight: 600;
  color: var(--bs-emphasis-color);
}

/* ==================== 程式碼區塊 ==================== */
.article pre {
  background: var(--bs-secondary-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  padding: 1.5rem;
  margin: 1.5rem 0;
  overflow-x: auto;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.article pre code {
  font-family: "Consolas", "Monaco", "Courier New", monospace;
  font-size: 0.9rem;
  line-height: 1.6;
  color: var(--bs-body-color);
  background: none;
  padding: 0;
  border: none;
}

/* 行內程式碼 */
.article code:not(pre code) {
  background: var(--bs-secondary-bg);
  border: 1px solid var(--bs-border-color);
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-family: "Consolas", "Monaco", "Courier New", monospace;
  font-size: 0.9em;
  color: var(--bs-danger);
  font-weight: 500;
}

/* ==================== 清單 ==================== */
.article ul,
.article ol {
  margin: 1.25rem 0 1.25rem 2rem;
  padding-left: 1rem;
}

.article li {
  margin-bottom: 0.75rem;
  color: var(--bs-body-color);
}

.article li::marker {
  color: var(--bs-success);
  font-weight: 600;
}

.article.article-preview li::marker {
  color: color-mix(in srgb, var(--bs-danger) 70%, black 30%);
}

/* ==================== 表格 ==================== */
.article table {
  width: 100%;
  margin: 2rem 0;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.article thead {
  background: var(--bs-success);
  color: white;
}

.article.article-preview thead {
  background: color-mix(in srgb, var(--bs-danger) 70%, black 30%);
}

.article thead th {
  padding: 1rem;
  font-weight: 600;
  text-align: left;
  border-bottom: 2px solid var(--bs-border-color);
  border-right: 1px solid rgba(255, 255, 255, 0.2);
}

.article thead th:last-child {
  border-right: none;
}

.article tbody tr {
  background: var(--bs-body-bg);
  transition: background-color 0.2s ease;
}

.article tbody tr:nth-child(even) {
  background: var(--bs-secondary-bg);
}

.article tbody tr:hover {
  background: var(--bs-tertiary-bg);
}

.article tbody td {
  padding: 1rem;
  border-bottom: 1px solid var(--bs-border-color);
  border-right: 1px solid var(--bs-border-color);
  color: var(--bs-body-color);
}

.article tbody td:last-child {
  border-right: none;
}

.article tbody tr:last-child td {
  border-bottom: none;
}

/* 表格內的 code 元素 */
.article table code {
  font-size: 0.85em;
  padding: 0.15rem 0.4rem;
}

/* ==================== 引用區塊 ==================== */
.article blockquote {
  margin: 2rem 0;
  padding: 1.25rem 1.5rem;
  background: var(--bs-info-bg-subtle);
  border-left: 5px solid var(--bs-info);
  border-radius: 0 8px 8px 0;
  color: var(--bs-body-color);
}

.article blockquote p {
  margin-bottom: 0;
}

.article blockquote p:last-child {
  margin-bottom: 0;
}

/* ==================== 分隔線 ==================== */
.article hr {
  margin: 3rem 0;
  border: none;
  border-top: 2px solid var(--bs-border-color);
  opacity: 0.5;
}

/* ==================== 連結 ==================== */
.article a {
  color: var(--bs-link-color);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: all 0.2s ease;
}

.article a:hover {
  color: var(--bs-link-hover-color);
  border-bottom-color: var(--bs-link-hover-color);
}

/* ==================== 響應式設計 ==================== */
@media (max-width: 768px) {
  .article {
    padding: 0;
    font-size: 1rem;
  }

  .article h1 {
    font-size: 1.75rem;
  }

  .article h2 {
    font-size: 1.5rem;
    margin-top: 2rem;
  }

  .article h3 {
    font-size: 1.25rem;
  }

  .article pre {
    padding: 1rem;
    font-size: 0.85rem;
  }

  .article table {
    font-size: 0.9rem;
  }

  .article thead th,
  .article tbody td {
    padding: 0.75rem;
  }

  /* 小螢幕上讓表格可以橫向滾動 */
  .article table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}

/* ==================== Dark Mode 特別優化 ==================== */
[data-bs-theme="dark"] .article pre {
  background: #1e1e1e;
  border-color: #3a3a3a;
}

[data-bs-theme="dark"] .article code:not(pre code) {
  background: #2a2a2a;
  border-color: #3a3a3a;
  color: #ff79c6;
}

[data-bs-theme="dark"] .article blockquote {
  background: rgba(13, 202, 240, 0.1);
  border-left-color: #0dcaf0;
}

/* ==================== 特殊元素 ==================== */
/* Emoji 調整 */
.article h3::before {
  margin-right: 0.5rem;
}

/* 數字列表樣式優化 */
.article ol {
  counter-reset: item;
  list-style: none;
}

.article ol li {
  counter-increment: item;
  position: relative;
  padding-left: 2rem;
}

.article ol li::before {
  content: counter(item) ".";
  position: absolute;
  left: 0;
  color: var(--bs-success);
  font-weight: 700;
  font-size: 1.1em;
}

.article.article-preview ol li::before {
  /* 使用 color-mix() 函式將基底顏色混合 30% 的黑色 */
  color: color-mix(in srgb, var(--bs-danger) 70%, black 30%);
}

/* ==================== 印刷優化 ==================== */
@media print {
  .article {
    max-width: 100%;
    padding: 0;
    font-size: 12pt;
    line-height: 1.6;
  }

  .article pre {
    border: 1px solid #000;
    page-break-inside: avoid;
  }

  .article table {
    page-break-inside: avoid;
  }

  .article h1,
  .article h2,
  .article h3 {
    page-break-after: avoid;
  }
}

/* ==================== 滾動優化 ==================== */
.article {
  scroll-behavior: smooth;
}

/* 錨點偏移（避免被固定導航欄遮擋） */
.article h2[id],
.article h3[id] {
  scroll-margin-top: 5rem;
}
