/* =========================================================
   ネット回線の教科書 — components.css
   ヒーロー / カード / ボタン / 診断 / FAQ / 運営者
   ========================================================= */

/* --- ボタン --- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 13px 26px; border-radius: 100px; font-size: var(--fs-sm); font-weight: 600;
  border: 1px solid transparent; transition: 0.25s var(--ease); line-height: 1;
}
.btn--primary { background: var(--color-accent); color: #fff; }
.btn--primary:hover { background: var(--color-accent-dark); color: #fff; transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--color-accent); border-color: var(--color-border); }
.btn--ghost:hover { border-color: var(--color-accent); background: var(--color-accent-soft); }
.btn--block { width: 100%; }

/* --- ヒーロー（ファーストビュー） --- */
.hero { padding-block: clamp(3rem, 9vw, 6.5rem) clamp(2.5rem, 6vw, 4rem); text-align: center; }
.hero__badge {
  display: inline-block; font-size: var(--fs-xs); font-weight: 600; color: var(--color-accent);
  background: var(--color-accent-soft); padding: 6px 14px; border-radius: 100px; margin-bottom: 1.4rem;
}
.hero__title { font-size: var(--fs-hero); margin: 0 0 1rem; letter-spacing: -0.03em; }
.hero__sub { font-size: clamp(1rem, 2.5vw, 1.25rem); color: var(--color-text-sub); margin: 0 auto 2.2rem; max-width: 30ch; line-height: 1.6; font-weight: 500; }

/* 検索フォーム */
.hero-search { max-width: 560px; margin: 0 auto; }
.hero-search__field {
  display: flex; align-items: center; gap: 8px; background: #fff;
  border: 1px solid var(--color-border); border-radius: 100px; padding: 7px 7px 7px 20px;
  box-shadow: var(--shadow); transition: 0.25s var(--ease);
}
.hero-search__field:focus-within { border-color: var(--color-accent); box-shadow: 0 0 0 4px var(--color-accent-soft); }
.hero-search__field svg { flex-shrink: 0; color: var(--color-text-mute); }
.hero-search input {
  flex: 1; border: 0; outline: 0; font-size: var(--fs-body); background: transparent;
  color: var(--color-text); min-width: 0; padding: 10px 0;
}
.hero-search button { white-space: nowrap; padding: 12px 22px; }
.hero-search__hint { margin-top: 0.9rem; font-size: var(--fs-xs); color: var(--color-text-mute); }

/* ヒーロー訴求強化（v1.2） */
.sp-br { display: none; }
@media (max-width: 480px) { .sp-br { display: inline; } }
.hero__cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 1.75rem; }
.hero__cta .btn { min-width: 200px; }
.hero__trust { list-style: none; display: flex; gap: 20px; justify-content: center; flex-wrap: wrap; margin: 1.75rem 0 0; padding: 0; }
.hero__trust li { display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-xs); font-weight: 600; color: var(--color-text-sub); }
.hero__trust svg { width: 16px; height: 16px; color: var(--color-success); }
@media (max-width: 420px) {
  .hero__cta { flex-direction: column; align-items: stretch; }
  .hero__cta .btn { min-width: 0; width: 100%; }
  .hero__trust { gap: 12px; }
}

/* 全体的な「アニメーション付き登場」 */
[data-reveal] { opacity: 0; transform: translateY(20px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
[data-reveal].is-visible { opacity: 1; transform: none; }

/* --- 悩み別導線カード --- */
.worry-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.worry-card {
  display: flex; align-items: center; gap: 14px; padding: 20px;
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius);
  transition: 0.25s var(--ease); color: var(--color-text);
}
.worry-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); border-color: transparent; color: var(--color-text); }
.worry-card__icon {
  flex-shrink: 0; width: 44px; height: 44px; border-radius: 12px;
  display: grid; place-items: center; background: var(--color-accent-soft); color: var(--color-accent);
}
.worry-card__label { font-size: var(--fs-sm); font-weight: 600; line-height: 1.4; }

/* --- 記事カード --- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; }
.post-card {
  /* カード単位の色（data-cat で上書き）。既定は青系 */
  --c: var(--cat-neutral); --c-soft: var(--cat-neutral-soft);
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius);
  overflow: hidden; transition: 0.3s var(--ease); display: flex; flex-direction: column;
  position: relative;
}
.post-card[data-cat="hikari"]     { --c: var(--cat-hikari);     --c-soft: var(--cat-hikari-soft); }
.post-card[data-cat="homerouter"] { --c: var(--cat-homerouter); --c-soft: var(--cat-homerouter-soft); }
.post-card[data-cat="mobile"]     { --c: var(--cat-mobile);     --c-soft: var(--cat-mobile-soft); }
.post-card[data-cat="sim"]        { --c: var(--cat-sim);        --c-soft: var(--cat-sim-soft); }
/* 上辺のカラーライン：一覧で瞬時に判別 */
.post-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: var(--c); z-index: 2; }
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); border-color: transparent; }
.post-card__thumb { aspect-ratio: 16 / 9; background: var(--c-soft); overflow: hidden; position: relative; display: block; }
.post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s var(--ease); }
.post-card:hover .post-card__thumb img { transform: scale(1.04); }
/* アイキャッチ未設定時のプレースホルダー（カテゴリ色で塗り分け） */
.post-card__placeholder { position: absolute; inset: 0; display: grid; place-items: center; background: linear-gradient(135deg, var(--c-soft) 0%, #fff 100%); }
.post-card__placeholder::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 70% 20%, var(--c) 0, transparent 42%); opacity: 0.12; }
.post-card__placeholder-cat { position: relative; font-size: var(--fs-sm); font-weight: 700; color: var(--c); padding: 6px 14px; background: #fff; border-radius: 100px; box-shadow: var(--shadow-sm); }
/* カテゴリバッジ（サムネ上に重ねて視認性UP） */
.post-card__badge { position: absolute; left: 10px; bottom: 10px; z-index: 2; font-size: var(--fs-xs); font-weight: 700; color: #fff; background: var(--c); padding: 4px 11px; border-radius: 100px; letter-spacing: 0.02em; box-shadow: 0 2px 6px rgba(0,0,0,0.18); }
.post-card__body { padding: 16px 18px 20px; display: flex; flex-direction: column; flex: 1; }
.post-card__cat { font-size: var(--fs-xs); font-weight: 600; color: var(--c); margin-bottom: 8px; }
.post-card__title { font-size: 1.05rem; line-height: 1.5; margin: 0 0 10px; color: var(--color-text); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.post-card:hover .post-card__title { color: var(--c); }
.post-card__meta { margin-top: auto; font-size: var(--fs-xs); color: var(--color-text-mute); }

/* --- 人気カテゴリ --- */
.cat-pills { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.cat-pill {
  --c: var(--cat-neutral);
  padding: 11px 22px; border-radius: 100px; background: #fff;
  border: 1px solid var(--color-border); font-size: var(--fs-sm); font-weight: 600; color: var(--color-text);
  transition: 0.25s var(--ease); position: relative;
}
.cat-pill[data-cat="hikari"]     { --c: var(--cat-hikari); }
.cat-pill[data-cat="homerouter"] { --c: var(--cat-homerouter); }
.cat-pill[data-cat="mobile"]     { --c: var(--cat-mobile); }
.cat-pill[data-cat="sim"]        { --c: var(--cat-sim); }
/* 左に色ドットで判別性を付与（デザインは維持） */
.cat-pill[data-cat]:not([data-cat="neutral"])::before { content: ""; display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--c); margin-right: 8px; vertical-align: 1px; }
.cat-pill:hover { background: var(--c); color: #fff; border-color: var(--c); transform: translateY(-2px); }
.cat-pill:hover::before { background: #fff; }
/* カテゴリ未作成時の非リンク表示（クリック不可を明示） */
.cat-pill--placeholder { opacity: 0.5; cursor: default; }
.cat-pill--placeholder:hover { background: #fff; color: var(--color-text); border-color: var(--color-border); transform: none; }
.cat-pill--placeholder:hover::before { background: var(--c); }

/* --- 回線診断 --- */
.diagnosis { background: linear-gradient(135deg, #f0f5ff 0%, #f7faff 100%); border-radius: var(--radius-lg); padding: clamp(2rem, 5vw, 3.5rem); border: 1px solid var(--color-border); }
.diagnosis__head { text-align: center; margin-bottom: 2rem; }
.diagnosis__head h2 { font-size: var(--fs-h2); margin: 0 0 0.5rem; }
.diagnosis__head p { color: var(--color-text-sub); margin: 0; font-size: var(--fs-sm); }
.diag-step { max-width: 540px; margin: 0 auto; }
.diag-step__q { font-size: var(--fs-h3); text-align: center; margin: 0 0 1.5rem; }
.diag-options { display: grid; gap: 12px; }
.diag-option {
  padding: 16px 20px; background: #fff; border: 1px solid var(--color-border);
  border-radius: var(--radius); font-size: var(--fs-sm); font-weight: 600; text-align: left;
  color: var(--color-text); transition: 0.2s var(--ease);
}
.diag-option:hover { border-color: var(--color-accent); background: var(--color-accent-soft); }
.diag-progress { display: flex; gap: 6px; justify-content: center; margin-bottom: 1.5rem; }
.diag-progress span { width: 28px; height: 4px; border-radius: 4px; background: var(--color-border); transition: 0.3s var(--ease); }
.diag-progress span.is-active { background: var(--color-accent); }
.diag-result { text-align: center; }
.diag-result__badge { display: inline-block; font-size: var(--fs-xs); font-weight: 600; color: var(--color-accent); background: var(--color-accent-soft); padding: 6px 14px; border-radius: 100px; margin-bottom: 1rem; }
.diag-result__title { font-size: var(--fs-h2); margin: 0 0 0.75rem; }
.diag-result__desc { color: var(--color-text-sub); margin: 0 auto 1.75rem; max-width: 42ch; font-size: var(--fs-sm); }
.diag-result__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.is-hidden { display: none !important; }

/* --- FAQ --- */
.faq-list { max-width: var(--container-narrow); margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--color-border); }
.faq-item summary {
  list-style: none; cursor: pointer; padding: 22px 44px 22px 4px; position: relative;
  font-weight: 600; font-size: 1.05rem; line-height: 1.5;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+"; position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  font-size: 1.4rem; font-weight: 400; color: var(--color-accent); transition: transform 0.3s var(--ease);
}
.faq-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-item__answer { padding: 0 4px 22px; color: var(--color-text-sub); font-size: var(--fs-sm); }

/* --- 運営者情報 --- */
.author-box { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: clamp(1.5rem, 4vw, 2.5rem); max-width: var(--container-narrow); margin: 0 auto; }
.author-box__head { display: flex; gap: 24px; align-items: center; }
.author-box__avatar { flex-shrink: 0; width: 96px; height: 96px; border-radius: 50%; object-fit: cover; background: var(--color-bg-tint); }
.author-box__name { font-size: 1.2rem; margin: 0 0 4px; }
.author-box__role { font-size: var(--fs-xs); color: var(--color-accent); font-weight: 600; margin: 0 0 10px; }
.author-box__bio { font-size: var(--fs-sm); color: var(--color-text-sub); margin: 0; }
.author-box__section { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--color-border); }
.author-box__label { font-size: var(--fs-xs); font-weight: 700; color: var(--color-text-mute); letter-spacing: 0.06em; margin: 0 0 10px; }
.author-box__career { margin: 0; padding-left: 1.2em; }
.author-box__career li { font-size: var(--fs-sm); color: var(--color-text-sub); margin-bottom: 6px; }
.author-box__career li::marker { color: var(--color-accent); }
.author-box__policy { font-size: var(--fs-sm); color: var(--color-text-sub); margin: 0; line-height: 1.8; }
@media (max-width: 540px) { .author-box__head { flex-direction: column; text-align: center; } }

/* --- ページネーション --- */
.pagination { display: flex; justify-content: center; gap: 8px; margin-top: 3rem; flex-wrap: wrap; }
.pagination .page-numbers {
  display: grid; place-items: center; min-width: 42px; height: 42px; padding: 0 12px;
  border-radius: 12px; border: 1px solid var(--color-border); background: #fff;
  color: var(--color-text); font-size: var(--fs-sm); font-weight: 600;
}
.pagination .page-numbers.current { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.pagination .page-numbers:hover:not(.current) { border-color: var(--color-accent); color: var(--color-accent); }

/* =========================================================
   追加コンポーネント（v1.1）
   比較ブロック / ランキング / CTA / 診断関連記事 / 2カラム
   ========================================================= */

/* --- セクション見出し（左寄せバリエーション） --- */
.section-head--left { text-align: left; margin-bottom: 1.5rem; }
.section-head--left h2 { font-size: var(--fs-h3); }

/* --- カードグリッド2列（最新記事サイド付き用） --- */
.card-grid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 560px) { .card-grid--2 { grid-template-columns: 1fr; } }

/* --- トップ2カラム（最新記事 + ランキング） --- */
.home-twocol { display: grid; grid-template-columns: 1fr 320px; gap: 40px; align-items: start; }
@media (max-width: 900px) { .home-twocol { grid-template-columns: 1fr; gap: 3rem; } }

/* --- 評価バー --- */
.rating-bar { display: inline-block; width: 84px; height: 7px; background: var(--color-border); border-radius: 4px; overflow: hidden; vertical-align: middle; }
.rating-bar__fill { display: block; height: 100%; background: var(--color-accent); border-radius: 4px; }

/* --- おすすめ回線比較ブロック --- */
.compare-block { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 820px) { .compare-block { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; } }
.compare-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius); padding: 24px 22px; display: flex; flex-direction: column; transition: 0.3s var(--ease); }
.compare-card:hover { box-shadow: var(--shadow-hover); border-color: transparent; transform: translateY(-3px); }
.compare-card__head { text-align: center; padding-bottom: 16px; border-bottom: 1px solid var(--color-border); margin-bottom: 16px; }
.compare-card__catch { font-size: var(--fs-xs); color: var(--color-text-mute); }
.compare-card__name { font-size: 1.3rem; margin: 6px 0 4px; }
.compare-card__price { font-size: var(--fs-sm); font-weight: 700; color: var(--color-accent); margin: 0; }
.compare-card__ratings { margin: 0 0 16px; display: grid; gap: 8px; }
.compare-card__ratings div { display: flex; align-items: center; justify-content: space-between; }
.compare-card__ratings dt { font-size: var(--fs-xs); color: var(--color-text-sub); margin: 0; }
.compare-card__ratings dd { margin: 0; }
.compare-card__fit { font-size: var(--fs-xs); color: var(--color-text-sub); line-height: 1.7; margin: 0 0 18px; flex: 1; }
.compare-card__fit strong { color: var(--color-text); }
.compare-card__actions { display: flex; flex-direction: column; gap: 10px; align-items: center; }
.compare-card__more { font-size: var(--fs-xs); color: var(--color-text-sub); text-decoration: underline; text-underline-offset: 2px; }
.compare-note { text-align: center; font-size: var(--fs-xs); color: var(--color-text-mute); margin-top: 1.5rem; }

/* --- 人気記事ランキング --- */
.ranking-list { list-style: none; counter-reset: rank; margin: 0; padding: 0; display: grid; gap: 8px; }
.ranking-item { --c: var(--cat-neutral); --c-soft: var(--cat-neutral-soft); }
.ranking-item[data-cat="hikari"]     { --c: var(--cat-hikari);     --c-soft: var(--cat-hikari-soft); }
.ranking-item[data-cat="homerouter"] { --c: var(--cat-homerouter); --c-soft: var(--cat-homerouter-soft); }
.ranking-item[data-cat="mobile"]     { --c: var(--cat-mobile);     --c-soft: var(--cat-mobile-soft); }
.ranking-item[data-cat="sim"]        { --c: var(--cat-sim);        --c-soft: var(--cat-sim-soft); }
.ranking-item a { display: flex; align-items: center; gap: 12px; padding: 10px; border-radius: var(--radius-sm); color: var(--color-text); transition: 0.2s var(--ease); }
.ranking-item a:hover { background: var(--color-bg-soft); }
.ranking-item__num { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; font-size: var(--fs-xs); font-weight: 700; background: var(--color-bg-soft); color: var(--color-text-mute); }
.ranking-item__num[data-rank="1"] { background: #ffd700; color: #6b5400; }
.ranking-item__num[data-rank="2"] { background: #d9dde3; color: #4a4f57; }
.ranking-item__num[data-rank="3"] { background: #e8c9a8; color: #7a5230; }
.ranking-item__thumb { flex-shrink: 0; width: 64px; height: 44px; border-radius: 8px; overflow: hidden; background: var(--c-soft); position: relative; }
.ranking-item__thumb img { width: 100%; height: 100%; object-fit: cover; }
.ranking-item__thumb-ph { position: absolute; inset: 0; background: linear-gradient(135deg, var(--c-soft), #fff); }
.ranking-item__thumb-ph::after { content: ""; position: absolute; left: 8px; top: 50%; width: 4px; height: 22px; transform: translateY(-50%); border-radius: 4px; background: var(--c); }
.ranking-item__text { min-width: 0; }
.ranking-item__cat { display: block; font-size: 0.7rem; color: var(--c); font-weight: 700; }
.ranking-item__title { display: block; font-size: var(--fs-sm); font-weight: 600; line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ranking-item a:hover .ranking-item__title { color: var(--c); }

/* --- 記事下CTA --- */
.article-cta { display: flex; align-items: center; justify-content: space-between; gap: 20px; background: linear-gradient(135deg, #f0f5ff 0%, #f7faff 100%); border: 1px solid #cfe0ff; border-radius: var(--radius-lg); padding: 24px 28px; margin: 2.5rem 0; }
.article-cta--diag { background: var(--color-bg-soft); border-color: var(--color-border); }
.article-cta__label { display: inline-block; font-size: var(--fs-xs); font-weight: 700; color: var(--color-accent); margin-bottom: 6px; }
.article-cta__title { font-size: 1.15rem; margin: 0 0 6px; }
.article-cta__desc { font-size: var(--fs-sm); color: var(--color-text-sub); margin: 0; }
.article-cta .btn { flex-shrink: 0; white-space: nowrap; }
@media (max-width: 600px) { .article-cta { flex-direction: column; align-items: stretch; text-align: left; } .article-cta .btn { width: 100%; } }

/* --- 診断結果の関連記事 --- */
.diag-related { margin-top: 1.75rem; padding-top: 1.5rem; border-top: 1px solid var(--color-border); }
.diag-related__loading { text-align: center; font-size: var(--fs-sm); color: var(--color-text-mute); margin: 0; }
.diag-related__label { font-size: var(--fs-xs); font-weight: 700; color: var(--color-text-mute); text-align: center; margin: 0 0 14px; letter-spacing: 0.04em; }
.diag-related__grid { display: grid; gap: 10px; }
.diag-related__card { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: 8px; color: var(--color-text); transition: 0.2s var(--ease); }
.diag-related__card:hover { border-color: var(--color-accent); transform: translateY(-1px); }
.diag-related__thumb { flex-shrink: 0; width: 60px; height: 42px; border-radius: 6px; overflow: hidden; background: var(--color-bg-tint); }
.diag-related__thumb img { width: 100%; height: 100%; object-fit: cover; }
.diag-related__cat { display: block; font-size: 0.7rem; color: var(--color-accent); font-weight: 600; }
.diag-related__title { display: block; font-size: var(--fs-sm); font-weight: 600; line-height: 1.4; }

/* --- 診断 質問番号 --- */
.diag-step__num { color: var(--color-accent); margin-right: 4px; }

/* --- スマホUX：固定追従CTAバー（記事ページ） --- */
.sticky-cta { position: fixed; left: 0; right: 0; bottom: 0; z-index: 90; background: rgba(255,255,255,0.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-top: 1px solid var(--color-border); padding: 10px 16px calc(10px + env(safe-area-inset-bottom)); transform: translateY(110%); transition: transform 0.35s var(--ease); }
.sticky-cta.is-visible { transform: translateY(0); }
.sticky-cta__inner { display: flex; align-items: center; gap: 12px; max-width: var(--container-narrow); margin: 0 auto; }
.sticky-cta__text { font-size: var(--fs-xs); font-weight: 600; line-height: 1.3; flex: 1; min-width: 0; }
.sticky-cta .btn { flex-shrink: 0; padding: 11px 20px; }
@media (min-width: 768px) { .sticky-cta { display: none; } }

/* =========================================================
   追加（v1.2）診断結果の導線強化 / カテゴリ色 関連記事
   ========================================================= */

/* 診断結果：回線タイプ色をアクセントに */
.diag-result { --c: var(--cat-neutral); --c-soft: var(--cat-neutral-soft); }
.diag-result[data-cat="hikari"]     { --c: var(--cat-hikari);     --c-soft: var(--cat-hikari-soft); }
.diag-result[data-cat="homerouter"] { --c: var(--cat-homerouter); --c-soft: var(--cat-homerouter-soft); }
.diag-result[data-cat="mobile"]     { --c: var(--cat-mobile);     --c-soft: var(--cat-mobile-soft); }
.diag-result .diag-result__badge { background: var(--c-soft); color: var(--c); }
.diag-result .diag-result__title { color: var(--c); }
.diag-cta.btn--primary { background: var(--c); }
.diag-cta.btn--primary:hover { filter: brightness(0.92); background: var(--c); }

/* 結果のサブ導線（比較・再診断） */
.diag-result__sub { display: flex; flex-direction: column; align-items: center; gap: 10px; margin-top: 14px; }
.diag-result__compare { font-size: var(--fs-sm); font-weight: 600; color: var(--c); text-decoration: underline; text-underline-offset: 3px; }
.diag-result__retry { border: 0; background: none; font-size: var(--fs-xs); color: var(--color-text-mute); text-decoration: underline; text-underline-offset: 2px; cursor: pointer; }

/* 関連記事カードのカテゴリ色 */
.diag-related__card { --c: var(--cat-neutral); --c-soft: var(--cat-neutral-soft); }
.diag-related__card[data-cat="hikari"]     { --c: var(--cat-hikari);     --c-soft: var(--cat-hikari-soft); }
.diag-related__card[data-cat="homerouter"] { --c: var(--cat-homerouter); --c-soft: var(--cat-homerouter-soft); }
.diag-related__card[data-cat="mobile"]     { --c: var(--cat-mobile);     --c-soft: var(--cat-mobile-soft); }
.diag-related__card[data-cat="sim"]        { --c: var(--cat-sim);        --c-soft: var(--cat-sim-soft); }
.diag-related__card:hover { border-color: var(--c); }
.diag-related__cat { color: var(--c); font-weight: 700; }
.diag-related__thumb { background: var(--c-soft); }
.diag-related__thumb--ph { position: relative; }
.diag-related__thumb--ph::after { content: ""; position: absolute; left: 8px; top: 50%; width: 4px; height: 20px; transform: translateY(-50%); border-radius: 4px; background: var(--c); }
