:root{--bg: #f3f7f5;--card: #ffffff;--text: #0e233c;--muted: #5b6b7d;--primary: #10b981;--success: #10b981;--border: rgba(0, 0, 0, .08)}*,*:before,*:after{box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;margin:0;scroll-behavior:smooth;display:flex;flex-direction:column;min-height:100vh}.container{max-width:640px;display:flex;flex-direction:column;justify-content:center;align-items:center;margin:auto;padding:2em 0}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px;box-shadow:0 10px 30px #00000014;width:calc(100% - 2em);text-align:center}.card:not(:first-of-type){min-height:380px}button{display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border:none;border-radius:12px;padding:14px 18px;font-weight:700;cursor:pointer}h1,h2{font-weight:800;font-size:clamp(22px,4vw,34px);line-height:1.15;margin:0 auto 24px;max-width:20ch}p{color:var(--muted);margin:0 0 16px;font-size:15px}button svg{pointer-events:none}.btn.secondary{background:transparent;border:1px solid #cfe7dc;color:#0e233c}input,select{padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#f6faf8;color:#0e233c;font-size:16px;width:100%}input.error,select.error{border-color:red}input::placeholder,select:has(option:first-child:checked){color:var(--muted)}.input-error-container,.select-error-container{color:red;font-size:11px;align-self:baseline;margin-left:5px;margin-top:3px;text-align:left}.progress{display:flex;gap:12px;align-items:center;margin-bottom:20px}.dot{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;border:2px solid #bfd6c9;background:#e9f4ef;color:#7b8a86;font-size:12px}.dot.active{background:var(--primary);border-color:var(--primary);color:#fff}.label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.disclaimer{font-size:12px}.row{display:flex;align-items:center;gap:10px;justify-content:center;padding:12px;border:1px dashed var(--border);border-radius:12px;background:#f7fbf9;font-size:14px}.tick{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;border:2px solid #c7d8d0;color:#5b6b7d;font-size:12px;background:#fff}.row.done .tick{background:var(--success);border-color:var(--success);color:#061a0f}.rows{display:grid;gap:10px}.hide{display:none!important}.fade{opacity:0;transition:opacity .28s ease}.fade.show{opacity:1}.spinner{width:34px;height:34px;border-radius:50%;border:3px solid #e5f3ec;border-top-color:var(--primary);margin:10px auto 16px;animation:spin 1s linear infinite}.grid{display:grid;gap:1em}@keyframes spin{to{transform:rotate(360deg)}}@media (min-width: 768px){p{font-size:16px}}
