:root{color-scheme:light;--bg: #D9F5EE;--card: #ffffff;--text: #1a1a2e;--muted: #6b7280;--border: #e5e7eb;--pink: #f472b6;--pink-light: #fce7f3;--pink-dark: #db2777;--blue: #60a5fa;--blue-light: #dbeafe;--blue-dark: #1d4ed8;--purple: #a78bfa;--purple-light:#ede9fe;--purple-dark: #6d28d9;--green: #22c55e;--green-light: #dcfce7;--red: #ef4444;--red-light: #fee2e2;--shadow: 0 4px 24px rgba(0,0,0,.08);--shadow-lg: 0 8px 40px rgba(0,0,0,.13);--radius: 20px;--radius-sm: 12px}:root{--sf-50: #F0FDFA;--sf-100: #CCFBF1;--sf-200: #99F6E4;--sf-500: #14B8A6;--sf-600: #0D9488;--sf-700: #0F766E}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Mulish,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;overscroll-behavior:none;-webkit-overflow-scrolling:touch}h1,h2,h3,.auth-brand,.name-display,.match-popup h2,.match-name{font-family:Raleway,sans-serif}.center-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.loading-content{text-align:center}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#14b8a6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:999;transition:opacity .5s ease}.splash-screen.fading{opacity:0;pointer-events:none}.splash-logo{transform-origin:center bottom;animation:splashDrop 4s cubic-bezier(.25,.1,.25,1) forwards}.splash-name{font-size:1.8rem;font-weight:800;color:#fff;letter-spacing:-.02em;opacity:0;animation:splashFadeUp .5s ease 1.1s forwards}@keyframes splashDrop{0%{transform:translateY(-500px) rotate(0);opacity:0;animation-timing-function:cubic-bezier(.25,.1,.25,1)}20%{opacity:1}28%{transform:translateY(0) rotate(0);animation-timing-function:ease-in-out}46%{transform:translateY(0) rotate(9deg);animation-timing-function:ease-in-out}64%{transform:translateY(0) rotate(-9deg);animation-timing-function:ease-in-out}82%{transform:translateY(0) rotate(9deg);animation-timing-function:ease-in-out}to{transform:translateY(0) rotate(0)}}@keyframes splashFadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.auth-screen{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;padding-top:calc(32px + env(safe-area-inset-top));padding-bottom:calc(32px + env(safe-area-inset-bottom));background:linear-gradient(160deg,var(--sf-50) 0%,var(--sf-100) 60%,var(--sf-200) 100%)}.auth-hero{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.auth-brand{font-size:2.6rem;font-weight:900;letter-spacing:-.05em;color:var(--sf-700);margin-top:12px;margin-bottom:6px}.auth-tagline{font-size:1rem;color:var(--sf-600);font-weight:500}.auth-card{background:#fff;border-radius:var(--radius);box-shadow:0 8px 48px #0d94881f;padding:36px 36px 28px;width:100%;max-width:400px}.auth-form-title{font-size:1.2rem;font-weight:800;color:var(--text);margin-bottom:24px;text-align:center}.auth-btn-primary{width:100%;padding:13px;background:var(--sf-500);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:700;cursor:pointer;margin-top:6px;transition:background .15s,transform .1s}.auth-btn-primary:hover:not(:disabled){background:var(--sf-600);transform:translateY(-1px)}.auth-btn-primary:active:not(:disabled){transform:translateY(0)}.auth-btn-primary:disabled{opacity:.45;cursor:not-allowed}.auth-card .form-group input:focus{border-color:var(--sf-500)}.auth-divider{position:relative;text-align:center;margin:18px 0 14px;color:var(--muted);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 22px);height:1px;background:var(--border)}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-divider span{background:var(--card);padding:0 8px}.btn-apple-signin{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;background:#000;color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-apple-signin:hover{opacity:.9}.btn-apple-signin:disabled{opacity:.5;cursor:not-allowed}.btn-apple-signin svg{margin-top:-2px}.paywall-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;padding:max(40px,env(safe-area-inset-top)) 20px max(40px,env(safe-area-inset-bottom));overflow-y:auto;z-index:200}.paywall-close{display:block;margin:0 auto 8px;color:var(--muted);font-size:.9rem}.btn-upgrade{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:100px;font-size:.74rem;font-weight:800;letter-spacing:.02em;white-space:nowrap;flex-shrink:0;cursor:pointer;border:none;background:linear-gradient(135deg,var(--sf-700),#064E47);color:#fff;box-shadow:0 2px 10px #0f766e66;transition:transform .1s}.btn-upgrade:hover{transform:translateY(-1px)}.btn-upgrade:active{transform:scale(.96)}.badge-premium{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:100px;font-size:.74rem;font-weight:800;white-space:nowrap;flex-shrink:0;background:var(--sf-100);color:var(--sf-700)}.paywall-card{background:var(--card);border-radius:24px;padding:32px 24px;max-width:480px;width:100%;margin:32px auto 0;box-shadow:var(--shadow-lg)}.paywall-hero{text-align:center;margin-bottom:24px}.paywall-title{font-size:1.6rem;font-weight:800;color:var(--sf-700);margin-top:12px}.paywall-tagline{color:var(--muted);margin-top:6px}.paywall-features{list-style:none;padding:0;margin:0 0 28px}.paywall-features li{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border);font-size:.95rem;color:var(--text)}.paywall-features li:last-child{border-bottom:none}.paywall-check{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--sf-100);color:var(--sf-700);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem}.paywall-loading{text-align:center;color:var(--muted);padding:16px}.paywall-buy{margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}.paywall-buy-sub{font-weight:500;opacity:.8;font-size:.85em}.paywall-buy-lifetime{padding:16px;font-size:1.05rem}.paywall-buy-monthly{padding:14px}.paywall-restore{width:100%;text-align:center;margin-top:8px;color:var(--muted)}.paywall-fineprint{margin-top:20px;font-size:.72rem;line-height:1.5;color:var(--muted);text-align:center}.paywall-fineprint a{color:var(--sf-600)}.btn-settings-premium{background:linear-gradient(135deg,var(--sf-100),var(--sf-50));color:var(--sf-700);font-weight:700}.name-info{margin-top:18px;padding:14px 16px;background:var(--sf-50);border-radius:14px;text-align:left;width:100%}.name-info-row{display:flex;gap:10px;align-items:baseline;padding:6px 0;border-bottom:1px solid var(--sf-100)}.name-info-row:last-of-type{border-bottom:none;padding-bottom:12px}.name-info-key{flex-shrink:0;width:64px;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--sf-700)}.name-info-val{flex:1;font-size:.9rem;color:var(--text);line-height:1.4}.popularity-row{display:flex;gap:10px;align-items:baseline;padding:6px 0;border-bottom:1px solid var(--sf-100);width:100%;background:none;border-left:none;border-right:none;border-top:none;cursor:pointer;text-align:left;color:inherit}.popularity-row:last-of-type{border-bottom:none;padding-bottom:12px}.popularity-row:hover .name-info-val{color:var(--sf-700)}.popularity-chart-icon{margin-left:6px;vertical-align:-2px;color:var(--sf-700)}.popularity-modal{background:#fff;border-radius:20px;padding:24px 20px;max-width:380px;width:calc(100% - 32px);box-shadow:0 20px 60px #00000040}.popularity-modal-title{font-size:1.5rem;font-weight:800;margin:0;text-align:center}.popularity-modal-subtitle{text-align:center;color:var(--muted);font-size:.85rem;margin:4px 0 18px}.popularity-stats{display:flex;justify-content:space-around;background:var(--sf-100);border-radius:12px;padding:12px 8px;margin-bottom:16px}.popularity-stat{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.popularity-stat-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--sf-700)}.popularity-stat-value{font-size:.82rem;font-weight:700;color:var(--text);text-align:center}.popularity-trend-rising{color:#15803d}.popularity-trend-falling{color:#b91c1c}.popularity-trend-stable{color:var(--muted)}.popularity-sparkline-wrap{background:var(--sf-100);border-radius:12px;padding:8px 4px 4px;box-sizing:border-box}.popularity-sparkline-label{text-align:center;font-size:.85rem;color:var(--text);font-weight:600;min-height:1.4em;margin-bottom:2px}.popularity-sparkline-label strong{color:var(--sf-700);font-weight:800;margin-right:2px}.popularity-sparkline-hint{color:var(--muted);font-size:.75rem;font-weight:500}.popularity-sparkline{display:block;width:100%;height:auto;touch-action:none;cursor:pointer}.popularity-loading{text-align:center;color:var(--muted);padding:24px 0}.name-info-famous{border-top:1px solid var(--sf-100);padding-top:12px}.name-info-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:6px}.name-info-famous ul{list-style:none;padding:0;margin:0}.name-info-famous li{font-size:.85rem;padding:3px 0;color:var(--text)}.famous-kind{color:var(--muted);font-size:.78rem;text-transform:capitalize}.name-info-locked{margin-top:16px;width:100%;padding:11px 14px;background:linear-gradient(135deg,var(--sf-700),#064E47);color:#fff;border:none;border-radius:100px;font-size:.82rem;font-weight:700;cursor:pointer;box-shadow:0 2px 10px #0f766e4d}.password-label-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:7px}.password-label-row label{margin-bottom:0}.btn-forgot{background:none;border:none;font-size:.78rem;color:var(--sf-600);cursor:pointer;padding:0;font-weight:600;transition:color .15s}.btn-forgot:hover{color:var(--sf-700)}.password-wrapper{position:relative}.password-wrapper input{width:100%;padding-right:44px}.btn-show-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;padding:0;transition:color .15s}.btn-show-password:hover{color:var(--text)}.onboarding-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px 20px}.onboarding-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;gap:0}.onboarding-welcome-title{font-size:1.6rem;font-weight:900;letter-spacing:-.03em;color:var(--text);margin-top:20px;margin-bottom:20px}.onboarding-welcome-body{font-size:1rem;color:var(--muted);line-height:1.6;margin-bottom:14px}.onboarding-welcome .auth-btn-primary{margin-top:12px;width:100%}.onboarding-card{background:#fff;border-radius:var(--radius);box-shadow:0 8px 48px #0d94881f;padding:40px 36px 32px;width:100%;max-width:420px}.onboarding-progress{display:flex;gap:8px;justify-content:center;margin-bottom:28px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.onboarding-dot.filled{background:var(--sf-500)}.onboarding-step-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--sf-500);text-align:center;margin-bottom:10px}.onboarding-congrats{text-align:center;padding:16px 0 8px}.onboarding-congrats-msg{font-size:1.15rem;font-weight:700;color:var(--sf-600);line-height:1.4}.onboarding-skip{display:block;width:100%;margin-top:8px;color:var(--muted);font-size:.85rem}.onboarding-invite{display:flex;flex-direction:column;gap:14px;text-align:center}.onboarding-invite-body{font-size:.95rem;color:var(--text);line-height:1.5;margin:0}.onboarding-invite-code{font-size:.9rem;color:var(--muted);margin:0}.onboarding-invite-code strong{color:var(--sf-700);letter-spacing:.06em;font-size:1rem}.onboarding-share-btn{margin-top:4px}.onboarding-question{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;text-align:center;margin-bottom:6px}.onboarding-hint{font-size:.85rem;color:var(--muted);text-align:center;margin-bottom:28px}.onboarding-answer{margin-bottom:24px}.onboarding-pills,.onboarding-options{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.onboarding-pill{padding:12px 22px;border-radius:100px;border:2px solid var(--border);background:#fafafa;font-size:1rem;font-weight:700;cursor:pointer;transition:border-color .15s,background .15s,color .15s;color:var(--text)}.onboarding-pill:hover{border-color:var(--sf-500);background:var(--sf-50)}.onboarding-pill.selected{border-color:var(--sf-500);background:var(--sf-100);color:var(--sf-700)}.onboarding-date-input{width:100%;padding:12px 15px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;color:var(--text);background:#fafafa;transition:border-color .15s}.onboarding-date-input:focus{outline:none;border-color:var(--sf-500);background:#fff}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:44px 40px;width:100%;max-width:420px;text-align:center}.card-icon{font-size:3.2rem;margin-bottom:12px}.card h1,.card h2{font-size:1.9rem;font-weight:800;letter-spacing:-.03em;margin-bottom:6px}.subtitle{color:var(--muted);font-size:.95rem;margin-bottom:28px}.connect-title{font-size:1.6rem;font-weight:800;margin-bottom:6px}.connect-sub{color:var(--muted);font-size:.9rem;margin-bottom:24px}.connect-your-code{background:var(--sf-50, #f0fdfa);border:2px solid var(--sf-300, #5eead4);border-radius:16px;padding:16px 20px;margin-bottom:20px;text-align:center}.connect-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--sf-600, #0d9488);margin-bottom:6px}.connect-code{font-size:2.2rem;font-weight:900;letter-spacing:.18em;color:var(--sf-700, #0f766e);font-variant-numeric:tabular-nums}.btn-share-code{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:7px 16px;border-radius:20px;border:1.5px solid var(--sf-400, #2dd4bf);background:transparent;color:var(--sf-600, #0d9488);font-size:.85rem;font-weight:600;cursor:pointer}.connect-divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.82rem;font-weight:600;margin-bottom:16px}.connect-divider:before,.connect-divider:after{content:"";flex:1;height:1px;background:var(--border)}.connect-input{text-align:center;font-size:1.3rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.connect-autofill{font-size:.85rem;color:var(--sf-600);margin-bottom:12px}.connect-skip{margin-top:10px;display:block;width:100%}.form-group{text-align:left;margin-bottom:18px}.form-group label{display:block;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:7px}.form-group input{width:100%;padding:12px 15px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;color:var(--text);background:#fafafa;transition:border-color .15s}.form-group input:focus{outline:none;border-color:var(--sf-500);background:#fff}.form-group input.monospace{font-family:SF Mono,Fira Code,monospace;letter-spacing:.2em}.btn-primary{width:100%;padding:13px;background:var(--sf-500);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:700;cursor:pointer;margin-top:6px;transition:background .15s,transform .1s}.btn-primary:hover:not(:disabled){background:var(--sf-600);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{width:100%;padding:13px;background:transparent;color:var(--sf-600);border:2px solid var(--sf-200);border-radius:var(--radius-sm);font-size:1rem;font-weight:700;cursor:pointer;margin-top:0;transition:border-color .15s,background .15s}.btn-secondary:hover{border-color:var(--sf-400);background:var(--sf-50)}.btn-text{background:none;border:none;color:var(--muted);font-size:.875rem;cursor:pointer;margin-top:14px;display:block;width:100%;text-align:center;transition:color .15s}.btn-text:hover{color:var(--text)}.tos-label{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;color:var(--gray-600);margin-bottom:14px;cursor:pointer;line-height:1.4}.tos-label input[type=checkbox]{margin-top:2px;flex-shrink:0;width:16px;height:16px;accent-color:var(--sf-500);cursor:pointer}.tos-label a{color:var(--sf-600);text-decoration:underline;font-weight:600}.msg-error{color:var(--red);font-size:.875rem;padding:10px 14px;background:var(--red-light);border-radius:var(--radius-sm);margin-bottom:14px;text-align:left}.msg-success{color:#15803d;font-size:.875rem;padding:10px 14px;background:var(--green-light);border-radius:var(--radius-sm);margin-bottom:14px;text-align:left}.invite-section{background:var(--sf-100);border-radius:var(--radius-sm);padding:20px;margin-bottom:8px;text-align:center}.invite-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--sf-700);margin-bottom:10px}.invite-code{font-family:SF Mono,Fira Code,monospace;font-size:2.4rem;font-weight:800;letter-spacing:.25em;color:var(--sf-700);cursor:pointer;-webkit-user-select:all;user-select:all}.copy-hint{font-size:.65rem;font-weight:400;letter-spacing:0;opacity:.7}.invite-section small{display:block;margin-top:8px;font-size:.8rem;color:var(--sf-700);opacity:.8}.divider{text-align:center;color:var(--muted);font-size:.8rem;margin:20px 0;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--border)}.divider:before{left:0}.divider:after{right:0}.divider span{position:relative;z-index:1;background:var(--card);padding:0 10px}.gender-picker-card{max-width:480px}.gender-options{display:flex;flex-direction:column;gap:12px;margin-top:8px}.gender-option-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:4px}.gender-option-grid .gender-option{flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 8px;text-align:center}.gender-option{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:var(--radius-sm);border:2px solid var(--border);background:transparent;cursor:pointer;transition:border-color .15s,background .15s,transform .1s;text-align:left}.gender-option.selected{border-width:3px;padding:14px 6px}.gender-option-girl.selected{border-color:var(--pink);background:var(--pink-light)}.gender-option-boy.selected{border-color:var(--blue);background:var(--blue-light)}.gender-option-neutral.selected{border-color:var(--purple);background:var(--purple-light)}@media (hover: hover){.gender-option:hover{transform:translateY(-1px)}.gender-option-girl:hover{border-color:var(--pink);background:var(--pink-light)}.gender-option-boy:hover{border-color:var(--blue);background:var(--blue-light)}.gender-option-neutral:hover{border-color:var(--purple);background:var(--purple-light)}}.gender-option-symbol{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.3rem;line-height:1}.gender-option-girl .gender-option-symbol{background:var(--pink-light);color:var(--pink-dark)}.gender-option-boy .gender-option-symbol{background:var(--blue-light);color:var(--blue-dark)}.gender-option-neutral .gender-option-symbol{background:var(--purple-light);color:var(--purple-dark)}.gender-option-label{font-size:1rem;font-weight:700;color:var(--text);line-height:1}.gender-tabs{display:flex;gap:8px}.gender-tab{display:inline-flex;align-items:center;gap:4px;padding:7px 14px;border-radius:100px;border:2px solid var(--border);background:#fafafa;font-size:.82rem;font-weight:700;cursor:pointer;transition:border-color .15s,background .15s;color:var(--muted)}.gender-tab:hover{border-color:#d1d5db;color:var(--text)}.gender-tab-label{font-size:.82rem;line-height:1}.gender-tab-girl.active{border-color:var(--pink);background:var(--pink-light);color:var(--pink-dark)}.gender-tab-boy.active{border-color:var(--blue);background:var(--blue-light);color:var(--blue-dark)}.gender-tab-neutral.active{border-color:var(--purple);background:var(--purple-light);color:var(--purple-dark)}.home-content{max-width:720px;margin:0 auto;padding:32px 24px;width:100%;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.partner-nudge{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--sf-100);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:28px}.partner-nudge p{font-size:.9rem;color:var(--sf-700);font-weight:500}.btn-nudge{background:var(--sf-500);color:#fff;border:none;padding:8px 16px;border-radius:100px;font-size:.85rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s}.btn-nudge:hover{background:var(--sf-600)}.searches-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.searches-header h2{font-size:1.3rem;font-weight:800}.btn-new-search{background:var(--sf-500);color:#fff;border:none;padding:9px 18px;border-radius:100px;font-size:.875rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s}.btn-new-search:hover{background:var(--sf-600);transform:translateY(-1px)}.empty-state{text-align:center;padding:64px 24px}.empty-icon{font-size:3rem;margin-bottom:16px}.empty-state h3{font-size:1.2rem;font-weight:800;margin-bottom:8px}.empty-state p{color:var(--muted);margin-bottom:28px}.empty-cta{width:auto;display:inline-block;padding:13px 28px}.empty-state-btn{width:auto;display:inline-block;padding:12px 28px;margin-top:4px}.hiw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .25s ease}.hiw-card{background:#fff;border-radius:24px;padding:32px 24px 24px;width:100%;max-width:360px;text-align:center;box-shadow:0 20px 60px #0003}.hiw-title{font-size:1.4rem;font-weight:800;color:#0f766e;margin:14px 0 20px}.hiw-steps{display:flex;flex-direction:column;gap:14px;text-align:left;margin-bottom:24px}.hiw-step{display:flex;align-items:flex-start;gap:14px}.hiw-step-icon{flex-shrink:0;width:32px;height:32px}.hiw-step strong{display:block;font-size:.95rem;color:#0f172a}.hiw-step p{font-size:.82rem;color:#64748b;margin:2px 0 0}.hiw-btn{width:100%}.ptr-indicator{text-align:center;padding:10px;font-size:1.3rem;color:var(--sf-500);animation:ptr-spin .6s linear infinite}@keyframes ptr-spin{to{transform:rotate(360deg)}}.matches-sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.matches-sidebar-header h3{margin-bottom:0}.btn-share-matches{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:600;color:var(--sf-600);background:transparent;border:none;cursor:pointer;padding:4px 0}.btn-share-matches-header{background:transparent;border:none;cursor:pointer;color:var(--sf-600);padding:4px 8px;display:flex;align-items:center}.partner-nudge{display:flex;align-items:center;gap:10px;margin:12px 16px 4px;padding:13px 16px;background:#f0fdfa;border:1.5px solid #99f6e4;border-radius:14px;cursor:pointer;text-align:left;width:calc(100% - 32px)}.partner-nudge-icon{font-size:1.3rem;flex-shrink:0}.partner-nudge-text{flex:1;font-size:.88rem;color:#0f766e;line-height:1.4}.partner-nudge-text strong{display:block;font-size:.95rem}.partner-nudge-arrow{font-size:1.3rem;color:#14b8a6;flex-shrink:0}.searches-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.search-card-wrap{position:relative;display:flex;flex-direction:column;align-items:center;width:100%}.search-card-delete{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--muted);border:2px solid white;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .15s;z-index:1}.search-card-delete:hover{background:var(--red)}.search-card{background:none;border:none;padding:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:10px;transition:transform .12s;width:100%}.search-card:hover{transform:scale(1.06)}.search-card:active{transform:scale(.97)}.search-card-icon{width:100%;aspect-ratio:1 / 1;border-radius:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000001a;position:relative}.gender-bg-girl{background:var(--pink-light)}.gender-bg-boy{background:var(--blue-light)}.gender-bg-neutral{background:var(--purple-light)}.search-gender-symbol{font-size:3.5rem;line-height:1}.search-card-partner-dot{position:absolute;top:12px;right:12px;width:12px;height:12px;border-radius:50%;background:var(--green);border:2px solid white}.search-card-label{font-size:1rem;font-weight:700;color:var(--text);text-align:center;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1 1 auto;overflow:hidden}.btn-back{background:#f3f4f6;border:none;width:44px;height:44px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;color:var(--text)}.btn-back:hover{background:var(--border)}.search-title-header{font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-flex;align-items:center;gap:5px;background:none;border:none;padding:0;cursor:pointer;color:inherit;min-width:0}.search-title-pencil{opacity:.5;flex-shrink:0}.btn-edit-search{background:none;border:none;padding:4px 8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;color:var(--text);transition:background .15s}.btn-edit-search:hover{background:var(--border)}.label-optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--muted);font-size:.75rem}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 16px;padding-top:max(14px,env(safe-area-inset-top));background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header-title-group{display:flex;align-items:center;gap:8px}.app-title{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:8px}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.partner-badge{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:#15803d}.dot-green{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.btn-link-partner{background:var(--sf-500);color:#fff;border:none;padding:6px 10px;border-radius:100px;font-size:.78rem;font-weight:700;white-space:nowrap;flex-shrink:0;cursor:pointer;transition:background .15s,transform .1s}.btn-link-partner:hover{background:var(--sf-600);transform:translateY(-1px)}.btn-settings{background:#f3f4f6;border:none;width:44px;height:44px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;color:var(--muted)}.btn-settings:hover{background:var(--border)}.btn-signout{background:#f3f4f6;border:none;width:44px;height:44px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;color:var(--muted)}.btn-signout:hover{background:var(--border)}.game-layout{display:flex;flex:1;min-height:0;position:relative}.game-main{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:24px;padding:32px 24px calc(80px + env(safe-area-inset-bottom));overflow-y:scroll;-webkit-overflow-scrolling:touch}.name-card{background:var(--card);border-radius:28px;box-shadow:var(--shadow-lg);padding:52px 72px;text-align:center;position:relative;border-top:6px solid transparent;min-width:300px;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.gender-border-girl{border-top-color:var(--pink)}.gender-border-boy{border-top-color:var(--blue)}.gender-border-neutral{border-top-color:var(--purple)}.gender-badge{position:absolute;top:14px;right:18px;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700}.gender-badge.gender-girl{background:var(--pink-light);color:var(--pink-dark)}.gender-badge.gender-boy{background:var(--blue-light);color:var(--blue-dark)}.gender-badge.gender-neutral{background:var(--purple-light);color:var(--purple-dark)}.name-display{font-size:3.2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}.name-remaining{font-size:.8rem;color:var(--muted)}.name-origin{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:6px}.vote-buttons{display:flex;gap:32px;align-items:center}.btn-dislike,.btn-like{width:76px;height:76px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px #0000001a;transition:transform .12s,box-shadow .12s}.btn-dislike{font-size:1.7rem}.btn-like{font-size:2.2rem}.btn-dislike{background:var(--red-light);color:var(--red)}.btn-like{background:var(--green-light);color:var(--green)}.btn-dislike:hover{transform:scale(1.12);box-shadow:0 6px 24px #ef444440}.btn-like:hover{transform:scale(1.12);box-shadow:0 6px 24px #22c55e40}.btn-dislike:active,.btn-like:active{transform:scale(.92)}.vote-hint{font-size:.82rem;color:var(--muted);text-align:center;line-height:1.6;max-width:300px}.filter-trigger{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:100px;background:var(--card);border:1.5px solid var(--border);color:var(--text);font-size:.85rem;font-weight:700;cursor:pointer;transition:border-color .15s,background .15s}.filter-trigger:hover{border-color:var(--sf-500)}.filter-trigger.has-active{border-color:var(--sf-500);background:var(--sf-50);color:var(--sf-700)}.filter-trigger-count{background:var(--sf-500);color:#fff;border-radius:100px;padding:1px 7px;font-size:.7rem;font-weight:800;margin-left:2px}.filter-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:100;animation:fadeIn .18s ease}.filter-sheet{background:var(--card);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;border-radius:24px 24px 0 0;padding:16px 20px calc(28px + env(safe-area-inset-bottom));animation:slideUp .25s cubic-bezier(.22,1,.36,1)}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.filter-sheet-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:12px}.filter-sheet-header h2{font-size:1rem;font-weight:800;text-align:center}.filter-sheet-reset{text-align:left;color:var(--muted)}.filter-sheet-reset:disabled{opacity:.4}.filter-sheet-done{text-align:right;color:var(--sf-600);font-weight:700}.filter-sheet-section{padding:14px 0;border-top:1px solid var(--border)}.filter-sheet-section:first-of-type{border-top:none}.filter-sheet-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:8px}.filter-sheet-premium-pill{background:linear-gradient(135deg,var(--sf-700),#064E47);color:#fff;font-size:.6rem;padding:2px 7px;border-radius:100px;text-transform:none;letter-spacing:.04em}.filter-sheet-count{background:var(--sf-500);color:#fff;font-size:.65rem;font-weight:800;padding:1px 7px;border-radius:100px;text-transform:none;letter-spacing:.04em}.filter-sheet-pills{display:flex;flex-wrap:wrap;gap:8px}.filter-pill{background:var(--surface);border:1.5px solid transparent;color:var(--text);border-radius:100px;padding:7px 14px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s}.filter-pill:hover{background:var(--sf-50)}.filter-pill.active{background:var(--sf-500);border-color:var(--sf-500);color:#fff;font-weight:700}.filter-sheet-unlock{width:100%;background:linear-gradient(135deg,var(--sf-700),#064E47);color:#fff;border:none;border-radius:14px;padding:14px;font-size:.95rem;font-weight:700;cursor:pointer}.filter-sheet-empty{color:var(--muted);font-size:.88rem;padding:8px 0}.name-search-bar{display:flex;align-items:center;gap:8px;width:100%;max-width:360px;background:var(--card);border:1.5px solid var(--border);border-radius:100px;padding:6px 14px 6px 12px;transition:border-color .15s,box-shadow .15s}.name-search-bar:focus-within{border-color:var(--sf-500);box-shadow:0 0 0 3px #14b8a61f}.name-search-icon{color:var(--muted);flex-shrink:0}.name-search-input{flex:1;border:none;outline:none;background:transparent;font-size:.92rem;color:var(--text);padding:6px 0;min-width:0}.name-search-input::placeholder{color:var(--muted)}.name-search-clear{background:var(--surface);color:var(--muted);border:none;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;cursor:pointer;flex-shrink:0}.name-search-clear:hover{background:var(--border);color:var(--text)}.name-search-bar-locked{cursor:pointer;background:var(--card);text-align:left;font-family:inherit;padding:9px 8px 9px 12px;justify-content:space-between}.name-search-bar-locked:hover{border-color:var(--sf-500)}.name-search-locked-label{flex:1;color:var(--muted);font-size:.92rem}.name-search-locked-pill{background:linear-gradient(135deg,var(--sf-700),#064E47);color:#fff;font-size:.65rem;font-weight:800;letter-spacing:.04em;padding:4px 9px;border-radius:100px;flex-shrink:0}.letter-filter-row{display:flex;align-items:center;gap:8px;margin:12px 0 4px;width:100%}.letter-filter-all{flex-shrink:0;font-size:.78rem;font-weight:700;padding:5px 10px;border-radius:20px;border:1.5px solid #cbd5e1;background:transparent;color:#64748b;cursor:pointer}.letter-filter-all.active{background:#14b8a6;border-color:#14b8a6;color:#fff}.letter-filter-scroll{display:flex;gap:5px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1}.letter-filter-scroll::-webkit-scrollbar{display:none}.letter-filter-btn{flex-shrink:0;font-size:.78rem;font-weight:700;width:30px;height:30px;border-radius:50%;border:1.5px solid #cbd5e1;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center}.letter-filter-btn.active{background:#14b8a6;border-color:#14b8a6;color:#fff}.all-done{text-align:center;max-width:300px;padding:8px 0}.all-done-icon{margin-bottom:16px}.all-done h2{font-size:1.5rem;font-weight:800;margin-bottom:10px}.all-done p{color:var(--muted);font-size:.95rem;line-height:1.5;margin-bottom:0}.all-done-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px;align-items:center}.matches-sidebar{width:240px;flex-shrink:0;background:var(--card);border-left:1px solid var(--border);padding:24px 20px;overflow-y:auto}.matches-sidebar h3{font-size:.9rem;font-weight:800;text-transform:uppercase;gap:6px;letter-spacing:.05em;margin-bottom:16px;display:flex;align-items:center;gap:8px}.match-count{background:var(--sf-100);color:var(--sf-700);font-size:.78rem;padding:2px 8px;border-radius:100px}.no-matches{color:var(--muted);font-size:.875rem}.matches-list{list-style:none;display:flex;flex-direction:column;gap:8px}.match-item{padding:9px 14px;border-radius:var(--radius-sm);font-weight:700;font-size:.95rem}.match-item.gender-girl{background:var(--pink-light);color:var(--pink-dark)}.match-item.gender-boy{background:var(--blue-light);color:var(--blue-dark)}.match-item.gender-neutral{background:var(--purple-light);color:var(--purple-dark)}.linked-toast{position:fixed;top:max(20px,calc(env(safe-area-inset-top) + 12px));left:50%;transform:translate(-50%);background:var(--sf-500);color:#fff;padding:12px 22px;border-radius:100px;font-size:.95rem;font-weight:700;z-index:100;box-shadow:0 8px 24px #14b8a666;display:flex;align-items:center;gap:10px;white-space:nowrap;animation:linkedToastIn .35s cubic-bezier(.22,1,.36,1)}.linked-toast strong{font-weight:800}.linked-toast-emoji{font-size:1.15rem}.linked-toast-warning{background:#ef4444;box-shadow:0 8px 24px #ef444466}@keyframes linkedToastIn{0%{transform:translate(-50%,-120%);opacity:0}to{transform:translate(-50%);opacity:1}}.match-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:50;animation:fadeIn .2s ease;cursor:pointer}.match-popup{background:var(--card);border-radius:var(--radius);padding:48px 56px;text-align:center;box-shadow:var(--shadow-lg);animation:popIn .4s cubic-bezier(.34,1.56,.64,1);cursor:default;max-width:320px;width:90%}.match-hearts-anim{margin-bottom:12px;animation:heartBeat .6s cubic-bezier(.34,1.56,.64,1)}@keyframes heartBeat{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.15);opacity:1}to{transform:scale(1)}}.match-eyebrow{font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--sf-600);margin-bottom:8px}.match-name{font-size:3rem;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}.match-subtext{font-size:.95rem;color:var(--muted);margin-bottom:24px}.match-dismiss-btn{font-size:.8rem;color:var(--muted);background:none;border:none;cursor:pointer;padding:0;opacity:.7}.match-name.gender-girl{color:var(--pink-dark)}.match-name.gender-boy{color:var(--blue-dark)}.match-name.gender-neutral{color:var(--purple-dark)}:root{--keyboard-height: 0px}#kb-dismiss-bar{position:fixed;bottom:var(--keyboard-height, 0px);left:0;right:0;height:44px;background:#f2f2f7;border-top:1px solid #c6c6c8;display:flex;align-items:center;justify-content:flex-end;padding:0 16px;z-index:9999}#kb-dismiss-btn{background:none;border:none;color:#14b8a6;font-size:17px;font-weight:600;padding:8px 4px;cursor:pointer}.keyboard-open .tab-bar{opacity:0;pointer-events:none;transform:none}.keyboard-open .tab-bar-spacer{height:72px}.keyboard-open .settings-content{padding-bottom:calc(var(--keyboard-height) + 56px)}.keyboard-open .delete-overlay{padding-bottom:var(--keyboard-height)}.keyboard-open .delete-dialog{overflow-y:auto;max-height:calc(100dvh - var(--keyboard-height) - 24px)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{transform:scale(.75);opacity:0}to{transform:scale(1);opacity:1}}@keyframes cardEnter{0%{transform:translateY(18px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes cardExitRight{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(110%) rotate(18deg);opacity:0}}@keyframes cardExitLeft{0%{transform:translate(0) rotate(0);opacity:1}to{transform:translate(-110%) rotate(-18deg);opacity:0}}.card-enter{animation:cardEnter .22s cubic-bezier(.22,1,.36,1) both}.card-exit-right{animation:cardExitRight .22s cubic-bezier(.4,0,1,1) both;pointer-events:none}.card-exit-left{animation:cardExitLeft .22s cubic-bezier(.4,0,1,1) both;pointer-events:none}.pulse-text{color:var(--muted);animation:pulse 1.8s ease-in-out infinite}.due-date-banner{display:flex;align-items:center;gap:10px;background:var(--sf-100);border-radius:var(--radius-sm);padding:12px 18px;margin-bottom:20px;font-size:.9rem;color:var(--sf-700)}.due-date-icon{font-size:1.1rem}.settings-card{max-width:420px;text-align:left}.settings-hint{font-size:.78rem;color:var(--muted);margin-top:6px}.btn-share-link{background:none;border:none;font-size:.82rem;color:var(--sf-600);display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;margin-top:10px;font-weight:600;transition:color .15s;display:block;width:100%}.btn-share-link:hover{color:var(--sf-700)}.name-card{touch-action:pan-y;-webkit-user-select:none;user-select:none;cursor:grab}.name-card:active{cursor:grabbing}.name-card.swiping-like{box-shadow:0 8px 40px #22c55e4d;border-top-color:var(--green)}.name-card.swiping-dislike{box-shadow:0 8px 40px #ef44444d;border-top-color:var(--red)}@keyframes cardEnter{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes swipeOutRight{to{opacity:0;transform:translate(110%) rotate(18deg)}}@keyframes swipeOutLeft{to{opacity:0;transform:translate(-110%) rotate(-18deg)}}.name-card.card-enter{animation:cardEnter .22s cubic-bezier(.22,1,.36,1) both}.name-card.swipe-out-right{animation:swipeOutRight .28s cubic-bezier(.4,0,1,1) both;pointer-events:none}.name-card.swipe-out-left{animation:swipeOutLeft .28s cubic-bezier(.4,0,1,1) both;pointer-events:none}.popularity-badge{position:absolute;top:14px;left:18px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;background:var(--sf-100);color:var(--sf-700);padding:3px 8px;border-radius:100px}.btn-keyboard-dismiss{position:fixed;bottom:calc(var(--keyboard-height, 0px) + 12px);right:16px;z-index:1000;width:44px;height:44px;border-radius:50%;border:none;background:var(--sf-500);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #14b8a666;cursor:pointer;transition:transform .12s,box-shadow .12s}.btn-keyboard-dismiss:active{transform:scale(.9)}.btn-undo{width:48px;height:48px;border-radius:50%;border:2px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:border-color .15s,color .15s,transform .12s;box-shadow:0 2px 8px #00000012}.btn-undo:hover{border-color:var(--sf-500);color:var(--sf-600);transform:scale(1.08)}.all-done-reset{width:auto;display:inline-block;padding:13px 28px;margin-top:8px}.match-item{cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:opacity .15s}.match-item:hover{opacity:.75}.note-dot{width:7px;height:7px;border-radius:50%;background:var(--sf-500);flex-shrink:0}.match-detail-card{max-width:480px;text-align:center}.btn-match-back{background:none;border:none;font-size:.85rem;color:var(--muted);cursor:pointer;padding:0;margin-bottom:20px;display:block;text-align:left;transition:color .15s}.btn-match-back:hover{color:var(--text)}.btn-match-remove{margin-top:28px;background:none;border:1px solid #fecaca;color:#ef4444;font-size:.9rem;font-weight:500;padding:10px 20px;border-radius:999px;cursor:pointer;transition:background .15s,color .15s}.btn-match-remove:hover{background:#fef2f2}.btn-match-remove:active{background:#fee2e2}.match-detail-hearts{font-size:2.8rem;margin-bottom:10px}.match-detail-info{margin-top:20px}.match-detail-locked{margin-top:16px}.match-notes-section{margin-top:24px;text-align:left;border-top:1px solid var(--border);padding-top:20px}.match-notes-title{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--sf-700);margin:0 0 12px;text-align:center}.match-note-block{margin-bottom:16px}.match-note-author{font-size:.78rem;font-weight:700;color:var(--muted);margin:0 0 6px}.match-note-display{display:block;width:100%;background:var(--sf-100);border:1px solid var(--sf-100);border-radius:12px;padding:12px 14px;text-align:left;cursor:pointer;transition:background .15s}.match-note-display:hover{background:#d1f5ee}.match-note-display span:first-child{display:block;font-size:.9rem;color:var(--text);line-height:1.45;white-space:pre-wrap}.match-note-edit-hint{display:block;font-size:.7rem;color:var(--muted);margin-top:6px}.match-note-textarea{width:100%;background:#fff;border:1.5px solid var(--sf-300, #99e1d5);border-radius:12px;padding:10px 12px;font:inherit;font-size:.9rem;color:var(--text);line-height:1.45;resize:vertical;box-sizing:border-box}.match-note-textarea:focus{outline:none;border-color:var(--sf-500)}.match-note-actions{display:flex;align-items:center;gap:10px;margin-top:8px}.match-note-save{flex:0 0 auto;padding:8px 18px;font-size:.85rem}.match-note-add{display:block;padding:10px 0;color:var(--sf-700);font-weight:700;font-size:.9rem}.match-note-partner{background:var(--sf-100);border-radius:12px;padding:12px 14px;margin:0;font-size:.9rem;color:var(--text);line-height:1.45;white-space:pre-wrap}.match-note-empty{color:var(--muted);font-size:.85rem;margin:0;font-style:italic}.btn-share-match{display:flex;align-items:center;gap:8px;background:var(--sf-100);border:1.5px solid var(--sf-200);color:var(--sf-700);border-radius:12px;padding:10px 20px;font-size:.9rem;font-weight:700;cursor:pointer;margin:12px auto 0;transition:background .15s}.btn-share-match:hover{background:var(--sf-200)}.match-detail-name{font-size:2.6rem;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}.match-detail-name.gender-girl{color:var(--pink-dark)}.match-detail-name.gender-boy{color:var(--blue-dark)}.match-detail-name.gender-neutral{color:var(--purple-dark)}.match-detail-date{font-size:.85rem;color:var(--muted);margin-bottom:28px}.notes-section{display:flex;flex-direction:column;gap:20px;text-align:left}.note-block{background:#fafafa;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:16px}.note-block-partner{background:var(--sf-50);border-color:var(--sf-200)}.note-partner-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}.btn-report-note{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-decoration:none;padding:2px 6px;border-radius:6px}.btn-report-note:hover{color:var(--red);background:#ef444414}.note-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:10px}.note-textarea{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:.95rem;font-family:Mulish,sans-serif;color:var(--text);background:#fff;resize:vertical;transition:border-color .15s;margin-bottom:12px}.note-textarea:focus{outline:none;border-color:var(--sf-500)}.note-save-btn{margin-top:0}.note-partner-text{font-size:.95rem;color:var(--text);line-height:1.6}.note-partner-text em{color:var(--muted);font-style:italic}.offline-banner{position:fixed;top:env(safe-area-inset-top);left:0;right:0;z-index:30;background:#1f2937;color:#f9fafb;font-size:.78rem;font-weight:600;padding:9px 16px;display:flex;align-items:center;gap:8px;justify-content:center;animation:slideDown .2s ease}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.offline-dot{width:7px;height:7px;border-radius:50%;background:#f87171;flex-shrink:0;animation:pulse 2s ease-in-out infinite}.offline-banner+* .header,.offline-banner+.app .header{top:calc(env(safe-area-inset-top) + 36px)}.tab-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);display:flex;z-index:20;padding-bottom:env(safe-area-inset-bottom)}.tab-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:none;cursor:pointer;color:var(--muted);font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:10px 4px;min-height:56px;transition:color .15s;-webkit-tap-highlight-color:transparent}.tab-bar-item svg{width:22px;height:22px}.tab-bar-item.active{color:var(--sf-600)}.tab-bar-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}.tab-bar-badge{position:absolute;top:-5px;right:-8px;background:var(--pink);color:#fff;font-size:.55rem;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.tab-bar-spacer{height:calc(56px + env(safe-area-inset-bottom));flex-shrink:0}.match-group{margin-bottom:28px}.match-group-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.match-group-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.gender-dot-girl{background:var(--pink)}.gender-dot-boy{background:var(--blue)}.gender-dot-neutral{background:var(--purple)}.match-group-title{font-size:1rem;font-weight:800;flex:1}.match-group-count{background:var(--sf-100);color:var(--sf-700);font-size:.75rem;font-weight:700;padding:2px 9px;border-radius:100px}.match-group-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.match-pill{padding:10px 12px;border-radius:100px;border:none;font-size:.95rem;font-weight:700;cursor:pointer;transition:transform .12s,opacity .12s;-webkit-tap-highlight-color:transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;text-align:center}.match-pill:active{transform:scale(.95)}.match-pill.gender-girl{background:var(--pink-light);color:var(--pink-dark)}.match-pill.gender-boy{background:var(--blue-light);color:var(--blue-dark)}.match-pill.gender-neutral{background:var(--purple-light);color:var(--purple-dark)}.settings-content{max-width:480px;margin:0 auto;padding:24px 16px;width:100%;display:flex;flex-direction:column;align-items:stretch;gap:8px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.settings-section{background:#fff;border-radius:var(--radius-sm);border:1.5px solid var(--border)}.settings-section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:14px 18px 8px}.settings-profile-row{display:flex;align-items:center;gap:14px;padding:8px 18px 18px}.settings-profile-info{flex:1;min-width:0}.settings-avatar{width:48px;height:48px;border-radius:50%;background:var(--sf-500);color:#fff;font-size:1.2rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:Raleway,sans-serif}.settings-profile-name-row{display:flex;align-items:center;gap:5px;margin-bottom:4px}.settings-profile-name-pencil{color:#94a3b8;flex-shrink:0}.settings-profile-name-input{font-size:1rem;font-weight:700;color:#0f172a;background:transparent;border:none;border-bottom:1.5px solid #cbd5e1;border-radius:0;padding:2px 0 3px;margin-bottom:4px;width:100%;outline:none;font-family:inherit}.settings-profile-name-input:focus{border-bottom-color:#14b8a6}.settings-profile-name{font-size:1rem;font-weight:700;margin-bottom:4px}.settings-profile-sub{font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:6px}.dot-green-inline{width:7px;height:7px;border-radius:50%;background:var(--green);display:inline-block;flex-shrink:0}.btn-settings-link{background:none;border:none;color:var(--sf-600);font-size:.82rem;font-weight:700;cursor:pointer;padding:0;transition:color .15s}.btn-settings-link:hover{color:var(--sf-700)}.settings-field{padding:0 18px 4px}.settings-field label{display:block;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}.settings-field input{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;color:var(--text);background:#fafafa;transition:border-color .15s}.settings-field input:focus{outline:none;border-color:var(--sf-500);background:#fff}.settings-save-btn{margin:14px 18px 18px;width:calc(100% - 36px)}.btn-settings-row{width:100%;padding:14px 18px;background:none;border:none;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:.95rem;font-weight:600;color:var(--text);cursor:pointer;text-align:left;transition:background .15s;-webkit-tap-highlight-color:transparent}.btn-settings-row:hover{background:#f9fafb}.settings-section .btn-settings-row:last-child{border-bottom:none}.settings-section .btn-settings-row:first-child{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.settings-section .btn-settings-row:last-child{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.settings-section .btn-settings-row:only-child{border-radius:var(--radius-sm)}.btn-signout-settings{border-radius:0 0 var(--radius-sm) var(--radius-sm)}.settings-row-arrow{font-size:1.2rem;color:var(--muted);line-height:1}.pw-field{text-align:left;margin-bottom:14px}.pw-field label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:7px}.pw-field input{width:100%;padding:12px 15px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;color:var(--text);background:#fafafa;transition:border-color .15s}.pw-field input:focus{outline:none;border-color:var(--sf-500);background:#fff}.btn-signout-settings{width:100%;padding:16px;background:none;border:none;color:var(--red);font-size:.95rem;font-weight:700;cursor:pointer;text-align:center;transition:background .15s}.btn-signout-settings:hover{background:var(--red-light)}.settings-section-delete{display:flex;justify-content:center;padding:8px 0 4px}.btn-delete-account{display:block;margin:0 auto;background:none;border:none;color:var(--muted);font-size:.8rem;font-weight:600;cursor:pointer;padding:8px 16px;transition:color .15s;text-decoration:underline;text-underline-offset:3px}.btn-delete-account:hover{color:var(--red)}.delete-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0 0 env(safe-area-inset-bottom);animation:fadeIn .2s ease}.delete-dialog{background:#fff;border-radius:var(--radius) var(--radius) 0 0;padding:32px 28px 28px;width:100%;max-width:480px;animation:slideUp .25s cubic-bezier(.34,1.2,.64,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.delete-dialog-icon{font-size:2.4rem;margin-bottom:12px;text-align:center}.delete-dialog-title{font-size:1.3rem;font-weight:800;text-align:center;margin-bottom:12px;color:var(--text)}.delete-dialog-body{font-size:.9rem;color:var(--muted);text-align:center;line-height:1.6;margin-bottom:24px}.delete-dialog-body strong{color:var(--text)}.btn-delete-confirm{width:100%;padding:14px;background:var(--red);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:700;cursor:pointer;margin-bottom:12px;transition:background .15s}.btn-delete-confirm:hover:not(:disabled){background:#dc2626}.btn-delete-confirm:disabled{opacity:.5;cursor:not-allowed}.btn-delete-cancel{width:100%;padding:14px;background:#f3f4f6;color:var(--text);border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:700;cursor:pointer;transition:background .15s}.btn-delete-cancel:hover:not(:disabled){background:var(--border)}.btn-delete-cancel:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.game-layout{flex-direction:column}.matches-sidebar{display:none}.matches-list{flex-direction:row;flex-wrap:wrap}.match-item{padding:7px 12px;font-size:.875rem}.name-card{padding:40px 44px;min-width:0;width:100%}.name-display{font-size:2.4rem}.btn-dislike,.btn-like{width:68px;height:68px;font-size:1.5rem}.btn-undo{width:42px;height:42px;font-size:1rem}.match-popup{padding:40px 32px}.match-name{font-size:2.2rem}.card{padding:36px 28px}}.btn-history{background:none;border:none;font-size:.78rem;color:var(--muted);cursor:pointer;padding:4px 8px;margin-top:4px;text-decoration:underline;text-underline-offset:3px}.history-tabs{display:flex;gap:8px;flex:1}.history-tab{background:var(--border);border:none;border-radius:20px;padding:6px 14px;font-size:.82rem;font-weight:700;cursor:pointer;color:var(--muted);transition:all .15s}.history-tab.active{background:var(--sf-500);color:#fff}.btn-name-search{background:none;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);margin-right:4px;transition:background .15s}.btn-name-search:hover{background:var(--border)}.name-search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;flex-direction:column;justify-content:flex-end}.name-search-panel{background:#fff;border-radius:24px 24px 0 0;height:75vh;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}.name-search-bar{display:flex;align-items:center;gap:10px;padding:16px 16px 12px;border-bottom:1px solid var(--border)}.name-search-input{flex:1;border:none;outline:none;font-size:1rem;font-family:inherit;background:none;color:var(--text)}.name-search-close{background:var(--border);border:none;width:28px;height:28px;border-radius:50%;font-size:.75rem;cursor:pointer;color:var(--muted);display:flex;align-items:center;justify-content:center}.name-search-results{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.name-search-hint{text-align:center;color:var(--muted);font-size:.9rem;padding:40px 20px}.name-search-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.name-search-info{display:flex;flex-direction:column;gap:2px}.name-search-info-btn{background:none;border:none;padding:4px 6px;margin-left:-6px;text-align:left;cursor:pointer;border-radius:8px;transition:background .15s;flex:1;min-width:0}.name-search-info-btn:active{background:#f1f5f9}.name-search-revote-hint{font-size:.7rem;color:var(--muted);font-weight:500}.name-search-name{font-size:1rem;font-weight:700;font-family:Raleway,sans-serif;color:var(--text)}.name-search-origin{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.name-search-actions{display:flex;gap:8px}.name-search-btn{width:38px;height:38px;border-radius:50%;border:2px solid var(--border);background:#fff;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .15s;color:var(--muted)}.name-search-btn.dislike.active{background:var(--red-light);border-color:var(--red);color:var(--red)}.name-search-btn.like.active{background:var(--pink-light);border-color:var(--pink);color:var(--pink)}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{background:linear-gradient(90deg,#e8eaed 25%,#f5f5f5,#e8eaed 75%);background-size:1200px 100%;animation:shimmer 1.5s infinite linear;border-radius:8px;flex-shrink:0}.skeleton-search-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}.skeleton-search-card-top{height:40px;background:#e8eaed;display:flex;align-items:center;justify-content:center}.skeleton-search-card-top .skeleton{width:36px;height:36px;border-radius:50%;background:linear-gradient(90deg,#dcdcdc 25%,#ececec,#dcdcdc 75%);background-size:1200px 100%;animation:shimmer 1.5s infinite linear}.skeleton-search-card-body{padding:14px 16px;display:flex;flex-direction:column;gap:8px}.skeleton-name-card{width:100%;max-width:340px;aspect-ratio:3/4;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px}.skeleton-header-title{width:130px;height:24px}.skeleton-header-btn{width:110px;height:32px;border-radius:20px}.skeleton-searches-label{width:90px;height:18px}.skeleton-new-btn{width:100px;height:32px;border-radius:8px}
