:root{
  --accent:#2563eb; --accent-dark:#1d4ed8; --ok:#16a34a; --bg:#f8fafc;
  --card:#fff; --line:#e2e8f0; --ink:#0f172a; --muted:#64748b; --maxw:820px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,"Segoe UI","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  margin:0;background:var(--bg);color:var(--ink);line-height:1.75;-webkit-font-smoothing:antialiased}
a{color:var(--accent)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}

/* header / footer */
.site-head{background:var(--card);border-bottom:1px solid var(--line)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:56px}
.brand{font-weight:800;font-size:1.05rem;color:var(--ink);text-decoration:none}
.brand span{color:var(--accent)}
.nav a{margin-left:16px;font-size:.9rem;text-decoration:none;color:var(--muted)}
.nav a:hover{color:var(--accent)}
.site-foot{margin-top:56px;border-top:1px solid var(--line);background:var(--card)}
.site-foot .wrap{padding:24px 16px;font-size:.82rem;color:var(--muted)}
.site-foot a{color:var(--muted);margin-right:14px}

/* hero + tool */
h1{font-size:1.5rem;line-height:1.4;margin:24px 0 6px}
.lead{color:var(--muted);margin-top:0}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 22px}
.badge{background:#ecfdf5;color:var(--ok);border:1px solid #a7f3d0;border-radius:999px;
  font-size:.8rem;padding:3px 11px;font-weight:600}
#drop{border:2px dashed #94a3b8;border-radius:14px;background:var(--card);padding:44px 20px;
  text-align:center;cursor:pointer;transition:.15s}
#drop.hover{border-color:var(--accent);background:#eff6ff}
#drop strong{color:var(--accent)}
.controls{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin:18px 0}
.controls label{font-size:.9rem;color:var(--muted)}
select{padding:4px 8px;border:1px solid var(--line);border-radius:6px}
#status{font-size:.9rem;color:var(--muted);min-height:1.4em;margin:8px 0}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-top:16px}
.item{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.item img{width:100%;height:120px;object-fit:cover;display:block;background:#f1f5f9}
.item .meta{padding:8px 10px;font-size:.78rem;color:var(--muted);word-break:break-all}
.item a.dl{display:block;text-align:center;padding:8px;background:var(--accent);color:#fff;
  text-decoration:none;font-size:.85rem;font-weight:600}
.item a.dl:hover{background:var(--accent-dark)}
.item .err{color:#dc2626;padding:8px 10px;font-size:.8rem}
.btn{padding:10px 18px;background:var(--ok);color:#fff;border:none;border-radius:8px;
  font-weight:600;cursor:pointer;font-size:.92rem}
.btn[hidden]{display:none}
.btn:disabled{opacity:.5;cursor:default}
#zipbtn{margin-top:16px}

/* article / content */
.content{padding:8px 0 8px}
.content h2{font-size:1.2rem;margin:32px 0 8px;padding-top:8px;border-top:1px solid var(--line)}
.content h3{font-size:1.03rem;margin:22px 0 6px}
.content p,.content li{font-size:.98rem}
.content ul,.content ol{padding-left:1.3em}
.content .cta{display:inline-block;margin:8px 0;padding:10px 18px;background:var(--accent);
  color:#fff;text-decoration:none;border-radius:8px;font-weight:600}
.content .note{background:#f1f5f9;border-left:4px solid var(--accent);padding:12px 16px;
  border-radius:6px;margin:16px 0;font-size:.92rem}
.breadcrumb{font-size:.8rem;color:var(--muted);margin:16px 0 0}
.breadcrumb a{text-decoration:none}
.updated{font-size:.8rem;color:var(--muted);margin-top:4px}
.related{margin-top:12px}
.related a{display:block;padding:6px 0}

/* small utilities (kept out of inline style= so CSP style-src can stay strict) */
.mt24{margin-top:24px}
.drop-main{margin:0 0 6px}
.drop-sub{margin:0;font-size:.85rem;color:var(--muted)}
.foot-note{margin:.6em 0 0}
