.q-block {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px;
  margin-bottom: 12px;
}
.q-label {
  font-size: 13px; font-weight: 700; color: var(--ink);
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.q-num {
  width: 22px; height: 22px;
  background: var(--accent); color: #fff;
  border-radius: 50%;
  font-size: 11px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.check-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
@media (min-width: 480px) { .check-grid { grid-template-columns: repeat(3, 1fr); } }
.chk-item {
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 9px 10px;
  cursor: pointer;
  font-size: 12px; color: var(--ink2);
  display: flex; align-items: center; gap: 7px;
  transition: all .15s;
  user-select: none;
}
.chk-item:hover { border-color: var(--accent); background: var(--accent-light); }
.chk-item.on { border-color: var(--accent); background: var(--accent-light); color: var(--accent); font-weight: 700; }
.chk-item input { display: none; }
.chk-box {
  width: 16px; height: 16px; min-width: 16px;
  border: 1.5px solid var(--border);
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  font-size:12px; color: transparent;
  transition: all .15s;
}
.chk-item.on .chk-box { background: var(--accent); border-color: var(--accent); color: #fff; }

/* 診断結果 */
.priority-card {
  border-radius: var(--r);
  padding: 14px 16px;
  margin-bottom: 10px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
}
.pri-now { background: #fff0f0; border: 1.5px solid #f0b0b0; }
.pri-soon { background: #fff8e0; border: 1.5px solid #e0c860; }
.pri-later { background: var(--green-light); border: 1.5px solid rgba(42,107,60,.25); }
.pri-ok { background: #f4f4f0; border: 1.5px solid var(--border); }

.pri-badge {
  font-size:12px; font-weight: 700;
  padding: 3px 9px;
  border-radius: var(--r-full);
  white-space: nowrap;
  flex-shrink: 0;
  margin-top: 2px;
}
.badge-now  { background: #c00; color: #fff; }
.badge-soon { background: #d4900a; color: #fff; }
.badge-later{ background: var(--green); color: #fff; }
.badge-ok   { background: var(--ink3); color: #fff; }

.pri-body { flex: 1; }
.pri-name { font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 3px; }
.pri-reason { font-size: 12px; color: var(--ink2); margin-bottom: 4px; line-height: 1.6; }
.pri-cost { font-family: 'DM Mono', monospace; font-size: 12px; color: var(--accent); }

.timeline-bar {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 16px;
  margin-bottom: 14px;
}
.tl-title { font-size: 13px; font-weight: 700; color: var(--ink2); margin-bottom: 14px; }
.tl-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  font-size: 12px;
}
.tl-row:last-child { margin-bottom: 0; }
.tl-label { width: 100px; min-width: 100px; color: var(--ink2); font-weight: 700; }
.tl-track { flex: 1; height: 10px; background: var(--border); border-radius: 5px; position: relative; overflow: visible; }
.tl-fill {
  height: 100%; border-radius: 5px;
  position: relative;
}
.fill-now  { background: #c00; }
.fill-soon { background: #d4900a; }
.fill-later{ background: var(--green); }
.tl-cost { width: 70px; min-width: 70px; text-align: right; font-family: 'DM Mono', monospace; color: var(--accent); }

.total-budget {
  background: var(--primary);
  border-radius: var(--r-lg);
  padding: 22px 16px;
  margin-bottom: 14px;
  position: relative; overflow: hidden;
}
.total-budget::before {
  content:''; position:absolute; top:-40px; right:-40px;
  width:160px; height:160px;
  background:radial-gradient(circle,rgba(107,159,212,.25),transparent 70%);
  pointer-events:none;
}
.tb-tag { font-size:11px;color:var(--primary-mid);font-family:'DM Mono',monospace;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px; }
.tb-val { font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(26px,6vw,42px);font-weight:900;color:#fff;margin-bottom:4px; }
.tb-val em { color:var(--primary-mid);font-style:normal;font-size:.55em; }
/* タイムラインアイテム */
.tl-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  border-radius: var(--r);
  margin-bottom: 8px;
  background: rgba(255,255,255,0.06);
  border-left: 3px solid var(--border);
}
.tl-urgent { border-left-color: #c00; background: rgba(200,0,0,0.08); }
.tl-soon   { border-left-color: #d4900a; background: rgba(212,144,10,0.08); }
.tl-later  { border-left-color: var(--green, #16a34a); background: rgba(22,163,74,0.06); }
.tl-icon { font-size: 22px; flex-shrink: 0; }
.tl-body { flex: 1; min-width: 0; }
.tl-name { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 2px; }
.tl-note { font-size: 12px; color: rgba(255,255,255,0.55); }
.tl-cost { width: 72px; min-width: 72px; text-align: right;
  font-family: 'DM Mono', monospace; font-size: 14px;
  font-weight: 700; color:var(--primary-mid); flex-shrink: 0; }
