/* =========================================================
   お役立ち情報TOP（固定ページ「ブログ」/blog/ = page-blog.php）
   ブログ / ウェビナー / お役立ち資料 への導線を1カラムで集約。
   配色・フォントは LP(lp-chrome.css) に合わせる。
   すべて .blog-hub 配下にスコープ（SWELL本文スタイルと干渉させない）。
   2026-06-30
   ========================================================= */
.blog-hub{
  --bg:#ffffff; --bg-soft:#f7f5f9; --bg-3:#eef1f4;
  --fg:#15212f; --fg-muted:#4b5663; --fg-dim:#86929f;
  --accent:#864B98; --accent-2:#6f3c80; --accent-soft:#f1e6f4; --accent-shadow:rgba(134,75,152,.12);
  --cv-orange:#ef7322; --cv-orange-hi:#f5912f;
  --border:#e2e7ec; --border-strong:#d4dae0; --radius:14px; --radius-sm:10px; --radius-pill:999px;
  --font-jp:'Noto Sans JP','Hiragino Sans','Yu Gothic UI',system-ui,sans-serif;
  --font-en:'Inter',system-ui,sans-serif;
  color:var(--fg); font-family:var(--font-jp);
  background:var(--bg);
}
.blog-hub *{ box-sizing:border-box; }
.blog-hub a{ color:inherit; text-decoration:none; }
.blog-hub img{ display:block; max-width:100%; height:auto; }

.blog-hub .bh-inner{ max-width:960px; margin:0 auto; padding:56px 24px 80px; }

/* ---------- Head ---------- */
.blog-hub .bh-head{ text-align:center; margin-bottom:44px; }
.blog-hub .bh-eyebrow{ font-family:var(--font-en); font-size:12px; letter-spacing:.22em; color:var(--accent); font-weight:600; margin:0 0 12px; }
.blog-hub .bh-title{ font-size:34px; font-weight:700; letter-spacing:.02em; margin:0 0 16px; line-height:1.3; }
.blog-hub .bh-lead{ font-size:15px; line-height:1.9; color:var(--fg-muted); max-width:680px; margin:0 auto; }

/* ---------- 3 導線タイル（横並び） ---------- */
.blog-hub .bh-tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-bottom:64px; }
.blog-hub .bh-tile{
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:14px; padding:30px 22px;
  background:var(--bg); border:1px solid var(--border); border-radius:var(--radius);
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.blog-hub .bh-tile:hover{ border-color:var(--accent); box-shadow:0 10px 28px var(--accent-shadow); transform:translateY(-2px); }
.blog-hub .bh-tile__ico{
  flex:none; width:58px; height:58px; border-radius:16px; display:grid; place-items:center;
  background:var(--accent-soft); color:var(--accent);
}
.blog-hub .bh-tile__ico svg{ width:28px; height:28px; }
.blog-hub .bh-tile__body{ min-width:0; }
.blog-hub .bh-tile__name{ display:block; font-size:18px; font-weight:700; margin-bottom:8px; }
.blog-hub .bh-tile__desc{ display:block; font-size:13px; line-height:1.7; color:var(--fg-muted); }

/* ---------- セクション共通 ---------- */
.blog-hub .bh-sec{ margin-bottom:60px; }
.blog-hub .bh-sec__head{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; padding-bottom:14px; margin-bottom:24px; border-bottom:2px solid var(--accent-soft); }
.blog-hub .bh-sec__title{ font-size:22px; font-weight:700; margin:0; position:relative; padding-left:15px; }
.blog-hub .bh-sec__title::before{ content:""; position:absolute; left:0; top:.18em; bottom:.18em; width:5px; border-radius:3px; background:var(--accent); }
.blog-hub .bh-sec__more{ flex:none; font-size:13px; font-weight:600; color:var(--accent); white-space:nowrap; transition:color .2s; }
.blog-hub .bh-sec__more:hover{ color:var(--cv-orange); }

/* ---------- カテゴリチップ ---------- */
.blog-hub .bh-cats{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:26px; }
.blog-hub .bh-cat{
  display:inline-flex; align-items:center; gap:8px; padding:9px 16px;
  background:var(--bg-soft); border:1px solid var(--border); border-radius:var(--radius-pill);
  font-size:13px; font-weight:500; color:var(--fg); transition:all .2s;
}
.blog-hub .bh-cat:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }
.blog-hub .bh-cat__count{ font-family:var(--font-en); font-size:11px; color:var(--fg-dim); }
.blog-hub .bh-cat:hover .bh-cat__count{ color:rgba(255,255,255,.85); }

/* ---------- ブログ記事リスト ---------- */
.blog-hub .bh-posts{ list-style:none; margin:0; padding:0; display:grid; gap:6px; }
.blog-hub .bh-post__link{ display:flex; gap:18px; align-items:center; padding:14px; border-radius:var(--radius-sm); transition:background .2s; }
.blog-hub .bh-post__link:hover{ background:var(--bg-soft); }
.blog-hub .bh-post__thumb{ flex:none; width:128px; height:80px; border-radius:8px; overflow:hidden; background:var(--bg-3); }
.blog-hub .bh-post__thumb img{ width:100%; height:100%; object-fit:cover; }
.blog-hub .bh-post__thumb--ph{ background:linear-gradient(135deg,var(--accent-soft),#fff); }
.blog-hub .bh-post__main{ min-width:0; }
.blog-hub .bh-post__metarow{ display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.blog-hub .bh-post__date{ font-family:var(--font-en); font-size:12px; color:var(--fg-dim); }
.blog-hub .bh-post__cat{ font-size:11px; font-weight:600; color:var(--accent); background:var(--accent-soft); padding:2px 9px; border-radius:var(--radius-pill); }
.blog-hub .bh-post__ttl{ display:block; font-size:15px; font-weight:600; line-height:1.6; color:var(--fg);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.blog-hub .bh-post__link:hover .bh-post__ttl{ color:var(--accent); }

/* ---------- ウェビナー カード ---------- */
.blog-hub .bh-cards{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.blog-hub .bh-card{ border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:border-color .2s, box-shadow .2s, transform .2s; }
.blog-hub .bh-card:hover{ border-color:var(--accent); box-shadow:0 10px 24px var(--accent-shadow); transform:translateY(-2px); }
.blog-hub .bh-card__link{ display:flex; flex-direction:column; height:100%; }
.blog-hub .bh-card__thumb{ aspect-ratio:16/9; background:var(--bg-3); overflow:hidden; }
.blog-hub .bh-card__thumb img{ width:100%; height:100%; object-fit:cover; }
.blog-hub .bh-card__thumb--ph{ display:grid; place-items:center; font-family:var(--font-en); font-size:13px; letter-spacing:.18em; color:#fff; background:linear-gradient(135deg,var(--accent),var(--accent-2)); }
.blog-hub .bh-card__body{ padding:14px 16px 18px; display:flex; flex-direction:column; gap:7px; }
.blog-hub .bh-card__date{ font-family:var(--font-en); font-size:12px; color:var(--fg-dim); }
.blog-hub .bh-card__ttl{ font-size:14px; font-weight:600; line-height:1.6; color:var(--fg);
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.blog-hub .bh-card:hover .bh-card__ttl{ color:var(--accent); }

/* ---------- お役立ち資料 ---------- */
.blog-hub .bh-docs{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.blog-hub .bh-doc{ border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:border-color .2s, box-shadow .2s; }
.blog-hub .bh-doc:hover{ border-color:var(--cv-orange); box-shadow:0 8px 22px rgba(239,115,34,.12); }
.blog-hub .bh-doc__link{ display:flex; align-items:center; gap:18px; padding:16px 20px; }
.blog-hub .bh-doc__thumb{ flex:none; width:96px; height:64px; border-radius:8px; overflow:hidden; background:var(--bg-3); display:grid; place-items:center; }
.blog-hub .bh-doc__thumb img{ width:100%; height:100%; object-fit:cover; }
.blog-hub .bh-doc__thumb--ph{ color:var(--cv-orange); background:#fdeee2; }
.blog-hub .bh-doc__thumb--ph svg{ width:30px; height:30px; }
.blog-hub .bh-doc__body{ flex:1 1 auto; min-width:0; display:flex; flex-direction:column; gap:8px; }
.blog-hub .bh-doc__ttl{ font-size:15px; font-weight:600; line-height:1.6; color:var(--fg); }
.blog-hub .bh-doc__cta{ font-size:13px; font-weight:600; color:var(--cv-orange); }

/* ---------- Responsive ---------- */
@media (max-width:680px){
  .blog-hub .bh-inner{ padding:36px 18px 60px; }
  .blog-hub .bh-title{ font-size:26px; }
  .blog-hub .bh-tiles{ gap:10px; }
  .blog-hub .bh-tile{ gap:10px; padding:18px 8px; }
  .blog-hub .bh-tile__ico{ width:44px; height:44px; border-radius:12px; }
  .blog-hub .bh-tile__ico svg{ width:22px; height:22px; }
  .blog-hub .bh-tile__name{ font-size:13px; margin-bottom:0; }
  .blog-hub .bh-tile__desc{ display:none; }
  .blog-hub .bh-cards{ grid-template-columns:1fr; }
  .blog-hub .bh-post__thumb{ width:96px; height:64px; }
  .blog-hub .bh-post__ttl{ font-size:14px; }
  .blog-hub .bh-doc__thumb{ width:72px; height:54px; }
}
