:root{--bg-1:#fff5f7;--bg-2:#f3f0ff;--bg-3:#eef7ff;--card:#ffffff;--ink:#4a3f55;--ink-soft:#8a7f96;--pink:#ff8fb1;--pink-deep:#ff6f9c;--purple:#b79cff;--mint:#8fe0c9;--sky:#8fc8ff;--yes:#5fd3a3;--no:#ff9aa8;--super:#7db9ff;--gold:#ffd479;--shadow:0 18px 40px -12px rgba(150,120,180,0.35);--serif:Georgia,"Iowan Old Style","Times New Roman",serif;--sans:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body,html{margin:0;padding:0;min-height:100%}body{font-family:var(--sans);color:var(--ink);background:linear-gradient(160deg,var(--bg-1) 0,var(--bg-2) 55%,var(--bg-3) 100%);background-attachment:fixed;min-height:100vh}a{color:var(--pink-deep);text-decoration:none}.page{max-width:520px;margin:0 auto;padding:18px 16px 48px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}.brand{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--pink-deep);letter-spacing:.5px}.brand .sparkle{color:var(--purple)}.role-pill{font-size:13px;font-weight:600;background:#fff;border-radius:999px;padding:6px 14px;box-shadow:var(--shadow);color:var(--ink-soft)}.role-pill b{color:var(--pink-deep)}.hero{text-align:center;margin:30px 0 26px}.hero h1{font-family:var(--serif);font-size:34px;margin:6px 0 4px;color:var(--ink)}.hero p{color:var(--ink-soft);margin:0}.role-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}.role-card{background:var(--card);border:none;border-radius:26px;padding:26px 16px;text-align:center;box-shadow:var(--shadow);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;font-family:var(--sans)}.role-card:hover{transform:translateY(-4px)}.role-card:active{transform:scale(.97)}.role-card .emoji{font-size:42px;display:block;margin-bottom:8px}.role-card .label{font-size:20px;font-weight:700;color:var(--ink)}.role-card .sub{font-size:12px;color:var(--ink-soft);margin-top:4px}.deck{position:relative;height:470px;margin:8px 0 18px;-webkit-user-select:none;user-select:none}.name-card{position:absolute;inset:0;background:var(--card);border-radius:30px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;touch-action:pan-y}.name-card .photo-wrap{flex:1 1 auto;background:linear-gradient(160deg,#ffe3ec,#efe6ff);display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.name-card .photo-wrap img{width:100%;height:100%;object-fit:contain}.name-card .photo-placeholder{font-size:64px;opacity:.5}.name-card .info{padding:18px 20px 22px;text-align:center;background:#fff}.name-card .first{font-family:var(--serif);font-size:44px;line-height:1.05;color:var(--ink);margin:0}.name-card .full{font-size:16px;color:var(--ink-soft);margin-top:8px;letter-spacing:.3px}.name-card .meaning{font-size:13px;color:var(--purple);margin-top:6px;font-style:italic}.name-card .badges{margin-top:10px;display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:#f3eefc;color:var(--purple)}.badge.match{background:#e3fbf0;color:#1f9d6b}.badge.super{background:#e6f1ff;color:var(--super)}.badge.mom{background:#ffe9f0;color:var(--pink-deep)}.badge.dad{background:#e9f7ff;color:var(--sky)}.stamp{position:absolute;top:26px;font-size:30px;font-weight:800;padding:6px 14px;border-radius:14px;border:4px solid;opacity:0;transition:opacity .05s linear;pointer-events:none;text-transform:uppercase}.stamp.yes{left:22px;color:var(--yes);transform:rotate(-14deg)}.stamp.no{right:22px;color:var(--no);transform:rotate(14deg)}.swipe-buttons{gap:22px;margin-top:6px}.swipe-btn,.swipe-buttons{display:flex;align-items:center;justify-content:center}.swipe-btn{border:none;border-radius:50%;background:#fff;box-shadow:var(--shadow);cursor:pointer;transition:transform .12s ease}.swipe-btn:active{transform:scale(.9)}.swipe-btn.no{width:64px;height:64px;font-size:28px;color:var(--no)}.swipe-btn.super{width:56px;height:56px;font-size:24px;color:var(--super)}.swipe-btn.yes{width:64px;height:64px;font-size:28px;color:var(--yes)}.btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:14px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;background:#fff;color:var(--ink);box-shadow:var(--shadow);font-family:var(--sans)}.btn.primary{background:var(--pink-deep);color:#fff}.btn.ghost{background:transparent;box-shadow:none;color:var(--ink-soft)}.btn:disabled{opacity:.5;cursor:default}.bottom-nav{display:flex;justify-content:center;gap:10px;margin-top:22px;flex-wrap:wrap}.drawer-backdrop{position:fixed;inset:0;background:rgba(80,60,100,.3);z-index:40}.drawer{position:fixed;top:0;right:0;height:100%;width:min(360px,88vw);background:var(--bg-2);box-shadow:-10px 0 40px -10px rgba(120,90,150,.4);z-index:50;padding:22px 20px;overflow-y:auto}.drawer h2{font-family:var(--serif);margin-top:0}.field{margin-bottom:16px}.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:6px}.field input[type=password],.field input[type=text]{width:100%;border:1px solid #e7def2;border-radius:12px;padding:11px 12px;font-size:15px;background:#fff;color:var(--ink);font-family:var(--sans)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #ece4f6}.toggle-row span{font-size:14px}.switch{position:relative;width:46px;height:26px}.switch input{opacity:0;width:0;height:0}.slider{inset:0;background:#ddd2ec;border-radius:999px;cursor:pointer}.slider,.slider:before{position:absolute;transition:.2s}.slider:before{content:"";height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%}.switch input:checked+.slider{background:var(--pink-deep)}.switch input:checked+.slider:before{transform:translateX(20px)}.modal-backdrop{position:fixed;inset:0;background:rgba(70,50,90,.45);display:flex;align-items:center;justify-content:center;z-index:60;padding:20px}.match-modal{background:#fff;border-radius:28px;padding:34px 26px;text-align:center;max-width:380px;width:100%;box-shadow:var(--shadow);animation:pop .35s cubic-bezier(.2,1.4,.5,1)}@keyframes pop{0%{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}.match-modal .its{font-family:var(--serif);font-size:32px;color:var(--pink-deep);margin:0 0 6px}.match-modal .sub{color:var(--ink-soft);margin:0 0 14px}.match-modal .name{font-family:var(--serif);font-size:30px;color:var(--ink);margin:8px 0 22px}.section-title{font-family:var(--serif);font-size:22px;margin:24px 0 10px;display:flex;align-items:center;gap:8px}.list-card{background:#fff;border-radius:18px;padding:14px 16px;box-shadow:var(--shadow);margin-bottom:12px}.list-card .name-line{font-family:var(--serif);font-size:22px;color:var(--ink)}.list-card .meta{margin-top:4px}.list-card .meta,.vote-grid{font-size:13px;color:var(--ink-soft)}.vote-grid{display:flex;flex-wrap:wrap;gap:6px 14px;margin-top:8px}.vote-grid b{color:var(--ink)}.empty{text-align:center;color:var(--ink-soft);padding:30px 10px;font-size:15px}textarea{width:100%;min-height:150px;border:1px solid #e7def2;padding:12px;font-family:var(--sans);resize:vertical;background:#fff;color:var(--ink)}.banner,textarea{border-radius:14px;font-size:14px}.banner{padding:12px 14px;margin:12px 0;background:#e3fbf0;color:#1f9d6b}.banner.error{background:#ffe8ec;color:#d65a73}.collapse-head{cursor:pointer;display:flex;align-items:center;justify-content:space-between}.search-input{width:100%;border:1px solid #e7def2;border-radius:14px;padding:12px 14px;font-size:15px;background:#fff;margin-bottom:14px;font-family:var(--sans);color:var(--ink)}.confetti-piece{position:fixed;top:-12px;width:9px;height:14px;border-radius:2px;z-index:70;animation:fall linear forwards}@keyframes fall{to{transform:translateY(105vh) rotate(2turn);opacity:.9}}