:root{
  --bg:#15131f; --bg2:#1d1a2b; --surface:#241f36; --line:#3a3350;
  --ink:#ECE8F7; --muted:#a99fc7; --gold:#e9c46a; --accent:#9b6cff; --accent2:#6c8cff;
  --ok:#46c98b; --radius:14px; --maxw:1080px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:radial-gradient(1200px 600px at 70% -10%,#2a2342,transparent),var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;line-height:1.5}
a{color:var(--accent2);text-decoration:none}a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}
header.site{border-bottom:1px solid var(--line);background:rgba(20,17,31,.7);backdrop-filter:blur(6px);position:sticky;top:0;z-index:10}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:58px}
.logo{font-weight:800;font-size:1.2rem;letter-spacing:.3px}
.logo b{color:var(--gold)}
.logo .spark{color:var(--accent)}
nav.top a{color:var(--muted);margin-left:16px;font-size:.9rem}
h1{font-size:1.9rem;margin:26px 0 6px;line-height:1.15}
.lede{color:var(--muted);margin:0 0 18px;font-size:1.05rem;max-width:60ch}
.layout{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start;padding-bottom:40px}
@media(max-width:840px){.layout{grid-template-columns:1fr}}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.panel h2{font-size:1rem;margin:0 0 12px;color:var(--gold);text-transform:uppercase;letter-spacing:.08em}
label{display:block;font-size:.8rem;color:var(--muted);margin:10px 0 4px;font-weight:600}
input[type=text],input[type=number],textarea,select{width:100%;background:var(--bg2);color:var(--ink);
  border:1px solid var(--line);border-radius:9px;padding:10px 11px;font-size:.95rem;font-family:inherit}
textarea{resize:vertical;min-height:60px}
input:focus,textarea:focus,select:focus{outline:2px solid var(--accent);border-color:var(--accent)}
.row{display:flex;gap:10px}.row>*{flex:1}
.btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;border:none;border-radius:10px;
  padding:11px 16px;font-size:.95rem;font-weight:700;white-space:nowrap;font-family:inherit}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}
.btn.gold{background:var(--gold);color:#2a2010}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn:hover{filter:brightness(1.08)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.member-edit{border:1px solid var(--line);border-radius:10px;padding:12px;margin:10px 0;background:var(--bg2)}
.member-edit .head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.member-edit .head b{font-size:.85rem;color:var(--muted)}
.x{cursor:pointer;color:var(--muted);border:none;background:none;font-size:1.1rem}
.x:hover{color:#e5604d}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{cursor:pointer;border:1px solid var(--line);background:var(--bg2);color:var(--muted);
  border-radius:999px;padding:6px 12px;font-size:.82rem;user-select:none}
.chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.copied{color:var(--ok);font-size:.85rem;margin-left:8px;opacity:0;transition:opacity .2s}.copied.show{opacity:1}
.small{font-size:.82rem;color:var(--muted)}
.preview-wrap{position:sticky;top:78px}

/* ---- The shareable card (rendered identically in builder + viewer) ---- */
.pf-card{background:linear-gradient(160deg,#2a2442,#1b1830);border:1px solid var(--line);
  border-radius:16px;padding:4px;box-shadow:0 18px 50px rgba(0,0,0,.45)}
.pf-card-inner{border:1px solid rgba(233,196,106,.25);border-radius:13px;padding:20px}
.pf-card-head{text-align:center;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:14px}
.pf-party{font-size:1.5rem;font-weight:800;color:var(--gold);letter-spacing:.3px}
.pf-system{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-top:2px}
.pf-members{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.pf-members{grid-template-columns:1fr}}
.pf-member{display:flex;gap:10px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;padding:10px}
.pf-av{width:42px;height:42px;border-radius:10px;flex:0 0 42px;object-fit:cover;background:#322a4d;display:flex;align-items:center;justify-content:center}
.pf-av-emoji{font-size:1.5rem}
.pf-m-name{font-weight:700}
.pf-m-meta{font-size:.78rem;color:var(--accent2)}
.pf-m-bond{font-size:.82rem;color:var(--muted);font-style:italic;margin-top:3px}
.pf-empty{color:var(--muted);grid-column:1/-1;text-align:center;padding:18px}
.pf-pact{margin-top:14px;border-top:1px solid var(--line);padding-top:12px;display:grid;gap:8px}
.pf-pact-row{display:flex;gap:10px;font-size:.85rem;align-items:baseline}
.pf-pact-row span{color:var(--muted);flex:0 0 110px}
.pf-pact-row b{color:var(--ink);font-weight:600}
.pf-tag{display:inline-block;background:rgba(155,108,255,.18);color:#c9b3ff;border-radius:999px;padding:2px 9px;font-size:.76rem;margin:0 4px 4px 0}
.pf-foot{text-align:center;margin-top:14px;font-size:.8rem;color:var(--muted)}
.pf-foot a{color:var(--gold);font-weight:700}

main{padding-top:6px}
footer.site{border-top:1px solid var(--line);color:var(--muted);font-size:.85rem;padding:22px 0;margin-top:20px}
.cta-big{display:inline-block;margin:18px 0;font-size:1.05rem}
.center{text-align:center}
.viewer-main{max-width:560px;margin:0 auto;padding:30px 0}
