:root{
  --bg:#F2F6F7;
  --surface:#FFFFFF;
  --ink:#14272C;
  --ink-soft:#516268;
  --ink-faint:#7C8B90;
  --line:#DDE7E9;
  --line-soft:#EAF1F2;
  --deep:#0E3940;
  --deep-700:#10454E;
  --teal:#2C7A87;
  --teal-soft:#E2EFF0;
  --gold:#BE7E1E;
  --gold-bright:#E0A53A;
  --gold-soft:#F7ECD6;
  --alert-bg:#FBEDEC;
  --alert-line:#E7CDCB;
  --alert-ink:#9A3328;
  --shadow:0 1px 2px rgba(14,57,64,.05), 0 10px 30px rgba(14,57,64,.07);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:1060px;margin:0 auto;padding:32px 20px 80px}

/* ---------- header ---------- */
header.head{margin-bottom:26px}
.eyebrow{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin:0 0 10px
}
h1{
  font-family:'Fraunces',Georgia,serif;
  font-weight:500;font-size:clamp(28px,4.6vw,42px);
  line-height:1.08;margin:0 0 8px;letter-spacing:-.01em;color:var(--deep)
}
.lede{font-size:16px;color:var(--ink-soft);max-width:62ch;margin:0}

.progress-shell{margin-top:22px}
.progress-meta{display:flex;justify-content:space-between;align-items:baseline}
.progress-meta span{font-size:13px;color:var(--ink-faint);font-weight:500}
.progress-meta b{color:var(--deep);font-weight:600}

/* ---------- layout ---------- */
.grid{display:grid;grid-template-columns:288px 1fr;gap:26px;margin-top:30px;align-items:start}

/* ---------- stepper rail ---------- */
nav.rail{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:10px;position:sticky;top:20px;box-shadow:var(--shadow)
}
.rail-title{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);
  font-weight:600;padding:10px 12px 8px
}
.step-btn{
  display:flex;gap:12px;align-items:center;width:100%;text-align:left;
  background:none;border:0;padding:11px 12px;border-radius:10px;cursor:pointer;
  font-family:inherit;font-size:14px;color:var(--ink-soft);transition:background .15s
}
.step-btn:hover{background:var(--line-soft)}
.step-btn.active{background:var(--teal-soft);color:var(--deep);font-weight:600}
.step-btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.marker{
  flex:0 0 26px;height:26px;border-radius:50%;display:grid;place-items:center;
  border:1.5px solid var(--line);font-size:12.5px;font-weight:600;color:var(--ink-faint);
  background:var(--surface);transition:all .2s
}
.step-btn.active .marker{border-color:var(--deep);color:var(--deep)}
.step-btn.done .marker{background:var(--gold);border-color:var(--gold);color:#fff}
.step-btn.done{color:var(--ink)}
.marker svg{width:13px;height:13px;display:none}
.step-btn.done .marker svg{display:block}
.step-btn.done .marker .num{display:none}
.step-label{flex:1;min-width:0}

/* ---------- content card ---------- */
main.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:34px 36px;box-shadow:var(--shadow);min-height:420px
}
.step-no{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:600;margin:0 0 6px}
.card h2{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:27px;color:var(--deep);margin:0 0 6px;letter-spacing:-.01em}
.card .sub{font-size:15.5px;color:var(--ink-soft);margin:0 0 22px;max-width:60ch}

/* ---------- alert + body copy ---------- */
.alert-block{background:var(--alert-bg);border:1px solid var(--alert-line);border-radius:12px;padding:16px 18px;margin:4px 0 20px}
.alert-caps{font-size:13.5px;font-weight:700;letter-spacing:.03em;color:var(--alert-ink);text-transform:uppercase;margin:0 0 10px;line-height:1.45}
.alert-bold{font-size:16px;font-weight:600;color:var(--ink);margin:0;line-height:1.5}
.bodytext{font-size:14.5px;color:var(--ink-soft);margin:0 0 14px;max-width:62ch}
.bodytext:last-child{margin-bottom:18px}
.bodytext b{color:var(--ink);font-weight:600}
.bodytext.alert{background:var(--alert-bg);border:1px solid var(--alert-line);border-radius:12px;padding:14px 16px;color:#5a2a22}
.bodytext.alert b{color:var(--alert-ink)}

.tasks{list-style:none;margin:0 0 4px;padding:0}
.tasks li{
  display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-top:1px solid var(--line-soft)
}
.tasks li:first-child{border-top:0}
.check{
  flex:0 0 22px;height:22px;margin-top:1px;border:1.6px solid var(--line);border-radius:6px;
  background:var(--surface);cursor:pointer;display:grid;place-items:center;transition:all .15s;padding:0
}
.check svg{width:13px;height:13px;opacity:0;transform:scale(.6);transition:all .15s;color:#fff}
.check.on{background:var(--teal);border-color:var(--teal)}
.check.on svg{opacity:1;transform:scale(1)}
.check:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.task-body{flex:1}
.task-body .t{font-size:15px;font-weight:500;color:var(--ink);transition:color .15s}
.tasks li.checked .t{color:var(--ink-faint);text-decoration:line-through;text-decoration-color:var(--line)}
.task-body .d{font-size:13.5px;color:var(--ink-soft);margin-top:2px}

.note{
  margin-top:22px;display:flex;gap:12px;background:var(--gold-soft);
  border:1px solid #ECDDBF;border-radius:12px;padding:14px 16px
}
.note .ic{flex:0 0 20px;color:var(--gold);margin-top:1px}
.note p{margin:0;font-size:13.8px;color:#6B5418}
.note b{color:#5A460F}

.why{margin-top:18px;font-size:13.8px;color:var(--ink-soft);padding-left:14px;border-left:3px solid var(--teal-soft)}
.why b{color:var(--deep)}

/* link out */
.linkout{
  display:inline-flex;align-items:center;gap:7px;margin-top:16px;text-decoration:none;
  background:var(--deep);color:#fff;font-weight:600;font-size:14px;padding:10px 16px;border-radius:10px;transition:background .15s
}
.linkout:hover{background:var(--deep-700)}
.linkout svg{width:14px;height:14px}

/* nav buttons */
.footnav{display:flex;justify-content:space-between;gap:12px;margin-top:30px;padding-top:22px;border-top:1px solid var(--line-soft)}
.btn{
  font-family:inherit;font-size:14.5px;font-weight:600;padding:11px 20px;border-radius:10px;
  cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--ink);transition:all .15s
}
.btn:hover{border-color:var(--ink-faint)}
.btn.primary{background:var(--deep);color:#fff;border-color:var(--deep)}
.btn.primary:hover{background:var(--deep-700)}
.btn:disabled{opacity:.4;cursor:default}
.btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

/* finish state */
.done-flag{display:none;text-align:center;padding:18px 0 4px}
.done-flag.show{display:block}
.done-flag .ring{width:58px;height:58px;border-radius:50%;background:var(--gold-soft);display:grid;place-items:center;margin:0 auto 14px;color:var(--gold)}
.done-flag .ring svg{width:28px;height:28px}

.toolbar{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.toolbar .btn{padding:9px 15px;font-size:13.5px}

footer.foot{margin-top:30px;text-align:center;font-size:12.5px;color:var(--ink-faint)}
footer.foot b{color:var(--ink-soft);font-weight:600}

@media (max-width:780px){
  .grid{grid-template-columns:1fr}
  nav.rail{position:static}
  .rail-track{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}
  .rail .rail-title{display:none}
  .step-btn{flex:0 0 auto;flex-direction:column;text-align:center;gap:6px;padding:9px 12px;font-size:11.5px;min-width:70px}
  .step-label{font-size:11px;white-space:nowrap}
  main.card{padding:26px 22px}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}

@media print{
  body{background:#fff}
  nav.rail,.footnav,.toolbar,.linkout,.progress-shell{display:none}
  .grid{display:block}
  main.card{box-shadow:none;border:0;padding:0}
}
