* { box-sizing: border-box; }
body { margin:0; font-family: system-ui, -apple-system, "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif; background:#f6f7fb; color:#111; }
.wrap { width:min(980px, 92vw); margin:0 auto; }
.site-header { padding: 24px 0; background:#fff; border-bottom:1px solid #e7e8ee; }
.site-header h1 { margin:0 0 6px; font-size: 22px; }
.sub { margin:0; color:#555; }
.card { background:#fff; border:1px solid #e7e8ee; border-radius:14px; padding:16px; margin:16px 0; box-shadow: 0 8px 22px rgba(0,0,0,.04); }
.label { display:block; font-weight:600; margin: 8px 0 6px; }
textarea, select { width:100%; padding:10px; border-radius:12px; border:1px solid #d9dbe7; font-size: 14px; }
.hint { color:#666; margin:0 0 10px; }
.grid { display:grid; grid-template-columns: 1fr 1fr; gap:12px; margin:10px 0; }
.btn { appearance:none; border:0; background:#111; color:#fff; padding:10px 14px; border-radius:12px; cursor:pointer; font-weight:700; }
.btn.small { padding:6px 10px; border-radius:10px; font-size: 12px; }
.meta { color:#444; margin-bottom: 12px; }
.candidate { border-top:1px solid #eee; padding-top: 12px; margin-top: 12px; }
.candidate-head { display:flex; align-items:center; gap:10px; justify-content:space-between; flex-wrap:wrap; }
.score { color:#666; font-size: 12px; }
.site-footer { padding: 20px 0; color:#666; }
.list { margin: 8px 0 0; }
@media (max-width: 720px){
  .grid { grid-template-columns: 1fr; }
}
