*{box-sizing:border-box}:root{--bg: #f5f4ef;--surface: #ffffff;--ink: #1c2620;--muted: #6a7570;--line: #d8d3c7;--accent: #2f6f4f;--accent-soft: #e1ede5;--danger: #b3433a;--shadow: 0 1px 2px rgba(20, 30, 25, .06), 0 6px 24px rgba(20, 30, 25, .06)}html,body,#app{margin:0;height:100%;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,system-ui,sans-serif;font-size:15px;line-height:1.45}button{font:inherit;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:8px 14px;border-radius:8px;transition:background .12s}button:hover{background:var(--accent-soft)}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover{background:#265a40}button.danger{color:var(--danger);border-color:var(--danger);background:transparent}button.danger:hover{background:#fbeae8}button.ghost{border-color:transparent;background:transparent}input,select,textarea{font:inherit;width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink)}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}.card{background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:20px}.row{display:flex;gap:12px;align-items:center}.stack{display:flex;flex-direction:column;gap:12px}.muted{color:var(--muted)}.error{color:var(--danger);font-size:13px}.spacer{flex:1}.topbar{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid var(--line);background:var(--surface)}.topbar h1{margin:0;font-size:18px;letter-spacing:.2px}.layout{display:grid;grid-template-columns:300px 1fr;height:calc(100% - 57px)}.layout.with-details{grid-template-columns:300px 340px 1fr}.sidebar{border-right:1px solid var(--line);background:var(--surface);padding:16px;display:flex;flex-direction:column;min-height:0}.sidebar-inner{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0}.sidebar-list{display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1;min-height:0}.sidebar-hint{border-top:1px solid var(--line);padding-top:12px;margin-top:8px;color:var(--muted);font-size:13px}.details{border-right:1px solid var(--line);background:var(--bg);overflow-y:auto;padding:16px}.details .card{padding:14px}.canvas{overflow:auto;padding:24px}.person-row{display:flex;gap:8px;align-items:center;padding:8px 10px;border-radius:8px;cursor:pointer}.person-row:hover{background:var(--accent-soft)}.person-row.active{background:var(--accent-soft);border:1px solid var(--accent)}.graph{position:relative}.graph-edges{position:absolute;left:0;top:0;pointer-events:none;z-index:5}.edge-halo{stroke:var(--bg);stroke-width:6;stroke-linecap:round;stroke-linejoin:round}.edge.dim,.edge-end.dim,.edge-halo.dim,.divorce-mark.dim{opacity:.16}.edge.highlight{stroke-width:3.5;filter:drop-shadow(0 0 3px rgba(212,160,23,.95)) drop-shadow(0 0 7px rgba(212,160,23,.65))}.edge-end.highlight{filter:drop-shadow(0 0 4px rgba(212,160,23,.95))}.divorce-mark.highlight line{filter:drop-shadow(0 0 3px rgba(212,160,23,.85));stroke-width:2.5}.edge{stroke-linecap:round;stroke-linejoin:round}.edge-parent{stroke:var(--accent);stroke-width:2}.edge-spouse{stroke:#b65a83;stroke-width:2;stroke-dasharray:5 5}.edge-spouse.divorced{stroke:#b3433a;stroke-dasharray:2 4;opacity:.85}.edge-sibling{stroke:#d4a017;stroke-width:1.6;stroke-dasharray:3 3}.edge-end{fill:var(--accent)}.edge-end-spouse{fill:#b65a83}.edge-end-divorced{fill:#b3433a}.edge-end-sibling{fill:#d4a017}.divorce-mark line{stroke:#b3433a;stroke-width:2;stroke-linecap:round}.node{border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:12px 14px;box-shadow:var(--shadow);text-align:left}.node h4{margin:0 0 4px;font-size:14px}.node .dates{font-size:12px;color:var(--muted);line-height:1.35}.node .occupation{color:var(--accent);font-weight:500}.node .phone{font-variant-numeric:tabular-nums}.node.male{border-top:3px solid #4d7ea8}.node.female{border-top:3px solid #b65a83}.node.other{border-top:3px solid #9a7bbf}.graph-node{position:absolute;cursor:pointer;transition:transform .12s,box-shadow .12s}.graph-node:hover{transform:translateY(-1px);box-shadow:0 2px 4px #141e1914,0 10px 30px #141e191a}.graph-node.selected{outline:2px solid var(--accent);outline-offset:2px}.port{position:absolute;width:10px;height:10px;background:var(--surface);border:2px solid var(--accent);border-radius:50%;z-index:2}.port-top{top:-5px;left:50%;transform:translate(-50%)}.port-bottom{bottom:-5px;left:50%;transform:translate(-50%)}.port-left{left:-5px;top:50%;transform:translateY(-50%);border-color:#b65a83}.port-right{right:-5px;top:50%;transform:translateY(-50%);border-color:#b65a83}.port-tl{top:-5px;left:14px;border-color:#d4a017;width:8px;height:8px}.port-tr{top:-5px;right:14px;border-color:#d4a017;width:8px;height:8px}.auth-hero{display:grid;grid-template-columns:1.15fr 1fr;height:100%;min-height:100vh;background:var(--bg)}.auth-art{position:relative;display:flex;flex-direction:column;justify-content:flex-end;padding:56px 56px 36px;color:#fff;overflow:hidden}.art-photo{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0;animation:heroPan 30s ease-in-out infinite alternate}.art-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f1e1626,#0f1e1673 45%,#0f1e16d9),linear-gradient(120deg,#2f6f4f2e,#0000 60%);z-index:1}.art-content{position:relative;z-index:2}@keyframes heroPan{0%{transform:scale(1.05) translate(0)}to{transform:scale(1.1) translate(-1.5%,-1%)}}.brand{text-align:left}.brand h1{margin:0 0 14px;font-size:44px;letter-spacing:-.5px;text-shadow:0 2px 18px rgba(0,0,0,.45)}.brand p{margin:0;max-width:460px;font-size:17px;line-height:1.55;opacity:.95;text-shadow:0 1px 12px rgba(0,0,0,.5)}.art-credit{margin-top:28px;font-size:11px;letter-spacing:.6px;text-transform:uppercase;opacity:.6}.auth-form-side{display:grid;place-items:center;padding:32px 24px}@media (max-width: 880px){.auth-hero{grid-template-columns:1fr;min-height:auto}.auth-art{min-height:280px;padding:36px 28px 24px;justify-content:flex-end}.brand h1{font-size:30px}.brand p{font-size:14px}.art-credit{margin-top:18px}}.tag{font-size:12px;background:var(--accent-soft);color:var(--accent);padding:2px 8px;border-radius:999px}.share-wrap{position:relative}.share-popover{position:absolute;top:calc(100% + 8px);right:0;min-width:360px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:16px;z-index:30;display:flex;flex-direction:column;gap:12px}.share-head{display:flex;align-items:center;gap:8px}.share-view-canvas{height:calc(100% - 57px);overflow:auto;padding:24px;background:var(--bg)}.picker{border:1px solid var(--line);border-radius:8px;background:var(--surface);max-height:220px;overflow-y:auto}.picker-row{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;border-bottom:1px solid var(--line)}.picker-row:last-child{border-bottom:none}.picker-row:hover{background:var(--accent-soft)}.picker-row.picked{background:var(--accent-soft);border:1px solid var(--accent);border-radius:8px;cursor:default}
