/* ===========================================================
   記事ページ用スタイル
   WordPress由来クラスの整形 + 読みやすい本文レイアウト
   =========================================================== */

/* ---------- 記事ヘッダー / パンくず ---------- */
.article-page { background: #fff; }

.breadcrumb {
  font-size: .82rem;
  color: var(--muted);
  padding: 18px 0 0;
}
.breadcrumb ol {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0;
  padding: 0;
}
.breadcrumb li { display: flex; align-items: center; gap: 6px; }
.breadcrumb li + li::before { content: "›"; color: var(--line); }
.breadcrumb a { color: var(--navy-light); }
.breadcrumb .current { color: var(--text-soft); }

.article-head {
  max-width: 820px;
  margin: 0 auto;
  padding: 26px 0 8px;
}
.article-head .cat-tag { margin-bottom: 16px; }
.article-head h1 {
  font-size: 1.8rem;
  line-height: 1.55;
  color: var(--navy);
  margin: 0 0 14px;
  letter-spacing: .01em;
}
.article-meta {
  font-size: .88rem;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 20px;
}
.article-eyecatch {
  max-width: 880px;
  margin: 26px auto 0;
}
.article-eyecatch img {
  width: 100%;
  border-radius: var(--radius);
  display: block;
}

/* ---------- 本文ラッパ ---------- */
.article-body {
  max-width: 760px;
  margin: 0 auto;
  padding: 36px 0 20px;
  font-size: 1.04rem;
  line-height: 2.0;
  color: var(--text);
}

.article-body p { margin: 0 0 1.5em; }
.article-body p:empty { display: none; margin: 0; }

/* 見出し */
.article-body h2 {
  font-size: 1.5rem;
  color: var(--navy);
  line-height: 1.5;
  margin: 2.2em 0 .9em;
  padding: 14px 0 14px 18px;
  border-left: 6px solid var(--navy);
  background: var(--bg-soft);
  border-radius: 0 6px 6px 0;
}
.article-body h3 {
  font-size: 1.24rem;
  color: var(--navy);
  line-height: 1.55;
  margin: 1.9em 0 .7em;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--bg-soft2);
}
.article-body h4 {
  font-size: 1.08rem;
  color: var(--navy-dark);
  margin: 1.6em 0 .6em;
  padding-left: 14px;
  border-left: 4px solid var(--navy-light);
}

/* ---------- 強調表現 ---------- */
.article-body .bold,
.article-body strong { font-weight: 700; }

.article-body .bold-red {
  font-weight: 700;
  color: #c0392b;
}

/* 黄色マーカー風 */
.article-body .marker-under {
  background: linear-gradient(transparent 60%, #fff1a8 60%);
  padding-bottom: 1px;
}

/* ---------- 画像 (wp-block-image / figure) ---------- */
.article-body figure {
  margin: 1.8em 0;
  text-align: center;
}
.article-body .wp-block-image { margin: 1.8em 0; }
.article-body figure img,
.article-body .wp-block-image img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  display: inline-block;
  box-shadow: var(--shadow);
}
.article-body figcaption,
.article-body .wp-element-caption {
  font-size: .82rem;
  color: var(--muted);
  margin-top: 8px;
  line-height: 1.6;
}
.article-body .wp-block-image.is-resized img { width: auto; }
.article-body .aligncenter { text-align: center; }

/* ギャラリー */
.article-body .wp-block-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 1.8em 0;
  padding: 0;
  list-style: none;
}
.article-body .wp-block-gallery figure {
  flex: 1 1 calc(50% - 12px);
  margin: 0;
}

/* ---------- リスト (wp-block-list / blank-box) ---------- */
.article-body ul,
.article-body ol {
  margin: 1.4em 0;
  padding: 22px 22px 22px 44px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 8px;
}
.article-body li { margin-bottom: .5em; }
.article-body li:last-child { margin-bottom: 0; }

.article-body .is-style-blank-box-orange {
  background: #fff8ef;
  border: 1px solid #f0d8b6;
  border-left: 4px solid #d9913a;
}
.article-body .is-style-blank-box-gray {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-left: 4px solid var(--muted);
}
.article-body ol.is-style-blank-box-gray,
.article-body ol.is-style-blank-box-orange { list-style: decimal; }

/* ---------- 注意ボックス (warning-box) ---------- */
.article-body .is-style-warning-box {
  background: #fdf3f2;
  border: 1px solid #f1c9c4;
  border-left: 5px solid #c0392b;
  border-radius: 8px;
  padding: 16px 20px;
  margin: 1.6em 0;
  font-size: .98rem;
}

/* ---------- テーブル (wp-block-table) ---------- */
.article-body .wp-block-table {
  margin: 1.8em 0;
  overflow-x: auto;        /* 横スクロール可 */
  -webkit-overflow-scrolling: touch;
}
.article-body table {
  width: 100%;
  border-collapse: collapse;
  font-size: .95rem;
  background: #fff;
  min-width: 480px;        /* 狭幅時に横スクロール */
}
.article-body table th,
.article-body table td {
  border: 1px solid var(--line);
  padding: 11px 14px;
  text-align: left;
  vertical-align: top;
  line-height: 1.7;
}
.article-body table tr:first-child td,
.article-body table thead th {
  background: var(--navy);
  color: #fff;
  font-weight: 600;
}
/* ストライプ (奇数偶数) */
.article-body table tr:nth-child(even):not(:first-child) td { background: var(--bg-soft); }
.article-body .wp-block-table.is-style-stripes tr:nth-child(even) td { background: var(--bg-soft); }

/* グループブロック */
.article-body .wp-block-group { margin: 1.4em 0; }
.article-body .has-cocoon-black-color { color: var(--text); }

/* ---------- 記事フッターCTA ---------- */
.article-cta {
  max-width: 760px;
  margin: 8px auto 0;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 30px 28px;
  text-align: center;
}
.article-cta .author {
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 6px;
  font-size: 1.05rem;
}
.article-cta .author-note {
  color: var(--text-soft);
  font-size: .92rem;
  margin: 0 0 22px;
}
.article-cta .cta-actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

.article-back {
  max-width: 760px;
  margin: 30px auto 0;
  text-align: center;
}
.article-back a { font-weight: 600; }
.article-back a::before { content: "← "; }

/* ---------- レスポンシブ ---------- */
@media (max-width: 760px) {
  .article-head h1 { font-size: 1.42rem; }
  .article-body { font-size: 1rem; line-height: 1.9; padding: 28px 0 14px; }
  .article-body h2 { font-size: 1.28rem; }
  .article-body h3 { font-size: 1.12rem; }
  .article-body ul, .article-body ol { padding: 18px 18px 18px 38px; }
  .article-body .wp-block-gallery figure { flex: 1 1 100%; }
}
