/* ======================================================
   single.css
   すべての singular（固定ページ / 投稿 / CPT）共通の読みやすさ基盤
====================================================== */

:root{
  --single-max: 980px;
  --single-gap: 16px;
  --single-border: rgba(0,0,0,.08);
  --single-shadow: 0 10px 26px rgba(0,0,0,.06);
}

/* main 内の基本幅（page.php 構造に合わせる） */
.site-main .page-header,
.site-main .page-content{
  max-width: var(--single-max);
  margin-inline: auto;
  padding-inline: var(--single-gap);
  box-sizing: border-box;
}

/* もし single でカード化したい場合の“土台” */
.site-main .page-content{
  /* 既存CSSで背景があるなら競合しないよう最小限 */
}

/* ------------------------------------------------------
   entry-content：ブロックエディタ本文の基本
------------------------------------------------------ */
.site-main .entry-content{
  color: var(--text, #333);
}

/* 先頭/末尾の余白を整える */
.site-main .entry-content > *:first-child{ margin-top: 0; }
.site-main .entry-content > *:last-child{  margin-bottom: 0; }

/* 段落の基本（common.css 側が優先でもOK） */
.site-main .entry-content p{
  margin: 0 0 16px;
  line-height: 1.8;
}

/* リンク */
.site-main .entry-content a{
  color: var(--brand, #004b8d);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.site-main .entry-content a:hover{
  text-decoration-thickness: 2px;
}

/* 画像 */
.site-main .entry-content img{
  max-width: 100%;
  height: auto;
}

/* 見出し：最低限（common 側があるなら共存） */
.site-main .entry-content h2{
  margin: 28px 0 12px;
  line-height: 1.35;
}
.site-main .entry-content h3{
  margin: 22px 0 10px;
  line-height: 1.4;
}
.site-main .entry-content h4,
.site-main .entry-content h5,
.site-main .entry-content h6{
  margin: 18px 0 8px;
  line-height: 1.5;
}

/* リスト */
.site-main .entry-content ul,
.site-main .entry-content ol{
  margin: 0 0 16px;
  padding-left: 1.4em;
}
.site-main .entry-content li{
  margin: 6px 0;
}

/* 引用 */
.site-main .entry-content blockquote{
  margin: 18px 0;
  padding: 12px 14px;
  border-left: 4px solid rgba(0,0,0,.16);
  background: rgba(0,0,0,.04);
}

/* 区切り線 */
.site-main .entry-content hr{
  border: 0;
  border-top: 1px solid rgba(0,0,0,.10);
  margin: 22px 0;
}

/* テーブル（WPブロック） */
.site-main .entry-content table{
  width: 100%;
  border-collapse: collapse;
  margin: 18px 0;
  background: #fff;
}
.site-main .entry-content th,
.site-main .entry-content td{
  border: 1px solid rgba(0,0,0,.12);
  padding: 10px 12px;
  vertical-align: top;
}
.site-main .entry-content th{
  background: rgba(0,0,0,.04);
  font-weight: 600;
}

/* コード */
.site-main .entry-content code{
  padding: 2px 6px;
  background: rgba(0,0,0,.06);
  border-radius: 4px;
}
.site-main .entry-content pre{
  overflow: auto;
  padding: 14px;
  background: rgba(0,0,0,.06);
  border-radius: 8px;
}

/* ボタン（wp-block-button） */
.site-main .wp-block-button__link{
  border-radius: 8px;
}

/* 余白の“詰まり”対策（group/columns の先頭末尾） */
.site-main .entry-content .wp-block-group > *:first-child,
.site-main .entry-content .wp-block-columns > *:first-child{
  margin-top: 0;
}
.site-main .entry-content .wp-block-group > *:last-child,
.site-main .entry-content .wp-block-columns > *:last-child{
  margin-bottom: 0;
}

/* ------------------------------------------------------
   ページャ（前後記事）がある場合の最低限
------------------------------------------------------ */
.nav-links,
.post-navigation{
  max-width: var(--single-max);
  margin: 18px auto 0;
  padding-inline: var(--single-gap);
  box-sizing: border-box;
}

/* ------------------------------------------------------
   Responsive
------------------------------------------------------ */
@media (max-width: 640px){
  :root{
    --single-gap: 16px;
  }
  .site-main .entry-content p{
    line-height: 1.75;
  }
}
