@import "https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";
:root{--primary:#8b4f6b;--primary-light:#a8607f;--primary-soft:#f2d0dc;--accent:#c9a84c;--accent-hover:#b8943d;--bg:#fdf8f5;--surface:#fff;--surface-2:#faf3f0;--surface-3:#f5ebe6;--text:#2d2d2d;--text-secondary:#6b5b55;--text-muted:#9e8c87;--text-faint:#c4b5b0;--border:#e8d8d0;--border-strong:#d4c0b8;--success:#6b9e7a;--success-soft:#edf5ef;--error:#c0524a;--error-soft:#fdf0ef;--r-sm:6px;--r-md:10px;--r-lg:16px;--r-xl:24px;--r-full:999px;--shadow-sm:0 1px 4px #8b4f6b14;--shadow-md:0 4px 16px #8b4f6b1f;--shadow-lg:0 8px 32px #8b4f6b29}*{box-sizing:border-box;min-width:0;max-width:100%;margin:0;padding:0}html,body{width:100%;max-width:100vw;height:100%;overflow-x:hidden}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;word-break:break-word;overflow-wrap:break-word;font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}.app-shell{background:var(--bg);flex-direction:column;width:100%;max-width:480px;min-height:100vh;margin:0 auto;display:flex;position:relative;overflow-x:hidden}.btn{border-radius:var(--r-full);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;height:52px;padding:0 24px;font-family:Poppins,sans-serif;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn.primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-md)}.btn.primary:hover{background:var(--primary-light);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn.primary:disabled{background:var(--text-faint);box-shadow:none;cursor:not-allowed;transform:none}.btn.accent{background:var(--accent);color:#fff}.btn.accent:hover{background:var(--accent-hover)}.btn.outline{color:var(--primary);border:2px solid var(--primary);background:0 0}.btn.outline:hover{background:var(--primary-soft)}.btn.ghost{color:var(--text-secondary);background:0 0;height:40px}.btn.ghost:hover{color:var(--primary)}.btn.danger{background:var(--error);color:#fff}.input{border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);width:100%;height:52px;color:var(--text);outline:none;padding:0 16px;font-family:Poppins,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #8b4f6b1f}.input::placeholder{color:var(--text-faint)}.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:20px}.screen{flex-direction:column;flex:1;min-height:100vh;padding:24px 20px;display:flex}.progress-dots{justify-content:center;gap:8px;margin-bottom:32px;display:flex}.progress-dots .dot{background:var(--border-strong);border-radius:50%;width:8px;height:8px;transition:all .2s}.progress-dots .dot.active{background:var(--primary);border-radius:var(--r-full);width:24px}.chips{flex-wrap:wrap;gap:10px;display:flex}.chip{border-radius:var(--r-full);border:1.5px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;padding:8px 18px;font-size:13px;font-weight:500;transition:all .2s}.chip:hover{border-color:var(--primary);color:var(--primary)}.chip.selected{background:var(--primary-soft);border-color:var(--primary);color:var(--primary);font-weight:600}.overlay{z-index:100;background:#0006;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.bottom-sheet{background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:480px;margin:0 auto;padding:28px 24px 36px;animation:.3s slideUp}.bottom-sheet-handle{background:var(--border-strong);border-radius:var(--r-full);width:40px;height:4px;margin:0 auto 24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.screen-title{color:var(--text);margin-bottom:8px;font-size:22px;font-weight:700;line-height:1.3}.screen-subtitle{color:var(--text-muted);margin-bottom:28px;font-size:14px;line-height:1.6}.divider{background:var(--border);height:1px;margin:20px 0}.privacy-badge{color:var(--text-muted);background:var(--surface-3);border-radius:var(--r-full);align-items:center;gap:6px;padding:6px 12px;font-size:12px;display:inline-flex}
