/* === SoHo Blog Hub — 1:1 design === */
.soho-bh{--container:1160px; --primary:#0f1d5b; --muted:#6b7280; --pill:#eef1f5; --bg:#fff; position:relative; margin-bottom: 50px}
.soho-bh-head{max-width:var(--container); margin:0 auto 50px; text-align:center}
.soho-bh-title{margin:12px 0 6px; font-family:'Playfair Display',serif; font-weight:800; color:var(--primary); font-size:36px; line-height:1.2}
.soho-bh-sub{margin:0 auto 16px; color:#7b7f87; font-size:14px; max-width:840px}
.soho-bh-search{position:relative; max-width:640px; margin:0 auto 50px}
.soho-bh-search .soho-bh-q{width:100%; height:44px; border:1px solid #dfe5ee; border-radius:999px; background:#fff; padding:0 52px 0 16px; font-size:15px; color:#111827; outline:none; box-shadow:0 1px 0 rgba(17,24,39,.02)}
.soho-bh-search .soho-bh-q::placeholder{color:#9aa3af}
.soho-bh-search .soho-bh-qbtn{position:absolute; right:6px; top:50%; transform:translateY(-50%); width:36px; height:36px; border-radius:999px; border:1px solid #dfe5ee; background:#fff; color:var(--primary); display:grid; place-items:center; cursor:pointer}
.soho-bh-search .soho-bh-qbtn:hover{background:#f2f6ff}
.soho-bh-tabs{max-width:var(--container); margin:6px auto 18px; display:flex; gap:8px; flex-wrap:wrap; justify-content:center}
.soho-bh-tab{border:1px solid #e5e7eb; background:#f6f7fb; color:#374151; border-radius:999px; padding:6px 14px; font-weight:600; font-size:12px; cursor:pointer}
.soho-bh-tab.is-active{ background:var(--primary); color:#fff; border-color:var(--primary) }
.soho-bh-results{max-width:var(--container); margin:0 auto; margin-top: 50px}
.soho-bh-empty, .soho-bh-loading{ text-align:center; color:var(--muted); padding:24px }
.soho-bh-grid{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:22px }
@media (max-width:1024px){ .soho-bh-grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:640px) { .soho-bh-grid{ grid-template-columns:1fr } }
.soho-bh-card{background:#fff; border:1px solid #e6e8ec; border-radius:8px; overflow:hidden; box-shadow:0 1px 2px rgba(16,24,40,.06)}
.soho-bh-thumb img{display:block; width:100%; height:214px; object-fit:cover}
.soho-bh-noimg{height:214px; display:flex; align-items:center; justify-content:center; background:#f3f4f6; color:#9ca3af}
.soho-bh-body{padding:14px 16px 12px}
.soho-bh-badge{font-size:11px; color:#9aa3af; margin-bottom:6px}
.soho-bh-title-sm{margin:0 0 6px; font-size:16px; font-weight:700; color:#0f172a; line-height:1.35}
.soho-bh-title-sm a{text-decoration:none; color:inherit}
.soho-bh-excerpt{color:#6b7280; font-size:13px; line-height:1.55; margin-bottom:10px}
.soho-bh-meta{display:flex; align-items:center; justify-content:space-between}
.soho-bh-date{color:#6b7280; font-size:12px}
.soho-bh-more{width:30px; height:30px; display:grid; place-items:center; border-radius:999px; background:#0f1d5b; color:#fff; text-decoration:none}
.soho-bh-more span{display:block; transform:translateX(1px)}
.soho-bh-more:hover{filter:brightness(1.05)}
.soho-bh-more-wrap{text-align:center; margin-top:16px}
.soho-bh-loadmore{background:#0f1d5b; color:#fff; border:0; border-radius:6px; padding:8px 14px; font-size:12px; cursor:pointer}
.soho-bh-loadmore:hover{filter:brightness(1.05)}