:root{
  --bg:#f3f4f6;
  --panel:#ffffff;
  --ink:#1f2733;
  --sub:#5b6675;
  --line:#e1e5ea;
  --brand:#0f4c81;
  --brand-d:#0c3c66;
  --accent:#2a9d8f;
  --danger:#c0392b;
  --warn:#b7791f;
  --ok:#2a9d8f;
  --radius:10px;
  --shadow:0 2px 10px rgba(20,30,50,.06);
}
*{box-sizing:border-box}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",-apple-system,"Segoe UI",sans-serif;
  line-height:1.7;font-size:15px;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

.topbar{
  background:var(--brand);color:#fff;padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.topbar .brand{font-weight:700;font-size:1.05rem;letter-spacing:.04em}
.topbar .brand small{display:block;font-weight:400;font-size:.7rem;opacity:.8;letter-spacing:.1em}
.topbar nav a{color:#dbe7f2;margin-left:16px;font-size:.85rem}
.topbar nav a:hover{color:#fff}
.topbar .who{font-size:.8rem;opacity:.9}

.wrap{max-width:1440px;margin:28px auto;padding:0 18px}
.wrap.narrow{max-width:560px}
.wrap.mid{max-width:760px}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;margin-bottom:22px}
h1.page{font-size:1.4rem;margin:0 0 4px;font-weight:700}
.lead{color:var(--sub);font-size:.9rem;margin:0 0 22px}
h2.sec{font-size:1.05rem;border-left:4px solid var(--brand);padding-left:10px;margin:26px 0 14px}

label.field{display:block;margin-bottom:16px;font-size:.85rem;font-weight:600;color:var(--ink)}
label.field .req{color:var(--danger);font-size:.75rem;margin-left:4px}
label.field input[type=text],
label.field input[type=password],
label.field input[type=number],
label.field select,
label.field textarea{
  display:block;width:100%;margin-top:6px;padding:10px 12px;
  border:1px solid #ccd2da;border-radius:8px;font-size:1rem;font-family:inherit;background:#fff;
}
label.field textarea{min-height:110px;resize:vertical;line-height:1.6}
label.field .hint{display:block;font-weight:400;color:var(--sub);font-size:.78rem;margin-top:4px}

.btn{display:inline-block;border:none;border-radius:30px;padding:12px 28px;font-size:1rem;font-weight:700;cursor:pointer;font-family:inherit;transition:.15s}
.btn.primary{background:var(--brand);color:#fff}
.btn.primary:hover{background:var(--brand-d)}
.btn.accent{background:var(--accent);color:#fff}
.btn.accent:hover{filter:brightness(.93)}
.btn.ghost{background:#eef1f5;color:var(--ink)}
.btn.ghost:hover{background:#e2e7ee}
.btn.danger{background:var(--danger);color:#fff}
.btn.sm{padding:7px 16px;font-size:.82rem}
.btn:disabled{opacity:.5;cursor:not-allowed}
.actions{margin-top:26px}
.actions.center{text-align:center}

table{width:100%;border-collapse:collapse;font-size:.88rem}
th,td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}
th{background:#f7f9fb;color:var(--sub);font-weight:600;font-size:.8rem}
tr:hover td{background:#fafbfc}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
/* テーブルを横スクロール可能にするラッパ（スマホで列が潰れるのを防ぐ） */
.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}

.tag{display:inline-block;padding:2px 10px;border-radius:20px;font-size:.74rem;font-weight:700}
.tag.green{background:#e3f3f0;color:#1c7a6e}
.tag.gray{background:#eceff3;color:#5b6675}
.tag.blue{background:#e3edf6;color:#0f4c81}
.tag.amber{background:#fbf0db;color:#9a6512}
.tag.red{background:#fae3df;color:#a5281b}

.msg{padding:12px 16px;border-radius:8px;margin-bottom:18px;font-size:.9rem}
.msg.err{background:#fbe9e7;border:1px solid #f3c0b8;color:#a5281b}
.msg.ok{background:#e6f4f1;border:1px solid #b7e0d8;color:#1c7a6e}
.msg.info{background:#e8eef5;border:1px solid #c4d4e6;color:#0f4c81}

.kv{display:grid;grid-template-columns:140px 1fr;gap:8px 16px;font-size:.9rem}
.kv dt{color:var(--sub);font-weight:600}
.kv dd{margin:0}

.report{white-space:pre-wrap;line-height:1.85;font-size:.95rem;background:#fbfcfd;border:1px solid var(--line);border-radius:8px;padding:20px}

.creds{font-family:"SF Mono",Consolas,monospace;background:#0f1b2a;color:#cfe3f5;padding:14px 16px;border-radius:8px;font-size:.85rem;white-space:pre;overflow:auto}

.footer{text-align:center;color:#9aa4b0;font-size:.75rem;padding:30px 0}

.q-card{padding:18px 4px;border-bottom:1px solid var(--line)}
.q-card:last-child{border-bottom:none}
.q-text{font-weight:600;margin-bottom:14px;font-size:1rem}
.q-num{color:var(--brand);font-weight:700;margin-right:8px}
.opts{display:flex;gap:6px}
.opt{flex:1 1 0;min-width:0}
.opt input{display:none}
.opt label{display:block;text-align:center;padding:10px 4px;border:1px solid #ccd2da;border-radius:8px;cursor:pointer;font-size:.78rem;color:var(--sub);transition:.12s;background:#fff;height:100%;overflow:hidden}
.opt input:checked + label{background:var(--brand);color:#fff;border-color:var(--brand);font-weight:700}
.opt label:hover{border-color:var(--brand)}
.opt .n{display:block;font-size:1.1rem;font-weight:700;margin-bottom:2px}
/* 文字ラベル（全く違う等）は狭い画面では隠して数字だけにする */
.opt .lbl{display:block;font-size:.72rem;line-height:1.2}

.progress{position:sticky;top:0;background:rgba(255,255,255,.96);backdrop-filter:blur(4px);padding:12px 0;border-bottom:1px solid var(--line);z-index:5;margin:-26px -26px 18px;padding-left:26px;padding-right:26px}
.progress .bar{height:8px;background:#e7ebf0;border-radius:6px;overflow:hidden}
.progress .bar i{display:block;height:100%;background:var(--accent);width:0;transition:width .2s}
.progress .txt{font-size:.8rem;color:var(--sub);margin-bottom:6px}

@media(max-width:600px){
  .kv{grid-template-columns:1fr}
  /* 選択肢は折り返さず1行。狭いので文字ラベルは隠し数字中心に */
  .opts{gap:4px}
  .opt label{padding:8px 2px;font-size:.7rem}
  .opt .n{font-size:1rem}
  .opt .lbl{display:none}
  /* スクロールラッパ内のテーブルは縮めず、横スクロールで見せる */
  .table-scroll table{min-width:720px}
  .table-scroll th{white-space:nowrap}
  /* セル内の文字が縦に折り返されないようにする */
  .table-scroll td{white-space:nowrap}
}
/* さらに狭い画面では選択肢のパディングを詰める（10段階対策）*/
@media(max-width:480px){
  .opt label{padding:7px 1px}
  .opt .n{font-size:.92rem}
}
