:root{--paper:oklch(96% .015 80);--paper-2:oklch(93% .02 75);--ink:oklch(25% .02 60);--ink-soft:oklch(45% .02 60);--ink-faint:oklch(65% .015 60);--bark:oklch(40% .05 50);--leaf:oklch(55% .08 140);--leaf-soft:oklch(70% .06 140);--blossom:oklch(68% .14 45);--blossom-soft:oklch(85% .06 45);--sepia:oklch(78% .04 70);--line:oklch(85% .02 70);--rule:oklch(75% .02 70)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{background:var(--paper);color:var(--ink);font-family:Sarabun,Cormorant Garamond,serif;font-size:14px;line-height:1.5}.serif{font-family:Cormorant Garamond,Sarabun,serif}.mono{font-family:JetBrains Mono,ui-monospace,monospace}.app{grid-template-rows:64px 1fr;grid-template-columns:260px 1fr;width:100vw;height:100vh;display:grid}.app-header{border-bottom:1px solid var(--line);background:var(--paper);z-index:3;grid-column:1/-1;align-items:center;gap:20px;padding:0 24px;display:flex;position:relative}.header-logo{letter-spacing:.02em;color:var(--ink);align-items:center;gap:10px;font-family:Cormorant Garamond,serif;font-size:24px;font-weight:600;display:flex}.header-logo .logo-mark{width:28px;height:28px;position:relative}.header-logo small{color:var(--ink-faint);letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--line);border-radius:3px;margin-left:6px;padding:3px 6px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:400}.tree-title{text-align:center;flex:1}.tree-title-kicker{letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:2px;font-family:JetBrains Mono,monospace;font-size:10px}.tree-title-name{font-family:Cormorant Garamond,serif;font-size:20px;font-style:italic;font-weight:500}.header-actions{gap:8px;display:flex}.header-btn{border:1px solid var(--line);color:var(--ink);cursor:pointer;background:0 0;border-radius:4px;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:13px;transition:all .12s;display:inline-flex}.header-btn:hover{background:var(--paper-2);border-color:var(--ink-soft)}.header-btn.primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}.header-btn.primary:hover{background:var(--blossom);border-color:var(--blossom)}.sidebar{border-right:1px solid var(--line);background:var(--paper);flex-direction:column;gap:20px;padding:20px 18px;display:flex;overflow-y:auto}.sidebar-section h4{letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:10px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:500}.sidebar-search{position:relative}.sidebar-search input{border:1px solid var(--line);width:100%;color:var(--ink);background:0 0;border-radius:4px;padding:10px 12px 10px 32px;font-family:inherit;font-size:13px}.sidebar-search input:focus{border-color:var(--ink);outline:none}.sidebar-search:before{content:"⌕";color:var(--ink-faint);font-size:16px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.people-list{flex-direction:column;gap:1px;max-height:340px;display:flex;overflow-y:auto}.people-item{text-align:left;cursor:pointer;color:var(--ink);background:0 0;border:none;border-radius:3px;align-items:center;gap:8px;padding:8px 10px;font-family:inherit;font-size:13px;transition:background .1s;display:flex}.people-item:hover{background:var(--paper-2)}.people-item.active{background:var(--blossom-soft)}.people-item .dot{background:var(--ink-faint);border-radius:50%;flex-shrink:0;width:6px;height:6px}.people-item.alive .dot{background:var(--leaf)}.people-item .name{flex:1}.people-item .yr{color:var(--ink-faint);font-family:JetBrains Mono,monospace;font-size:10px}.sidebar-stats{grid-template-columns:1fr 1fr;gap:8px;display:grid}.stat-card{border:1px solid var(--line);border-radius:4px;padding:10px 12px}.stat-card .num{font-family:Cormorant Garamond,serif;font-size:28px;font-weight:500;line-height:1}.stat-card .lbl{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:4px;font-family:JetBrains Mono,monospace;font-size:9px}.legend{color:var(--ink-soft);flex-direction:column;gap:6px;font-size:11px;display:flex}.legend-row{align-items:center;gap:8px;display:flex}.legend-sw{border:1px solid var(--ink);border-radius:50%;flex-shrink:0;width:14px;height:14px}.legend-sw.me{background:var(--blossom)}.legend-sw.alive{background:oklch(84% .03 200)}.legend-sw.passed{background:var(--sepia);opacity:.6}.legend-sw.ext{background:var(--paper);border:1px dashed var(--leaf)}.tree-canvas{background:var(--paper);-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.paper-bg{pointer-events:none;background-image:radial-gradient(at 30% 20%,oklch(92% .03 70/.4) 0%,#0000 50%),radial-gradient(at 70% 80%,oklch(93% .025 80/.35) 0%,#0000 55%),repeating-linear-gradient(0deg,#0000 0 30px,oklch(25% .02 60/.015) 30px 31px);position:absolute;inset:0}.paper-vignette{pointer-events:none;background:radial-gradient(#0000 55%,oklch(40% .05 50/.1) 100%);position:absolute;inset:0}.tree-inner{transform-origin:top;width:1200px;margin-left:-600px;position:absolute;top:0;left:50%}.person-node{cursor:pointer;z-index:2;transition:transform .2s;position:absolute;transform:translate(-50%,-50%)}.person-node:hover{z-index:3}.person-node:hover .node-photo{transform:scale(1.08)}.person-node.dragging{z-index:10;transition:none!important}.person-node.dragging .node-photo{transform:scale(1.1);box-shadow:0 8px 24px #0000002e}.person-node{-webkit-user-select:none;user-select:none}.node-photo{background:var(--paper);border-radius:50%;width:60px;height:60px;transition:transform .18s ease-out;position:relative;box-shadow:0 2px 6px oklch(25% .02 60/.15)}.node-photo svg{display:block}.me-badge{background:var(--blossom);color:var(--paper);white-space:nowrap;border-radius:8px;padding:1px 6px;font-size:10px;font-weight:600;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.external-dot{background:var(--leaf);border:2px solid var(--paper);border-radius:50%;width:10px;height:10px;position:absolute;top:0;right:0}.upstream-btn{background:var(--paper);border:1.5px solid var(--leaf);width:22px;height:22px;color:var(--leaf);cursor:pointer;z-index:4;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:all .14s;display:flex;position:absolute;top:-14px;left:50%;transform:translate(-50%);box-shadow:0 2px 6px oklch(25% .02 60/.15)}.upstream-btn:hover{background:var(--leaf);color:var(--paper);transform:translate(-50%)scale(1.12)}.upstream-btn:before{content:"";background:var(--leaf);opacity:.5;width:1px;height:8px;position:absolute;top:100%;left:50%;transform:translate(-50%)}.upstream-pop{background:var(--paper);border:1px solid var(--line);z-index:8;border-radius:6px;width:300px;padding:16px 14px 14px;animation:.18s ease-out slideIn;position:absolute;box-shadow:0 12px 32px oklch(25% .02 60/.18)}.upstream-pop.empty{text-align:center;width:240px}.up-close{width:22px;height:22px;color:var(--ink-faint);cursor:pointer;background:0 0;border:none;font-size:16px;line-height:1;position:absolute;top:8px;right:8px}.up-head{margin-bottom:10px}.up-head-kicker{letter-spacing:.15em;text-transform:uppercase;color:var(--leaf);margin-bottom:4px;font-family:JetBrains Mono,monospace;font-size:9px}.up-head-title{font-family:Cormorant Garamond,serif;font-size:22px;font-style:italic;font-weight:500;line-height:1}.up-head-en{color:var(--ink-faint);margin-top:3px;font-family:JetBrains Mono,monospace;font-size:10px}.up-svg{background:var(--paper-2);border-radius:4px;margin-bottom:10px;padding:4px 0;display:block}.up-footer{flex-direction:column;gap:8px;display:flex}.up-status{color:var(--ink-faint);font-family:JetBrains Mono,monospace;font-size:10px}.up-status .mono{color:var(--blossom)}.up-status.linked,.up-status.linked span{color:var(--leaf)}.up-empty{color:var(--ink-soft);margin:10px 0;font-family:Cormorant Garamond,serif;font-size:15px;font-style:italic}.passed-ring{border:1px dashed var(--ink-faint);opacity:.6;border-radius:50%;position:absolute;inset:-4px}.person-node.passed .node-photo{filter:saturate(.4)brightness(1.05)}.person-node.external .node-photo{box-shadow:0 0 0 2px var(--paper), 0 0 0 3px var(--leaf-soft)}.person-node.selected .node-photo{box-shadow:0 0 0 3px var(--paper), 0 0 0 5px var(--blossom);transform:scale(1.15)}.person-node.highlighted .node-photo{box-shadow:0 0 0 3px var(--paper), 0 0 0 5px var(--blossom);animation:1.6s ease-in-out infinite pulse}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.node-label{text-align:center;white-space:nowrap;pointer-events:none;position:absolute;top:66px;left:50%;transform:translate(-50%)}.node-nick{color:var(--ink);font-family:Cormorant Garamond,serif;font-size:15px;font-style:italic;font-weight:500}.node-dates{color:var(--ink-faint);letter-spacing:.05em;margin-top:1px;font-family:JetBrains Mono,monospace;font-size:9px}.zoom-controls{background:var(--paper);border:1px solid var(--line);border-radius:4px;flex-direction:column;display:flex;position:absolute;bottom:24px;right:24px;overflow:hidden;box-shadow:0 2px 10px oklch(25% .02 60/.08)}.zoom-controls button{width:36px;height:36px;color:var(--ink);cursor:pointer;border:none;border-bottom:1px solid var(--line);background:0 0;font-family:inherit;font-size:16px}.zoom-controls button:last-child{border-bottom:none}.zoom-controls button:hover{background:var(--paper-2)}.drawer{background:var(--paper);border-left:1px solid var(--line);z-index:10;width:420px;height:calc(100vh - 64px);padding:28px 24px;animation:.24s ease-out slideIn;position:fixed;top:64px;right:0;overflow-y:auto;box-shadow:-10px 0 30px oklch(25% .02 60/.06)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.drawer-close{border:1px solid var(--line);cursor:pointer;width:28px;height:28px;color:var(--ink);background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:16px;line-height:1;display:flex;position:absolute;top:16px;right:16px}.drawer-close:hover{background:var(--paper-2)}.profile-header{border-bottom:1px solid var(--line);gap:18px;margin-bottom:20px;padding-bottom:20px;display:flex}.profile-photo{flex-shrink:0;position:relative}.profile-photo svg{border-radius:50%}.photo-upload-btn{background:var(--ink);color:var(--paper);cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:3px 8px;font-family:inherit;font-size:10px;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)}.profile-ident{flex:1;min-width:0}.profile-role{letter-spacing:.12em;text-transform:uppercase;color:var(--blossom);margin-bottom:4px;font-family:JetBrains Mono,monospace;font-size:10px}.profile-name{margin-bottom:2px;font-family:Cormorant Garamond,serif;font-size:26px;font-weight:500;line-height:1.1}.profile-name-en{color:var(--ink-soft);margin-bottom:10px;font-family:Cormorant Garamond,serif;font-size:14px;font-style:italic}.profile-meta{flex-wrap:wrap;gap:6px;display:flex}.meta-chip{border:1px solid var(--line);color:var(--ink);border-radius:3px;align-items:center;gap:6px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-flex}.meta-chip span{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em;font-size:9px}.meta-chip.passed{color:var(--ink-soft);font-style:italic}.tab{border-bottom:1px solid var(--line)}.tab-head{cursor:pointer;width:100%;color:var(--ink);background:0 0;border:none;align-items:center;gap:10px;padding:14px 0;font-family:inherit;display:flex}.tab-label{text-align:left;flex:1;font-family:Cormorant Garamond,serif;font-size:18px;font-style:italic}.tab-count{background:var(--paper-2);color:var(--ink-soft);border-radius:10px;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:10px}.tab-caret{color:var(--ink-faint);text-align:center;width:14px;font-size:14px}.tab.open .tab-head{color:var(--blossom)}.tab.open .tab-label{color:var(--ink)}.tab-body{padding:4px 0 20px}.relation-grid{flex-direction:column;gap:14px;display:flex}.rel-section h4{letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px;font-family:JetBrains Mono,monospace;font-size:9px}.rel-chips{flex-wrap:wrap;gap:6px;display:flex}.rel-chip{border:1px solid var(--line);color:var(--ink);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:8px;padding:6px 12px;font-family:inherit;font-size:12px;transition:all .12s;display:inline-flex}.rel-chip:hover{background:var(--paper-2);border-color:var(--ink-soft)}.rel-chip.heart{border-color:var(--blossom-soft)}.rel-chip.heart:before{content:"♡";color:var(--blossom)}.rel-dot{background:var(--ink-soft);border-radius:50%;width:6px;height:6px}.timeline{padding-left:60px;position:relative}.timeline:before{content:"";background:var(--line);width:1px;position:absolute;top:8px;bottom:40px;left:50px}.timeline-item{padding:12px 0 16px;display:block;position:relative}.timeline-year{color:var(--ink-faint);text-align:right;width:40px;font-family:JetBrains Mono,monospace;font-size:11px;position:absolute;top:14px;left:-60px}.timeline-dot{background:var(--blossom);border:2px solid var(--paper);width:8px;height:8px;box-shadow:0 0 0 1px var(--blossom);border-radius:50%;position:absolute;top:18px;left:-14px}.timeline-item h5{margin-bottom:2px;font-family:Cormorant Garamond,serif;font-size:17px;font-style:italic;font-weight:500}.timeline-item p{color:var(--ink-soft);font-size:13px}.timeline-add{margin-top:10px}.photo-grid{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px;display:grid}.photo-tile{aspect-ratio:1;border:1px solid var(--line);cursor:pointer;border-radius:2px;transition:transform .12s;animation:.3s both fadeInTile;position:relative;overflow:hidden}@keyframes fadeInTile{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.photo-tile:hover{z-index:2;transform:scale(1.02)}.photo-tile-bg{background:repeating-linear-gradient(135deg,oklch(82% .03 70) 0 8px,oklch(78% .04 70) 8px 16px);position:absolute;inset:0}.photo-tile-label{color:var(--ink);background:oklch(96% .015 80/.75);border-radius:2px;padding:1px 4px;font-family:JetBrains Mono,monospace;font-size:9px;position:absolute;bottom:4px;left:6px}.photo-tile.more{color:var(--ink-soft);background:var(--paper-2);border-style:dashed;justify-content:center;align-items:center;font-family:Cormorant Garamond,serif;font-size:22px;font-style:italic;display:flex}.memo-list{flex-direction:column;gap:10px;display:flex}.memo-card{border:1px solid var(--line);background:var(--paper-2);border-radius:4px;gap:12px;padding:12px;display:flex}.memo-play{background:var(--blossom);width:36px;height:36px;color:var(--paper);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;font-size:12px}.memo-body{flex:1;min-width:0}.memo-title{margin-bottom:2px;font-family:Cormorant Garamond,serif;font-size:16px;font-style:italic}.memo-meta{color:var(--ink-faint);gap:6px;margin-bottom:6px;font-family:JetBrains Mono,monospace;font-size:9px;display:flex}.memo-wave{align-items:center;gap:1.5px;height:30px;display:flex}.wave-bar{background:var(--blossom);opacity:.7;border-radius:.5px;flex:1}.memo-duration{color:var(--ink-faint);text-align:right;margin-top:2px;font-family:JetBrains Mono,monospace;font-size:9px}.btn-primary,.btn-secondary,.btn-ghost{cursor:pointer;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-family:inherit;font-size:13px;transition:all .12s;display:inline-flex}.btn-primary{background:var(--ink);color:var(--paper)}.btn-primary:hover{background:var(--blossom)}.btn-secondary{color:var(--ink);border-color:var(--line);background:0 0}.btn-secondary:hover{background:var(--paper-2);border-color:var(--ink-soft)}.btn-ghost{color:var(--ink-soft);background:0 0}.btn-ghost:hover{color:var(--ink)}.full-width{width:100%}.empty-state{text-align:center;color:var(--ink-soft);flex-direction:column;align-items:center;gap:12px;padding:20px;display:flex}.pathfinder{background:var(--paper);border:1px solid var(--line);z-index:9;border-radius:6px;width:420px;padding:16px;animation:.24s ease-out slideIn;position:fixed;top:80px;left:280px;box-shadow:0 8px 24px oklch(25% .02 60/.12)}.pf-title{justify-content:space-between;align-items:center;margin-bottom:12px;font-family:Cormorant Garamond,serif;font-size:18px;font-style:italic;display:flex}.pf-close{cursor:pointer;width:22px;height:22px;color:var(--ink-faint);background:0 0;border:none;font-size:16px}.pf-picker{align-items:center;gap:8px;display:flex}.pf-from{flex-shrink:0}.pf-chip.me-chip{background:var(--blossom);color:var(--paper);border-radius:4px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:inline-flex}.me-dot{background:var(--paper);border-radius:50%;width:6px;height:6px}.pf-arrow{color:var(--ink-faint)}.pf-select{border:1px solid var(--line);color:var(--ink);background:0 0;border-radius:4px;flex:1;padding:8px 10px;font-family:inherit;font-size:12px}.pf-select:focus{border-color:var(--ink);outline:none}.pf-result{border-top:1px solid var(--line);margin-top:12px;padding-top:12px}.pf-relation{font-family:Cormorant Garamond,serif;font-size:18px;font-style:italic}.pf-relation strong{color:var(--blossom);font-family:Sarabun,sans-serif;font-size:16px;font-style:normal;font-weight:600}.pf-hops{color:var(--ink-faint);margin-top:4px;font-family:JetBrains Mono,monospace;font-size:10px}.pf-hint{color:var(--blossom)}.merge-drawer{width:460px}.merge-header{margin-bottom:20px}.merge-kicker{letter-spacing:.15em;text-transform:uppercase;color:var(--blossom);margin-bottom:6px;font-family:JetBrains Mono,monospace;font-size:10px}.merge-header h2{margin-bottom:8px;font-family:Cormorant Garamond,serif;font-size:32px;font-weight:500;line-height:1}.merge-header p{color:var(--ink-soft);font-size:13px}.merge-tabs{border-bottom:1px solid var(--line);gap:4px;margin-bottom:20px;display:flex}.merge-tabs button{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 14px;font-family:inherit;font-size:13px}.merge-tabs button.active{color:var(--ink);border-bottom-color:var(--blossom)}.invite-card{background:linear-gradient(135deg, var(--paper-2), var(--paper));border:1px solid var(--line);border-radius:6px;margin-bottom:18px;padding:20px}.invite-kicker{letter-spacing:.15em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:9px}.invite-link{word-break:break-all;border:1px dashed var(--rule);background:var(--paper);border-radius:3px;margin-bottom:6px;padding:10px;font-family:Cormorant Garamond,serif;font-size:22px;font-style:italic}.invite-code{color:var(--ink-soft);margin-bottom:14px;font-family:JetBrains Mono,monospace;font-size:12px}.invite-code strong{color:var(--blossom)}.invite-flow{flex-direction:column;gap:10px;display:flex}.flow-step{color:var(--ink-soft);align-items:center;gap:12px;font-size:13px;display:flex}.flow-step span{background:var(--ink);width:22px;height:22px;color:var(--paper);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.qr-body{text-align:center}.qr-card{background:var(--paper-2);border:1px solid var(--line);border-radius:6px;flex-direction:column;align-items:center;gap:12px;margin-bottom:14px;padding:24px;display:inline-flex}.qr-frame{background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:14px}.qr-label{color:var(--ink-soft);font-family:Cormorant Garamond,serif;font-size:14px;font-style:italic}.qr-hint{color:var(--ink-soft);font-size:12px}.suggest-intro{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:12px;font-family:JetBrains Mono,monospace;font-size:10px}.suggest-card{border:1px solid var(--line);border-radius:5px;margin-bottom:10px;padding:14px}.suggest-head{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.suggest-name{font-family:Cormorant Garamond,serif;font-size:20px;font-style:italic;font-weight:500}.suggest-meta{color:var(--ink-faint);margin-top:2px;font-family:JetBrains Mono,monospace;font-size:10px}.suggest-badge{letter-spacing:.08em;text-transform:uppercase;border-radius:10px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:9px}.suggest-badge.auto{background:var(--leaf-soft);color:oklch(30% .06 140)}.suggest-badge.invite{background:var(--blossom-soft);color:oklch(30% .1 45)}.suggest-overlap{color:var(--ink-soft);margin-bottom:10px;font-size:13px}.suggest-actions{gap:8px;display:flex}.tweaks-panel{background:var(--paper);border:1px solid var(--ink);z-index:20;border-radius:6px;width:260px;padding:16px;animation:.2s ease-out slideIn;position:fixed;bottom:24px;left:24px;box-shadow:0 10px 30px oklch(25% .02 60/.2)}.tweaks-panel h4{border-bottom:1px solid var(--line);margin-bottom:14px;padding-bottom:10px;font-family:Cormorant Garamond,serif;font-size:18px;font-style:italic}.tweak-row{margin-bottom:12px}.tweak-row label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px;font-family:JetBrains Mono,monospace;font-size:9px;display:block}.tweak-options{border:1px solid var(--line);border-radius:4px;gap:4px;padding:2px;display:flex}.tweak-options button{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;border-radius:3px;flex:1;padding:6px 8px;font-family:inherit;font-size:11px}.tweak-options button.active{background:var(--ink);color:var(--paper)}body.theme-forest{--paper:oklch(22% .02 160);--paper-2:oklch(26% .025 160);--ink:oklch(92% .02 90);--ink-soft:oklch(75% .03 90);--ink-faint:oklch(55% .03 90);--bark:oklch(85% .04 80);--leaf:oklch(75% .1 140);--leaf-soft:oklch(50% .08 140);--blossom:oklch(75% .14 55);--blossom-soft:oklch(30% .08 45);--sepia:oklch(60% .05 80);--line:oklch(35% .02 160);--rule:oklch(45% .02 160)}body.theme-blueprint{--paper:oklch(32% .08 250);--paper-2:oklch(36% .08 250);--ink:oklch(95% .02 250);--ink-soft:oklch(80% .03 250);--ink-faint:oklch(60% .04 250);--bark:oklch(90% .02 250);--leaf:oklch(85% .08 220);--leaf-soft:oklch(50% .1 220);--blossom:oklch(90% .1 80);--blossom-soft:oklch(45% .08 250);--sepia:oklch(70% .04 250);--line:oklch(48% .06 250);--rule:oklch(60% .06 250)}body.shape-polaroid .node-photo{background:var(--paper);border-radius:3px;padding:4px 4px 20px;box-shadow:0 3px 8px oklch(25% .02 60/.2)}body.shape-polaroid .node-photo svg{border-radius:2px}body.shape-polaroid .node-photo svg circle{rx:0;ry:0}body.shape-polaroid .node-label{top:84px}body.shape-square .node-photo svg circle[r="28"]{display:none}body.shape-square .node-photo{border:1.5px solid var(--ink);background:var(--paper-2);border-radius:3px;overflow:hidden}.active-view-pill{background:var(--paper);border:1px solid var(--line);z-index:5;border-radius:100px;align-items:center;gap:10px;padding:6px 8px 6px 14px;font-size:13px;display:flex;position:fixed;top:80px;left:50%;transform:translate(-50%);box-shadow:0 4px 14px oklch(25% .02 60/.08)}.avp-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-family:JetBrains Mono,monospace;font-size:10px}.active-view-pill select{color:var(--blossom);cursor:pointer;background:0 0;border:none;padding:4px 6px;font-family:Cormorant Garamond,serif;font-size:16px;font-style:italic}.active-view-pill select:focus{outline:none}.avp-clear{border:1px solid var(--line);width:22px;height:22px;color:var(--ink-faint);cursor:pointer;background:0 0;border-radius:50%;font-size:14px;line-height:1}.avp-clear:hover{background:var(--paper-2);color:var(--ink)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--rule);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--ink-faint)}.person-node.lineage{opacity:.85;width:44px;transition:opacity .2s,transform .24s;animation:.26s cubic-bezier(.2,.7,.3,1) both lineageIn}.person-node.lineage:hover{opacity:1}.person-node.lineage .node-photo{width:44px;height:44px}.person-node.lineage .node-label{color:var(--ink);font-size:11px}.person-node.lineage .node-nick{opacity:.72;letter-spacing:.01em;font-family:Cormorant Garamond,serif;font-size:13px;font-style:italic}.person-node.lineage .node-dates{opacity:.5;font-family:JetBrains Mono,monospace;font-size:9px}@keyframes lineageIn{0%{opacity:0;transform:translate(-50%,calc(8px - 50%))scale(.85)}to{opacity:.85;transform:translate(-50%,-50%)scale(1)}}.upstream-btn.expanded{background:var(--leaf);color:var(--paper);border-color:var(--leaf);box-shadow:0 2px 10px oklch(55% .12 145/.4)}.upstream-btn.expanded:hover{background:oklch(50% .13 145);transform:translate(-50%)scale(1.05)}.lineage-link{background:var(--paper-2);border:1px solid var(--line);border-left:3px solid var(--leaf);border-radius:6px;margin:0 20px 20px;padding:14px 14px 12px}.lineage-link-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.ll-kicker{color:var(--ink);margin-bottom:2px;font-family:Cormorant Garamond,serif;font-size:15px;font-weight:600}.ll-meta{color:var(--ink-soft);letter-spacing:.02em;font-size:11px}.ll-status{background:var(--paper);border:1px solid var(--line);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;border-radius:99px;padding:3px 8px;font-size:10px;font-weight:500}.ll-status.linked{background:var(--leaf);color:var(--paper);border-color:var(--leaf)}.ll-hint{color:var(--ink-soft);margin-top:10px;font-size:11px;font-style:italic;line-height:1.55}.lineage-actions{flex-wrap:wrap;gap:8px;display:flex}.lineage-actions .btn-secondary{flex:1;min-width:120px}.btn-primary.is-on{background:var(--bark)}.btn-primary.is-on:hover{background:oklch(40% .04 50)}.mono{font-family:JetBrains Mono,monospace;font-size:.9em}
