/* ==========================================================================
   kurashi-help child theme — category / single components
   トークンは本番TOP（kh-global-css）の :root と同一。子テーマ側でも定義して自立させる
   ========================================================================== */
:root{
  --navy-900:#0f1c33;
  --navy-800:#132548;
  --navy-700:#16305a;
  --navy-600:#1c3d70;
  --blue-500:#2f7dfa;
  --blue-400:#5b9bff;
  --blue-50:#eef5ff;
  --amber-500:#f59e0b;
  --amber-50:#fff8ec;
  --red-500:#ef4444;
  --green-500:#10b981;           /* 追加: 「自分で直せる」 */
  --green-50:#ecfdf5;
  --ink-900:#171b24;
  --ink-600:#4b5563;
  --ink-400:#8a93a3;
  --line:#e6e9ef;
  --bg:#f6f7fa;
  --white:#ffffff;
  --radius-lg:20px;
  --radius-md:14px;
  --radius-sm:10px;
  --shadow-card:0 1px 2px rgba(15,28,51,.04), 0 8px 24px rgba(15,28,51,.06);
  --line-dark:rgba(138,147,163,.22);
  --grid-dark:rgba(47,125,250,.06);
  --font-head:"Noto Sans JP",-apple-system,system-ui,sans-serif;
}

/* ---------- ページ上部ダーク帯（カテゴリ/記事 共通） ---------- */
.khc-page-head{background:var(--navy-900);color:#fff;position:relative;overflow:hidden;left:50%;width:100vw;transform:translateX(-50%)}
.khc-page-head::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--grid-dark) 1px,transparent 1px),linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px);
  background-size:48px 48px}
.khc-page-head .khc-head-inner{position:relative;max-width:1600px;margin:0 auto;padding:32px 32px 40px}
.khc-crumb{font-size:12px;color:var(--ink-400);margin-bottom:20px}
.khc-crumb a{color:var(--ink-400)}
.khc-crumb a:hover{color:var(--blue-400)}
.khc-eyebrow{font-size:12px;font-weight:700;letter-spacing:.35em;color:var(--blue-400);margin-bottom:10px}

/* ---------- ファクトバー（TOPのスタッツ行と同スタイル） ---------- */
.khc-facts{display:flex;margin-top:24px;background:rgba(19,37,72,.6);border:1px solid var(--line-dark);border-radius:var(--radius-md);overflow:hidden;max-width:720px}
.khc-facts>div{flex:1;text-align:center;padding:15px 8px;border-right:1px solid var(--line-dark)}
.khc-facts>div:last-child{border-right:0}
.khc-facts .v{font-size:20px;font-weight:800;color:#fff;font-family:var(--font-head)}
.khc-facts .v small{font-size:12px;color:var(--blue-400);font-weight:700;margin-left:2px}
.khc-facts .v.self{color:var(--green-500);font-size:15px}
.khc-facts .v.pro{color:var(--amber-500);font-size:15px}
.khc-facts .k{font-size:11px;color:var(--ink-400);margin-top:2px}


.khc-layout{position:relative;left:50%;width:100vw;transform:translateX(-50%);box-sizing:border-box;padding-left:max(24px,calc((100vw - 1600px) / 2));padding-right:max(24px,calc((100vw - 1600px) / 2));padding-top:32px;padding-bottom:72px;display:grid;grid-template-columns:1fr 320px;gap:40px;align-items:start}
.khc-main{min-width:0}
.khc-aside{min-width:0;position:sticky;top:24px}
.admin-bar .khc-aside{top:56px}

/* ==========================================================================
   カテゴリページ
   ========================================================================== */
.khc-cat-hero{display:flex;gap:22px;align-items:center}
.khc-cat-hero .khc-chip{width:72px;height:72px;border-radius:var(--radius-lg);background:rgba(47,125,250,.15);border:1px solid rgba(91,155,255,.35);display:flex;align-items:center;justify-content:center;font-size:34px;flex-shrink:0}
.khc-cat-hero h1{font-family:var(--font-head);font-size:clamp(26px,3.6vw,36px);font-weight:900;line-height:1.4;color:#fff;margin:0}
.khc-cat-hero p{font-size:14px;color:var(--ink-400);margin:8px 0 0;max-width:640px}
.khc-cat-stats{display:flex;margin-top:28px;background:rgba(19,37,72,.6);border:1px solid var(--line-dark);border-radius:var(--radius-md);overflow:hidden;max-width:640px}
.khc-cat-stats>div{flex:1;text-align:center;padding:16px 10px;border-right:1px solid var(--line-dark)}
.khc-cat-stats>div:last-child{border-right:0}
.khc-cat-stats .v{font-size:24px;font-weight:800;color:#fff;font-family:var(--font-head)}
.khc-cat-stats .v small{font-size:13px;color:var(--blue-400);font-weight:700;margin-left:1px}
.khc-cat-stats .k{font-size:11px;color:var(--ink-400);margin-top:2px}

.khc-filter-label{font-size:11px;font-weight:700;letter-spacing:.2em;color:var(--ink-600);margin:18px 0 8px}
.khc-filterbar{display:flex;gap:8px;flex-wrap:wrap;font-size:13px;font-weight:700}
.khc-filterbar a{background:#fff;border:1px solid var(--line);color:var(--ink-600);border-radius:999px;padding:8px 18px;transition:.15s;text-decoration:none}
.khc-filterbar a:hover{border-color:var(--blue-500);color:var(--blue-500)}
.khc-filterbar a.is-on{background:var(--navy-900);border-color:var(--navy-900);color:#fff}
.khc-filterbar a.is-hot{color:var(--red-500)}
.khc-filterbar a.is-hot.is-on{background:var(--red-500);border-color:var(--red-500);color:#fff}
.khc-result-count{font-size:13px;color:var(--ink-600);margin:22px 0 14px}
.khc-result-count b{color:var(--ink-900)}

/* 記事リストカード */
.khc-arow{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);display:flex;gap:20px;padding:16px;margin-bottom:14px;align-items:center;transition:.18s;text-decoration:none;color:inherit}
.khc-arow:hover{box-shadow:var(--shadow-card);transform:translateY(-2px);border-color:#cdd4df}
.khc-arow .khc-thumb{width:200px;aspect-ratio:16/10;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--navy-800),var(--navy-600));flex-shrink:0;position:relative;overflow:hidden}
.khc-arow .khc-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.khc-urgency{position:absolute;left:10px;top:10px;font-size:10px;font-weight:700;border-radius:999px;padding:3px 10px;color:#fff;z-index:1}
.khc-urgency.lv3{background:var(--red-500)}
.khc-urgency.lv2{background:var(--amber-500)}
.khc-urgency.lv1{background:var(--ink-600)}
.khc-arow .khc-arow-in{flex:1;min-width:0}
.khc-arow h3{font-family:var(--font-head);font-size:16px;font-weight:700;line-height:1.6;margin:0}
.khc-arow:hover h3{color:var(--blue-500)}
.khc-arow p{font-size:13px;color:var(--ink-600);margin:6px 0 0}
.khc-badges{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;font-size:11px;font-weight:700}
.khc-badge-self{color:var(--green-500);border:1.5px solid var(--green-500);border-radius:999px;padding:3px 12px;background:var(--green-50)}
.khc-badge-pro{color:#fff;background:var(--red-500);border-radius:999px;padding:4px 13px}
.khc-badge-meta{color:var(--ink-600);background:var(--bg);border-radius:999px;padding:4px 13px}
.khc-badge-meta b{color:var(--ink-900)}
.khc-arow .khc-arr{width:38px;height:38px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--ink-600);flex-shrink:0;transition:.18s}
.khc-arow:hover .khc-arr{background:var(--blue-500);color:#fff}

/* ページネーション（GP出力をkh化） */
.khc-layout .nav-links{display:flex;gap:8px;justify-content:center;margin-top:36px;font-weight:700;font-size:14px}
.khc-layout .nav-links .page-numbers{width:42px;height:42px;border-radius:var(--radius-sm);background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-600);text-decoration:none}
.khc-layout .nav-links .page-numbers.current{background:var(--navy-900);border-color:var(--navy-900);color:#fff}
.khc-layout .nav-links .page-numbers:hover:not(.current){border-color:var(--blue-500);color:var(--blue-500)}

/* ==========================================================================
   記事ページ
   ========================================================================== */
.khc-cat-chip{display:inline-flex;gap:8px;font-size:12px;font-weight:700;margin-bottom:14px;flex-wrap:wrap}
.khc-cat-chip span{background:rgba(47,125,250,.15);border:1px solid rgba(91,155,255,.35);color:var(--blue-400);border-radius:999px;padding:5px 16px}
.khc-cat-chip span.lv{background:rgba(138,147,163,.12);border-color:rgba(138,147,163,.35);color:var(--ink-400)}
.khc-page-head h1.khc-title{font-family:var(--font-head);font-size:clamp(24px,3.2vw,34px);font-weight:900;line-height:1.55;max-width:960px;color:#fff;margin:0}
.khc-byline{display:flex;gap:18px;align-items:center;font-size:12px;color:var(--ink-400);margin-top:16px;flex-wrap:wrap}

article.khc-post{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);padding:44px 52px;min-width:0}
.khc-pr-note{font-size:11.5px;color:var(--ink-600);background:var(--bg);border-radius:8px;padding:8px 14px;margin-bottom:24px}

/* 本文タイポグラフィ */
.khc-post .entry-content{font-size:16px;line-height:2;color:#1f2733}
.khc-post .entry-content p{margin-bottom:20px}
.khc-post .entry-content b,.khc-post .entry-content strong{background:linear-gradient(transparent 65%,rgba(91,155,255,.35) 65%)}
.khc-post .entry-content h2{font-family:var(--font-head);font-size:24px;font-weight:900;margin:52px 0 18px;display:flex;align-items:center;gap:12px;line-height:1.5;border:0;padding:0}
.khc-post .entry-content h2::before{content:"";width:6px;height:26px;border-radius:3px;background:linear-gradient(180deg,var(--blue-500),var(--blue-400));flex-shrink:0}
.khc-post .entry-content h3{font-family:var(--font-head);font-size:17px;font-weight:900;margin:32px 0 12px;padding-left:14px;border-left:3px solid var(--line);line-height:1.5}
.khc-post .entry-content table{width:100%;border-collapse:collapse;font-size:13.5px;margin:16px 0 24px}
.khc-post .entry-content th{background:var(--navy-800);color:#fff;font-weight:700;padding:10px 14px;text-align:left;border:0}
.khc-post .entry-content td{border:1px solid var(--line);padding:10px 14px;background:#fff}
.khc-post .entry-content tr:nth-child(even) td{background:#fafbfd}
.khc-post .entry-content img{border-radius:var(--radius-sm)}

/* 応急処置ボックス */
.khc-firstaid{border:1.5px solid rgba(245,158,11,.55);background:var(--amber-50);border-radius:var(--radius-md);overflow:hidden;margin:32px 0}
.khc-firstaid .khc-h{background:linear-gradient(135deg,#f97316,var(--amber-500));color:#fff;font-weight:900;padding:13px 22px;font-size:15px}
.khc-firstaid .khc-b{padding:20px 24px;font-size:14px}
.khc-firstaid ol{padding-left:22px;margin:0}
.khc-firstaid li{margin-bottom:10px}
.khc-firstaid li:last-child{margin-bottom:0}
.khc-firstaid b,.khc-firstaid strong{color:#b45309;background:none}

/* ステップ（TOPのHOW TO USE数字円の縦展開） */
.khc-steps{counter-reset:st;margin:10px 0}
.khc-step{display:flex;gap:20px;position:relative;padding-bottom:30px}
.khc-step::before{counter-increment:st;content:counter(st);width:46px;height:46px;border-radius:50%;background:var(--navy-800);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;flex-shrink:0;position:relative;z-index:1;border:3px solid #fff;box-shadow:0 0 0 1.5px var(--line);font-family:var(--font-head)}
.khc-step:first-child::before{background:linear-gradient(135deg,var(--blue-500),var(--blue-400));box-shadow:0 6px 16px rgba(47,125,250,.35)}
.khc-step::after{content:"";position:absolute;left:22px;top:46px;bottom:0;width:2px;background:linear-gradient(180deg,var(--blue-400),var(--line))}
.khc-step:last-child::after{display:none}
.khc-step:last-child{padding-bottom:0}
.khc-step .khc-in{padding-top:2px;flex:1;min-width:0}
.khc-step h4{font-family:var(--font-head);font-size:16px;font-weight:900;margin:0}
.khc-step p{font-size:14px;color:#333c49;margin:6px 0 0}
.khc-tip,.khc-warn{margin-top:12px;font-size:12.5px;border-radius:var(--radius-sm);padding:9px 14px;display:inline-block}
.khc-tip{background:var(--green-50);border:1px solid rgba(16,185,129,.3);color:#047857}
.khc-tip::before{content:"POINT";font-weight:800;letter-spacing:.15em;font-size:10px;color:var(--green-500);margin-right:10px}
.khc-warn{background:var(--amber-50);border:1px solid rgba(245,158,11,.4);color:#b45309}
.khc-warn::before{content:"注意";font-weight:900;font-size:11px;margin-right:10px}

/* 商品カード（Amazon/楽天） */
.khc-item{border:1px solid var(--line);border-radius:var(--radius-md);display:flex;gap:20px;padding:20px;margin:18px 0;background:#fff;transition:.18s}
.khc-item:hover{box-shadow:var(--shadow-card)}
.khc-item .khc-ph{width:120px;height:120px;border-radius:var(--radius-sm);background:var(--bg);flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden}
.khc-item .khc-ph img{width:100%;height:100%;object-fit:contain}
.khc-item .khc-in{flex:1;min-width:0}
.khc-item .khc-lbl{font-size:10.5px;font-weight:700;color:var(--blue-500);letter-spacing:.1em;margin-bottom:2px}
.khc-item h4{font-family:var(--font-head);font-size:14.5px;font-weight:700;line-height:1.6;margin:0}
.khc-item .khc-price{font-weight:800;font-size:20px;margin:4px 0;font-family:var(--font-head)}
.khc-item .khc-price small{font-size:11px;color:var(--ink-600);font-weight:500;margin-left:6px}
.khc-item p{font-size:12.5px;color:var(--ink-600);margin:0 0 12px}
.khc-item .khc-btns{display:flex;gap:10px;flex-wrap:wrap}
.khc-btn-amz{display:inline-flex;align-items:center;background:linear-gradient(180deg,#ffd814,#f7ca00);color:#0f1111!important;border:1px solid #fcd200;border-radius:999px;padding:9px 22px;font-size:12.5px;font-weight:700;text-decoration:none}
.khc-btn-rkt{display:inline-flex;align-items:center;background:#bf0000;color:#fff!important;border-radius:999px;padding:9px 22px;font-size:12.5px;font-weight:700;text-decoration:none}
.khc-item strong,.khc-item b{background:none}

/* 業者判断ボックス */
.khc-judge{background:var(--bg);border:1.5px dashed #cdd4df;border-radius:var(--radius-md);padding:26px 28px;margin:40px 0 0}
.khc-judge h3{font-family:var(--font-head);font-size:17px;font-weight:900;margin:0 0 14px;padding:0;border:0}
.khc-judge ul{list-style:none;margin:0;padding:0}
.khc-judge li{font-size:14px;padding:9px 0;border-bottom:1px solid var(--line);display:flex;gap:10px}
.khc-judge li:last-child{border-bottom:0}
.khc-judge li::before{content:"⚠";color:var(--red-500);flex-shrink:0}

/* 業者CTA（記事末） */
.khc-pro-cta{background:var(--navy-900);border-radius:var(--radius-md);color:#fff;padding:36px;text-align:center;margin-top:32px;position:relative;overflow:hidden}
.khc-pro-cta::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--grid-dark) 1px,transparent 1px),linear-gradient(90deg,var(--grid-dark) 1px,transparent 1px);background-size:40px 40px}
.khc-pro-cta>*{position:relative}
.khc-status{display:inline-flex;align-items:center;gap:8px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.35);color:var(--green-500);border-radius:999px;padding:6px 16px;font-size:11.5px;font-weight:700;margin-bottom:14px}
.khc-status::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green-500);box-shadow:0 0 10px var(--green-500)}
.khc-pro-cta h3{font-family:var(--font-head);font-size:21px;font-weight:900;margin:0;color:#fff;border:0;padding:0}
.khc-range{margin:16px auto 20px;display:inline-flex;background:rgba(19,37,72,.7);border:1px solid var(--line-dark);border-radius:var(--radius-sm);overflow:hidden}
.khc-range>div{padding:12px 24px;border-right:1px solid var(--line-dark)}
.khc-range>div:last-child{border-right:0}
.khc-range .k{font-size:10.5px;color:var(--ink-400)}
.khc-range .v{font-size:17px;font-weight:800;color:var(--blue-400);font-family:var(--font-head)}
.khc-pro-cta .khc-small{font-size:11px;color:var(--ink-400);margin-top:12px}
.khc-btn-blue{display:inline-block;background:linear-gradient(135deg,var(--blue-500),var(--blue-400));color:#fff!important;border:0;border-radius:var(--radius-md);padding:16px 40px;font-size:15px;font-weight:900;cursor:pointer;box-shadow:0 10px 30px rgba(47,125,250,.35);transition:.15s;text-decoration:none;font-family:var(--font-head)}
.khc-btn-blue:hover{transform:translateY(-2px)}

/* FAQ */
.khc-faq{border:1px solid var(--line);border-radius:var(--radius-md);overflow:hidden;margin-top:8px}
.khc-faq details{border-bottom:1px solid var(--line)}
.khc-faq details:last-child{border-bottom:0}
.khc-faq summary{padding:16px 20px;font-size:14.5px;font-weight:700;cursor:pointer;display:flex;gap:12px;list-style:none}
.khc-faq summary::-webkit-details-marker{display:none}
.khc-faq summary::before{content:"Q";font-weight:800;color:var(--blue-500);flex-shrink:0}
.khc-faq .khc-a{padding:0 20px 18px 44px;font-size:14px;color:#333c49}

/* サイドバー */
.khc-aside .khc-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);margin-bottom:20px;overflow:hidden}
.khc-aside .khc-box .khc-h{padding:14px 18px;font-size:12px;font-weight:800;letter-spacing:.25em;color:var(--blue-500);border-bottom:1px solid var(--line)}
.khc-aside .khc-box ul{list-style:none;padding:6px 18px;margin:0}
.khc-aside .khc-box li{font-size:13px;padding:11px 0;border-bottom:1px solid var(--bg)}
.khc-aside .khc-box li:last-child{border-bottom:0}
.khc-aside .khc-box li a{text-decoration:none;color:var(--ink-600)}
.khc-aside .khc-box li a:hover{color:var(--blue-500)}
#khc-toc li.khc-now{border-left:3px solid var(--blue-500);padding-left:12px;margin-left:-2px}
#khc-toc li.khc-now a{color:var(--ink-900);font-weight:700}
.khc-aside .khc-rank li{display:flex;gap:12px;align-items:baseline}
.khc-aside .khc-rank .no{font-weight:800;color:var(--blue-500);font-size:15px;flex-shrink:0;font-family:var(--font-head)}
.khc-mini-cta{background:var(--navy-900);color:#fff;text-align:center;padding:26px 20px;border-radius:var(--radius-md);margin-bottom:20px}
.khc-mini-cta .khc-cat-tag{display:inline-block;font-size:10.5px;font-weight:700;border-radius:999px;padding:4px 14px;margin-bottom:10px;background:rgba(91,155,255,.15);border:1px solid rgba(91,155,255,.4);color:var(--blue-400)}
.khc-mini-cta .khc-t{font-family:var(--font-head);font-weight:900;font-size:15px;line-height:1.65}
.khc-mini-cta p{font-size:11.5px;color:var(--ink-400);margin:10px 0 14px}
.khc-mini-cta .khc-btn-blue{padding:12px 24px;font-size:13px;border-radius:11px}

/* 関連記事 */
.khc-related{margin-top:44px}
.khc-related .khc-rt{font-size:12px;font-weight:800;letter-spacing:.3em;color:var(--blue-500);margin-bottom:6px}
.khc-related h2{font-family:var(--font-head);font-size:22px;font-weight:900;margin:0 0 20px}
.khc-rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.khc-rel-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);overflow:hidden;transition:.18s;text-decoration:none;color:inherit}
.khc-rel-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}
.khc-rel-card .khc-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--navy-800),var(--navy-600));overflow:hidden}
.khc-rel-card .khc-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.khc-rel-card .khc-in{padding:14px 16px}
.khc-rel-card h3{font-family:var(--font-head);font-size:13.5px;font-weight:700;line-height:1.6;margin:0}
.khc-rel-card .khc-m{margin-top:10px;font-size:11px;color:var(--ink-600)}

/* レスポンシブ */
@media(max-width:900px){
  .khc-layout{grid-template-columns:1fr}
  .khc-aside{position:static}
  .khc-rel-grid{grid-template-columns:1fr}
  article.khc-post{padding:26px 20px}
  .khc-facts,.khc-cat-stats{flex-wrap:wrap}
  .khc-facts>div,.khc-cat-stats>div{flex:1 1 40%;border-bottom:1px solid var(--line-dark)}
  .khc-item{flex-direction:column}
  .khc-range{flex-direction:column}
  .khc-range>div{border-right:0;border-bottom:1px solid var(--line-dark)}
}
@media(max-width:600px){
  .khc-arow{flex-direction:column;align-items:stretch}
  .khc-arow .khc-thumb{width:100%}
  .khc-arow .khc-arr{display:none}
  .khc-cat-hero{flex-direction:column;align-items:flex-start}
}

body.single .site-main,body.category .site-main{max-width:none}