/*
Theme Name: S-Buddy LP
Theme URI: https://gd-core.grow-days.com
Author: GrowDays
Description: 中古買取・リユース店向けクラウド業務システム「S-Buddy（エスバディ）」の製品紹介サイト用テーマ。1ページ完結のLP（モダン・洗練リニューアル版 v2）。
Version: 2.0.0
*/

/* ===== Design tokens（青〜紺：信頼カラー） ===== */
:root{
  --navy:#0b1f44; --navy-2:#10306e;
  --brand:#1d4ed8; --brand-2:#3b82f6; --brand-ink:#1e3a8a;
  --accent:#06b6d4;
  --ink:#0f172a; --sub:#334155; --muted:#64748b;
  --line:#e5e9f0; --bg:#fff; --bg-soft:#f5f8fc; --bg-soft-2:#eef3fb;
  --ok:#16a34a; --warn:#dc2626;
  --radius:16px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.08);
  --shadow:0 10px 30px rgba(16,48,110,.10);
  --shadow-lg:0 24px 60px rgba(11,31,68,.22);
  --maxw:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:var(--bg);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Hiragino Kaku Gothic ProN","Noto Sans JP","Yu Gothic",Meiryo,sans-serif;
  line-height:1.8;font-size:16px;letter-spacing:.01em;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.center{text-align:center}

/* ヘッダー */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;gap:16px;height:64px}
.brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:20px;letter-spacing:.02em;color:var(--navy)}
.brand .mark{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;font-weight:900;font-size:16px;box-shadow:0 4px 12px rgba(29,78,216,.35)}
.nav{margin-left:auto;display:flex;align-items:center;gap:6px}
.navlink{padding:8px 12px;color:var(--sub);font-size:14px;font-weight:600;border-radius:8px}
.navlink:hover{color:var(--brand);background:var(--bg-soft)}
@media(max-width:880px){.nav .navlink{display:none}}

/* ボタン */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;border-radius:12px;padding:12px 20px;font-size:15px;cursor:pointer;border:1px solid transparent;transition:transform .15s,box-shadow .15s,background .15s;white-space:nowrap}
.btn--primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;box-shadow:0 8px 22px rgba(29,78,216,.35)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(29,78,216,.45)}
.btn--ghost{background:#fff;color:var(--brand-ink);border-color:var(--line);box-shadow:var(--shadow-sm)}
.btn--ghost:hover{border-color:var(--brand-2);color:var(--brand)}
.btn--lg{padding:15px 28px;font-size:16px;border-radius:14px}
.btn--sm{padding:9px 16px;font-size:14px;border-radius:10px}
.btn--white{background:#fff;color:var(--navy)}
.btn--white:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.2)}

/* セクション共通 */
.section{padding:88px 0}
.section--soft{background:var(--bg-soft)}
.section--navy{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff}
.eyebrow{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);background:var(--bg-soft-2);padding:6px 14px;border-radius:999px;margin-bottom:16px}
.section--navy .eyebrow{color:#bfdbfe;background:rgba(255,255,255,.08)}
.h2{font-size:clamp(26px,3.4vw,40px);line-height:1.3;font-weight:800;margin:0 0 14px;color:var(--ink)}
.section--navy .h2{color:#fff}
.lead{font-size:17px;color:var(--muted);max-width:680px;margin:0 auto}
.section--navy .lead{color:#c7d6f0}
.section__head{margin-bottom:48px}

/* ヒーロー */
.hero{position:relative;overflow:hidden;color:#fff;padding:116px 0 96px;
  background:radial-gradient(1100px 520px at 78% -8%,#1e50b0 0%,transparent 60%),radial-gradient(900px 500px at 0% 0%,#155fc0 0%,transparent 55%),linear-gradient(160deg,#0a1c40,#0f2c66)}
.hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1px);background-size:22px 22px;opacity:.5;pointer-events:none}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:36px}}
.pill{display:inline-flex;gap:8px;align-items:center;font-size:13px;font-weight:700;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);color:#dbe7ff;padding:7px 14px;border-radius:999px;margin-bottom:20px}
.hero h1{font-size:clamp(30px,4.6vw,52px);line-height:1.22;font-weight:900;margin:0 0 18px}
.hero h1 .hl{background:linear-gradient(120deg,#7dd3fc,#a5b4fc);-webkit-background-clip:text;background-clip:text;color:transparent}
.catch{font-size:clamp(20px,2.6vw,28px);font-weight:900;margin:0 0 18px;color:#fff}
.catch b{background:linear-gradient(120deg,#7dd3fc,#a5b4fc);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.sub{font-size:17px;color:#c7d6f0;margin:0 0 28px;max-width:560px}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .micro{margin-top:18px;font-size:13px;color:#9fb6e0;display:flex;gap:18px;flex-wrap:wrap}
.hero .micro span{display:inline-flex;gap:6px;align-items:center}

/* 画面モック */
.mock{background:#fff;border-radius:18px;box-shadow:var(--shadow-lg);overflow:hidden;color:var(--ink);border:1px solid rgba(255,255,255,.2)}
.mock__bar{display:flex;align-items:center;gap:6px;padding:11px 14px;background:#f1f5fb;border-bottom:1px solid var(--line)}
.mock__bar i{width:11px;height:11px;border-radius:50%;background:#cbd5e1}
.mock__bar span{margin-left:10px;font-size:12px;color:var(--muted);font-weight:600}
.mock__body{padding:18px}
.mstats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.mstat{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:12px}
.mstat .k{font-size:11px;color:var(--muted)}
.mstat .v{font-size:20px;font-weight:800;margin-top:2px}
.mstat .v.g{color:var(--ok)} .mstat .v.b{color:var(--brand)}
.mbars{display:flex;align-items:flex-end;gap:8px;height:96px;padding:8px 4px 0}
.mbars .bar{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--brand-2),var(--brand))}

/* 信頼バー */
.trustbar{border-bottom:1px solid var(--line);background:#fff}
.trustbar .wrap{display:flex;flex-wrap:wrap;gap:14px 28px;align-items:center;justify-content:center;padding:22px 20px}
.trustbar .label{font-size:12px;color:var(--muted);font-weight:700}
.chip{display:inline-flex;gap:7px;align-items:center;font-size:13px;font-weight:700;color:var(--brand-ink);background:var(--bg-soft);border:1px solid var(--line);padding:8px 14px;border-radius:999px}

/* 統計バンド */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:760px){.statband{grid-template-columns:repeat(2,1fr)}}
.statband .num{font-size:clamp(28px,3.4vw,42px);font-weight:900;color:#fff;line-height:1}
.statband .num small{font-size:16px;font-weight:800}
.statband .cap{font-size:13px;color:#bcd0f2;margin-top:8px}

/* グリッド/カード */
.grid{display:grid;gap:20px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.grid--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid--2,.grid--3{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s,border-color .18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#cfe0fa}
.card .ic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;font-size:22px;background:linear-gradient(135deg,#e8f0ff,#dbe7ff);color:var(--brand);margin-bottom:14px}
.card h3{font-size:17px;font-weight:800;margin:0 0 8px}
.card p{font-size:14px;color:var(--sub);margin:0}

.prob{background:#fff;border:1px solid var(--line);border-left:4px solid #f59e0b;border-radius:12px;padding:18px 20px;font-size:15px;color:var(--sub);box-shadow:var(--shadow-sm)}

/* コスト削減（数字カード） */
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;text-align:center;box-shadow:var(--shadow-sm)}
.kpi .big{font-size:clamp(34px,4.4vw,48px);font-weight:900;color:var(--brand);line-height:1}
.kpi .big small{font-size:18px}
.kpi .ttl{font-weight:800;margin:10px 0 6px}
.kpi .desc{font-size:13px;color:var(--muted);margin:0}
.kpi .arrow{font-size:13px;color:var(--ok);font-weight:700;margin-top:8px}

/* 3本柱 */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
@media(max-width:760px){.pillars{grid-template-columns:1fr}}
.pillar{padding:28px;border-right:1px solid var(--line)}
.pillar:last-child{border-right:0}
.pillar .step{font-size:12px;font-weight:800;color:var(--brand);letter-spacing:.1em}
.pillar h3{font-size:18px;margin:8px 0}
.pillar p{font-size:14px;color:var(--sub);margin:0}

/* 機能（交互） */
.feat{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;margin-bottom:64px}
.feat:last-child{margin-bottom:0}
.feat:nth-child(even) .feat__media{order:2}
@media(max-width:860px){.feat{grid-template-columns:1fr;gap:24px}.feat:nth-child(even) .feat__media{order:0}}
.feat__media{background:linear-gradient(160deg,#eef3fb,#dfeaff);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.feat__tag{display:inline-block;font-size:12px;font-weight:800;color:var(--brand);letter-spacing:.08em;margin-bottom:10px}
.feat h3{font-size:24px;font-weight:800;margin:0 0 12px}
.feat ul{margin:0;padding-left:0;list-style:none}
.feat li{position:relative;padding-left:28px;margin:10px 0;color:var(--sub);font-size:15px}
.feat li::before{content:"✓";position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:50%;background:var(--brand);color:#fff;font-size:12px;display:grid;place-items:center;font-weight:900}

.mtable{width:100%;border-collapse:collapse;font-size:13px}
.mtable th{text-align:left;color:var(--muted);font-weight:700;padding:8px;border-bottom:2px solid var(--line);font-size:12px}
.mtable td{padding:9px 8px;border-bottom:1px solid var(--line)}
.mtable .pos{color:var(--ok);font-weight:700}
.pill-s{font-size:11px;background:#ede9fe;color:#6d28d9;padding:2px 8px;border-radius:999px;font-weight:700}

.phone{width:230px;margin:0 auto;background:#0b1f44;border-radius:30px;padding:12px;box-shadow:var(--shadow-lg)}
.phone__screen{background:#fff;border-radius:20px;overflow:hidden}
.mc-head{background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;padding:14px;font-weight:800;text-align:center;font-size:14px}
.mc-body{padding:16px;text-align:center}
.mc-no{font-family:monospace;font-size:13px;color:var(--muted)}
.mc-bar{height:40px;margin:10px 0;background:repeating-linear-gradient(90deg,#0f172a 0 2px,#fff 2px 4px)}
.mc-pt{font-size:30px;font-weight:900;color:var(--brand)}

/* Before/After */
.ba{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:620px){.ba{grid-template-columns:1fr}}
.ba__col{border-radius:var(--radius);padding:26px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm)}
.ba__col h3{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:17px}
.ba__col ul{margin:0;padding-left:18px;line-height:2;color:var(--sub);font-size:14px}
.ba--before{border-top:4px solid #dc2626}
.ba--after{border-top:4px solid var(--ok);background:linear-gradient(180deg,#f6fff9,#fff)}

/* 導入の流れ */
.steps{counter-reset:s;display:grid;gap:18px}
.step-row{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}
.step-row .no{counter-increment:s;flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-weight:900}
.step-row .no::before{content:counter(s)}
.step-row h3{margin:0 0 4px;font-size:17px}
.step-row p{margin:0;color:var(--sub);font-size:14px}

/* 料金 */
.price-wrap{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:820px;margin:0 auto}
@media(max-width:620px){.price-wrap{grid-template-columns:1fr}}
.price{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.price.is-rec{border:2px solid var(--brand);box-shadow:var(--shadow);position:relative}
.price.is-rec::before{content:"おすすめ";position:absolute;top:-12px;left:30px;background:var(--brand);color:#fff;font-size:12px;font-weight:800;padding:4px 12px;border-radius:999px}
.price .pname{font-weight:800;color:var(--brand-ink)}
.price .amt{font-size:30px;font-weight:900;margin:8px 0 16px}
.price .amt small{font-size:14px;color:var(--muted);font-weight:600}
.price ul{margin:0;padding-left:0;list-style:none}
.price li{position:relative;padding-left:24px;margin:9px 0;font-size:14px;color:var(--sub)}
.price li::before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:900}
.callout{max-width:820px;margin:24px auto 0;border:2px solid var(--brand);border-radius:var(--radius);padding:24px;background:linear-gradient(180deg,#f3f8ff,#fff)}
.badge-free{background:var(--accent);color:#fff;font-weight:900;font-size:14px;padding:5px 14px;border-radius:999px}

/* FAQ */
.faq{max-width:760px;margin:0 auto;display:grid;gap:12px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px 18px;box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:700;padding:16px 0;list-style:none;position:relative;padding-right:28px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:0;top:14px;font-size:22px;color:var(--brand);font-weight:400;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin:0 0 16px;color:var(--sub);font-size:14px}

/* CTAバンド */
.ctaband{background:linear-gradient(135deg,var(--navy),var(--brand));border-radius:24px;padding:54px 40px;text-align:center;color:#fff;box-shadow:var(--shadow-lg)}
.ctaband h2{font-size:clamp(24px,3vw,34px);font-weight:900;margin:0 0 12px}
.ctaband p{color:#cfe0ff;margin:0 0 26px}

/* フォーム */
.form{max-width:680px;margin:40px auto 0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.form label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin:16px 0 6px}
.form input[type=text],.form input[type=email],.form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:15px;font-family:inherit;background:#fcfdff}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(59,130,246,.15)}
.form .radio-row{display:flex;gap:18px;margin:6px 0 4px;flex-wrap:wrap}
.form .radio-row label{font-weight:500;display:flex;gap:7px;align-items:center;margin:0;font-size:14px}
.form .submit{width:100%;margin-top:22px}
.form .hp{position:absolute !important;left:-9999px !important}
.notice{border-radius:12px;padding:16px 18px;font-size:14px;font-weight:600}
.notice--ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.notice--ng{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* フッター */
.site-footer{background:var(--navy);color:#cdd9ee;padding:48px 0 32px}
.site-footer .top{display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.1)}
.site-footer .brand{color:#fff}
.site-footer a{color:#cdd9ee} .site-footer a:hover{color:#fff}
.site-footer .links{display:flex;gap:20px;font-size:14px;flex-wrap:wrap}
.site-footer .copy{font-size:12px;color:#8ea4c9;padding-top:20px}
.note-s{font-size:12px;color:var(--muted)}
.section--navy .note-s{color:#9fb6e0}

/* ===== v2.1 追加：リッチ画面モック・ショーケース ===== */
/* 画面ショーケース（一目でわかる） */
.showcase{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:820px){.showcase{grid-template-columns:1fr}}
.shot{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s}
.shot:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.shot__cap{padding:16px 18px;border-top:1px solid var(--line);background:#fff}
.shot__cap b{display:block;font-size:15px;color:var(--ink)}
.shot__cap span{font-size:13px;color:var(--muted)}
.shot .mock{border-radius:0;box-shadow:none;border:0;border-bottom:1px solid var(--line)}

/* 買取受付フォーム風モック */
.mform{padding:16px}
.mfield{margin-bottom:10px}
.mfield .lb{font-size:11px;color:var(--muted);font-weight:700;margin-bottom:4px}
.mfield .in{background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:9px 11px;font-size:13px;color:var(--ink)}
.mfield .in.acc{border-color:var(--brand-2);background:#eef4ff;font-weight:700;color:var(--brand-ink)}
.mrow2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mbtn{margin-top:6px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;text-align:center;border-radius:9px;padding:10px;font-weight:800;font-size:13px}

/* 在庫一覧（サムネ付き） */
.mlist{padding:8px}
.mli{display:flex;align-items:center;gap:12px;padding:10px;border-bottom:1px solid var(--line)}
.mli:last-child{border-bottom:0}
.thumb{width:40px;height:40px;border-radius:8px;flex:none;background:linear-gradient(135deg,#dbe7ff,#c7dcff)}
.thumb.t2{background:linear-gradient(135deg,#fde68a,#fcd34d)}
.thumb.t3{background:linear-gradient(135deg,#bbf7d0,#86efac)}
.thumb.t4{background:linear-gradient(135deg,#e9d5ff,#d8b4fe)}
.mli .nm{font-size:13px;font-weight:700;flex:1}
.mli .pr{font-size:13px;font-family:monospace}
.mli .bd{font-size:10px;padding:2px 8px;border-radius:999px;font-weight:700}
.bd-in{background:#dbeafe;color:#1e40af}.bd-sell{background:#ede9fe;color:#6d28d9}.bd-hold{background:#fef3c7;color:#92400e}

/* POS/レジ風（タブレット枠） */
.tablet{background:#0b1f44;border-radius:18px;padding:10px;box-shadow:var(--shadow-lg)}
.tablet__screen{background:#fff;border-radius:12px;overflow:hidden}
.pos-row{display:flex;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--line);font-size:13px}
.pos-total{display:flex;justify-content:space-between;padding:12px 14px;background:var(--bg-soft);font-weight:800}
.pos-total .v{color:var(--brand);font-size:18px}
.pos-pay{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:10px}
.pos-pay div{background:#eef4ff;border:1px solid #cfe0fa;border-radius:8px;text-align:center;padding:8px;font-size:11px;font-weight:700;color:var(--brand-ink)}

/* 直感操作・タップ訴求 */
.easy{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){.easy{grid-template-columns:1fr}}
.easy .e{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;text-align:center;box-shadow:var(--shadow-sm)}
.easy .e .em{font-size:34px}
.easy .e h3{margin:10px 0 6px;font-size:17px}
.easy .e p{font-size:14px;color:var(--sub);margin:0}
.taphint{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--brand);background:#eef4ff;border:1px solid #cfe0fa;padding:5px 12px;border-radius:999px;margin-top:10px}

/* 継続アップデート・タイムライン */
.timeline{max-width:720px;margin:0 auto;border-left:2px solid var(--brand-2);padding-left:26px;display:grid;gap:22px}
.tl{position:relative}
.tl::before{content:"";position:absolute;left:-33px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--brand);border:3px solid #fff;box-shadow:0 0 0 2px var(--brand-2)}
.tl .d{font-size:12px;font-weight:800;color:var(--brand);letter-spacing:.05em}
.tl h3{margin:2px 0 4px;font-size:16px}
.tl p{margin:0;font-size:14px;color:var(--sub)}
.voice{background:linear-gradient(135deg,#eef4ff,#e0ecff);border:1px solid #cfe0fa;border-radius:var(--radius);padding:24px;margin-top:8px}
.voice .q{font-size:15px;color:var(--brand-ink);font-weight:700}
.voice .a{font-size:14px;color:var(--sub);margin-top:8px}

/* ===== v2.2 追加：機能網羅表・比較表・使い方フロー・ターゲット ===== */
/* 機能カテゴリ網羅 */
.catgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.catgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.catgrid{grid-template-columns:1fr}}
.catcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}
.catcard h3{display:flex;align-items:center;gap:8px;font-size:16px;margin:0 0 12px;color:var(--brand-ink)}
.catcard h3 .ci{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,#e8f0ff,#dbe7ff);color:var(--brand);font-size:16px}
.catcard ul{margin:0;padding-left:0;list-style:none}
.catcard li{position:relative;padding-left:20px;font-size:13.5px;color:var(--sub);margin:7px 0}
.catcard li::before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:800;font-size:12px}

/* 比較表 */
.cmp{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);font-size:14px}
.cmp th,.cmp td{padding:14px 16px;text-align:center;border-bottom:1px solid var(--line)}
.cmp thead th{background:var(--bg-soft);font-size:13px;color:var(--muted);font-weight:700}
.cmp thead th.is-sb{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-size:15px}
.cmp td:first-child,.cmp th:first-child{text-align:left;font-weight:700;color:var(--ink);background:#fcfdff}
.cmp td.sb{background:#f3f8ff;font-weight:800;color:var(--brand-ink)}
.cmp .o{color:var(--ok);font-weight:900}.cmp .x{color:#cbd5e1;font-weight:900}.cmp .t{color:#d97706;font-weight:800}
.cmp tr:last-child td{border-bottom:0}
.cmp-wrap{overflow-x:auto}

/* 使い方フロー（画面遷移） */
.flowx{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:12px;align-items:center}
@media(max-width:860px){.flowx{grid-template-columns:1fr;gap:14px}.flowx .arrowx{transform:rotate(90deg);justify-self:center}}
.flowx .arrowx{font-size:26px;color:var(--brand-2);font-weight:900}
.flowcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.flowcard .cap{padding:12px 14px}
.flowcard .cap b{display:block;font-size:14px}
.flowcard .cap span{font-size:12px;color:var(--muted)}
.flowcard .stepno{display:inline-block;font-size:11px;font-weight:800;color:#fff;background:var(--brand);border-radius:999px;padding:2px 9px;margin-bottom:6px}

/* こんな方に */
.persona{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){.persona{grid-template-columns:1fr}}
.persona .p{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;text-align:center;box-shadow:var(--shadow-sm);border-top:3px solid var(--brand-2)}
.persona .p .em{font-size:34px}
.persona .p h3{margin:8px 0 6px;font-size:16px}
.persona .p p{font-size:13.5px;color:var(--sub);margin:0}

/* オプション機能バッジ */
.opt-badge{display:inline-block;font-size:11px;font-weight:800;color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:999px;padding:2px 10px;margin-left:8px;vertical-align:middle;letter-spacing:.02em}

/* ===== FC比較（しばられない本部サポート） ===== */
.fc-lead{max-width:780px;margin:0 auto 36px;text-align:center}
.fc-lead .quote{font-size:clamp(18px,2.4vw,24px);font-weight:800;color:var(--brand-ink);line-height:1.6;margin:0 0 12px}
.fc-lead .quote b{background:linear-gradient(120deg,#1d4ed8,#06b6d4);-webkit-background-clip:text;background-clip:text;color:transparent}
.fc-lead p{font-size:15px;color:var(--sub);margin:0}

.fccmp-wrap{overflow-x:auto;max-width:920px;margin:0 auto}
.fccmp{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);font-size:14.5px}
.fccmp th,.fccmp td{padding:16px 18px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.fccmp thead th{background:var(--bg-soft);font-size:13px;color:var(--muted);font-weight:700;text-align:center}
.fccmp thead th.is-sb{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-size:16px}
.fccmp thead th:first-child{text-align:left;background:#fcfdff}
.fccmp td:first-child{font-weight:800;color:var(--ink);background:#fcfdff;width:30%}
.fccmp td.fc{color:var(--muted);text-align:center}
.fccmp td.sb{background:#f3f8ff;font-weight:800;color:var(--brand-ink);text-align:center}
.fccmp td.sb .big{display:block;font-size:18px;color:var(--brand)}
.fccmp tr:last-child td{border-bottom:0}
.fccmp .mini{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-top:3px}

.fc-points{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:920px;margin:28px auto 0}
@media(max-width:760px){.fc-points{grid-template-columns:1fr}}
.fc-pt{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);border-top:3px solid var(--brand-2)}
.fc-pt .em{font-size:28px}
.fc-pt h3{margin:8px 0 6px;font-size:16px;color:var(--brand-ink)}
.fc-pt p{margin:0;font-size:13.5px;color:var(--sub)}

/* ===== 料金：基本1プラン＋オプション ===== */
.plan-one{max-width:600px;margin:0 auto;background:#fff;border:2px solid var(--brand);border-radius:20px;padding:34px 30px;box-shadow:var(--shadow);text-align:center;position:relative}
.plan-one .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--brand);color:#fff;font-size:12px;font-weight:800;padding:5px 16px;border-radius:999px;white-space:nowrap}
.plan-one .pname{font-weight:800;color:var(--brand-ink);font-size:18px;margin-top:4px}
.plan-one .amt{font-size:clamp(30px,4vw,38px);font-weight:900;margin:6px 0 2px;line-height:1.1}
.plan-one .amt small{font-size:15px;color:var(--muted);font-weight:600}
.plan-one .allin{font-size:13px;color:var(--ok);font-weight:800;margin-bottom:18px}
.plan-one ul{margin:0;padding:0;list-style:none;text-align:left;display:grid;grid-template-columns:1fr 1fr;gap:2px 18px}
@media(max-width:520px){.plan-one ul{grid-template-columns:1fr}}
.plan-one li{position:relative;padding-left:24px;margin:8px 0;font-size:14px;color:var(--sub)}
.plan-one li::before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:900}

.opts{max-width:720px;margin:34px auto 0}
.opts .ohd{text-align:center;margin-bottom:18px}
.opts .ohd h3{font-size:20px;font-weight:800;margin:0 0 4px}
.opts .ohd p{font-size:14px;color:var(--muted);margin:0}
.optrow{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:15px 18px;margin-bottom:10px;box-shadow:var(--shadow-sm);transition:border-color .18s}
.optrow:hover{border-color:#cfe0fa}
.optrow .oem{font-size:24px;flex:none;width:30px;text-align:center}
.optrow .otxt{flex:1;min-width:0}
.optrow .otxt b{display:block;font-size:15px;color:var(--ink)}
.optrow .otxt span{font-size:12.5px;color:var(--muted)}
.optrow .oamt{flex:none;font-weight:900;color:var(--brand);font-size:16px;white-space:nowrap;text-align:right}
.optrow .oamt small{display:block;font-size:11px;color:var(--muted);font-weight:600}
.optrow.is-site{border:2px solid var(--brand);background:linear-gradient(180deg,#f3f8ff,#fff)}

/* 集客サイト 3プラン */
.price3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:980px;margin:0 auto}
@media(max-width:820px){.price3{grid-template-columns:1fr;max-width:460px}}
