/* ==== Blog page only ==== */
.page-hero{background:linear-gradient(180deg, var(--hero-from), transparent 60%),#fff;border-top:1px solid var(--line)}
.crumbs{color:var(--muted);font-size:12px}

.toolbar{position:sticky;top:64px;z-index:10;background:#fff;border-bottom:1px solid var(--line)}
.toolbar__inner{display:flex;gap:12px;align-items:center;flex-wrap:wrap;padding:12px 0}
.tool-input{flex:1;min-width:220px}

.pill-tab{padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#fff;font-size:12px;text-decoration:none}
.pill-tab.is-active{background:var(--brand);border-color:var(--brand);color:#fff}

.blog-grid{display:grid;gap:20px;grid-template-columns:repeat(1,minmax(0,1fr))}
@media(min-width:900px){.blog-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}

.post-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.post-media{aspect-ratio:16/9;background:linear-gradient(135deg,#e9f1ff,#eef6ff);border-bottom:1px solid var(--line);display:block;position:relative}
.post-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.post-body{padding:14px 16px}
.post-title{font-size:16px;font-weight:800;line-height:1.4;margin:6px 0 4px}
.post-title a{text-decoration:none}
.post-desc{font-size:13px;color:var(--muted)}
.meta-small{font-size:12px;color:var(--muted);margin-top:6px}
.post-cta{display:flex;gap:10px; padding:12px 16px; border-top:1px solid var(--line)}

.tag-mini{display:inline-flex; align-items:center; gap:8px; font-size:12px}
.tag-mini .tag{display:inline-block; padding:4px 10px; border-radius:999px; background:#eaf2ff; color:#1d4ed8; border:1px solid #dbe7ff; font-weight:700}
.tag-mini .date{color:var(--muted)}

.pager{display:flex; gap:10px; justify-content:center; align-items:center; padding:24px 0}
.pager ul{display:flex;gap:8px;list-style:none;margin:0;padding:0}
.pager a, .pager span{min-width:36px;height:36px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:10px;background:#fff;font-weight:700;transition:all .15s;text-decoration:none}
.pager .current{background:var(--brand);color:#fff;border-color:var(--brand)}
.pager a:hover{border-color:var(--brand)}

.cat-wrap{background:#fafafa; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.cat-grid{display:grid; gap:12px; grid-template-columns:repeat(1,minmax(0,1fr))}
@media(min-width:900px){ .cat-grid{grid-template-columns:repeat(3,minmax(0,1fr))} }
.cat-item{display:flex; align-items:center; justify-content:space-between; padding:14px 16px; background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:var(--shadow)}
.cat-item .name{font-weight:700}
.cat-item .chev{opacity:.5}
/* ===== Blog list grid (new) ===== */
.blog-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(1, minmax(0, 1fr));
}
@media (min-width: 900px){
  .blog-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
}

/* tile */
.blog-tile{
  display:block;
  text-decoration:none;
  color:inherit;
  background:#fff;
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  overflow:hidden;      /* 画像のはみ出し防止 */
  border-radius:0;      /* 角丸なし */
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.blog-tile:hover{
  transform: translateY(-1px);
  border-color: var(--brand);
}

/* thumbnail area: 高さを常に一定にする */
.blog-tile__thumb{
  aspect-ratio: 2400 / 1260; /* ←あなたのサムネ比率に固定（高さ一定） */
  background:#f3f5f7;        /* contain時の余白の色 */
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
}

/* 画像は切らずに全体表示（横が切れない） */
.blog-tile__img{
  width:100%;
  height:100%;
  object-fit: contain; /* ←ここが重要：coverだと横が切れます */
  display:block;
}

/* body */
.blog-tile__body{
  padding:12px 14px 14px;
}
.blog-tile__meta{
  display:flex;
  gap:10px;
  align-items:center;
  font-size:12px;
  margin-bottom:8px;
}
.blog-tile__cat{
  display:inline-block;
  padding:3px 10px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:700;
}
.blog-tile__date{
  color: var(--muted);
}

.blog-tile__title{
  font-size:15px;
  font-weight:800;
  line-height:1.45;
  margin:0;
}
/* ===== Override: card-like white background 제거 ===== */
.blog-grid .blog-tile{
  background: transparent !important; /* 白背景なし */
  border: 0 !important;               /* 枠線なし */
  box-shadow: none !important;        /* 影なし（白枠感の原因） */
  border-radius: 0 !important;        /* 角丸なし */
  overflow: visible !important;       /* 背景枠がないのでOK */
  transform: none;
  transition: none;
  color: inherit;
  text-decoration: none;
}

/* 青枠っぽい hover border を無効化（前回の hover を潰す） */
.blog-grid .blog-tile:hover{
  border-color: transparent !important;
  transform: none !important;
}

/* クリック要素のフォーカス青枠を消す（※アクセシビリティ的には別途整えるの推奨） */
.blog-grid .blog-tile:focus,
.blog-grid .blog-tile:focus-visible{
  outline: none;
}

/* ===== 画像だけ“モダンに”強調（ホバー時） ===== */
.blog-grid .blog-tile__thumb{
  aspect-ratio: 2400 / 1260;     /* 高さ一定 */
  background: transparent;       /* 余白背景もなし（必要なら #f3f5f7 に） */
  border: 0;
  display: block;
  overflow: hidden;              /* 画像のズームに備えて */
}

/* 横が切れない（全体表示） */
.blog-grid .blog-tile__img{
  width: 100%;
  height: 100%;
  object-fit: contain;           /* ←横切れ防止 */
  display: block;
  transform: translateZ(0);
  transition: transform .18s ease, filter .18s ease;
}

/* hoverで“ちょい強調”：画像を少しだけズーム＆コントラスト */
@media (hover:hover){
  .blog-grid .blog-tile:hover .blog-tile__img{
    transform: scale(1.02);
    filter: contrast(1.03);
  }
}

/* ===== テキスト部：背景なし、最小限の余白 ===== */
.blog-grid .blog-tile__body{
  padding: 10px 0 0;     /* 白枠っぽくならないよう左右paddingなし */
  background: transparent;
}

/* カテゴリ＋日付：背景なし */
.blog-grid .blog-tile__meta{
  display: flex;
  gap: 10px;
  align-items: center;
  font-size: 12px;
  margin: 0 0 6px;
}

/* “ピル”をやめてテキスト表示に（背景・枠なし） */
.blog-grid .blog-tile__cat{
  padding: 0;
  border: 0;
  background: transparent;
  font-weight: 700;
  color: inherit;
}

/* 日付は控えめ */
.blog-grid .blog-tile__date{
  color: var(--muted);
}

/* タイトル：見た目を整えつつ、行数を揃えて高さを安定させる */
.blog-grid .blog-tile__title{
  margin: 0;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.45;

  /* 高さを揃える（2行で打ち切り） */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

/* hover時のタイトル強調：下線 or 文字色変化（青枠じゃない） */
@media (hover:hover){
  .blog-grid .blog-tile:hover .blog-tile__title{
    text-decoration: underline;
    text-underline-offset: 3px;
  }
}
