/* まちの随契 — design tokens + components（モック再現・数字を持たないコード） */
:root{
  --ink:#0f172a; --mut:#64748b; --line:#e6ebf2; --bg:#f5f8fc; --card:#fff;
  --blue:#2563eb; --teal:#0d9488; --amber:#f59e0b; --red:#ef4444; --navy:#0b2545;
  --r:14px; --r2:10px; --sp:16px; --sh:0 1px 3px rgba(15,23,42,.06),0 8px 24px rgba(15,23,42,.04);
  --teal-bg:#e8f5f3; --blue-bg:#e8f1fe; --amber-bg:#fef3e2; --gray-mz:#e3e8ef;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:system-ui,"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;margin:0;background:var(--bg);color:var(--ink);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}
/* header */
header{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.hd{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px}
.brand .lg{font-size:25px;line-height:1}
.brand b{font-size:17px;letter-spacing:.2px}
.brand small{display:block;color:var(--mut);font-size:10.5px;font-weight:400;margin-top:1px}
nav a{color:#475569;font-size:13px;margin-left:20px;font-weight:500}
nav a:hover{color:var(--blue)}
/* hero */
.hero{display:grid;grid-template-columns:0.92fr 1.08fr;gap:30px;padding:40px 0 14px;align-items:start}
h1.big{font-size:42px;line-height:1.28;margin:0 0 18px;letter-spacing:-.6px;font-weight:800}
.lead{color:#334155;font-size:15px;margin:0 0 22px;max-width:30em}
.feat{display:flex;gap:16px;margin:22px 0}
.feat .f{flex:1}
.feat .ic{width:34px;height:34px;border-radius:9px;background:var(--teal-bg);color:var(--teal);display:flex;align-items:center;justify-content:center;font-size:17px;margin-bottom:6px}
.feat b{font-size:12.5px;display:block}
.feat small{color:var(--mut);font-size:11px}
.guard{background:#fffdf4;border:1px solid #fde9b8;border-radius:var(--r);padding:15px 17px;margin:18px 0 0}
.guard b{font-size:13px;color:#92660a}
.guard p{margin:6px 0 0;font-size:12px;color:#7c5e1a}
.guard a{font-size:12px;font-weight:600}
/* stat bar */
.statbar{display:grid;grid-template-columns:repeat(4,1fr);background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);margin-bottom:14px}
.sb{padding:12px 10px;text-align:center;border-left:1px solid var(--line)}
.sb:first-child{border-left:none}
.sb .l{font-size:11px;color:var(--mut)}
.sb .n{font-size:27px;font-weight:800;font-feature-settings:"tnum";line-height:1.15}
.sb .p{font-size:11px;color:var(--mut);font-feature-settings:"tnum"}
.sb.c2 .n{color:var(--blue)} .sb.c3 .n{color:var(--teal)} .sb.c4 .n{color:var(--red)}
/* map card */
.mapcard{background:linear-gradient(180deg,#eaf2fb,#e3eefa);border:1px solid var(--line);border-radius:var(--r);padding:14px;position:relative;box-shadow:var(--sh)}
.maphd{display:inline-flex;flex-direction:column;background:var(--navy);color:#fff;font-size:12px;font-weight:600;padding:6px 13px;border-radius:9px;margin-bottom:6px}
.maphd small{color:#9fb6d6;font-size:10px;font-weight:400}
.maptools{position:absolute;right:24px;top:64px;display:flex;flex-direction:column;gap:5px;z-index:4}
.maptools button{width:30px;height:30px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:17px;cursor:pointer;box-shadow:var(--sh);color:#334155}
.prefsel{position:absolute;right:24px;bottom:22px;z-index:4}
.prefsel select{border:1px solid var(--line);background:#fff;border-radius:9px;padding:7px 11px;font-size:12px;box-shadow:var(--sh);cursor:pointer}
#mapsvg{width:100%;height:430px;display:block;cursor:grab;touch-action:none}
#mapsvg:active{cursor:grabbing}
.muni{stroke:#fff;stroke-width:.18;vector-effect:non-scaling-stroke}
.muni.hl{stroke:#0f172a;stroke-width:1.4}
.prefline{fill:none;stroke:#fff;stroke-width:.5;vector-effect:non-scaling-stroke;pointer-events:none}
.dist{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:var(--r2);padding:11px 13px;position:absolute;left:24px;top:64px;width:218px;font-size:12px;box-shadow:var(--sh);z-index:4}
.dist h4{margin:0 0 1px;font-size:12.5px}
.dist .s{color:var(--mut);font-size:10px;margin-bottom:7px}
.dist .row{display:flex;align-items:center;gap:7px;margin:4px 0}
.dist .sw{width:11px;height:11px;border-radius:3px}
.dist .v{margin-left:auto;font-weight:700;font-feature-settings:"tnum"}
.dist .nt{font-size:9px;color:var(--mut);margin-top:7px;border-top:1px solid var(--line);padding-top:5px}
.tip{position:absolute;pointer-events:none;background:#0f172a;color:#fff;font-size:11px;padding:5px 8px;border-radius:6px;opacity:0;transition:opacity .1s;z-index:9;white-space:nowrap}
/* search */
.search{position:relative;margin:10px 0 0}
.search input{width:100%;padding:9px 13px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#fff}
.sugg{position:absolute;z-index:8;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:9px;margin-top:4px;max-height:240px;overflow:auto;box-shadow:var(--sh)}
.sugg div{padding:7px 12px;font-size:12.5px;cursor:pointer}
.sugg div:hover{background:var(--bg)}
.hide{display:none}
/* selected card */
.selcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;box-shadow:var(--sh);min-height:60px}
.selcard .ph{color:var(--mut);font-size:13px;text-align:center;padding:18px 0}
.selcard h3{margin:0 0 4px;font-size:16px}
.badge{display:inline-block;padding:1px 9px;border-radius:9px;font-size:11px;color:#fff;margin-right:4px}
.selcard dl{margin:10px 0 0}.selcard dt{font-size:10.5px;color:var(--mut);margin-top:9px}
.selcard dd{margin:0;font-size:13px}
.selcard .ct{border-radius:9px;padding:9px 11px;font-size:12px;margin-top:11px}
.ct.unk{background:var(--blue-bg);color:#1e3a8a}.ct.yes{background:var(--teal-bg);color:#0f5f57}.ct.gai{background:var(--amber-bg);color:#92660a}
/* sections */
section{padding:34px 0;border-top:1px solid var(--line)}
h2{font-size:21px;margin:0 0 4px;font-weight:800}
.h2sub{font-size:12px;color:var(--mut);font-weight:400}
/* rings */
.rings{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:16px}
.ring{text-align:center}
.ring svg{width:82px;height:82px}
.ring .rl{font-size:11px;color:#334155;margin-top:3px}
/* steps + cta */
.joinrow{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.joincol{background:var(--navy);border-radius:18px;padding:22px;color:#cfdaeb}
.joincol h3{color:#fff;margin:0 0 4px;font-size:19px}
.joincol .sl{color:#8aa0c2;font-size:12px;margin:0 0 16px}
.step{display:flex;gap:13px;align-items:flex-start;background:#12305a;border:1px solid #1c3f6e;border-radius:12px;padding:13px 15px;margin:10px 0}
.step .num{width:27px;height:27px;border-radius:50%;background:#fff;color:var(--navy);font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.step b{color:#fff;font-size:14px}.step p{margin:3px 0 0;font-size:12.5px;color:#a9bcd6}
.cta{display:flex;align-items:center;justify-content:space-between;background:var(--amber);color:#3b2606;border-radius:12px;padding:14px 17px;margin-top:14px;font-weight:800;font-size:15px}
.cta small{display:block;font-weight:400;font-size:11px;color:#7c5a14}
.cta .ar{font-size:18px}
.dl{display:flex;align-items:center;gap:8px;color:#cfdaeb;font-size:12.5px;margin-top:12px}
.tmpl{margin-top:12px}
.tmpl summary{cursor:pointer;font-size:13px;color:#fff;font-weight:600}
.tmpl pre{white-space:pre-wrap;background:#0a1f3c;border:1px solid #1c3f6e;border-radius:8px;padding:11px;font-size:11px;line-height:1.7;color:#bcd0ec;font-family:ui-monospace,Consolas,monospace;margin:8px 0}
/* 3 cols */
.cols3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cardx{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:17px;box-shadow:var(--sh)}
.cardx h3{margin:0 0 12px;font-size:15px}
.feedph{background:var(--bg);border:1px dashed #c3cede;border-radius:11px;padding:22px 14px;text-align:center;color:var(--mut);font-size:12px}
.feedph b{display:block;color:#475569;font-size:13px;margin-bottom:3px}
.eq{display:flex;align-items:stretch;gap:9px;margin:6px 0}
.eq .box{background:var(--amber-bg);border:1px solid #fbe0b0;border-radius:9px;padding:9px 10px;font-size:11px;flex:1;color:#7c5e1a}
.eq .neq{display:flex;align-items:center;color:var(--mut);font-size:17px;font-weight:700}
.warnh{display:flex;align-items:center;gap:6px}
.minirow{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px solid #eef2f7}
.minirow b{font-feature-settings:"tnum"}
.linklist a{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #eef2f7;font-size:13px;color:#334155}
.linklist a:hover{color:var(--blue)}
.faq details{border-bottom:1px solid #eef2f7}
.faq summary{cursor:pointer;padding:10px 0;font-size:13px;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"›";color:var(--mut);margin-right:8px}
.faq p{font-size:12px;color:var(--mut);margin:0 0 11px 18px}
/* footer */
.foot{background:radial-gradient(900px 400px at 28% 60%,rgba(245,200,120,.18),transparent 60%),linear-gradient(120deg,#0a1f3c,#13315c);color:#cdd9e8;margin-top:36px}
.footin{display:grid;grid-template-columns:1.25fr .9fr .85fr;gap:26px;padding:40px 0;align-items:center}
.foot h3{color:#fff;font-size:22px;margin:0;line-height:1.45;font-weight:800}
.foot .btn{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--amber);color:#3b2606;border-radius:11px;padding:12px;font-weight:800;margin:8px 0}
.foot .btn.ghost{background:transparent;border:1px solid #3f5a82;color:#dbe7f5}
.foot .nos b{color:#fff;font-size:17px}
.foot .nos small{color:#8fa6c4}
.foot .nos p{font-size:12.5px;margin:0 0 10px}
.footbar{border-top:1px solid #234168;font-size:11px;color:#85a0c2;padding:13px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:6px}
@media(max-width:900px){.hero{grid-template-columns:1fr}.joinrow{grid-template-columns:1fr}.cols3{grid-template-columns:1fr}.rings{grid-template-columns:repeat(4,1fr)}.statbar{grid-template-columns:repeat(2,1fr)}.footin{grid-template-columns:1fr}nav{display:none}h1.big{font-size:33px}.dist{position:static;width:auto;margin-bottom:8px}.maptools,.prefsel{position:static;flex-direction:row;margin-top:6px}}
/* status tables */
.stbl{width:100%;border-collapse:collapse;font-size:13px}
.stbl th{text-align:left;color:var(--mut);font-size:11px;font-weight:600;border-bottom:1px solid var(--line);padding:6px 4px}
.stbl td{padding:6px 4px;border-bottom:1px solid #f1f5f9}
.stbl td.num,.stbl th.num{text-align:right;font-feature-settings:"tnum"}
.dot{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:-1px}
/* page map (fullscreen) */
.pagemap{background:linear-gradient(180deg,#eaf2fb,#e3eefa);border:1px solid var(--line);border-radius:var(--r);padding:14px;position:relative;box-shadow:var(--sh)}
.pagemap #mapsvg{height:600px}
.maplayout{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}
@media(max-width:900px){.maplayout{grid-template-columns:1fr}}
