/* ─── Layout ──────────────────────────────────────── */
.page { display: grid; grid-template-columns: 1fr 300px; gap: 22px; padding: 1.75rem 2rem; max-width: 940px; margin: 0 auto; }
@media (max-width: 640px) { .page { grid-template-columns: 1fr; } .preview-col { display: none; } }

/* ─── Form card ───────────────────────────────────── */
.form-card { background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--radius-lg); padding: 1.75rem; }
.form-head { margin-bottom: 1.4rem; }
.form-head h1 { font-size: 1.3rem; font-weight: 800; margin-bottom: 4px; }
.form-head p { font-size: 13px; color: var(--text-soft); }

/* ─── Progress ────────────────────────────────────── */
.progress-bar { height: 4px; background: var(--border-soft); border-radius: 2px; margin-bottom: 6px; overflow: hidden; }
.progress-fill { height: 100%; background: var(--green); border-radius: 2px; transition: width .4s; }
.progress-row { display: flex; justify-content: space-between; margin-bottom: 1.4rem; }

/* ─── Pill group ──────────────────────────────────── */
.pill-group { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 6px; }
.pill { font-size: 12px; padding: 5px 12px; }

/* ─── Level selector ──────────────────────────────── */
.level-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 6px; }
.level-opt { padding: 10px 6px; border-radius: var(--radius-md); border: 1px solid var(--border); text-align: center; cursor: pointer; font-size: 13px; font-weight: 500; color: var(--text-soft); background: var(--surface); transition: all .15s; user-select: none; }
.level-opt:hover { border-color: var(--green); }
.level-opt.active { background: var(--green-light); color: var(--green-dark); border-color: var(--green); }
.lv-icon { display: block; font-size: 18px; margin-bottom: 4px; }

/* ─── Tip box ─────────────────────────────────────── */
.tip-box { background: var(--bg); border-radius: var(--radius-md); padding: 11px 13px; margin-top: 1.1rem; font-size: 12px; color: var(--text-soft); line-height: 1.55; }
.tip-box strong { color: var(--text); }

/* ─── Preview column ──────────────────────────────── */
.preview-col { position: sticky; top: 1.5rem; align-self: start; }
.preview-label { font-size: 11px; font-weight: 500; color: var(--text-muted); letter-spacing: .5px; text-transform: uppercase; margin-bottom: 8px; }

/* ─── Checklist ───────────────────────────────────── */
.check-item { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.check-item.done { color: var(--text); }
.check-item.pending { color: var(--text-muted); }
