/* =========================================================
   ネット回線の教科書 — single.css
   記事ページ専用（AEO/GEO/LLMO対応の構造化要素）
   ========================================================= */

.article-header { padding-block: 2rem 1.5rem; max-width: var(--container-narrow); margin-inline: auto; }
.article-header__cat { font-size: var(--fs-xs); font-weight: 600; color: var(--color-accent); }
.article-header__title { font-size: var(--fs-h1); margin: 0.6rem 0 1rem; }
.article-meta { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; font-size: var(--fs-xs); color: var(--color-text-mute); }
.article-meta__author { display: flex; align-items: center; gap: 8px; }
.article-meta__author img { width: 28px; height: 28px; border-radius: 50%; }
.article-meta time + time::before { content: "更新 "; }

.article-body { max-width: var(--container-narrow); margin-inline: auto; }
.article-body p { margin: 0 0 1.5rem; }
.article-body h2 { font-size: var(--fs-h2); margin: 3rem 0 1.2rem; padding-bottom: 0.6rem; border-bottom: 2px solid var(--color-accent-soft); }
.article-body h3 { font-size: var(--fs-h3); margin: 2.2rem 0 1rem; }
.article-body img { border-radius: var(--radius); margin: 1.5rem auto; }
.article-body a { text-decoration: underline; text-underline-offset: 3px; }

/* --- 結論ボックス（記事冒頭・AIが引用しやすい構造） --- */
.conclusion-box {
  background: var(--color-accent-soft); border: 1px solid #cfe0ff;
  border-radius: var(--radius); padding: 24px 28px; margin: 0 0 2.5rem;
}
.conclusion-box__label {
  display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-xs);
  font-weight: 700; color: var(--color-accent); margin-bottom: 10px; letter-spacing: 0.04em;
}
.conclusion-box__label::before { content: "✓"; display: grid; place-items: center; width: 18px; height: 18px; background: var(--color-accent); color: #fff; border-radius: 50%; font-size: 11px; }
.conclusion-box p { margin: 0 0 0.6rem; font-size: var(--fs-sm); font-weight: 500; }
.conclusion-box p:last-child { margin: 0; }
.conclusion-box ul { margin: 0; font-size: var(--fs-sm); }
.conclusion-box li { margin-bottom: 0.4rem; }

/* --- 要点まとめブロック --- */
.keypoints {
  background: #fff; border: 1px solid var(--color-border); border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-sm); padding: 20px 24px; margin: 2rem 0;
}
.keypoints__label { font-size: var(--fs-xs); font-weight: 700; color: var(--color-text-mute); letter-spacing: 0.06em; margin-bottom: 10px; }
.keypoints ul { margin: 0; padding-left: 1.2em; }
.keypoints li { font-size: var(--fs-sm); margin-bottom: 0.5rem; }
.keypoints li::marker { color: var(--color-accent); }

/* --- 目次 --- */
.toc { background: var(--color-bg-soft); border-radius: var(--radius); padding: 20px 24px; margin: 0 0 2.5rem; }
.toc__label { font-size: var(--fs-sm); font-weight: 700; margin-bottom: 10px; }
.toc ol { margin: 0; padding-left: 1.4em; }
.toc li { margin-bottom: 0.4rem; font-size: var(--fs-sm); }
.toc a { color: var(--color-text-sub); }

/* --- 注意・ポイント差し込み --- */
.callout { border-radius: var(--radius-sm); padding: 16px 20px; margin: 1.5rem 0; font-size: var(--fs-sm); }
.callout--info { background: var(--color-accent-soft); }
.callout--warn { background: #fff7e6; border: 1px solid #ffe1a8; }
.callout__title { font-weight: 700; margin: 0 0 6px; }

/* --- 記事内テーブル（比較は控えめに） --- */
.article-body table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: var(--fs-sm); }
.article-body th, .article-body td { padding: 12px 14px; border: 1px solid var(--color-border); text-align: left; }
.article-body th { background: var(--color-bg-soft); font-weight: 600; }

/* --- 記事フッター・関連記事 --- */
.article-footer { max-width: var(--container-narrow); margin: 3rem auto 0; padding-top: 2rem; border-top: 1px solid var(--color-border); }
.related { margin-top: var(--space-section); }
