/* ===========================
   Blog Archive — カテゴリ切替＋一覧
=========================== */

/* ヒーロー */
.blog-hero{
  max-width: 1200px;
  margin: 0 auto 12px;
  padding: 0 16px;
  text-align: center;
}
.blog-hero__lead{ color:#555; margin:.2em 0 0; }

/* カテゴリフィルタ（横スクロールチップ） */
.blog-filters{
  max-width: 1200px;
  margin: 0 auto 20px;
  padding: 0 16px;
}
.bf-list{
  display: flex;
  gap: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 6px 2px;
  margin: 0;
  list-style: none;
}
.bf-item{ flex: 0 0 auto; }
.bf-chip{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  text-decoration: none;
  background: #f2f2f5;
  color: #333;
  border: 1px solid rgba(0,0,0,.06);
}
.bf-chip__count{
  font-size: .85em;
  color: #666;
}
.bf-chip:is(:hover, .is-active){
  background: var(--c-deep, #823327);
  color: var(--c-pale, #eecebf);
  border-color: transparent;
}

/* 一覧カード */
.blog-listing{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px 40px;
}
.blog-cards{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: clamp(14px, 2vw, 22px);
}
@media (max-width: 960px){ .blog-cards{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 600px){ .blog-cards{ grid-template-columns: 1fr; } }

.bcard{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  transition: transform .18s ease, box-shadow .18s ease;
}
.bcard:hover{ transform: translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.12); }

.bcard__link{ display:block; color:inherit; text-decoration:none; }

.bcard__thumb img,
.bcard__ph{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio: 16/9;
  object-fit: cover;
  background:#eee;
}
.bcard__body{ padding: 10px 12px 12px; }
.bcard__title{
  font-size: clamp(18px, 2.2vw, 20px);
  margin: 2px 0 6px;
  line-height: 1.35;
}
.bcard__date{ font-size: .9rem; color:#666; }
.bcard__excerpt{ margin: 6px 0 10px; color:#444; }
.bcard__cats{ display:flex; flex-wrap:wrap; gap:6px; }
.bcard__cat{
  font-size:.85rem;
  padding: 2px 8px;
  border-radius: 999px;
  background: #f5e9e6;
  color:#5a2a22;
}

/* もっとみる */
.blog-more{
  text-align:center;
  margin-top: 18px;
}
.btn-more{
  display:inline-block;
  padding: 12px 28px;
  border-radius:999px;
  background: var(--c-deep, #823327);
  color: var(--c-pale, #eecebf);
  border:0;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.btn-more:hover{ transform: translateY(-1px); box-shadow:0 8px 18px rgba(0,0,0,.12); }
.btn-more:disabled{ opacity:.45; cursor:not-allowed; }
