.stepPage{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:20px 16px 28px;opacity:0;animation:stepPageEnter .28s ease-out forwards}.flowHeader{width:min(1080px,100%);margin-bottom:18px}.flowBrand{display:block;height:136px;width:auto;max-width:100%;margin:0 auto 18px;object-fit:contain}.flowSteps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);position:relative}.flowSteps:before{content:"";position:absolute;left:0;right:0;top:8px;height:2px;background:var(--progress-track)}.flowSteps:after{content:"";position:absolute;left:0;top:8px;height:2px;width:0;background:var(--progress-fill);transition:width .35s ease}.flowSteps.is-step-1:after{width:0%}.flowSteps.is-step-2:after{width:33.333%}.flowSteps.is-step-3:after{width:66.666%}.flowSteps.is-step-4:after{width:100%}.flowStep{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:21px;font-weight:700;color:var(--text);z-index:1}.flowDot{width:16px;height:16px;border-radius:999px;border:2px solid var(--progress-fill);background:var(--surface-muted)}.flowStep.is-active .flowDot,.flowStep.is-completed .flowDot{background:var(--progress-fill)}.milestoneToast{--milestone-toast-transform: translate(-50%, -50%);position:fixed;left:50%;top:50%;transform:var(--milestone-toast-transform);background:linear-gradient(180deg,rgba(var(--brand-amber-rgb),.18),rgba(var(--brand-orange-soft-rgb),.12));color:var(--brand-charcoal);border:2px solid var(--brand-orange-soft);padding:14px 22px;border-radius:18px;font-family:"DM Sans",var(--font-main);font-size:36px;line-height:1.2;font-weight:600;letter-spacing:.2px;text-align:center;max-width:min(90vw,740px);opacity:0;pointer-events:none;z-index:70;box-shadow:0 10px 24px rgba(var(--brand-charcoal-rgb),.22)}.milestoneToast.is-visible{animation:milestoneToastInOut 2.2s ease forwards}.confettiLayer{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:65}.confettiPiece{position:absolute;top:-16px;width:8px;height:12px;border-radius:2px;opacity:.95;animation:confettiFall 1.25s ease-in forwards}@keyframes stepPageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes milestoneToastInOut{0%{opacity:0;transform:var(--milestone-toast-transform) scale(.96)}18%{opacity:1;transform:var(--milestone-toast-transform) scale(1)}85%{opacity:1;transform:var(--milestone-toast-transform) scale(1)}to{opacity:0;transform:var(--milestone-toast-transform) scale(.98)}}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translate(var(--drift, 0px),84vh) rotate(520deg);opacity:0}}.stepPanel{width:min(1280px,100%);background:var(--card);border-radius:24px;padding:24px;border:1px solid var(--border-default);box-shadow:var(--panel-shadow)}.stepTitle{margin:0;text-align:center;font-size:clamp(36px,4.4vw,60px);line-height:1.05}.stepSubtitle{margin:10px 0 14px;text-align:center;font-size:20px;color:var(--muted)}.stepNotice{margin:8px auto 18px;width:min(900px,100%);background:var(--notice-bg);border:1px solid var(--notice-border);color:var(--notice-text);border-radius:12px;padding:12px 14px;font-size:16px;line-height:1.35}.interactiveMap{margin:10px auto 0;width:min(1080px,100%)}.mapCanvas{position:relative;overflow:hidden;border-radius:0;border:0;background:var(--surface-alt)}.mapBaseImage{display:block;width:100%;height:auto}.mapOverlay{position:absolute;inset:0;width:100%;height:100%}.mapArea{fill:#ffffff26;stroke:#fff9;stroke-width:2;pointer-events:all;cursor:pointer;transition:fill .18s ease,stroke .18s ease,stroke-width .18s ease;animation:mapAreaShimmer 2.4s ease-in-out infinite}.mapArea:hover,.mapArea:focus-visible{fill:#ffffffb8;stroke:#fff;stroke-width:3;outline:none;animation:none}.mapArea.is-selected{fill:#ffffffd9;stroke:#fff;stroke-width:3;animation:none}@keyframes mapAreaShimmer{0%,to{fill:#ffffff1a;stroke:#ffffff73}50%{fill:#ffffff59;stroke:#fffffff2}}@media(prefers-reduced-motion:reduce){.mapArea{animation:none;fill:#fff3;stroke:#fff9}}.stepActions{margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:10px}.stepConfirmBtn,.stepBackBtn{height:56px;width:min(420px,100%);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;letter-spacing:.5px}.stepConfirmBtn{border:0;background:var(--btn-bg);color:var(--btn-text);box-shadow:var(--shadow-soft);transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.stepConfirmBtn:disabled{background:var(--btn-disabled-bg);color:var(--btn-disabled-text);cursor:not-allowed}.stepConfirmBtn:not(:disabled):hover{transform:scale(1.04);box-shadow:var(--shadow)}.stepBackBtn{background:var(--btn-bg);color:var(--btn-text);text-decoration:none;transition:transform .18s ease}.stepBackBtn:hover{transform:scale(1.02)}.stepMeta{margin:0;font-size:14px;color:var(--muted-soft);text-align:center}.stepBackLink{display:inline-flex;align-items:center;gap:4px;font-size:14px;font-weight:600;color:var(--muted);text-decoration:none;padding:6px 10px;border-radius:8px;transition:color .15s ease,background-color .15s ease}.stepBackLink:hover{color:var(--text);background:var(--surface-muted)}.stepBackLink svg{flex-shrink:0}@media(prefers-reduced-motion:reduce){.stepPage{animation:none;opacity:1}}@media(max-width:900px){.flowHeader{margin-bottom:14px}.flowBrand{height:112px}.flowStep{font-size:16px;gap:6px}.flowDot{width:14px;height:14px}.stepPanel{padding:18px 12px;border-radius:18px}.stepSubtitle{font-size:16px}.stepConfirmBtn,.stepBackBtn{width:min(290px,100%);height:46px;border-radius:11px;font-size:14px;letter-spacing:.35px}.milestoneToast{left:50%;top:auto;bottom:calc(18px + env(safe-area-inset-bottom,0px));--milestone-toast-transform: translateX(-50%);transform:var(--milestone-toast-transform);font-size:clamp(20px,5.8vw,28px);line-height:1.15;padding:10px 14px;border-radius:14px;width:min(92vw,520px);max-width:min(92vw,520px)}.stepMeta{font-size:13px}}@media(max-width:520px){.stepActions{gap:8px}.stepConfirmBtn,.stepBackBtn{width:min(260px,100%);height:42px;border-radius:10px;font-size:13px}.milestoneToast{font-size:clamp(18px,6.2vw,24px);line-height:1.14;padding:9px 12px;width:min(92vw,360px);max-width:min(92vw,360px)}}
