/* ==========================================================================
   main.css — 共通スタイル＋LPスタイル
   既存LP（LP_WordPress用.html）の<style>を移植・整理。クラス名は既存LP準拠。
   トークンは tokens.css に定義済み（enqueueで tokens→main の順に読み込む）。
   ========================================================================== */

/* ==========================================================================
   1. リセット・ベース
   ========================================================================== */
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:var(--font-base);
  color:var(--text);line-height:1.9;background:var(--bg);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--sp-5)}
img{max-width:100%;height:auto;display:block}
a{color:var(--gold-d)}

/* アクセシビリティ：フォーカスリング可視化 */
a:focus-visible,button:focus-visible,summary:focus-visible{
  outline:3px solid var(--gp-blue);outline-offset:2px;border-radius:4px;
}
/* スクリーンリーダー専用テキスト */
.screen-reader-text{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
/* スキップリンク */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:1000;background:#fff;
  color:var(--ink);padding:10px 16px;border-radius:0 0 var(--r-sm) 0;
}
.skip-link:focus{left:0}

/* ==========================================================================
   2. 共通パーツ（eyebrow / 見出し / lead / accent）
   ========================================================================== */
.eyebrow{
  display:inline-block;color:var(--gold-d);font-weight:800;letter-spacing:.16em;
  font-size:.74rem;margin-bottom:10px;text-transform:uppercase;
}
.eyebrow:before{
  content:"";display:inline-block;width:22px;height:2px;background:var(--gold);
  vertical-align:middle;margin-right:8px;margin-bottom:4px;
}
h2.t{font-size:var(--fs-h2);color:var(--ink);font-weight:900;line-height:1.4;letter-spacing:.01em}
.lead{font-size:var(--fs-lead);color:var(--text);margin-top:16px}
.accent{color:var(--gold-d);font-weight:800}
.center{text-align:center}
.secthead{text-align:center;margin-bottom:46px}

/* プレースホルダ（要確認事項の視覚マーク） */
.ph{
  background:rgba(168,127,37,.12);border:1px dashed var(--gold);color:var(--gold-d);
  border-radius:var(--r-sm);padding:3px 8px;font-size:.78rem;font-weight:700;display:inline-block;
}

/* ==========================================================================
   3. CTA（Primary：greenグラデ＋pill＋アイコン）
   ========================================================================== */
.cta{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,var(--green-l),var(--green));
  color:#fff;font-weight:800;font-size:1.1rem;padding:16px 40px;border-radius:var(--r-pill);
  text-decoration:none;box-shadow:var(--sh-cta);transition:.2s;
}
.cta:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(44,150,80,.46)}
.cta svg{width:19px;height:19px}
.cta-note{display:block;font-size:.84rem;color:var(--muted);margin-top:11px}

/* ==========================================================================
   4. グローバルヘッダー（サイト共通）
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:50;background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-header-in{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:12px 0;
}
.site-logo a{
  display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:900;
  font-size:1.15rem;text-decoration:none;letter-spacing:.01em;
}
.site-logo .logo-dot{width:12px;height:12px;border-radius:50%;background:var(--green-l);display:inline-block}

/* PCナビ */
.primary-nav{display:flex;align-items:center;gap:6px}
.primary-nav ul{list-style:none;display:flex;gap:4px;margin:0;padding:0}
.primary-nav a{
  display:block;color:#cdd9ea;text-decoration:none;font-weight:700;font-size:.92rem;
  padding:8px 12px;border-radius:var(--r-sm);transition:.2s;
}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:#fff;background:rgba(255,255,255,.08)}

/* ヘッダー右のミニCTA */
.header-cta{
  display:inline-flex;align-items:center;gap:7px;
  background:linear-gradient(135deg,var(--green-l),var(--green));
  color:#fff;font-weight:800;font-size:.9rem;padding:9px 18px;border-radius:var(--r-pill);
  text-decoration:none;box-shadow:0 6px 16px rgba(44,150,80,.3);transition:.2s;white-space:nowrap;
}
.header-cta:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(44,150,80,.42)}
.header-cta svg{width:15px;height:15px}

/* SPハンバーガー（CSSのみのトグル：チェックボックスハック） */
.nav-toggle{display:none}
.nav-toggle-label{display:none;cursor:pointer;padding:8px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14)}
.nav-toggle-label span,.nav-toggle-label span:before,.nav-toggle-label span:after{
  display:block;width:22px;height:2px;background:#fff;border-radius:2px;position:relative;
}
.nav-toggle-label span:before,.nav-toggle-label span:after{content:"";position:absolute}
.nav-toggle-label span:before{top:-7px}
.nav-toggle-label span:after{top:7px}

/* ==========================================================================
   5. 信頼ストリップ（theme_mod数値を出力・ヘッダー直下常設）
   ========================================================================== */
.stats{background:#fff;border-bottom:1px solid var(--line)}
.stats-in{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;padding:22px 0}
.stats .n{font-size:1.5rem;font-weight:900;color:var(--ink);line-height:1.2}
.stats .n .star{color:var(--gold)}
.stats .l{font-size:.8rem;color:var(--muted)}
.stats .col+.col{border-left:1px solid var(--line)}

/* ==========================================================================
   6. HERO
   ========================================================================== */
.hero{
  position:relative;color:#fff;overflow:hidden;
  background:
    radial-gradient(900px 560px at 88% -12%,rgba(66,133,244,.26),transparent 62%),
    radial-gradient(680px 500px at 2% 112%,rgba(52,168,90,.18),transparent 58%),
    radial-gradient(520px 520px at 62% 46%,rgba(168,127,37,.12),transparent 60%),
    linear-gradient(158deg,#081120,#0c2040 60%,#091a31);
}
/* うっすら光の格子ドット */
.hero:after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.055) 1.2px,transparent 1.2px);
  background-size:26px 26px;opacity:.55;pointer-events:none;
}
/* 上端の柔らかいハイライト（奥行き） */
.hero:before{
  content:"";position:absolute;left:0;right:0;top:0;height:220px;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.06),transparent);
}
.dot{position:absolute;border-radius:50%;filter:blur(.3px);opacity:.9}
.hero-grid{
  position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;
  gap:44px;align-items:center;padding:74px 0;
}
.hero h1{font-size:var(--fs-hero);font-weight:900;line-height:1.4;color:#fff;letter-spacing:.01em}
.hero h1 .g{
  color:var(--gold-l);
  background:linear-gradient(90deg,#f6e4ac,#e4c36b);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.gbadge{
  display:inline-block;background:linear-gradient(135deg,var(--green-l),var(--green));color:#fff;
  padding:2px 14px;border-radius:40px;font-weight:800;
  box-shadow:0 8px 22px rgba(44,150,80,.34);
}
.hero p .gbadge{color:#fff}
.hero p{font-size:var(--fs-lead);color:#cdd9ea;margin:18px 0 24px;line-height:1.85}
.hero p b{color:#fff}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.chips span{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:7px 14px;
  border-radius:30px;font-size:.85rem;font-weight:700;transition:.2s;
}
.chips span:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.28);transform:translateY(-1px)}
.chips .s{color:var(--gold-l)}
/* ヒーローの図（インラインアニメーションSVG） */
.hero-art-wrap{position:relative;z-index:1;display:flex;justify-content:center}
.hero-art{
  width:100%;max-width:470px;height:auto;margin:0 auto;
  filter:drop-shadow(0 26px 46px rgba(0,0,0,.42));
}

/* ==========================================================================
   7. feature 共通（画像＋コピーの2カラム）
   ========================================================================== */
section{padding:84px 0;position:relative}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.feature.rev .copy{order:2}
.feature.rev .vis{order:1}
.frame{
  border-radius:var(--r-lg);box-shadow:var(--sh-3);border:6px solid #fff;background:#fff;transition:.25s;
}
.frame:hover{transform:translateY(-5px);box-shadow:0 30px 60px rgba(12,27,48,.26)}
.soft-bg{background:var(--soft)}
.pill-line{
  display:inline-flex;align-items:center;gap:8px;background:rgba(44,150,80,.1);color:var(--green);
  font-weight:800;font-size:.92rem;padding:8px 16px;border-radius:30px;margin-top:18px;
}
.pill-line svg{width:18px;height:18px}
.mini{margin-top:18px;color:var(--muted);font-size:.95rem}

/* ==========================================================================
   8. 完走保証（濃色の山場）
   ========================================================================== */
.spotlight{
  color:#fff;
  background:radial-gradient(700px 420px at 80% 10%,rgba(52,168,90,.22),transparent 60%),
    linear-gradient(160deg,#0a1a30,#0c2240);
}
.spotlight .eyebrow{color:var(--gold-on-dark)}
.spotlight h2.t{color:#fff}
.spotlight .lead{color:#cdd9ea}
.spotlight .frame{border-color:rgba(255,255,255,.9)}
.guar{
  display:inline-block;background:var(--green);color:#fff;font-weight:900;font-size:1.05rem;
  padding:8px 22px;border-radius:var(--r-md);margin-top:6px;
}
.checks{list-style:none;margin:20px 0 0}
.checks li{padding:8px 0 8px 32px;position:relative;color:#e7eefb}
.checks li:before{
  content:"";position:absolute;left:0;top:13px;width:18px;height:18px;border-radius:50%;
  background:var(--green);
  -webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="white" d="M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z"/></svg>') center/12px no-repeat;
  mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="white" d="M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z"/></svg>') center/12px no-repeat;
}

/* ==========================================================================
   9. 安全性・差別化（比較カード）
   ========================================================================== */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:860px;margin:0 auto}
.compare-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:24px}
.compare-card.good{border:2px solid var(--green);box-shadow:0 12px 30px rgba(44,150,80,.12)}
.compare-card h3{font-weight:900;font-size:1.08rem;margin-bottom:12px}
.compare-card.good h3{color:var(--green)}
.compare-card.bad h3{color:var(--muted)}
.compare-card ul{list-style:none;font-size:.95rem;line-height:1.6}
.compare-card.good ul{color:var(--text)}
.compare-card.bad ul{color:var(--muted)}
.compare-card li{padding:6px 0}
.lead-narrow{max-width:760px;margin:0 auto 30px}

/* ==========================================================================
   10. 料金
   ========================================================================== */
.pricebox{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--sh-2)}
.base{
  display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;
  border:1.5px solid var(--gold);border-radius:var(--r-md);padding:15px 18px;margin-bottom:16px;background:#fffdf6;
}
.base b{color:var(--gold-d)}
.base .yen{font-size:1.5rem;font-weight:900;color:var(--ink)}
.opt{display:flex;gap:13px;align-items:center;padding:11px 0;border-bottom:1px dashed var(--line)}
.opt:last-child{border:none}
.opt .k{
  min-width:30px;height:30px;border-radius:50%;background:var(--soft);display:flex;align-items:center;
  justify-content:center;font-weight:800;color:var(--gold-d);font-size:.9rem;
}
.opt.rec .k{background:var(--green);color:#fff}
/* B+C など複数文字キーが潰れないよう横方向に余白を確保 */
.opt .k{padding:0 8px;border-radius:16px}
.opt .optyen{margin-left:auto;white-space:nowrap;font-weight:800;color:var(--gold-d);font-size:.95rem}
.recpill{background:var(--green);color:#fff;font-size:.7rem;font-weight:800;padding:1px 8px;border-radius:20px;margin-left:6px}
.choose{background:var(--soft);border-radius:var(--r-md);padding:16px 18px;margin-top:16px;font-size:.92rem;color:var(--text)}
.choose h4{color:var(--gold-d);margin-bottom:6px}
.repeat{text-align:center;margin-top:13px;color:var(--muted);font-size:.9rem}

/* ==========================================================================
   11. FAQ（details・JSゼロ）
   ========================================================================== */
.faq{max-width:760px;margin:34px auto 0}
details{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:18px 22px;margin-bottom:12px;
  box-shadow:var(--sh-1);
}
summary{font-weight:700;color:var(--ink);cursor:pointer;list-style:none;position:relative;padding-right:30px}
summary::-webkit-details-marker{display:none}
summary:before{content:"Q";background:var(--gold);color:#fff;font-size:.74rem;font-weight:800;padding:2px 8px;border-radius:6px;margin-right:10px}
summary:after{content:"+";position:absolute;right:0;top:-2px;font-size:1.5rem;color:var(--green);font-weight:400}
details[open] summary:after{content:"\2013"}
details p{margin-top:13px;color:var(--text);padding-left:34px}

/* ==========================================================================
   12. 最終CTA
   ========================================================================== */
.final{
  position:relative;color:#fff;text-align:center;overflow:hidden;
  background:radial-gradient(700px 400px at 80% 0%,rgba(52,168,90,.25),transparent 60%),
    linear-gradient(135deg,#091422,#0c2240);
}
.final h2{font-size:1.9rem;font-weight:900;color:#fff}
.final p{color:#cdd9ea;margin:12px 0 26px}

/* ==========================================================================
   13. フッター
   ========================================================================== */
.site-footer{background:var(--navy);color:#cdd9ea;padding:48px 0 28px}
.footer-in{display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;margin-bottom:24px}
.footer-brand{max-width:320px}
.footer-brand .fname{color:#fff;font-weight:900;font-size:1.1rem;margin-bottom:8px}
.footer-brand p{font-size:.86rem;color:#9fb0c6;line-height:1.8}
.footer-nav{display:flex;gap:40px;flex-wrap:wrap}
.footer-nav ul{list-style:none;margin:0;padding:0}
.footer-nav li{margin-bottom:8px}
.footer-nav a{color:#cdd9ea;text-decoration:none;font-size:.88rem;transition:.2s}
.footer-nav a:hover{color:#fff;text-decoration:underline}
.footer-title{color:var(--gold-on-dark);font-weight:800;font-size:.8rem;letter-spacing:.08em;margin-bottom:12px;text-transform:uppercase}
/* SNSアイコン行（URL設定時のみ表示） */
.footer-sns{display:flex;gap:14px;align-items:center;margin:4px 0 24px}
.footer-sns-link{
  display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;
  border-radius:50%;background:rgba(255,255,255,.08);color:#cdd9ea;transition:.2s;
}
.footer-sns-link:hover{background:var(--gold-on-dark);color:var(--navy)}
.footer-sns-link svg{width:18px;height:18px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.8rem;color:#9fb0c6}

/* ==========================================================================
   14. SP追従CTAバー（sticky bottom bar）
   ========================================================================== */
.sp-cta-bar{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;
  background:rgba(9,20,34,.96);border-top:1px solid rgba(255,255,255,.12);
  padding:10px 14px;backdrop-filter:blur(6px);
}
.sp-cta-bar .cta{width:100%;justify-content:center;padding:14px 20px;font-size:1.02rem}

/* ==========================================================================
   17. パンくず（表示とBreadcrumbList schemaは一致）
   ========================================================================== */
.breadcrumb{background:#fff;border-bottom:1px solid var(--line);font-size:var(--fs-sm)}
.breadcrumb-list{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:0;padding:12px 0}
.breadcrumb-item{display:inline-flex;align-items:center;color:var(--muted)}
.breadcrumb-item+.breadcrumb-item:before{content:"/";color:var(--line);margin-right:6px}
.breadcrumb-item a{color:var(--gold-d);text-decoration:none}
.breadcrumb-item a:hover{text-decoration:underline}
.breadcrumb-item span[aria-current]{color:var(--muted)}

/* ==========================================================================
   18. 下層ページ共通（page.php / page-price / page-contact / 404）
   ========================================================================== */
.page-wrap{padding:56px 0 72px}
.page-header{margin-bottom:32px}
.page-title{font-size:var(--fs-h2);color:var(--ink);font-weight:900;line-height:1.4;letter-spacing:.01em}
.page-lead{font-size:var(--fs-lead);color:var(--text);margin-top:14px;max-width:760px}

/* 記事・固定ページ本文（可読幅720〜760px） */
.entry-content{max-width:760px;color:var(--text);font-size:var(--fs-body);line-height:1.9}
.entry-content > *+*{margin-top:20px}
.entry-content h2{font-size:var(--fs-h3);color:var(--ink);font-weight:900;line-height:1.4;margin-top:40px;padding-bottom:8px;border-bottom:2px solid var(--line)}
.entry-content h3{font-size:1.15rem;color:var(--ink);font-weight:800;line-height:1.5;margin-top:32px}
.entry-content h4{font-size:1.02rem;color:var(--ink);font-weight:800;margin-top:24px}
.entry-content a{color:var(--gold-d);text-decoration:underline}
.entry-content a:hover{color:var(--gold)}
.entry-content ul,.entry-content ol{padding-left:1.4em}
.entry-content li{margin-top:8px}
.entry-content img{border-radius:var(--r-md);box-shadow:var(--sh-1)}
.entry-content blockquote{
  border-left:4px solid var(--gold);background:var(--soft);
  padding:14px 20px;border-radius:0 var(--r-sm) var(--r-sm) 0;color:var(--text);
}
.entry-content code{background:var(--soft);padding:2px 6px;border-radius:var(--r-sm);font-size:.92em}
.entry-content pre{background:var(--navy);color:#e7eefb;padding:18px;border-radius:var(--r-md);overflow:auto}
.entry-content pre code{background:none;padding:0;color:inherit}
.entry-content table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.entry-content th{background:var(--soft);font-weight:800;color:var(--ink)}
.page-links{margin-top:24px;font-size:var(--fs-sm);color:var(--muted)}
.page-links a{color:var(--gold-d)}

/* ==========================================================================
   19. 共通CTAカード（template-parts/cta）
   ========================================================================== */
.cta-card{
  position:relative;overflow:hidden;color:#fff;text-align:center;margin:56px auto 0;
  max-width:860px;border-radius:var(--r-lg);
  background:radial-gradient(600px 360px at 80% 0%,rgba(52,168,90,.25),transparent 60%),
    linear-gradient(135deg,#091422,#0c2240);
  box-shadow:var(--sh-2);
}
.cta-card-in{position:relative;z-index:1;padding:48px 28px}
.cta-card .eyebrow{color:var(--gold-on-dark)}
.cta-card-title{font-size:1.5rem;font-weight:900;color:#fff;line-height:1.4;margin-bottom:14px}
.cta-card-lead{color:#cdd9ea;font-size:var(--fs-body);max-width:620px;margin:0 auto 24px}
.cta-card-links{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:18px}
.cta-card-links a{color:var(--gold-on-dark);font-weight:700;font-size:var(--fs-sm);text-decoration:none}
.cta-card-links a:hover{text-decoration:underline;color:#fff}

/* ==========================================================================
   20. 料金ページ（page-price）※LPのpriceboxを流用しつつ差分のみ
   ========================================================================== */
.price-plans{max-width:760px;margin:0 auto}
.price-base-note{font-size:var(--fs-sm);color:var(--muted);margin:-6px 0 16px}
.price-opt-amount{margin-left:auto;white-space:nowrap;font-size:.78rem}
.opt > div{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1}
.price-caveat{font-size:var(--fs-sm);color:var(--muted);margin-top:16px;text-align:center}

/* ==========================================================================
   21. お問い合わせ（page-contact）
   ========================================================================== */
.contact-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:32px;max-width:960px}
.contact-subtitle{font-size:var(--fs-h3);color:var(--ink);font-weight:800;margin-bottom:16px}
.contact-form-area .entry-content{max-width:none}
.contact-coconala{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);
  padding:26px;box-shadow:var(--sh-2);text-align:center;align-self:start;
}
.contact-coconala p{color:var(--text);font-size:var(--fs-sm);margin-bottom:18px}
.contact-placeholder{margin-top:8px}

/* Contact Form 7 の最低限の見た目調整（プラグイン未導入でも崩れない範囲） */
.contact-form-area input[type="text"],
.contact-form-area input[type="email"],
.contact-form-area input[type="tel"],
.contact-form-area textarea,
.contact-form-area select{
  width:100%;border:1px solid var(--line);border-radius:var(--r-sm);
  padding:12px 14px;font-family:var(--font-base);font-size:var(--fs-body);
  color:var(--text);background:#fff;margin-top:6px;
}
.contact-form-area textarea{min-height:140px;resize:vertical}
.contact-form-area input:focus,
.contact-form-area textarea:focus,
.contact-form-area select:focus{outline:3px solid var(--gp-blue);outline-offset:1px;border-color:var(--gp-blue)}
.contact-form-area .wpcf7-submit{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:none;
  background:linear-gradient(135deg,var(--green-l),var(--green));
  color:#fff;font-weight:800;font-size:1.05rem;padding:14px 36px;border-radius:var(--r-pill);
  box-shadow:var(--sh-cta);transition:.2s;width:auto;margin-top:10px;
}
.contact-form-area .wpcf7-submit:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(44,150,80,.46)}

/* ==========================================================================
   22. ブログ一覧（home / archive / search）レイアウト
   ========================================================================== */
.blog-wrap{padding:48px 0 72px}
.blog-header{margin-bottom:28px}
.blog-header-search,.no-results-search{margin-top:20px;max-width:480px}
.search-term{color:var(--gold-d)}

/* カテゴリナビ */
.cat-nav{margin-bottom:32px}
.cat-nav-list{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:0;padding:0}
.cat-nav-list a{
  display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);
  color:var(--text);font-weight:700;font-size:var(--fs-sm);padding:8px 16px;border-radius:var(--r-pill);
  text-decoration:none;transition:.2s;
}
.cat-nav-list a:hover,.cat-nav-list a.is-current{background:var(--navy);color:#fff;border-color:var(--navy)}
.cat-nav-list .cat-count{
  background:var(--soft);color:var(--gold-d);font-size:.72rem;font-weight:800;
  min-width:20px;height:20px;border-radius:20px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;
}
.cat-nav-list a:hover .cat-count,.cat-nav-list a.is-current .cat-count{background:rgba(255,255,255,.16);color:#fff}

/* 本文＋サイドバーの2カラム */
.blog-layout{display:grid;grid-template-columns:1fr 300px;gap:44px;align-items:start}
.blog-main{min-width:0}

/* 記事カードのグリッド */
.article-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}

/* 記事カード */
.article-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--sh-1);transition:.2s;display:flex;flex-direction:column;
}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}
.article-card-thumb{display:block;aspect-ratio:16/9;background:var(--soft);overflow:hidden}
.article-card-thumb img{width:100%;height:100%;object-fit:cover}
.article-card-noimg{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,#0c1f38,#13294a)}
.article-card-noimg .logo-dot{width:28px;height:28px;border-radius:50%;background:var(--green-l);display:block}
.article-card-body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.article-card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.article-card-date{color:var(--muted);font-size:var(--fs-xs)}
.article-card-title{font-size:1.08rem;line-height:1.5;font-weight:800;margin:0}
.article-card-title a{color:var(--ink);text-decoration:none}
.article-card-title a:hover{color:var(--gold-d)}
.article-card-excerpt{color:var(--text);font-size:var(--fs-sm);line-height:1.7;margin:0}

/* カテゴリチップ（カード・記事メタ共通） */
.cat-chip{
  display:inline-block;background:var(--soft);color:var(--gold-d);font-weight:800;
  font-size:var(--fs-xs);padding:3px 12px;border-radius:var(--r-pill);text-decoration:none;
}
.cat-chip:hover{background:var(--navy);color:#fff}

.no-posts{color:var(--muted);font-size:var(--fs-lead);padding:40px 0}
.no-results{padding:20px 0}

/* ページネーション（WP標準クラスに合わせる） */
.pagination{margin-top:44px;display:flex;justify-content:center}
.pagination .nav-links{display:inline-flex;flex-wrap:wrap;gap:6px;align-items:center}
.pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;
  padding:0 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:#fff;
  color:var(--text);font-weight:700;text-decoration:none;transition:.2s;
}
.pagination .page-numbers:hover{border-color:var(--navy);color:var(--ink)}
.pagination .page-numbers.current{background:var(--navy);color:#fff;border-color:var(--navy)}
.pagination .page-numbers.dots{border:none;background:none}

/* ==========================================================================
   23. サイドバー（ウィジェット）
   ========================================================================== */
.blog-sidebar{display:flex;flex-direction:column;gap:24px}
.widget{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:22px;box-shadow:var(--sh-1)}
.widget-title{font-size:1rem;font-weight:800;color:var(--ink);margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--line)}
.widget-cat-list{list-style:none;margin:0;padding:0}
.widget-cat-list li{padding:7px 0;border-bottom:1px dashed var(--line)}
.widget-cat-list li:last-child{border:none}
.widget-cat-list a{color:var(--text);text-decoration:none;font-size:var(--fs-sm);font-weight:700}
.widget-cat-list a:hover{color:var(--gold-d)}
.widget-recent-list{list-style:none;margin:0;padding:0}
.widget-recent-list li{padding:10px 0;border-bottom:1px dashed var(--line)}
.widget-recent-list li:last-child{border:none}
.widget-recent-list a{text-decoration:none;display:block}
.widget-recent-ttl{display:block;color:var(--ink);font-size:var(--fs-sm);font-weight:700;line-height:1.5}
.widget-recent-list a:hover .widget-recent-ttl{color:var(--gold-d)}
.widget-recent-date{display:block;color:var(--muted);font-size:var(--fs-xs);margin-top:4px}
/* CTAミニカード */
.widget-cta{background:radial-gradient(400px 240px at 80% 0%,rgba(52,168,90,.22),transparent 60%),linear-gradient(135deg,#091422,#0c2240);border:none}
.widget-cta-in{text-align:center}
.widget-cta-copy{color:#e7eefb;font-size:var(--fs-sm);font-weight:700;margin-bottom:16px;line-height:1.7}
.widget-cta .cta{font-size:.95rem;padding:12px 24px}

/* ==========================================================================
   24. 検索フォーム
   ========================================================================== */
.search-form{display:flex;gap:8px}
.search-field{
  flex:1;border:1px solid var(--line);border-radius:var(--r-pill);padding:11px 20px;
  font-family:var(--font-base);font-size:var(--fs-body);color:var(--text);background:#fff;
}
.search-field:focus{outline:3px solid var(--gp-blue);outline-offset:1px;border-color:var(--gp-blue)}
.search-submit{
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border:none;
  background:var(--navy);color:#fff;width:46px;height:46px;border-radius:50%;transition:.2s;flex:none;
}
.search-submit:hover{background:var(--navy2)}
.search-submit svg{width:18px;height:18px}

/* ==========================================================================
   25. 記事詳細（single）
   ========================================================================== */
.single-wrap{padding:48px 0 72px}
.single-article{max-width:760px;margin:0 auto}
.single-header{margin-bottom:24px}
.single-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.single-date,.single-updated{color:var(--muted);font-size:var(--fs-sm)}
.single-title{font-size:1.9rem;line-height:1.5;font-weight:900;color:var(--ink)}
.single-thumb{margin:0 0 32px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2)}
.single-thumb img{width:100%;height:auto;display:block}
.single-content{margin:0 auto}
.single-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px;padding-top:24px;border-top:1px solid var(--line)}
.tag-chip{color:var(--gold-d);font-size:var(--fs-sm);font-weight:700;text-decoration:none}
.tag-chip:hover{text-decoration:underline}

/* 記事末CTAカードはsingle幅に馴染ませる（共通CTAカードのmax-widthを継承） */
.single-wrap .cta-card{max-width:760px}

/* 関連記事 */
.related{max-width:760px;margin:56px auto 0}
.related-title{font-size:var(--fs-h3);color:var(--ink);font-weight:900;margin-bottom:20px}
.related .article-grid{grid-template-columns:repeat(3,1fr)}

/* 前後記事ナビ */
.post-nav{max-width:760px;margin:44px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.post-nav-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:16px 20px;
  text-decoration:none;transition:.2s;display:flex;flex-direction:column;gap:6px;
}
.post-nav-item:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:var(--sh-1)}
.post-nav-item.next{text-align:right}
.post-nav-label{color:var(--gold-d);font-size:var(--fs-xs);font-weight:800}
.post-nav-ttl{color:var(--ink);font-size:var(--fs-sm);font-weight:700;line-height:1.5}

/* ==========================================================================
   26. 404
   ========================================================================== */
.error-404{text-align:center;max-width:640px;margin:0 auto;padding:32px 0}
.error-404-search{max-width:480px;margin:24px auto 0}
.error-404-posts{margin-top:44px;text-align:left}
.error-404-list{list-style:none;margin:0;padding:0}
.error-404-list li{padding:10px 0;border-bottom:1px dashed var(--line)}
.error-404-list li:last-child{border:none}
.error-404-list a{color:var(--ink);text-decoration:none;font-weight:700;font-size:var(--fs-sm)}
.error-404-list a:hover{color:var(--gold-d)}

/* ==========================================================================
   15. レスポンシブ（既存LP準拠：820px境界）
   ========================================================================== */
@media(max-width:820px){
  /* --- ブログ：サイドバーを本文下へ・カードを1カラム化 --- */
  .blog-layout{grid-template-columns:1fr;gap:36px}
  .article-grid{grid-template-columns:1fr}
  .related .article-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .post-nav{grid-template-columns:1fr}
  .post-nav-item.next{text-align:left}
  .single-title{font-size:1.5rem}
  .cta-card-title{font-size:1.3rem}
  .hero-grid{grid-template-columns:1fr;text-align:center;padding:52px 0}
  .hero h1{font-size:1.72rem}
  .chips{justify-content:center}
  .hero-art{max-width:340px;margin-top:8px}
  .hero-art-wrap{margin-top:8px}
  .stats-in{grid-template-columns:repeat(2,1fr);gap:18px 0}
  .stats .col:nth-child(3){border-left:none}
  .feature{grid-template-columns:1fr;gap:26px}
  .feature.rev .copy{order:1}
  .feature.rev .vis{order:2}
  h2.t{font-size:1.5rem}
  .frame{max-width:420px;margin:0 auto}
  .compare{grid-template-columns:1fr}

  /* ヘッダー：PCナビを隠しハンバーガー化 */
  .header-cta{display:none}
  .nav-toggle-label{display:inline-block}
  .primary-nav{
    position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;
    background:var(--navy);border-top:1px solid rgba(255,255,255,.08);
    max-height:0;overflow:hidden;transition:max-height .25s ease;
  }
  .primary-nav ul{flex-direction:column;gap:0;padding:6px 0}
  .primary-nav a{padding:12px 24px;border-radius:0}
  .nav-toggle:checked ~ .primary-nav{max-height:80vh;overflow:auto}

  /* SP追従CTAバー表示（本文下部の被り回避余白はfooterで確保） */
  .sp-cta-bar{display:block}
  .site-footer{padding-bottom:88px}
}

/* ==========================================================================
   16. モーション抑制（アクセシビリティ）
   ========================================================================== */
@media(prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important}
  .cta:hover,.frame:hover,.header-cta:hover{transform:none}
}
