/* ============================================================
   koyaku-redesign.css  — 本番用スタイルシート
   47ものがたり v3 DNA × 常磐 #1a7244（明朝 / キナリ / Mono）
   見本 公約マップ_リデザイン見本.html と同一のクラス設計。
   ※ mock専用UI（.mockbar/.swatchbar/.sw/.seg/.note）は含みません。
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@500;600;700&family=Noto+Sans+JP:wght@400;500;700&family=JetBrains+Mono:wght@500;700&display=swap");

:root{
  /* ── 本家47ものがたり v3 茜ベース トークン（実測値） ── */
  --paper:#ffffff;
  --bg:#f4f1ea;          /* キナリ（紙） */
  --bg-soft:#faf8f3;
  --ink:#1f1c14;         /* 墨 */
  --ink-2:#3a342a;
  --ink-3:#7a7060;       /* メタ */
  --border:#d8d0bc;
  --border-soft:#ebe5d6;
  --akane:#1a7244;       /* 常磐（姉妹サイト用アクセント） */
  --akane-soft:#4d9568;  /* hover */
  --neg:#7a2848;

  --serif:"Noto Serif JP","Yu Mincho","Times New Roman",serif;
  --sans:"Noto Sans JP",-apple-system,"Helvetica Neue",sans-serif;
  --mono:"JetBrains Mono","Menlo",monospace;

  --r-card:12px; --r-pill:999px; --r-bdg:4px;
}
*{box-sizing:border-box;}
html,body{margin:0;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--serif);
  font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;
  line-height:1.7;
}
a{color:inherit;text-decoration:none;}
.num{font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum","lnum";}

/* ── kicker ── */
.kicker{font-family:var(--mono);font-size:10px;letter-spacing:.18em;font-weight:700;color:var(--akane);text-transform:uppercase;}
.kicker-meta{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);text-transform:uppercase;}
.kicker-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px;}
.section-h{font-family:var(--serif);font-weight:600;font-size:28px;letter-spacing:-.01em;margin:0;line-height:1.2;}
.section-h .dash{color:var(--akane);margin-right:8px;}

/* ── containers ── */
.wrap{max-width:1152px;margin:0 auto;padding:0 20px;}
@media(min-width:768px){.wrap{padding:0 32px;}}
.wrap-narrow{max-width:672px;margin:0 auto;padding:0 20px;}

/* ── header ── */
header.site{position:sticky;top:0;z-index:50;background:var(--paper);border-bottom:1px solid var(--border);}
header.site .row{height:56px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.brand{display:flex;align-items:center;gap:9px;flex-shrink:0;}
.brand .mark{width:30px;height:30px;border-radius:7px;background:var(--akane);color:#fff;font-family:var(--serif);font-weight:700;font-size:17px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.brand .name{font-family:var(--serif);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:.01em;line-height:1.05;}
.brand .sub{font-family:var(--mono);font-size:9px;color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase;display:block;margin-top:1px;}
nav.main{display:none;align-items:center;gap:2px;}
@media(min-width:900px){nav.main{display:flex;}}
nav.main a{font-family:var(--sans);font-size:11px;font-weight:700;color:var(--ink-2);padding:6px 9px;border-bottom:2px solid transparent;margin-bottom:-1px;}
nav.main a:hover{color:var(--ink);}
nav.main a.active{color:var(--ink);border-bottom-color:var(--akane);}
/* 検索ボタンは全幅で常時表示（モバイルではアイコンのみのコンパクト表示） */
.searchbtn{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--r-pill);background:var(--bg);color:var(--ink-3);font-family:var(--sans);font-size:11px;cursor:pointer;flex-shrink:0;}
.searchbtn kbd{font-family:var(--mono);font-size:9px;border:1px solid var(--border);border-radius:3px;padding:1px 4px;color:var(--ink-3);}
@media(max-width:767px){
  .searchbtn{padding:8px 11px;font-size:13px;}
  .searchbtn .searchbtn-label,.searchbtn kbd{display:none;}
  .searchbtn .ico,.searchbtn>span[aria-hidden]{font-size:16px;}
}

/* ── sister strip ── */
.sister{background:var(--akane);color:#fff;}
.sister .wrap{display:flex;align-items:center;justify-content:center;gap:8px;height:30px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;}
.sister a{border-bottom:1px solid rgba(255,255,255,.45);padding-bottom:1px;}

/* ── hero ── */
.hero{padding:56px 0 40px;}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4.6vw,46px);letter-spacing:-.025em;line-height:1.1;margin:10px 0 0;}
.hero .lead{font-size:14px;color:var(--ink-2);max-width:56ch;margin:16px 0 0;line-height:1.85;text-wrap:pretty;}
/* hero variants */
.hero2{display:grid;grid-template-columns:1fr;gap:30px;align-items:start;}
@media(min-width:880px){.hero2{grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;}}
.hero h1.big{font-size:clamp(34px,5.4vw,58px);line-height:1.05;}
.hero h1.big2{font-size:clamp(32px,5vw,54px);line-height:1.07;margin:12px 0 0;}
.searchbox{display:flex;align-items:center;gap:8px;margin-top:22px;background:var(--paper);border:1px solid var(--border);border-radius:var(--r-pill);padding:6px 6px 6px 16px;max-width:440px;}
.searchbox.center{margin-left:auto;margin-right:auto;}
.searchbox.big{max-width:560px;padding:9px 9px 9px 20px;}
.searchbox .si{color:var(--ink-3);font-size:16px;}
.searchbox input{flex:1;border:0;outline:0;background:transparent;font-family:var(--sans);font-size:14px;color:var(--ink);min-width:0;}
.searchbox button{font-family:var(--sans);font-weight:700;font-size:13px;color:#fff;background:var(--akane);border:0;border-radius:var(--r-pill);padding:9px 18px;cursor:pointer;white-space:nowrap;}
.searchbox.big button{padding:11px 24px;font-size:14px;}
.cov{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);text-transform:uppercase;margin-top:12px;}
.spotlight{background:var(--paper);border:1px solid var(--border);border-top:3px solid var(--akane);border-radius:2px 2px var(--r-card) var(--r-card);padding:22px 24px 24px;}
.spotlight .sh{font-family:var(--serif);font-weight:600;font-size:17px;margin:4px 0 16px;}
.bars{display:flex;flex-direction:column;gap:9px;}
.barrow{display:grid;grid-template-columns:96px 1fr 36px;align-items:center;gap:10px;}
.barrow .bn{font-family:var(--sans);font-size:12px;color:var(--ink-2);}
.bt{height:9px;border-radius:3px;background:var(--bg-soft);overflow:hidden;}
.bf{display:block;height:100%;border-radius:3px;background:var(--akane);}
.barrow .bp{font-family:var(--mono);font-size:10px;color:var(--ink-3);text-align:right;}
.spotnote{font-size:11px;color:var(--ink-3);margin-top:16px;line-height:1.6;}
.stats.thin{margin-top:30px;}
/* picker index */
.pnames{display:grid;grid-template-columns:repeat(2,1fr);gap:3px 12px;}
.pname{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--serif);font-size:14px;color:var(--ink);padding:2px 0;border-bottom:1px solid transparent;text-decoration:none;}
.pname small{font-family:var(--mono);font-size:9px;color:var(--ink-3);margin-left:8px;}
.pname:hover{color:var(--akane);border-bottom-color:var(--border);}

/* ── stats ── */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;margin-top:34px;}
@media(min-width:768px){.stats{grid-template-columns:repeat(4,1fr);}}
.stat{background:var(--paper);padding:18px 20px 16px;}
.stat .lab{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--akane);font-weight:700;}
.stat .jp{font-family:var(--sans);font-size:11px;color:var(--ink-3);display:block;margin-top:1px;}
.stat .val{font-family:var(--serif);font-weight:700;font-size:34px;color:var(--ink);line-height:1.1;margin-top:8px;}
.stat .val small{font-size:14px;font-weight:600;color:var(--ink-3);margin-left:3px;}

/* ── section spacing ── */
section.block{padding:44px 0;}
.section-head{margin-bottom:22px;}
.section-head .desc{font-size:13.5px;color:var(--ink-2);margin:10px 0 0;max-width:58ch;line-height:1.8;}

/* ── heatmap ── */
.legend{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:9px;color:var(--ink-3);letter-spacing:.08em;margin-top:14px;}
.legend .bar{width:58px;height:5px;border-radius:3px;background:linear-gradient(to right,color-mix(in srgb,var(--akane) 12%,transparent),var(--akane));}
.regions{display:grid;grid-template-columns:repeat(1,1fr);gap:14px;margin-top:18px;}
@media(min-width:600px){.regions{grid-template-columns:repeat(2,1fr);}}
@media(min-width:900px){.regions{grid-template-columns:repeat(3,1fr);}}
@media(min-width:1100px){.regions{grid-template-columns:repeat(4,1fr);}}
.region{background:var(--paper);border:1px solid var(--border);border-radius:14px;padding:14px 14px 13px;}
.region .rlab{font-family:var(--serif);font-weight:600;font-size:14px;color:var(--ink);letter-spacing:.02em;margin-bottom:10px;}
.tiles{display:flex;flex-wrap:wrap;gap:6px;}
.tile{width:30px;height:30px;border-radius:var(--r-bdg);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:14px;font-weight:600;border:1px solid var(--border);background:var(--bg-soft);color:var(--ink);cursor:pointer;transition:transform .08s ease;line-height:1;}
.tile:hover{transform:translateY(-2px);border-color:var(--akane);}

/* ── glyph cards ── */
.glyphs{display:grid;grid-template-columns:repeat(1,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;margin-top:4px;}
@media(min-width:680px){.glyphs{grid-template-columns:repeat(2,1fr);}}
.glyph{background:var(--paper);padding:24px 26px;}
.glyph .g{font-family:var(--serif);font-size:26px;font-weight:600;color:var(--akane);line-height:1;}
.glyph .gk{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-top:14px;}
.glyph h3{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:-.005em;margin:4px 0 8px;}
.glyph p{font-size:13px;color:var(--ink-2);margin:0;line-height:1.75;}

/* ── flagged card sample ── */
.flagged{background:var(--paper);border:1px solid var(--border);border-top:3px solid var(--akane);border-radius:2px 2px var(--r-card) var(--r-card);padding:20px 22px 22px;margin-top:18px;}
.flagged .meta{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.18em;color:var(--ink-3);text-transform:uppercase;}
.flagged h3{font-family:var(--serif);font-weight:600;font-size:19px;line-height:1.5;margin:8px 0 0;}

/* ── footer ── */
footer.site{background:var(--paper);border-top:3px solid var(--akane);margin-top:30px;}
footer.site .cols{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:44px 0 4px;}
@media(min-width:680px){footer.site .cols{grid-template-columns:repeat(4,1fr);}}
.fcol .fh{font-family:var(--serif);font-weight:600;font-size:14px;color:var(--ink);letter-spacing:.04em;margin-bottom:10px;}
.fcol .fh .dash{color:var(--akane);margin-right:6px;}
.fcol a{display:block;font-family:var(--sans);font-size:12.5px;color:var(--ink-2);padding:4px 0;}
.fcol a:hover{text-decoration:underline;text-decoration-color:var(--akane);text-underline-offset:3px;}
.legal{border-top:1px solid var(--border-soft);margin-top:26px;padding:16px 0;display:flex;flex-wrap:wrap;gap:18px;}
.legal a{font-family:var(--sans);font-size:11.5px;color:var(--ink-3);}
.legal a:hover{color:var(--ink-2);}
.brandfoot{padding:6px 0 44px;}
.brandfoot .bn{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--ink);}
.brandfoot .bn .ak{color:var(--akane);}
.brandfoot .tag{font-family:var(--serif);font-size:12.5px;color:var(--ink-2);letter-spacing:.04em;margin-top:4px;}
.brandfoot .op,.brandfoot .src{font-family:var(--mono);font-size:10px;color:var(--ink-3);line-height:1.7;margin-top:8px;}

/* ── 下層：自治体一覧 ── */
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px;}
.filters .searchbox{margin-top:0;}
.sel{font-family:var(--sans);font-size:12.5px;color:var(--ink-2);background:var(--paper);border:1px solid var(--border);border-radius:var(--r-pill);padding:8px 14px;cursor:pointer;}
.rescount{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;margin:0 0 14px;}
.muni-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;}
@media(min-width:760px){.muni-grid{grid-template-columns:repeat(2,1fr);}}
.muni{background:var(--paper);padding:18px 20px;display:flex;justify-content:space-between;gap:14px;cursor:pointer;text-decoration:none;color:inherit;}
.muni:hover{background:var(--bg-soft);}
.muni .mn{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--ink);}
.muni .mm{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);text-transform:uppercase;margin-top:3px;}
.chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:11px;}
.chip{font-family:var(--sans);font-size:11px;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--r-pill);padding:2px 9px;}
.depth{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;color:var(--akane);border:1px solid var(--akane);border-radius:var(--r-bdg);padding:2px 7px;text-transform:uppercase;white-space:nowrap;height:fit-content;}
/* ── 下層：自治体詳細 ── */
.badge{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:var(--r-bdg);padding:3px 8px;white-space:nowrap;}
.b-hi{color:#fff;background:var(--akane);}
.b-mid{color:var(--akane);border:1px solid var(--akane);}
.b-prog{color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--border);}
.cmp{display:flex;flex-direction:column;gap:13px;}
.cmprow .cl{display:flex;justify-content:space-between;font-family:var(--sans);font-size:12.5px;color:var(--ink-2);margin-bottom:5px;}
.pledge{background:var(--paper);border:1px solid var(--border);border-radius:var(--r-card);padding:18px 20px;}
.pledge + .pledge{margin-top:12px;}
.pledge .pt{font-family:var(--serif);font-weight:600;font-size:17px;line-height:1.5;}
.prow{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:11px;}
.pledge .src{font-family:var(--sans);font-size:12px;color:var(--ink-3);margin-top:11px;line-height:1.7;}
.pledge .src a{color:var(--akane);text-decoration:underline;text-underline-offset:2px;}
.sim{display:grid;grid-template-columns:1fr;gap:10px;}
@media(min-width:680px){.sim{grid-template-columns:repeat(3,1fr);}}
.simcard{border:1px solid var(--border);border-radius:var(--r-card);padding:15px 16px;text-decoration:none;color:inherit;display:block;}
.simcard:hover{border-color:var(--akane);}
.simcard .sn{font-family:var(--serif);font-weight:600;font-size:15px;}
.simcard .sr{font-size:11.5px;color:var(--ink-3);margin-top:5px;line-height:1.6;}

/* ── アンカー着地位置（sticky ヘッダー分のオフセット） ── */
#prefectures,#explore,#about,#cityPage{scroll-margin-top:74px;}

/* ── フローティング：トップへ／一覧へ ── */
.totop{
  position:fixed;right:18px;bottom:18px;bottom:calc(18px + env(safe-area-inset-bottom));
  z-index:60;display:flex;align-items:center;gap:6px;
  padding:10px 16px;border:1px solid var(--akane);border-radius:var(--r-pill);
  background:var(--akane);color:#fff;cursor:pointer;
  font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.02em;
  box-shadow:0 4px 14px rgba(31,28,20,.18);
  opacity:0;transform:translateY(8px);transition:opacity .18s ease,transform .18s ease;
}
.totop.show{opacity:1;transform:translateY(0);}
.totop:hover{background:var(--akane-soft);border-color:var(--akane-soft);}
.totop .ico{font-size:14px;line-height:1;}
@media(max-width:767px){
  .totop{right:14px;bottom:calc(14px + env(safe-area-inset-bottom));padding:11px 15px;font-size:12.5px;}
}

/* ── 検証の進捗（トップ） ── */
.vp-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:2px 0 18px;}
.vp-num{font-family:var(--serif);font-weight:700;font-size:40px;color:var(--akane);line-height:1;}
.vp-of{font-family:var(--sans);font-size:13px;color:var(--ink-2);}
.vp-grid{display:grid;grid-template-columns:1fr;gap:12px 28px;}
@media(min-width:680px){.vp-grid{grid-template-columns:repeat(2,1fr);}}
.vp-row-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;}
.vp-label{font-family:var(--serif);font-size:14px;font-weight:600;color:var(--ink);}
.vp-row.done .vp-label{color:var(--akane);}
.vp-count{font-family:var(--mono);font-size:11px;color:var(--ink-3);}
.vp-bar{height:7px;border-radius:4px;background:var(--bg-soft);border:1px solid var(--border-soft);overflow:hidden;}
.vp-bar>span{display:block;height:100%;background:var(--akane);border-radius:4px;min-width:2px;transition:width .4s ease;}

/* ── 情報レベルchip（平易語） ── */
.chip.lv-verified{color:#00582c;background:#e3f0e8;border-color:#1a7244;font-weight:700;}
.chip.lv-official{color:var(--ink-2);background:var(--bg-soft);border-color:var(--border);}
.chip.lv-min{color:var(--ink-3);background:transparent;border-color:var(--border-soft);}
.chip.lv-todo{color:#8a5a00;background:#fbf3e2;border-color:#e3c98a;font-weight:600;}

/* ── 県ページのヘッダー（独立ページ化） ── */
.pref-head{padding:34px 0 6px;}
.pref-head .pref-kicker{font-family:var(--mono);font-size:10px;letter-spacing:.18em;font-weight:700;color:var(--akane);text-transform:uppercase;}
.pref-head h1{font-family:var(--serif);font-weight:700;font-size:clamp(28px,5vw,42px);line-height:1.15;margin:8px 0 0;}
.pref-head .pref-desc{font-size:14px;color:var(--ink-2);margin:12px 0 0;line-height:1.8;max-width:60ch;}
