/* ----------------------------------------------------------------
   single-blog.css — ブログ詳細ページ用スタイル
   要件要約：
   - 両サイド空間（.bs-wrap）
   - パンくず先頭 BLOG、下に区切り線（← 余白を拡張）
   - 公開日（Day大→Month英→Year）、カテゴリ（左に太線）、更新日(↻)
   - 大きめタイトル＋区切り線
   - 本文の見出し/段落/リンク（#333・下線・点線）
   - タグ（横並び、無ければ #noTag）
   - X 共有アイコン
   - 前後記事：角丸なし枠／Prev=サムネ→タイトル、Next=タイトル→サムネ
   - AUTHOR 情報：角丸なし枠中央、丸アバター、右に表示名＋プロフィール
   - 関連記事：3件表示（取得6件）・矢印は3カードの外側・4:3サムネ・
               ホバーで#333が下からスライドイン（画像は上／文字は反転）
----------------------------------------------------------------- */

/* ================================================================
   公開日の「日（Day）」サイズ / 関連gap を変数化
   - JSは gap を実測するため、ここを単一情報源に
   - ★追加：AUTHORアバター共通サイズ変数（PC=96px / SPで上書き）
   - ★今回の変更（フォント）：.blog-single 配下の基本フォントを指定
================================================================ */
.blog-single{
  --bs-day-size: clamp(44px, 7vw, 64px); /* Dayのサイズ */
  --rel-gap: 14px;                       /* 関連カード間隔 */
  --bs-avatar: 96px;                     /* ★アバター直径（PC既定） */

  /* ★追加（今回の要望）：
     ブログ詳細ページ全体のフォントファミリを指定。
     → タイトル/本文/カテゴリ/AUTHOR/関連リンク/前次リンクまで原則継承されます。 */
  font-family: Arial, "Hiragino Sans", "Yu Gothic Medium", "Meiryo", sans-serif;
}

/* ベース：ラップ幅と左右空間 */
.blog-single .bs-wrap {
  max-width: 1000px;                 /* 広すぎない可読幅 */
  margin-inline: auto;
  padding-inline: clamp(16px, 4vw, 32px); /* 画面両サイドに余白 */
  /* ▼追加：フッター直前での“マージン相殺”を避け、確実に下側のゆとりを確保 */
  padding-block-end: clamp(56px, 7vw, 96px);
  /* ★修正：固定メニューとパンくずの“被り”を防ぐパディング（+16pxの余白を常時付与） */
  padding-block-start: calc(var(--stickyTop, 0px) + 16px);
}

/* ルール線（区切り） */
.blog-single .bs-rule {
  border: 0;
  border-top: 1px solid #ddd;
  margin: 20px 0 24px;
}
.blog-single .bs-rule--under-breadcrumb {
  /* パンくずの“下側”は十分空けつつ、上記のパディングと重複しない程度に */
  margin-top: clamp(10px, 1.4vw, 18px);
}

/* ----------------------- パンくず -----------------------
   - 余白を上下パディングで確保（視認性・可読性をUP）
-------------------------------------------------------- */
.blog-single .bs-breadcrumb{
  padding-block: clamp(14px, 2.6vw, 28px); /* ← ご要望：上下にゆとり */
}
.blog-single .bs-breadcrumb ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 12px;
  color: #666;
}
.blog-single .bs-breadcrumb a {
  color: #333;
  text-decoration: underline;
  text-decoration-style: dotted;      /* 点線下線（非対応ブラウザは通常下線） */
}
.blog-single .bs-breadcrumb li+li::before {
  content: "›";
  color: #aaa;
  margin: 0 6px 0 2px;
}

/* ------------------------ ヘッダ ------------------------ */
.blog-single .bs-head { margin-top: 8px; }

/* 公開日（左）＋ カテゴリ＆更新日（右） */
.blog-single .bs-meta {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: flex-start;      /* ← 日（Day）の上端に右側を揃える */
  gap: 8px 20px;
}

/* 公開日：日→月（英）→年 */
.blog-single .bs-datepub {
  display: grid;
  text-align: center;
  line-height: 1;
}
.blog-single .bs-datepub__day  {
  font-size: var(--bs-day-size);  /* ← 変数に差し替え */
  font-weight: 800;
  color: #111;
}
.blog-single .bs-datepub__mon  { font-size: 14px; color: #333; margin-top: 6px; text-transform: uppercase; }
.blog-single .bs-datepub__year { fontサイズ: 12px; color: #777; margin-top: 2px; }

/* ================================================================
   カテゴリ（左に太線）＋ 更新日（↻）を「日（Day）」の横へ
   - .bs-catmod の高さ＝ var(--bs-day-size)
   - 左の太線は ::before で描画（高さ=100%＝Dayの高さ）
   - .bs-cat の border-left は撤去して二重線を防止
================================================================ */
.blog-single .bs-catmod{
  position: relative;
  display: flex;
  align-items: center;          /* テキスト縦位置を中央に */
  gap: 16px;
  padding-left: 16px;           /* 縦線とテキストの間 */
  height: var(--bs-day-size);   /* ← 高さ＝“日(Day)” と同じ */
}
.blog-single .bs-catmod::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;                 /* ← Day と同じ高さまで伸ばす */
  width: 8px;                   /* 太さ */
  background: #111;
}
.blog-single .bs-cat{
  border-left: none;            /* ← 重要：二重線防止 */
  padding-left: 0;
  line-height: 1.2;
}
.blog-single .bs-cat__link {
  color: #111;
  font-weight: 700;
  text-decoration: none;
}
.blog-single .bs-cat__link.is-empty { color: #aaa; font-weight: 400; }
.blog-single .bs-mod {
  color: #666;
  font-size: 13px;
}
.blog-single .bs-mod__icon { margin-right: 6px; }

/* ★追加：更新日＋編集リンクの“まとまり”を整える
   - .bs-modwrap を inline-flex にして、間隔を安定化
   - .bs-mod__edit は既存のリンク表現（ドット下線）と調和させる */
.blog-single .bs-modwrap{
  display: inline-flex;
  align-items: center;
  gap: 8px;                     /* 更新日と「編集」の距離 */
}
.blog-single .bs-mod__edit{
  font-size: 13px;
  color: #111;
  text-decoration: underline;
  text-decoration-style: dotted;
  line-height: 1;
}
.blog-single .bs-mod__edit:hover{ opacity: .8; }

/* タイトル（大きめ） */
.blog-single .bs-title {
  font-size: clamp(28px, 5.2vw, 40px);
  line-height: 1.25;
  font-weight: 800;
  margin: 18px 0 12px;
}

/* アイキャッチは“非表示運用”
   - HTML側は残してもここで完全に隠す（将来復活に備えて） */
.blog-single .bs-thumb { display: none !important; }
.blog-single .bs-thumb img { display: none !important; }

/* ------------------------ 本文 ------------------------ */
.blog-single .bs-article { margin-top: 20px; }

.blog-single .bs-content {
  color: #222;
  line-height: 1.9;
  font-size: 16px;
}
.blog-single .bs-content h1,
.blog-single .bs-content h2,
.blog-single .bs-content h3,
.blog-single .bs-content h4 {
  margin: 2.2em 0 0.8em;
  line-height: 1.35;
  font-weight: 800;
}
.blog-single .bs-content h1 { font-size: 1.9em; }
.blog-single .bs-content h2 { font-size: 1.6em; } /* ← 誤字修正の意図を維持：font-size */
.blog-single .bs-content h3 { font-size: 1.3em; }
.blog-single .bs-content p  { margin: 1.2em 0; }
.blog-single .bs-content ul,
.blog-single .bs-content ol { padding-left: 1.2em; margin: 1.2em 0; }
.blog-single .bs-content blockquote {
  border-left: 4px solid #ddd;
  padding: 0.6em 1em;
  color: #555;
  background: #fafafa;
}
.blog-single .bs-content a {
  color: #333;                       /* ← #333 */
  text-decoration: underline;        /* ← 下線あり */
  text-decoration-style: dotted;     /* ← 点線（非対応は通常下線） */
}
.blog-single .bs-content img {
  display: block;
  max-width: 100%;
  height: auto;
}

/* ------------------------ タグ ------------------------ */
.blog-single .bs-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin-top: 20px;
}
.blog-single .bs-tag {
  display: inline-block;
  padding: 6px 10px;
  border: 1px solid #ddd;
  color: #333;
  text-decoration: none;
  font-size: 13px;
}
.blog-single .bs-tag.is-empty {
  color: #999;
  background: #fafafa;
}

/* ------------------------ 共有（X） ------------------------ */
.blog-single .bs-share { margin-top: 18px; }
.blog-single .bs-share__x {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid #111;
  color: #111;
  text-decoration: none;
}
.blog-single .icon-x { width: 18px; height: 18px; fill: currentColor; }

/* --------------------- 前／次記事カード ---------------------
   ★変更点：上下の余白を“増加”。コンテナ自体に margin を与えるのが最も素直
---------------------------------------------------------------- */
.blog-single .bs-prevnext {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  /* 旧: margin-top: 22px; → 下のセクションとの“呼吸感”も取りたいので上下とも拡張 */
  margin-top: clamp(48px, 6vw, 72px);
  margin-bottom: clamp(56px, 7vw, 88px);
}
.blog-single .bs-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  border: 2px solid #111;   /* 角丸なしの枠 */
  border-radius: 0;
  padding: 10px;
  text-decoration: none;
  color: inherit;
}
/* ★追加：前後リンクの枠線色を白に上書き（背景に溶け込ませる） */
.blog-single .bs-card { border-color: #fff; }

.blog-single .bs-card__media img,
.blog-single .bs-card__noimg {
  display: block;
  width: 100%;
  height: 100px;
  object-fit: cover;
  background: #eee;
}
.blog-single .bs-card__noimg { display: grid; place-items: center; color: #aaa; font-size: 12px; }

/* ★追加：前・次リンクの“タイトルを中央揃え”
   - 既存の縦方向センタリング（align-self）は維持し、横方向を text-align で中央に */
.blog-single .bs-card__title {
  font-weight: 700;
  line-height: 1.4;
  align-self: center;
  /* ★追加 */ text-align: center;
}

/* Prev：左にサムネ / Next：右にサムネ */
.blog-single .bs-card--prev { grid-template-columns: 120px 1fr; }
.blog-single .bs-card--next { grid-template-columns: 1fr 120px; }

/* ------------------------ AUTHOR ------------------------ */
.blog-single .bs-author { margin-top: 28px; }
.blog-single .bs-author__box {
  margin-inline: auto;          /* 中央配置 */
  border: 2px solid #111;       /* 角丸なし枠 */
  border-radius: 0;
  padding: 16px;
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 16px;
  max-width: 720px;
}
/* ★追加：AUTHOR 枠線＝白、背景＝白で上書き（無彩に馴染ませる） */
.blog-single .bs-author__box { border-color: #fff; background: #fff; }

/* ★修正：アバターを常に“正円”にするための共通指定
   - 幅・高さを同値（--bs-avatar）で固定
   - 50%の角丸＋overflowで完全に円形を保証
   - 実画像は object-fit: cover で中央クロップ
   - ダミー（--none）にも同サイズを適用して楕円化を防止 */
.blog-single .bs-author__avatarimg,
.blog-single .bs-author__avatarimg--none{
  width: var(--bs-avatar);
  height: var(--bs-avatar);
  border-radius: 50%;
  overflow: hidden;
}
.blog-single .bs-author__avatarimg {
  object-fit: cover;
  display: block;
}
.blog-single .bs-author__avatarimg--none {
  background: #eee;
  color: #aaa;
  display: grid;
  place-items: center;
}
.blog-single .bs-author__name { font-weight: 800; font-size: 18px; }
.blog-single .bs-author__bio  { color: #444; }
.blog-single .bs-author__bio .is-empty { color: #aaa; }

/* ======================== 関連記事 =========================
   - 表示：PC=3枚 / SP=1枚（取得は最大6件）
   - トラックは flex 横並び（JSがgapを実測）
   - サムネ 4:3。ホバーの黒スライドは“カード全体”で発火
     ただし画像はスライドより“上”に置く、テキストは反転（白）
   - ナビ矢印は PC では“3カードの外側”、SP では“カード上に重ねる”
=========================================================== */
.blog-single .bs-related {
  /* ★変更：AUTHOR 情報と関連記事の間隔をさらに拡大（PCはゆったり） */
  margin-top: clamp(56px, 7vw, 96px);
  position: relative;  /* ← 矢印（絶対配置）の基準にするため追加 */
  /* ▼既存：ここで「関連記事とフッターの間」をしっかり確保 */
  margin-bottom: clamp(72px, 8vw, 120px);
}
.blog-single .bs-rel__title { font-size: 18px; font-weight: 800; margin-bottom: 10px; }

/* ビューポート：3枚だけ見える窓 */
.blog-single .bs-rel__viewport{
  position: relative;
  overflow: hidden;
}

/* 横に流れるトラック */
.blog-single .bs-rel__track{
  display: flex;
  gap: var(--rel-gap);
  transition: transform .35s ease;
  will-change: transform;
}

/* 1カード＝(ビューポート幅 - gap×2) / 3（PC） */
.blog-single .bs-rel__item{
  flex: 0 0 calc((100% - var(--rel-gap) * 2) / 3);
}

/* カード本体（オーバーレイ用に相対配置）
   ★変更点：内部に余白（パディング）を追加。枠と白背景で“カード感”を強調
   - この余白は .bs-rel__item の幅計算に影響しない（子要素のため） */
.blog-single .bs-rel__link{
  position: relative;                 /* ← カード全体にホバーを適用 */
  display: grid;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  isolation: isolate;                 /* 重なり順の安定化 */
  padding: 12px;                      /* ← 内部余白（PC） */
  background: #fff;                   /* ← 背景（任意だが視認性向上） */
  border: 1px solid #ddd;             /* ← 薄い枠。角丸なし */

  /* ★バグ修正（重要）：
     下からスライドインする ::after を「カード外に押し出して隠す」設計だが、
     親に overflow が無いと、その“はみ出し分”が外側に見えてしまう。
     → 親で確実にクリップして、カード外に一切出さない。 */
  overflow: hidden;
}

/* サムネ：4:3で面積を確保。画像はスライドより“上”に置く */
.blog-single .bs-rel__thumb{
  position: relative;
  aspect-ratio: 4 / 3;                /* ← 4:3 に固定 */
  overflow: hidden;
  background: #eee;
  z-index: 2;                          /* ← 画像がオーバーレイの上 */
}
.blog-single .bs-rel__thumb img,
.blog-single .rel-noimg{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.blog-single .rel-noimg { display: grid; place-items: center; color: #aaa; font-size: 12px; }

/* 黒スライド（カード全体）— 初期は下に隠す
   ★A対策：境界の1pxにじみ防止のため、100%より“2px深く”下へ送る
   ※ 上の overflow:hidden とワンセットで、外側に見えることを完全に防ぐ。 */
.blog-single .bs-rel__link::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(51,51,51,.9);      /* #333 */
  transform: translateY(calc(100% + 2px)); /* ← A対策：はみ出し線を確実に消す */

  /* ★速度調整：従来 .3s → .6s（よりゆっくりとしたスライドイン） */
  transition: transform .6s ease;

  pointer-events: none;
  z-index: 1;                          /* 画像(z=2)より下 */
}
.blog-single .bs-rel__link:hover::after{ transform: translateY(0); }

/* テキストは上に出し、ホバー時は白へ反転 */
.blog-single .bs-rel__cat,
.blog-single .bs-rel__ttl,
.blog-single .bs-rel__date{
  position: relative;
  z-index: 2;                          /* ← オーバーレイより上に表示 */
  color: inherit;
}
.blog-single .bs-rel__link:hover .bs-rel__cat,
.blog-single .bs-rel__link:hover .bs-rel__ttl,
.blog-single .bs-rel__link:hover .bs-rel__date{ color: #fff; }

/* テキスト部の既定色 */
.blog-single .bs-rel__cat  { font-size: 12px; color: #666; }
.blog-single .bs-rel__ttl  { font-weight: 700; line-height: 1.4; }
.blog-single .bs-rel__date { font-size: 12px; color: #666; }

/* ナビゲーション（丸ボタン）— PCは“外側”に配置 */
.blog-single .bs-rel__btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;                           /* オーバーレイ・内容より上 */
  width: 42px; height: 42px;            /* 丸ボタン */
  padding: 0;
  border: 1px solid #111;
  border-radius: 9999px;                /* ← 〇 にする */
  background: #fff;
  display: grid; place-items: center;   /* 文字 ‹ › を中央に */
  line-height: 1;
  cursor: pointer;

  /* ★追加（フォント反映の徹底）：
     一部ブラウザで form要素が親のフォントを継承しないことがあるため明示。 */
  font-family: inherit;
}
/* ← 外側へ8px分出す（PC時） */
.blog-single .bs-rel__btn[data-dir="-1"]{ left: calc(-42px - 8px); }
/* → 外側へ8px分出す（PC時） */
.blog-single .bs-rel__btn[data-dir="1"] { right: calc(-42px - 8px); }
.blog-single .bs-rel__btn:disabled { opacity: .35; cursor: not-allowed; }

/* ------------------------ レスポンシブ ------------------------
   - SPでは Day とカテゴリ・更新日を縦積みに
   - 関連記事は 1枚ビューに変更（幅100%）
   - 丸ボタンは“外側 → カード上に重ねる”へ切り替え（今回の修正）
---------------------------------------------------------------- */
@media (max-width: 720px) {
  /* ★SPではアバター直径を72pxに統一（列幅と一致させる） */
  .blog-single { --bs-avatar: 72px; }

  .blog-single .bs-meta { grid-template-columns: 1fr; }

  /* SP時は高さ固定を解除。縦線は1行分だけ軽く表示（お好みで調整可） */
  .blog-single .bs-catmod{
    height: auto;               /* ← 解除 */
    align-items: flex-start;
    padding-left: 14px;
  }
  .blog-single .bs-catmod::before{
    top: .25em;
    height: 1.2em;              /* 1行ぶんの高さに */
  }

  /* ★SPの前後リンクは上下の余白を控えめに再設定（読みやすさ優先） */
  .blog-single .bs-prevnext {
    margin-top: clamp(28px, 5vw, 40px);
    margin-bottom: clamp(36px, 6vw, 56px);
    grid-template-columns: 1fr;        /* 既存：SPは縦1列 */
  }

  .blog-single .bs-card--prev { grid-template-columns: 100px 1fr; }
  .blog-single .bs-card--next { grid-template-columns: 1fr 100px; }

  .blog-single .bs-author__box { grid-template-columns: 72px 1fr; }

  /* ★変更：関連記事は“1枚表示”。幅100%×横スクロール */
  .blog-single .bs-rel__item { flex: 0 0 100%; }

  /* ★今回の修正：矢印を“外側”→“カード上（内側）”に配置変更
     - 既定（PC）の left/right: calc(…) を SP だけ上書き
     - 8px 内側に寄せて、画面外へはみ出さないようにする */
  .blog-single .bs-rel__btn{ width: 36px; height: 36px; }
  .blog-single .bs-rel__btn[data-dir="-1"]{ left: 8px; }   /* ← 内側へ */
  .blog-single .bs-rel__btn[data-dir="1"] { right: 8px; }  /* → 内側へ */

  /* ★SP時のカード内部余白は少し控えめに */
  .blog-single .bs-rel__link{ padding: 8px; }

  /* ★SPでも AUTHOR→関連記事の“間隔”を拡大（PCより控えめに） */
  .blog-single .bs-related { margin-top: clamp(40px, 7vw, 64px); }

  /* SPでもフッター前の“最終余白”は維持（やや控えめでもOK） */
  .blog-single .bs-wrap { padding-block-end: clamp(40px, 7vw, 72px); }
}

/* =================================================================
   ▼▼ Reveal（初期入場＋スクロール連動）の基礎スタイル ＊最小差分追加 ▼▼
   - JS側で <body> に is-mounted を付与 → 初期入場（.bs-wrap）を発火
   - 各要素は data-reveal で初期非表示、IntersectionObserver で is-inview を付与
   - prefers-reduced-motion には全面配慮（下部参照）
   ※ このブロック自体は維持しつつ、この後ろに
     「ファーストビューでは無効化する」上書きを追加（＝Gallery準拠）
================================================================= */

/* 1) 初期入場：ページ全体（.bs-wrap）を“下からふわっと” */
.blog-single .bs-wrap{
  /* 初期（JSが is-mounted を付けるまで） */
  opacity: 0;
  transform: translateY(var(--enter-distance, 24px));
  transition: transform var(--enter-dur, .5s) ease-out,
              opacity   var(--enter-dur, .5s) ease-out;
  will-change: transform, opacity; /* 1回の入場のみ：負荷は軽微 */
}
body.is-mounted .blog-single .bs-wrap{
  opacity: 1;
  transform: none;
}

/* 2) スクロール連動：共通の reveal 初期状態（下から） */
[data-reveal]{
  opacity: 0;
  transform: translateY(var(--reveal-distance, 18px)); /* “下から”が基本 */
  transition:
    transform var(--reveal-dur, .42s) var(--reveal-ease, cubic-bezier(.215,.61,.355,1)),
    opacity   var(--reveal-dur, .42s) var(--reveal-ease, cubic-bezier(.215,.61,.355,1));
  transition-delay: var(--reveal-delay, 0ms); /* JSでスタッガー付与 */
  will-change: transform, opacity;            /* 表示直前にGPU合成 */
}

/* 3) 可視化時の状態（IOが is-inview を付与） */
.is-inview[data-reveal]{
  opacity: 1;
  transform: none;
}

/* 4) “向き”のバリエーション（必要になったら拡張）
   - data-reveal="up" は既定（translateY）
   - 他に left/right/fade 等を増やすならここに追記 */
[data-reveal="up"]{ /* 既定どおりなので特別指定なし */ }

/* 5) アクセシビリティ：アニメーションを望まない利用者には即時表示 */
@media (prefers-reduced-motion: reduce){
  body.is-mounted .blog-single .bs-wrap,
  [data-reveal]{
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}

/* ================================================================
   ▼▼ 追加：①方針（Gallery準拠）— ファーストビューのRevealを無効化 ▼▼
   目的：
   - 初期表示でスクロールアンカーが“補正”してしまう要因（入場アニメ）を排除
   - Gallery詳細と同じく、ファーストビューは最初から最終状態で描画する
   実装：
   - ページ全体（.bs-wrap）の入場アニメを無効化（初期から opacity:1 / transform:none）
   - 初期表示で必ず視界に入る .bs-breadcrumb / .bs-head の reveal を無効化
   - それ以外（本文要素や下部セクション）の reveal は従来どおり
================================================================= */

/* ページ全体：入場アニメを無効化（= 初回から最終状態で描画） */
.blog-single .bs-wrap{
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* ファーストビュー主要要素：reveal を無効化 */
.blog-single .bs-breadcrumb[data-reveal],
.blog-single .bs-head[data-reveal]{
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}
