/*
Theme Name: 不動産の参謀
Theme URI: https://fudosanbo.com/
Description: 不動産の参謀 専用テーマ。SaaS構造化DB（製品/比較/カテゴリハブ）をマッチング型で描画。デザインv1（コバルト×白・洗練/モダン/先進）準拠。Twenty Twenty-Five 子テーマ。
Author: 不動産の参謀編集部
Template: twentytwentyfive
Version: 0.2.0
Text Domain: fudosanbo
*/

:root{
  --accent:#2f6bff; --accent-2:#1e4fd6; --accent-ink:#163a9e; --accent-soft:#eaf0ff;
  --ink:#0e1526; --ink-2:#2a3346; --muted:#697489; --line:#e7ecf4;
  --bg:#ffffff; --bg-soft:#f5f7fc; --bg-soft2:#eef2fa; --gold:#c8a24a;
  --ok:#2f6bff; --warn:#9a6b00; --dark:#0c1226;
  --maxw:1140px; --radius:16px; --shadow:0 10px 30px -16px rgba(20,33,77,.25);
}
*{box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:var(--bg);
  font-family:-apple-system,"Hiragino Kaku Gothic ProN","Yu Gothic UI","Yu Gothic",Meiryo,system-ui,sans-serif;
  line-height:1.8;-webkit-font-smoothing:antialiased;letter-spacing:.01em}
a{color:var(--accent-2);text-decoration:none}
a:hover{opacity:.85}
.fs-container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===== header ===== */
.fs-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
.fs-header .fs-container{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:66px}
.fs-brand a{display:flex;flex-direction:column;color:var(--ink);font-weight:900;font-size:1.22rem;letter-spacing:.06em;line-height:1.1}
.fs-brand small{color:var(--muted);font-weight:500;font-size:.66rem;letter-spacing:.02em;margin-top:3px}
.fs-nav{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.fs-nav a{color:var(--ink-2);font-size:.9rem;font-weight:600}
.fs-nav a:hover{color:var(--accent-2)}
.fs-nav .fs-navcta{background:var(--ink);color:#fff;padding:8px 16px;border-radius:10px;font-size:.84rem}
.fs-nav .fs-navcta:hover{background:var(--accent-2);opacity:1}

/* ===== layout ===== */
.fs-main{padding:0 0 64px}
.fs-section{padding:46px 0}
.fs-bc{font-size:.8rem;color:var(--muted);margin:18px 0}
.fs-bc a{color:var(--muted)}
h1.fs-title{font-size:2rem;line-height:1.35;margin:.2em 0 .5em;letter-spacing:.01em;font-weight:900}
.fs-lead{color:var(--muted);font-size:1.02rem;margin:.2em 0 1.4em;max-width:48em}
.fs-h2{font-size:1.35rem;font-weight:800;margin:0 0 .2em;letter-spacing:.02em}
.fs-h2 .fs-en{display:block;font-size:.72rem;font-weight:700;letter-spacing:.18em;color:var(--accent);margin-bottom:.1em}
.fs-shead{margin:0 0 22px}
.fs-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin:0 0 18px;box-shadow:var(--shadow)}

/* ===== hero ===== */
.fs-hero{background:
   radial-gradient(1200px 500px at 88% -10%,#eef3ff 0,rgba(238,243,255,0) 60%),
   linear-gradient(180deg,#fbfcff 0,#fff 70%);
  border-bottom:1px solid var(--line);overflow:hidden}
.fs-hero .fs-container{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  padding-top:56px;padding-bottom:56px}
.fs-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--accent-soft);color:var(--accent-ink);
  font-weight:700;font-size:.76rem;letter-spacing:.04em;padding:6px 13px;border-radius:999px;margin-bottom:18px}
.fs-eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}
.fs-hero h1{font-size:2.7rem;line-height:1.28;font-weight:900;letter-spacing:.01em;margin:0 0 16px}
.fs-hero h1 .hl{color:var(--accent)}
.fs-hero p.sub{color:var(--ink-2);font-size:1.06rem;margin:0 0 24px;max-width:24em}

/* selector */
.fs-selector{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:16px}
.fs-selector .row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}
.fs-field label{display:block;font-size:.72rem;font-weight:700;color:var(--muted);margin:0 0 4px}
.fs-field select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:var(--bg-soft);
  font-size:.92rem;color:var(--ink);appearance:none;cursor:pointer}
.fs-field select:focus{outline:2px solid var(--accent);border-color:var(--accent)}
.fs-submit{display:block;width:100%;background:linear-gradient(100deg,var(--accent),var(--accent-2));color:#fff;
  border:none;font-weight:800;font-size:1rem;padding:14px;border-radius:11px;cursor:pointer;letter-spacing:.04em}
.fs-submit:hover{filter:brightness(1.06)}
.fs-microtrust{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px;color:var(--muted);font-size:.8rem}
.fs-microtrust b{color:var(--ink)}

/* hero data panel (decorative dashboard) */
.fs-panel{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:20px;position:relative}
.fs-panel .ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.fs-panel .ph b{font-size:.92rem}
.fs-panel .ph span{font-size:.7rem;color:var(--muted);background:var(--bg-soft2);padding:3px 9px;border-radius:999px}
.fs-panel .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:12px}
.fs-stat{background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:14px}
.fs-stat .n{font-size:2rem;font-weight:900;color:var(--accent);line-height:1}
.fs-stat .l{font-size:.72rem;color:var(--muted);margin-top:4px}
.fs-bars{display:flex;align-items:flex-end;gap:7px;height:74px;margin-top:8px}
.fs-bars i{flex:1;background:linear-gradient(180deg,var(--accent),#9db8ff);border-radius:5px 5px 0 0;display:block}
.fs-rate{display:flex;align-items:baseline;gap:8px;margin-top:6px}
.fs-rate .s{font-size:1.5rem;font-weight:900}
.fs-rate .star{color:var(--gold);letter-spacing:2px}
.fs-mini{margin-top:12px;border-top:1px dashed var(--line);padding-top:10px;font-size:.78rem;color:var(--muted)}
.fs-mini .r{display:flex;justify-content:space-between;padding:3px 0}
.fs-mini .ok{color:var(--accent);font-weight:800}

/* ===== chips ===== */
.fs-chips{display:flex;flex-wrap:wrap;gap:9px;margin:.4em 0}
.fs-chip{background:#fff;color:var(--ink-2);border:1px solid var(--line);border-radius:999px;
  font-size:.84rem;font-weight:600;padding:8px 15px;transition:.15s}
.fs-chip:hover{border-color:var(--accent);color:var(--accent);opacity:1;box-shadow:0 4px 14px -8px rgba(47,107,255,.5)}

/* ===== sections bg ===== */
.fs-soft{background:var(--bg-soft)}

/* product cards */
.fs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.fs-pcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;transition:.18s}
.fs-pcard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#d4deef}
.fs-pcard h3{margin:.3em 0 .25em;font-size:1.1rem;font-weight:800}
.fs-pcard h3 a{color:var(--ink)}
.fs-pcard .fs-vendor{color:var(--muted);font-size:.78rem}
.fs-pcard .fs-excerpt{font-size:.9rem;color:var(--ink-2);margin:.6em 0}
.fs-pcard .fs-more{margin-top:auto;font-weight:800;font-size:.88rem;color:var(--accent)}

/* table / matrix */
.fs-tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;background:#fff}
table.fs-matrix{border-collapse:collapse;width:100%;font-size:.9rem;background:#fff;min-width:640px}
.fs-matrix th,.fs-matrix td{border-bottom:1px solid var(--line);padding:12px 12px;text-align:center;vertical-align:middle}
.fs-matrix thead th{background:var(--ink);color:#fff;font-weight:600;font-size:.82rem}
.fs-matrix thead th:first-child{text-align:left}
.fs-matrix tbody tr:hover{background:var(--accent-soft)}
.fs-matrix td.fs-name{text-align:left;font-weight:800;white-space:nowrap}
.fs-matrix td.fs-name a{color:var(--ink)}
.fs-matrix td.fs-note{text-align:left;color:var(--muted);font-size:.82rem;min-width:200px}
.fs-yes{color:var(--accent);font-weight:900;font-size:1.05rem}
.fs-no{color:#cfd6e3}

/* fit / non-fit blocks */
.fs-fit,.fs-nonfit{border-radius:12px;padding:16px 18px;margin:.6em 0}
.fs-fit{background:var(--accent-soft);border:1px solid #cdd9ff;border-left:4px solid var(--accent)}
.fs-nonfit{background:#fbf6ec;border:1px solid #ecdcb8;border-left:4px solid var(--warn)}
.fs-fit b,.fs-nonfit b{display:block;margin-bottom:.25em;font-size:.92rem}

/* CTA */
.fs-cta{background:
   radial-gradient(700px 240px at 85% -40%,rgba(47,107,255,.55),rgba(47,107,255,0) 70%),
   linear-gradient(110deg,var(--dark),#15205a);
  color:#fff;border-radius:20px;padding:34px 36px;margin:28px 0;display:flex;
  align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.fs-cta .t b{font-size:1.3rem;display:block;margin-bottom:.3em}
.fs-cta .t p{margin:0;color:#c8d2f0;font-size:.94rem;max-width:34em}
.fs-btn{display:inline-block;background:var(--gold);color:#1b1300;font-weight:900;padding:14px 26px;border-radius:11px;white-space:nowrap}
.fs-btn:hover{filter:brightness(1.06);opacity:1}
.fs-btn-accent{background:linear-gradient(100deg,var(--accent),var(--accent-2));color:#fff}

/* buttons inline */
.fs-link-all{display:inline-block;margin-top:14px;font-weight:800;color:var(--accent)}

/* footer */
.fs-footer{background:var(--dark);color:#9fabce;padding:46px 0 30px;font-size:.86rem;margin-top:40px}
.fs-footer a{color:#c3cdec}
.fs-footer .fs-fbrand{color:#fff;font-weight:900;font-size:1.1rem;letter-spacing:.06em}
.fs-footer .fs-fnav{display:flex;gap:20px;flex-wrap:wrap;margin:14px 0}
.fs-footer .fs-fcopy{border-top:1px solid #232c4d;margin-top:18px;padding-top:16px;color:#7a87ad;font-size:.8rem}

.fs-noindex{background:#7a1c1c;color:#fff;text-align:center;font-size:.76rem;padding:5px;letter-spacing:.03em}

@media(max-width:880px){
  .fs-hero .fs-container{grid-template-columns:1fr;gap:28px}
  .fs-hero h1{font-size:2.1rem}
  h1.fs-title{font-size:1.6rem}
  .fs-panel{order:2}
}
@media(max-width:560px){
  .fs-selector .row{grid-template-columns:1fr}
  .fs-hero h1{font-size:1.8rem}
  .fs-nav{gap:14px}
}
