/* =========================================================
   シェアひろば 共通テーマ  theme.css
   ★ ここを変えるとサイト全体のデザインが変わります ★
   ========================================================= */

:root{
  /* ===== ブランドカラー ===== */
  --brand-orange:      #ea580c;
  --brand-orange-light:#f59e0b;
  --brand-navy:        #1e293b;

  /* ===== ベースカラー ===== */
  --ink:        #0f172a;
  --ink2:       #1e293b;
  --ink-light:  #64748b;
  --ink-lighter:#94a3b8;
  --paper:      #f0f3f8;
  --surface:    #ffffff;
  --border:     #e2e8f0;
  --border-soft:#eef2f6;

  /* ===== アクセント（鈍金） ===== */
  --gold:       #a07c34;
  --gold-light: #c8a557;
  --gold-dark:  #7a5d27;
  --gold-muted: #fdf8eb;

  /* ===== リンク ===== */
  --link:       #1d4ed8;
  --link-hover: #1e40af;
  --link-visit: #6b21a8;

  /* ===== 状態色 ===== */
  --red:    #dc2626;
  --orange: #ea580c;
  --green:  #16a34a;
  --blue:   #0284c7;
  --purple: #7c3aed;

  /* ===== 地域カラー（8地方） ===== */
  --r-hokkaido:#2563eb; --r-hokkaido-bg:#dbeafe;
  --r-tohoku:  #0891b2; --r-tohoku-bg:  #cffafe;
  --r-kanto:   #dc2626; --r-kanto-bg:   #fee2e2;
  --r-chubu:   #7c3aed; --r-chubu-bg:   #ede9fe;
  --r-kansai:  #ea580c; --r-kansai-bg:  #ffedd5;
  --r-chugoku: #16a34a; --r-chugoku-bg: #dcfce7;
  --r-shikoku: #db2777; --r-shikoku-bg: #fce7f3;
  --r-kyushu:  #4338ca; --r-kyushu-bg:  #e0e7ff;

  /* ===== カテゴリカラー（8区分） ===== */
  --c-nouhau:  #a07c34; --c-nouhau-bg:  #fdf8eb;
  --c-chishiki:#2563eb; --c-chishiki-bg:#dbeafe;
  --c-seikatsu:#16a34a; --c-seikatsu-bg:#dcfce7;
  --c-yarikata:#ea580c; --c-yarikata-bg:#ffedd5;
  --c-shumi:   #7c3aed; --c-shumi-bg:   #ede9fe;
  --c-otoku:   #dc2626; --c-otoku-bg:   #fee2e2;
  --c-chiiki:  #0891b2; --c-chiiki-bg:  #cffafe;
  --c-zatsudan:#6b21a8; --c-zatsudan-bg:#f3e8ff;

  /* ===== タイポgrafィ ===== */
  --font-base: "Noto Sans JP","Inter",system-ui,-apple-system,sans-serif;
  --font-en:   "Inter",system-ui,sans-serif;
  --fs-root:   clamp(17px, calc(16px + 0.40vw), 23px);  /* ← 全体の基準サイズ */

  /* ===== レイアウト ===== */
  --maxw:   2100px;
  --radius: .5rem;
  --radius-lg: .75rem;
  --shadow-card:      0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --shadow-cardHover: 0 4px 12px rgba(15,23,42,.10), 0 2px 4px rgba(15,23,42,.06);
}

/* ===== ダークテーマ（html data-theme="dark" で切替） ===== */
html[data-theme="dark"]{
  --ink:#f1f5f9; --ink2:#e2e8f0; --ink-light:#94a3b8; --ink-lighter:#64748b;
  --paper:#0f172a; --surface:#1e293b; --border:#334155; --border-soft:#1e293b;
  --gold-muted:#2a2417; --link:#60a5fa; --link-hover:#93c5fd;
}
/* ===== ポップテーマ（html data-theme="pop"） ===== */
html[data-theme="pop"]{
  --gold:#ea580c; --gold-light:#fb923c; --gold-muted:#fff7ed;
  --brand-navy:#7c3aed; --ink:#1e1b4b;
}

/* ===== ベース ===== */
html{font-size:var(--fs-root);scroll-behavior:smooth}
body{font-family:var(--font-base);background:var(--paper);color:var(--ink);
     -webkit-font-smoothing:antialiased;word-wrap:break-word;margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.wrap{max-width:min(98vw,var(--maxw));margin:0 auto;
      padding-left:clamp(.5rem,1vw,1rem);padding-right:clamp(.5rem,1vw,1rem)}

/* ===== テキストリンク（記事内・見出し） ===== */
.h-link{color:#2a3340}
.h-link:hover{color:var(--link-hover);text-decoration:underline;text-underline-offset:2px}
.h-link:visited{color:var(--link-visit)}

/* ===== ロゴ ===== */
.logo-wrap{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.logo-text{font-weight:800;font-size:1.15rem;line-height:1;letter-spacing:-.01em}
.logo-text .a{color:var(--brand-orange)}
.logo-text .b{color:var(--brand-navy)}
.logo-sub{font-size:.6rem;color:var(--ink-light);font-family:var(--font-en);letter-spacing:.08em;margin-top:.15rem}

/* ===== カテゴリ・地域バッジ ===== */
.tag-cat{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:.3rem;
         font-size:.72em;font-weight:600;border:1px solid transparent;white-space:nowrap}
.tag-c-nouhau  {background:var(--c-nouhau-bg);  color:var(--c-nouhau);border-color:transparent}
.tag-c-chishiki{background:var(--c-chishiki-bg);color:var(--c-chishiki)}
.tag-c-seikatsu{background:var(--c-seikatsu-bg);color:var(--c-seikatsu)}
.tag-c-yarikata{background:var(--c-yarikata-bg);color:var(--c-yarikata)}
.tag-c-shumi   {background:var(--c-shumi-bg);   color:var(--c-shumi);border-color:transparent}
.tag-c-otoku   {background:var(--c-otoku-bg);   color:var(--c-otoku);border-color:transparent}
.tag-c-chiiki  {background:var(--c-chiiki-bg);  color:var(--c-chiiki);border-color:transparent}
.tag-c-zatsudan{background:var(--c-zatsudan-bg);color:var(--c-zatsudan)}

.tag-region{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:9999px;
            font-size:.72em;font-weight:600;white-space:nowrap}
.tag-r-hokkaido{background:var(--r-hokkaido-bg);color:var(--r-hokkaido)}
.tag-r-tohoku  {background:var(--r-tohoku-bg);  color:var(--r-tohoku)}
.tag-r-kanto   {background:var(--r-kanto-bg);   color:var(--r-kanto)}
.tag-r-chubu   {background:var(--r-chubu-bg);   color:var(--r-chubu)}
.tag-r-kansai  {background:var(--r-kansai-bg);  color:var(--r-kansai)}
.tag-r-chugoku {background:var(--r-chugoku-bg); color:var(--r-chugoku)}
.tag-r-shikoku {background:var(--r-shikoku-bg); color:var(--r-shikoku)}
.tag-r-kyushu  {background:var(--r-kyushu-bg);  color:var(--r-kyushu)}

/* キーワードタグ */
.tag-kw{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:9999px;
        font-size:.78em;font-weight:500;background:var(--gold-muted);color:var(--gold);
        border:1px solid var(--gold);transition:all .15s}
.tag-kw:hover{background:var(--gold);color:#fff}

/* ===== ボタン ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
     padding:.55rem 1.1rem;border-radius:var(--radius);font-weight:600;font-size:.9em;
     transition:all .15s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--gold);color:#fff}
.btn-primary:hover{background:var(--gold-light)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--ink2)}
.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ===== カード ===== */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
      box-shadow:var(--shadow-card);transition:all .2s;overflow:hidden}
.card:hover{box-shadow:var(--shadow-cardHover);border-color:var(--gold)}
.card-img{transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.card:hover .card-img{transform:scale(1.05)}

/* ===== 共通ヘッダー ===== */
.site-header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40}
.site-header .bar{display:flex;align-items:center;height:3.6rem;gap:.75rem}

/* ===== 共通フッター ===== */
.site-footer{background:var(--ink);color:rgba(255,255,255,.85);padding:2.5rem 0;margin-top:2rem}
.site-footer a{color:rgba(255,255,255,.6)}
.site-footer a:hover{color:var(--gold)}

/* ===== 記事本文 ===== */
.article-body{line-height:1.95;color:var(--ink2);font-size:1.05em}
.article-body h2{font-size:1.5em;font-weight:700;margin:2rem 0 .8rem;padding-bottom:.4rem;
                 border-bottom:2px solid var(--gold-muted);color:var(--ink)}
.article-body h3{font-size:1.2em;font-weight:700;margin:1.5rem 0 .5rem;color:var(--ink)}
.article-body p{margin:.9rem 0}
.article-body ul{margin:.6rem 0 1rem 1.5rem;list-style:disc}
.article-body ol{margin:.6rem 0 1rem 1.5rem;list-style:decimal}
.article-body li{margin:.3rem 0}
.article-body strong{font-weight:700;color:var(--ink)}
.article-body blockquote{border-left:4px solid var(--gold);background:var(--gold-muted);
                         padding:.85rem 1.1rem;margin:1.2rem 0;color:var(--ink2);border-radius:0 .4rem .4rem 0}
.article-body img{border-radius:.6rem;margin:1.5rem 0}

/* ===== ユーティリティ ===== */
.scrollbar-none::-webkit-scrollbar{display:none}
.scrollbar-none{-ms-overflow-style:none;scrollbar-width:none}
.clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.av{border-radius:50%;background:linear-gradient(135deg,var(--gold-muted),var(--gold));
    border:2px solid var(--surface);flex-shrink:0}

/* ===== リアクション・シェア・コメント（バックエンド連携UI） ===== */
.rx-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .75rem;font-size:.9em;
        background:var(--surface);border:1px solid var(--border);border-radius:9999px;
        color:var(--ink-light);cursor:pointer;transition:all .15s}
.rx-btn:hover,.rx-btn.active{background:var(--gold-muted);border-color:var(--gold);color:var(--gold)}
.share-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem .95rem;font-size:.85em;
           font-weight:600;color:#fff;border:none;border-radius:.4rem;cursor:pointer;transition:opacity .15s;font-family:inherit}
.share-btn:hover{opacity:.88}
#cmt-form input,#cmt-form textarea{width:100%;padding:.65rem .8rem;border:1px solid var(--border);
   border-radius:.45rem;font-family:inherit;font-size:.95em;background:var(--surface);color:var(--ink)}
#cmt-form input:focus,#cmt-form textarea:focus{outline:none;border-color:var(--gold);
   box-shadow:0 0 0 3px rgba(160,124,52,.15)}
#cmt-form textarea{min-height:5.5rem;resize:vertical}

/* ===== フル幅BBSリスト（爆サイ/5ch風・知識サイト版） ===== */
.bbs-list{border:1px solid var(--border);border-radius:.6rem;overflow:hidden;background:var(--surface)}
.bbs-row{display:flex;gap:.75rem;align-items:center;padding:.7rem .85rem;border-bottom:1px solid var(--border-soft);text-decoration:none;color:inherit;transition:background .12s}
.bbs-row:last-child{border-bottom:none}
.bbs-row:hover{background:var(--paper)}
.bbs-no{font-family:var(--font-en);font-weight:800;color:var(--gold);width:1.7rem;text-align:center;flex-shrink:0;font-size:1.05rem;line-height:1}
.bbs-no.top{color:#dc2626}
.bbs-thumb{width:60px;height:60px;border-radius:.45rem;object-fit:cover;flex-shrink:0;background:var(--paper)}
.bbs-main{min-width:0;flex:1}
.bbs-row-tags{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center;margin-bottom:.2rem}
.bbs-title{font-weight:700;color:var(--ink);line-height:1.4;font-size:1.02rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.bbs-row:hover .bbs-title{color:var(--gold-dark);text-decoration:underline;text-underline-offset:2px}
.bbs-meta{font-size:.8rem;color:var(--ink-light);margin-top:.25rem;display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}
.bbs-meta .n{font-weight:700;color:var(--ink2)}
.bbs-head{display:flex;align-items:center;gap:.6rem;padding:.6rem .85rem;background:var(--ink);color:#fff;font-weight:700;font-size:.95rem}
.bbs-head .c{margin-left:auto;font-size:.78rem;font-weight:500;color:rgba(255,255,255,.7)}
@media(max-width:520px){.bbs-thumb{width:48px;height:48px}.bbs-title{font-size:.95rem}}

/* ジャンルタイルの文字を大きく */
.gtile .lb{font-size:1.02rem !important}
.gtile .em{font-size:1.2rem !important}
@media(max-width:640px){.gtile .lb{font-size:.86rem !important}}

/* ===== 新ジャンル配色（枠線なし・落ち着いたパステル） ===== */
.tag-c-okane   {background:#dcfce7;color:#15803d}
.tag-c-kurashi {background:#ccfbf1;color:#0d7d72}
.tag-c-ryouri  {background:#ffedd5;color:#c2410c}
.tag-c-kenko   {background:#fce7f3;color:#be185d}
.tag-c-shigoto {background:#e0e7ff;color:#4338ca}
.tag-c-kosodate{background:#fef3c7;color:#b45309}
.tag-c-sumai   {background:#eef2ff;color:#4f46e5}
.site-footer{padding:3rem 0 3.5rem}

/* ===== 記事本文タイポグラフィ ===== */
.article-body{font-size:1.1rem;line-height:1.95;color:var(--ink)}
.article-body h2{font-size:1.5rem;font-weight:800;margin:2.2rem 0 .9rem;padding-left:.75rem;border-left:5px solid var(--gold);line-height:1.4}
.article-body h3{font-size:1.22rem;font-weight:700;margin:1.6rem 0 .6rem;color:var(--ink2)}
.article-body p{margin:1rem 0}
.article-body ul{margin:1rem 0;padding-left:1.5rem;list-style:disc}
.article-body li{margin:.45rem 0}
.article-body blockquote{margin:1.3rem 0;padding:1rem 1.2rem;background:var(--gold-muted);border-left:4px solid var(--gold);border-radius:.4rem;color:var(--ink2);font-size:1.02rem}
.article-body strong{font-weight:700;color:var(--gold-dark)}
.article-hero{position:relative;min-height:200px;display:flex;align-items:flex-end;overflow:hidden}
.article-hero img{width:100%;height:100%;object-fit:cover}
.article-hero .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.15),rgba(15,23,42,.75))}

/* ===== コメント ===== */
.cm-avatars{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:.45rem;padding:.45rem;border:1px solid var(--border);border-radius:.5rem;background:var(--paper);margin-bottom:.7rem}
.cm-av{padding:0;border:2px solid transparent;border-radius:50%;cursor:pointer;background:#fff;overflow:hidden;line-height:0}
.cm-av img{width:100%;aspect-ratio:1;border-radius:50%;display:block}
.cm-av.on{border-color:var(--gold);box-shadow:0 0 0 2px rgba(160,124,52,.3)}
.cm-i{width:100%;padding:.65rem .8rem;border:1px solid var(--border);border-radius:.5rem;margin-bottom:.6rem;font-size:1rem;font-family:inherit;background:#fff}
.cm-i:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(160,124,52,.15)}
.cm-row{display:flex;gap:.7rem;padding:.9rem 0;border-bottom:1px solid var(--border-soft)}
.cm-row>img{width:2.6rem;height:2.6rem;border-radius:50%;flex-shrink:0;background:#fff;border:1px solid var(--border)}
.cm-name{font-weight:700;font-size:.92rem}
.cm-time{font-size:.72rem;color:var(--ink-lighter);margin-left:.3rem}
.cm-text{margin-top:.25rem;line-height:1.7;white-space:pre-wrap;word-break:break-word}

/* ===== 追加ジャンル配色 ===== */
.tag-c-pc     {background:#dbeafe;color:#1d4ed8}
.tag-c-kaden  {background:#cffafe;color:#0e7490}
.tag-c-kuruma {background:#f1f5f9;color:#475569}
.tag-c-pet    {background:#fef3c7;color:#b45309}
.tag-c-garden {background:#dcfce7;color:#15803d}
.tag-c-bousai {background:#fee2e2;color:#dc2626}
.tag-c-manner {background:#e0e7ff;color:#4338ca}
.tag-c-fashion{background:#fce7f3;color:#be185d}

/* ===== ジャンル横スライダー ===== */
.genre-slider-wrap{position:relative}
.genre-scroll{display:flex;gap:.6rem;overflow-x:auto;scroll-behavior:smooth;padding:.2rem .1rem .25rem;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.genre-scroll::-webkit-scrollbar{display:none}
.genre-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:9999px}
.genre-scroll .gtile{flex:0 0 auto;width:174px}
.genre-nav{position:absolute;top:calc(50% - .35rem);transform:translateY(-50%);z-index:3;width:2.5rem;height:2.5rem;border-radius:50%;border:1px solid var(--border);background:#fff;box-shadow:0 2px 10px rgba(15,23,42,.2);cursor:pointer;font-size:1.6rem;line-height:1;color:var(--ink);display:flex;align-items:center;justify-content:center;padding:0}
.genre-nav.prev{left:-.7rem}.genre-nav.next{right:-.7rem}
.genre-nav:hover{background:var(--gold);color:#fff;border-color:var(--gold)}
@media(max-width:640px){.genre-nav{display:none}}

/* ===== 追加ジャンル配色（第2弾） ===== */
.tag-c-ryokou {background:#e0f2fe;color:#0369a1}
.tag-c-supotsu{background:#dcfce7;color:#15803d}
.tag-c-tezukuri{background:#f3e8ff;color:#7c3aed}
.tag-c-manabi {background:#e0e7ff;color:#4338ca}
.tag-c-eco    {background:#d1fae5;color:#047857}
.tag-c-kaigo  {background:#ccfbf1;color:#0d7d72}
.tag-c-hoken  {background:#f1f5f9;color:#475569}
.tag-c-hikkoshi{background:#fef3c7;color:#b45309}
.tag-c-souji  {background:#cffafe;color:#0e7490}

/* ===== サイドバー共通（トップ以外でも使う）＋記事ページ2カラム ===== */
.side-card{background:var(--surface);border:1px solid var(--border);border-radius:.6rem;overflow:hidden;margin-bottom:1rem}
.side-head{padding:.6rem .85rem;border-bottom:1px solid var(--border-soft);background:var(--paper);font-weight:700;font-size:.95rem}
.cat-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem .85rem;border-bottom:1px solid var(--border-soft);text-decoration:none;color:var(--ink);font-weight:600}
.cat-row:last-child{border-bottom:none}.cat-row:hover{background:var(--paper);color:var(--gold-dark)}
.cat-row .n{font-size:.8rem;color:var(--ink-light);font-weight:500}
.article-layout{display:grid;grid-template-columns:1fr;gap:1.5rem}
.article-aside{display:none}
@media(min-width:1100px){.article-layout{grid-template-columns:215px minmax(0,1fr)}.article-aside{display:block}}

/* ===== モバイル対応 ===== */
.mnav{white-space:nowrap;font-size:.85rem;padding:.35rem .8rem;border-radius:9999px;background:var(--paper);color:var(--ink);font-weight:600;flex:0 0 auto;text-decoration:none}
.mnav:hover{background:var(--gold);color:#fff}
.site-header nav::-webkit-scrollbar{display:none}
@media(max-width:480px){
  .logo-sub{display:none}
  .logo-text{font-size:1.05rem}
  .site-header .bar{gap:.5rem;height:3.3rem}
  .site-header .bar input[type=search]{width:7.5rem !important}
}
@media(max-width:640px){
  .genre-band h1{font-size:1.18rem !important}
  .bbs-row{padding:.6rem .6rem;gap:.6rem}
  .bbs-title{font-size:.95rem}
}

/* ===== 記事＋掲示板 2カラム（記事を読みながら掲示板も見られる） ===== */
.art-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:1000px){.art-grid{grid-template-columns:minmax(0,1fr) 360px}}
.bbs-col{min-width:0}
@media(min-width:1000px){.bbs-col{position:sticky;top:.7rem;align-self:start;max-height:calc(100vh - 1.4rem);overflow-y:auto}}
.bbs-thread{background:var(--surface);border:1px solid var(--border);border-radius:.6rem;overflow:hidden}
.bbs-thread-head{background:var(--ink);color:#fff;padding:.5rem .8rem;font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:.4rem}
.res{padding:.55rem .8rem;border-bottom:1px solid var(--border-soft)}
.res:nth-child(even){background:var(--paper)}
.res-head{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;font-size:.75rem;margin-bottom:.25rem}
.res-no{font-family:var(--font-en);font-weight:800;color:#15803d}
.res-av{width:1.4rem;height:1.4rem;border-radius:50%;background:#fff;flex-shrink:0}
.res-name{font-weight:700;color:#1f7a3d}
.res-date{color:var(--ink-light)}
.res-body{font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-break:break-word}
.bbs-write{padding:.8rem;border-top:2px solid var(--border)}
.bbs-empty{padding:1.3rem .8rem;color:var(--ink-light);font-size:.85rem}

/* ===== BBS行をコンパクトに（バッジを下段にまとめ・タイトル1行・サムネ小） ===== */
.bbs-row{padding:.5rem .7rem !important;gap:.6rem !important}
.bbs-thumb{width:50px !important;height:50px !important}
.bbs-title{font-size:.98rem !important;line-height:1.35 !important;-webkit-line-clamp:1 !important}
.bbs-meta{margin-top:.2rem !important;gap:.45rem !important;font-size:.76rem !important}
.bbs-no{width:1.4rem !important;font-size:1rem !important}

/* ===== トップの検索システム（スライダー下・全幅） ===== */
.home-search{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:.7rem;padding:.6rem;box-shadow:var(--shadow-card)}
.home-search input[type=search]{flex:1 1 280px;min-width:0;padding:.75rem 1rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem;background:#fff}
.home-search input[type=search]:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(160,124,52,.15)}
.home-search select{padding:.75rem .8rem;border:1px solid var(--border);border-radius:.5rem;background:#fff;font-size:.92rem}
.home-search .btn{padding:.75rem 1.6rem;font-size:1rem}
@media(max-width:640px){.home-search select{flex:1 1 46%}.home-search .btn{flex:1 1 100%}}

/* ===== ヘッダーのシェアボタン ===== */
.hdr-share{display:flex;gap:.35rem;align-items:center;flex-shrink:0}
.sbtn{display:inline-flex;align-items:center;justify-content:center;min-width:1.95rem;height:1.95rem;padding:0 .55rem;border:none;border-radius:.45rem;color:#fff;font-size:.78rem;font-weight:700;cursor:pointer;line-height:1;text-decoration:none}
.sbtn:hover{opacity:.85}
@media(max-width:420px){.hdr-share .sbtn{min-width:1.8rem;height:1.8rem;padding:0 .4rem;font-size:.72rem}}

/* ===== SNSアイコン(SVG)サイズ ===== */
.sbtn svg{width:1.05rem;height:1.05rem;display:block}

/* ===== 追加ジャンル配色（第3弾・20色） ===== */
.tag-c-bigaku{background:#fce7f3;color:#be185d}
.tag-c-diet{background:#dcfce7;color:#15803d}
.tag-c-renai{background:#ffe4e6;color:#e11d48}
.tag-c-shukatsu{background:#e0e7ff;color:#4338ca}
.tag-c-toushi{background:#d1fae5;color:#047857}
.tag-c-camp{background:#dcfce7;color:#166534}
.tag-c-game{background:#ede9fe;color:#6d28d9}
.tag-c-eiga{background:#f1f5f9;color:#334155}
.tag-c-ongaku{background:#fae8ff;color:#a21caf}
.tag-c-camera{background:#e0f2fe;color:#0369a1}
.tag-c-gengo{background:#fef3c7;color:#b45309}
.tag-c-sake{background:#fee2e2;color:#b91c1c}
.tag-c-cafe{background:#f5ede1;color:#92400e}
.tag-c-mental{background:#ccfbf1;color:#0d7d72}
.tag-c-shukan{background:#fef9c3;color:#a16207}
.tag-c-app{background:#dbeafe;color:#1d4ed8}
.tag-c-bouhan{background:#fee2e2;color:#dc2626}
.tag-c-interia{background:#f5f5f4;color:#57534e}
.tag-c-tsuhan{background:#ffedd5;color:#c2410c}
.tag-c-tetsuduki{background:#e2e8f0;color:#475569}

/* 記事ヒーロー：タイトルを画像に重ねる（自動高さ） */
.article-hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.article-hero .hero-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.18),rgba(15,23,42,.78))}
.hero-content{position:relative;z-index:1;width:100%;padding-top:2.6rem;padding-bottom:1.4rem}
@media(max-width:640px){.hero-content{padding-top:1.6rem}.article-hero{min-height:160px}}

/* ジャンルのグループ見出し（左サイド） */
.cat-group{font-size:.74rem;font-weight:800;color:var(--gold-dark);background:var(--gold-muted);padding:.4rem .85rem;border-bottom:1px solid var(--border-soft);border-top:1px solid var(--border)}
.cat-group:first-of-type{border-top:none}
