:root{--brand: #1c7d47;--brand-strong: #135c33;--brand-soft: #e7f3ec;--mango: #e89a35;--mango-soft: #fdf1dd;--bg: #f4f3ee;--panel: #ffffff;--surface-2: #faf9f5;--border: #e7e4da;--border-strong: #d7d3c7;--text: #20261f;--text-2: #4c5450;--muted: #828b81;--accent: var(--brand);--accent-soft: var(--brand-soft);--male: #d3e3fb;--male-border: #4a90e2;--female: #fbd9e7;--female-border: #e24a8b;--unknown: #e8e7e1;--unknown-border: #9aa5a0;--danger: #d24b3e;--danger-soft: #fbe9e6;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--r-pill: 999px;--shadow-xs: 0 1px 2px rgba(28, 36, 24, .06);--shadow-sm: 0 2px 6px rgba(28, 36, 24, .08);--shadow-md: 0 8px 24px rgba(28, 36, 24, .12);--shadow-lg: 0 18px 48px rgba(20, 30, 18, .18);--ring: 0 0 0 3px var(--brand-soft);font-family:Segoe UI,system-ui,-apple-system,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg);color:var(--text);font-size:14px}::selection{background:var(--brand-soft)}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-pill);border:3px solid transparent;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:var(--muted);background-clip:content-box}:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.app{display:flex;flex-direction:column;height:100vh}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:9px 16px;background:var(--panel);border-bottom:1px solid var(--border);gap:12px;box-shadow:var(--shadow-xs);z-index:30}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:10px;min-width:0}.toolbar-left{flex:1;min-width:0}.toolbar-titlewrap{display:flex;flex-direction:column;min-width:0;gap:1px;margin-left:2px}.toolbar-sub{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}.dot-divider{color:var(--border-strong)}.toolbar-group{display:flex;align-items:center;gap:2px;padding:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md)}.app-title{font-size:16px}.app-logo{width:28px;height:28px;display:block;flex:none}.brand{display:inline-flex;align-items:center;gap:11px}.brand-logo{width:30px;height:30px;display:block;flex:none}.brand-name{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--text)}.project-title{font-weight:650;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toolbar-left .project-title{max-width:38vw}.muted{color:var(--muted);font-size:13px}button{background:var(--panel);border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:7px 12px;font-size:13px;font-family:inherit;font-weight:550;cursor:pointer;color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:6px;line-height:1.2;transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease,transform .08s ease}button:hover:not(:disabled){border-color:var(--brand);color:var(--brand-strong);background:var(--surface-2)}button:active:not(:disabled){transform:translateY(.5px)}button:disabled{opacity:.45;cursor:not-allowed}button.danger{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 45%,var(--border-strong))}button.danger:hover:not(:disabled){background:var(--danger);border-color:var(--danger);color:#fff}.btn-primary,button.primary{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled),button.primary:hover:not(:disabled){background:var(--brand-strong);border-color:var(--brand-strong);color:#fff}.btn-lg{padding:11px 18px;font-size:14.5px;border-radius:var(--r-md)}.btn-showcase{background:linear-gradient(135deg,#2aa15e,#1c7d47);border-color:transparent;color:#fff;box-shadow:var(--shadow-xs)}.btn-showcase:hover:not(:disabled){filter:brightness(1.06);border-color:transparent;color:#fff;background:linear-gradient(135deg,#2aa15e,#1c7d47)}.btn-icon{width:34px;height:34px;padding:0;border:1px solid transparent;background:transparent;border-radius:var(--r-sm);color:var(--text-2)}.btn-icon:hover:not(:disabled){background:var(--surface-2);border-color:var(--border);color:var(--brand-strong)}.toolbar-group .btn-icon:hover:not(:disabled){background:var(--panel);box-shadow:var(--shadow-xs)}.workspace{flex:1;display:flex;min-height:0}.canvas-area{flex:1;position:relative;overflow:hidden;background:radial-gradient(circle,#e3e8ee 1px,transparent 1px) 0 0 / 24px 24px}.tree-canvas{display:block;width:100%;height:100%;cursor:grab}.tree-canvas:active{cursor:grabbing}.canvas-wrap{position:absolute;top:0;right:0;bottom:0;left:0}.empty-canvas{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;gap:12px;align-items:center;justify-content:center;color:var(--muted);pointer-events:none;z-index:1}.empty-canvas button{pointer-events:auto}.canvas-legend{position:absolute;left:12px;bottom:12px;background:#ffffffeb;border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:11px;color:var(--muted);display:flex;flex-direction:column;gap:5px;pointer-events:none;box-shadow:0 1px 4px #00000014;z-index:1;max-width:360px}.legend-keys{display:flex;gap:12px}.legend-key{display:flex;align-items:center;gap:4px}.legend-dot{width:11px;height:11px;border-radius:3px;border:2px solid}.legend-dot.m{background:var(--male);border-color:var(--male-border)}.legend-dot.f{background:var(--female);border-color:var(--female-border)}.legend-dot.u{background:var(--unknown);border-color:var(--unknown-border)}.legend-shortcuts{line-height:1.7}.canvas-legend kbd{background:#eef1f5;border:1px solid var(--border);border-bottom-width:2px;border-radius:4px;padding:1px 5px;font-family:inherit;font-size:10px;color:var(--text)}.canvas-zoom{position:absolute;right:12px;bottom:12px;display:flex;flex-direction:column;align-items:stretch;background:#fffffff2;border:1px solid var(--border);border-radius:9px;box-shadow:0 1px 6px #0000001f;overflow:hidden;z-index:2}.canvas-zoom button{width:34px;height:32px;border:none;background:transparent;color:var(--text);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.canvas-zoom button:hover{background:var(--accent-soft);color:var(--accent)}.canvas-zoom .zoom-level{font-size:10px;color:var(--muted);text-align:center;padding:2px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none}.canvas-zoom .zoom-reset{border-top:1px solid var(--border);font-size:16px}.canvas-minimap{position:absolute;right:12px;top:12px;background:#fffffff2;border:1px solid var(--border);border-radius:9px;box-shadow:0 1px 6px #0000001f;padding:4px;line-height:0;z-index:2}.canvas-minimap svg{cursor:pointer;display:block;border-radius:5px;background:#f4f6f9}.canvas-minimap .mini-node{fill:#c2ccd8}.canvas-minimap .mini-node.sex-M{fill:var(--male-border)}.canvas-minimap .mini-node.sex-F{fill:var(--female-border)}.canvas-minimap .mini-node.selected{fill:var(--accent)}.canvas-minimap .mini-viewport{fill:#2f80ed1f;stroke:var(--accent);stroke-width:1.5px;pointer-events:none}.tree-link{fill:none;stroke:#9aa5b1;stroke-width:1.5px}.person-card{position:relative;height:100%;border:2px solid var(--unknown-border);background:var(--unknown);border-radius:10px;padding:8px 10px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;box-shadow:0 1px 3px #0000001f;transition:box-shadow .12s,transform .12s;-webkit-user-select:none;user-select:none}.person-card:hover{box-shadow:0 3px 8px #0003}.person-card.selected{outline:3px solid var(--accent);outline-offset:1px}.person-card.sex-M{background:var(--male);border-color:var(--male-border)}.person-card.sex-F{background:var(--female);border-color:var(--female-border)}.person-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:16px}.sex-badge{position:absolute;top:4px;right:6px;font-size:13px;font-weight:700;line-height:1;pointer-events:none}.sex-badge.sex-M{color:var(--male-border)}.sex-badge.sex-F{color:var(--female-border)}.sex-badge.sex-U{color:var(--unknown-border)}.person-name-input{width:100%;box-sizing:border-box;font-weight:600;font-size:14px;font-family:inherit;padding:2px 4px;border:1px solid var(--accent);border-radius:4px;outline:none;background:#fff}.person-dates{font-size:12px;color:#52606d}.person-partner{font-size:11px;color:#616e7c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.collapse-toggle{fill:#fff;stroke:#9aa5b1;stroke-width:1.5px;cursor:pointer}.collapse-toggle:hover{stroke:var(--accent)}.collapse-icon{font-size:14px;font-weight:700;fill:#52606d;pointer-events:none}.node-add{cursor:pointer}.node-add circle{fill:var(--accent);stroke:#fff;stroke-width:2px;box-shadow:0 1px 3px #0000004d;transition:r .1s}.node-add:hover circle{fill:#1c6dd0}.node-add.add-partner circle{fill:var(--female-border)}.node-add.add-partner:hover circle{fill:#c13b76}.node-add.add-son circle,.node-add.add-brother circle,.node-add.add-father circle{fill:var(--male-border)}.node-add.add-son:hover circle,.node-add.add-brother:hover circle,.node-add.add-father:hover circle{fill:#2f6fc0}.node-add.add-daughter circle,.node-add.add-sister circle,.node-add.add-mother circle{fill:var(--female-border)}.node-add.add-daughter:hover circle,.node-add.add-sister:hover circle,.node-add.add-mother:hover circle{fill:#c13b76}.node-add text{fill:#fff;font-size:18px;font-weight:700;pointer-events:none}.edit-panel{width:320px;background:var(--panel);border-left:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.edit-panel h2{margin:0;font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-panel-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 14px 12px 16px;border-bottom:1px solid var(--border)}.edit-panel-id{display:flex;align-items:center;gap:9px;min-width:0}.sex-chip{flex:none;width:26px;height:26px;border-radius:var(--r-pill);display:grid;place-items:center;font-size:14px;font-weight:700;background:var(--unknown);color:var(--unknown-border);border:1.5px solid var(--unknown-border)}.sex-chip.sex-M{background:var(--male);color:var(--male-border);border-color:var(--male-border)}.sex-chip.sex-F{background:var(--female);color:var(--female-border);border-color:var(--female-border)}.panel-close{flex:none}.panel-scroll{flex:1;min-height:0;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:12px}.panel-fields{display:flex;flex-direction:column;gap:10px}.edit-panel label{display:flex;flex-direction:column;font-size:11.5px;font-weight:600;letter-spacing:.01em;text-transform:uppercase;color:var(--muted);gap:5px}.edit-panel input,.edit-panel select,.edit-panel textarea{padding:8px 10px;border:1px solid var(--border-strong);border-radius:var(--r-sm);font-size:13.5px;font-weight:400;text-transform:none;letter-spacing:normal;color:var(--text);font-family:inherit;background:var(--panel);transition:border-color .15s ease,box-shadow .15s ease}.edit-panel input:focus,.edit-panel select:focus,.edit-panel textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--ring)}.edit-panel textarea{resize:vertical}.edit-panel fieldset{border:1px solid var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:7px;padding:10px 12px 12px;margin:0;background:var(--surface-2)}.edit-panel legend{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:0 6px}.panel-section{display:flex;flex-direction:column;gap:9px;padding-top:4px;border-top:1px solid var(--border)}.panel-section-title{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.rel-group{display:flex;flex-direction:column;gap:5px}.rel-label{font-size:11.5px;color:var(--text-2);font-weight:600}.rel-row{display:flex;gap:6px}.rel-row button{flex:1;font-size:12.5px;padding:7px 8px;gap:4px}.panel-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface-2)}.panel-footer button{flex:1}.save-status{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;transition:color .2s ease}.save-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.save-status.save-saved{color:#2faa6a}.save-status.save-pending,.save-status.save-saving{color:var(--mango)}.save-status.save-saving .save-dot{animation:save-pulse 1s ease-in-out infinite}@keyframes save-pulse{50%{opacity:.3}}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0f172073;animation:dialog-fade .12s ease}.dialog{width:min(420px,calc(100vw - 32px));background:var(--panel);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);padding:22px;animation:dialog-pop .14s ease}.dialog-title{margin:0 0 6px;font-size:17px;font-weight:600;color:var(--text)}.dialog-message{margin:0 0 14px;font-size:13.5px;line-height:1.5;color:var(--muted);white-space:pre-wrap}.dialog-input{width:100%;padding:9px 11px;font-size:14px;color:var(--text);border:1px solid var(--border);border-radius:7px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.dialog-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.dialog-btn{padding:8px 16px;font-size:13.5px;font-weight:500;border:1px solid var(--border);border-radius:7px;background:var(--panel);color:var(--text);cursor:pointer;transition:background .15s ease,border-color .15s ease}.dialog-btn:hover{background:var(--bg)}.dialog-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.dialog-btn.primary:hover{background:#2468c8}.dialog-btn.primary.danger{background:var(--danger);border-color:var(--danger)}.dialog-btn.primary.danger:hover{background:#c94545}@keyframes dialog-fade{0%{opacity:0}}@keyframes dialog-pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}.modal-panel{width:min(480px,calc(100vw - 32px));display:flex;flex-direction:column;max-height:min(640px,calc(100vh - 48px))}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.modal-head .dialog-title{display:flex;align-items:center;gap:8px;margin:0}.modal-note{margin:14px 0 0;font-size:12px;line-height:1.5;color:var(--muted)}.modal-empty{padding:18px 4px;text-align:center;font-size:13px}.share-error{margin-top:12px;padding:9px 12px;border-radius:9px;background:var(--danger-soft, #fdecec);color:var(--danger, #b3261e);font-size:12.5px;line-height:1.45}.share-toggle{display:flex;align-items:center;gap:11px;margin-top:16px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-md, 12px);cursor:pointer}.share-toggle input{width:18px;height:18px;accent-color:var(--brand);cursor:pointer;flex:none}.share-toggle span{display:flex;flex-direction:column;gap:1px}.share-toggle strong{font-size:13.5px;color:var(--text)}.share-toggle small{font-size:12px;color:var(--muted)}.share-tabs{display:flex;gap:6px;margin-top:16px}.share-tab{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1px solid var(--border);background:var(--panel);border-radius:var(--r-pill, 999px);font-size:12.5px;font-weight:600;color:var(--text-2, #5b6158);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.share-tab:hover{border-color:var(--border-strong)}.share-tab.active{background:var(--brand-soft);border-color:transparent;color:var(--brand)}.share-field{display:flex;gap:8px;margin-top:12px}.share-field-col{flex-direction:column}.share-readonly{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;color:var(--text-2, #5b6158);background:var(--bg, #f7f6f1)}.share-embed-code{resize:vertical;line-height:1.5;width:100%}.share-copy{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;align-self:flex-start}.share-revoke-note{margin-top:10px}.public-showcase{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:#11151b}.public-showcase .showcase-stage{flex:1}.public-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 18px;background:#14181feb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.08);z-index:2}.public-brand{display:flex;align-items:center;gap:10px}.public-brand-logo{width:24px;height:24px;display:block;flex:none}.public-brand-name{font-size:16px;font-weight:700;letter-spacing:.2px;color:#eef0f2}.public-bar-actions{display:flex;align-items:center;gap:12px}.public-customize-wrap{position:relative}.public-customize{display:inline-flex;align-items:center;gap:7px;background:#ffffff1a;border:1px solid rgba(255,255,255,.16);color:#eef0f2;border-radius:8px;padding:7px 14px 7px 11px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.public-customize:hover,.public-customize.is-open{background:linear-gradient(135deg,#4e9a5a,#84c265);border-color:transparent;color:#fff}.public-panel{position:absolute;top:calc(100% + 10px);right:0;width:320px;max-height:calc(100vh - 100px);overflow-y:auto;display:flex;flex-direction:column;gap:16px;padding:16px;background:#1a1f27fa;border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:0 18px 50px #00000080;z-index:20;animation:panel-pop .16s ease}.public-panel-head{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#aeb4bb}.public-panel-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:7px;background:transparent;color:#c4c9cf;cursor:pointer;transition:background .15s ease,color .15s ease}.public-panel-close:hover{background:#ffffff1f;color:#fff}.public-join-btn{white-space:nowrap}.public-state{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#11151b;color:#cdd3da;text-align:center;padding:24px;font-size:15px}.public-invite{position:absolute;left:18px;bottom:18px;z-index:5;display:inline-flex;align-items:center;gap:11px;padding:9px 15px 9px 12px;border-radius:var(--r-pill, 999px);background:#14181fdb;border:1px solid rgba(255,255,255,.14);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 26px #00000059;text-decoration:none;transition:transform .15s ease,background .15s ease}.public-invite:hover{transform:translateY(-1px);background:#1c222bf2}.public-invite-mark{font-size:20px;line-height:1}.public-invite-logo{width:24px;height:24px;display:block;flex:none}.public-invite-text{display:flex;flex-direction:column;gap:1px}.public-invite-text strong{font-size:13px;color:#f1f3f5}.public-invite-text small{font-size:11.5px;color:#9aa3ad}.share-invite{display:flex;gap:8px;margin-bottom:14px}.share-invite .dialog-input{flex:1}.member-list{display:flex;flex-direction:column;gap:2px;overflow-y:auto}.member-row{display:flex;align-items:center;gap:11px;padding:8px 6px;border-radius:9px}.member-row:hover{background:var(--bg)}.member-avatar{display:grid;place-items:center;width:32px;height:32px;flex-shrink:0;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:13px;font-weight:600}.member-info{display:flex;flex-direction:column;min-width:0;flex:1}.member-email{font-size:13.5px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-you{color:var(--muted);font-weight:400}.member-role{font-size:11.5px;color:var(--muted)}.member-remove{flex-shrink:0;color:var(--muted)}.member-remove:hover{color:var(--danger)}.history-actions{display:flex;justify-content:flex-end;margin-bottom:12px}.version-list{display:flex;flex-direction:column;gap:2px;overflow-y:auto}.version-row{display:flex;align-items:center;gap:12px;padding:10px 6px;border-radius:9px}.version-row:hover{background:var(--bg)}.version-info{display:flex;flex-direction:column;min-width:0;flex:1;gap:2px}.version-title{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--text)}.version-current{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);background:var(--accent-soft);padding:1px 7px;border-radius:999px}.version-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:11.5px;color:var(--muted)}.version-count{display:inline-flex;align-items:center;gap:3px}.btn-sm{padding:5px 11px;font-size:12.5px;gap:5px;flex-shrink:0}.card-shared-tag{display:inline-flex;align-items:center;gap:5px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--accent)}.dir-select{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--muted)}.dir-select select{padding:5px 6px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-family:inherit;color:var(--text);background:var(--panel);cursor:pointer}.dir-select select:focus{outline:none;border-color:var(--accent)}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover:not(:disabled){background:#1f6fd6;color:#fff}.export-menu{position:relative}.export-dropdown{position:absolute;right:0;top:calc(100% + 4px);background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 14px #00000026;display:flex;flex-direction:column;min-width:150px;z-index:20;overflow:hidden}.export-dropdown a{padding:9px 12px;font-size:13px;color:var(--text);text-decoration:none}.export-dropdown a:hover{background:var(--accent-soft);color:var(--accent)}.export-dropdown button{border:none;border-radius:0;background:var(--panel);text-align:left;padding:9px 12px;font-size:13px}.export-dropdown button:hover{background:var(--accent-soft);color:var(--accent)}.menu{position:relative;display:inline-flex}.menu-trigger{color:var(--text-2)}.menu-list{position:absolute;top:calc(100% + 6px);min-width:210px;background:var(--panel);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:6px;z-index:200;animation:menu-pop .13s ease;transform-origin:top right}.menu-list.menu-end{right:0}.menu-list.menu-start{left:0;transform-origin:top left}@keyframes menu-pop{0%{opacity:0;transform:translateY(-4px) scale(.97)}}.menu-item{width:100%;border:none;background:transparent;border-radius:var(--r-sm);padding:8px 10px;font-size:13.5px;font-weight:500;color:var(--text);display:flex;align-items:center;gap:10px;text-align:left;justify-content:flex-start}.menu-item:hover:not(:disabled),.menu-item:focus-visible{background:var(--brand-soft);color:var(--brand-strong);outline:none}.menu-item.danger{color:var(--danger)}.menu-item.danger:hover:not(:disabled),.menu-item.danger:focus-visible{background:var(--danger-soft);color:var(--danger)}.menu-item-icon{display:inline-flex;color:var(--muted);flex:none}.menu-item:hover:not(:disabled) .menu-item-icon,.menu-item.danger .menu-item-icon{color:currentColor}.menu-item-label{flex:1;min-width:0}.menu-sep{height:1px;background:var(--border);margin:6px 4px}.menu-header{padding:6px 10px 8px;border-bottom:1px solid var(--border);margin-bottom:4px}.menu-account-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.menu-account-email{font-size:13px;font-weight:600;color:var(--text);word-break:break-all}.gallery{min-height:100vh;display:flex;flex-direction:column}.app-bar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px;background:#ffffffd9;-webkit-backdrop-filter:saturate(1.4) blur(10px);backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--border)}.app-bar-actions{display:flex;align-items:center;gap:8px}.avatar-btn{width:36px;height:36px;padding:0;border-radius:var(--r-pill);border:1px solid var(--border-strong);background:var(--panel);cursor:pointer;display:grid;place-items:center}.avatar-btn:hover{box-shadow:var(--ring);border-color:var(--brand)}.avatar{width:28px;height:28px;border-radius:var(--r-pill);background:linear-gradient(135deg,#2aa15e,#1c7d47);color:#fff;font-size:13px;font-weight:700;display:grid;place-items:center}.gallery-body{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:28px 24px 56px}.gallery-titlebar{display:flex;align-items:baseline;gap:12px;margin-bottom:22px}.page-title{margin:0;font-size:24px;font-weight:750;letter-spacing:-.015em}.page-subtitle{margin:0;font-size:14px;color:var(--muted)}.banner{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r-md);font-size:13.5px;margin-bottom:20px}.banner-error{background:var(--danger-soft);color:#9a2f24;border:1px solid color-mix(in srgb,var(--danger) 30%,transparent)}.banner svg{flex:none}.error{color:var(--danger)}.tree-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:20px}.tree-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--r-lg);position:relative;display:flex;flex-direction:column;cursor:pointer;box-shadow:var(--shadow-xs);transition:box-shadow .18s ease,transform .18s ease,border-color .18s ease}.tree-card:hover,.tree-card:focus-visible{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--border-strong);outline:none}.tree-card-cover{position:relative;height:132px;display:grid;place-items:center;background:radial-gradient(120% 120% at 50% 0%,#f0f8f1,#e6f1e8 55%,#e9efe2);border-bottom:1px solid var(--border);border-radius:var(--r-lg) var(--r-lg) 0 0;overflow:hidden}.tree-card-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(60% 60% at 50% 120%,rgba(28,125,71,.1),transparent 70%);pointer-events:none}.tree-card-mark{width:64px;height:64px;opacity:.92;filter:drop-shadow(0 4px 8px rgba(19,92,51,.18));transition:transform .25s ease}.tree-card:hover .tree-card-mark{transform:scale(1.06) translateY(-1px)}.tree-card-count{position:absolute;left:10px;top:10px;display:inline-flex;align-items:center;gap:4px;padding:3px 9px 3px 7px;border-radius:var(--r-pill);background:#ffffffe6;border:1px solid var(--border);font-size:12px;font-weight:650;color:var(--text-2)}.tree-card-count svg{color:var(--brand)}.tree-card-menu{position:absolute;right:8px;top:8px;z-index:3;opacity:0;transition:opacity .15s ease}.tree-card:hover .tree-card-menu,.tree-card:focus-within .tree-card-menu,.menu.open~.tree-card-menu,.tree-card-menu .menu.open{opacity:1}.tree-card-menu .menu-trigger{background:#ffffffeb;border:1px solid var(--border)}.tree-card-menu .menu-trigger:hover{background:#fff}.tree-card-open{position:absolute;right:10px;bottom:10px;padding:4px 12px;border-radius:var(--r-pill);background:var(--brand);color:#fff;font-size:12px;font-weight:650;opacity:0;transform:translateY(4px);transition:opacity .18s ease,transform .18s ease}.tree-card:hover .tree-card-open,.tree-card:focus-visible .tree-card-open{opacity:1;transform:translateY(0)}.tree-card-body{padding:13px 15px 15px;border-radius:0 0 var(--r-lg) var(--r-lg)}.tree-card-title{font-weight:650;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-card-meta{font-size:12.5px;color:var(--muted);margin-top:3px}.tree-card.is-skeleton{cursor:default;pointer-events:none}.tree-card.is-skeleton:hover{transform:none;box-shadow:var(--shadow-xs)}.is-skeleton .tree-card-cover{background:linear-gradient(100deg,#efeee8 30%,#f7f6f2,#efeee8 70%);background-size:200% 100%;animation:shimmer 1.3s linear infinite}.skeleton-line{height:13px;border-radius:var(--r-pill);background:linear-gradient(100deg,#efeee8 30%,#f7f6f2,#efeee8 70%);background-size:200% 100%;animation:shimmer 1.3s linear infinite}.skeleton-line.short{width:55%;margin-top:9px;height:11px}@keyframes shimmer{to{background-position:-200% 0}}.empty-state{text-align:center;padding:64px 20px 80px;display:flex;flex-direction:column;align-items:center;gap:8px}.empty-mark{width:96px;height:96px;margin-bottom:8px;filter:drop-shadow(0 8px 18px rgba(19,92,51,.2))}.empty-state h2{margin:0;font-size:22px;font-weight:750}.empty-state p{margin:0;max-width:420px;color:var(--muted);font-size:14.5px;line-height:1.5}.empty-actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;justify-content:center}.splash{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--muted)}.auth-page{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}.auth-hero{display:flex;flex-direction:column;justify-content:center;gap:14px;padding:48px 8vw;color:#eaf6ee;background:radial-gradient(130% 110% at 0% 0%,#2aa15e,#1c7d47 45%,#135c33);position:relative;overflow:hidden}.auth-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(60% 60% at 90% 90%,rgba(255,255,255,.12),transparent 70%);pointer-events:none}.auth-hero-logo{width:76px;height:76px;background:#ffffffeb;border-radius:20px;padding:10px;box-shadow:var(--shadow-md)}.auth-hero-title{margin:8px 0 0;font-size:32px;font-weight:800;letter-spacing:-.02em;line-height:1.1;color:#fff}.auth-hero-text{margin:0;max-width:420px;font-size:16px;line-height:1.55;color:#ffffffdb}.auth-panel{display:flex;align-items:center;justify-content:center;padding:32px 24px;background:var(--bg)}.auth-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:30px 28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.auth-brand{display:inline-flex;align-items:center;gap:9px;margin-bottom:4px}.auth-brand-logo{width:28px;height:28px}.auth-brand-name{font-size:16px;font-weight:700}.auth-heading{margin:0;font-size:22px;font-weight:750;letter-spacing:-.01em}.auth-sub{margin:0 0 8px;color:var(--muted);font-size:14px}.auth-card label{display:flex;flex-direction:column;font-size:12.5px;font-weight:600;color:var(--text-2);gap:5px}.auth-card input{padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--r-sm);font-size:14px;font-family:inherit;font-weight:400;transition:border-color .15s ease,box-shadow .15s ease}.auth-card input:focus{outline:none;border-color:var(--brand);box-shadow:var(--ring)}.auth-card .btn-primary{margin-top:8px;width:100%}.auth-card .error{font-size:13px;margin:0}.auth-card .success{font-size:13px;margin:0;color:var(--success, #22a34a);background-color:#22a34a14;padding:10px 12px;border-radius:6px}.auth-card .info{font-size:13px;margin:0;color:var(--info, #0066cc);background-color:#0066cc14;padding:10px 12px;border-radius:6px}.auth-switch{text-align:center;font-size:13.5px;color:var(--muted);margin:6px 0 0}.link-button{background:none;border:none;color:var(--brand);cursor:pointer;padding:0;font-size:13.5px;font-weight:650}.link-button:hover{text-decoration:underline;border:none;background:none;color:var(--brand-strong)}@media(max-width:760px){.auth-page{grid-template-columns:1fr}.auth-hero{display:none}}.search-box{position:absolute;top:14px;left:14px;width:300px;max-width:calc(100% - 28px);z-index:20;font-size:14px}.search-field{display:flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);border-radius:9px;padding:7px 10px;box-shadow:0 4px 14px #0f17201f}.search-field:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft),0 4px 14px #0f17201f}.search-icon{font-size:13px;opacity:.7}.search-input{flex:1;border:none;outline:none;background:transparent;color:var(--text);font-size:14px}.search-clear{border:none;background:transparent;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:0 2px}.search-clear:hover{color:var(--text)}.search-results{margin-top:6px;background:var(--panel);border:1px solid var(--border);border-radius:9px;box-shadow:0 8px 22px #0f172029;max-height:320px;overflow-y:auto;padding:4px}.search-empty{padding:10px 12px;color:var(--muted)}.search-result{display:flex;flex-direction:column;align-items:flex-start;gap:1px;width:100%;text-align:left;border:none;background:transparent;border-radius:7px;padding:7px 10px;cursor:pointer}.search-result.active,.search-result:hover{background:var(--accent-soft)}.search-result-name{font-weight:600;color:var(--text)}.search-result-detail{font-size:12px;color:var(--muted)}.person-card.flash{animation:card-flash 1.6s ease-out}@keyframes card-flash{0%,60%{outline:3px solid #f2b21e;box-shadow:0 0 0 6px #f2b21e59}to{outline:3px solid transparent;box-shadow:0 0 #f2b21e00}}.showcase-btn{background:linear-gradient(135deg,#6a8dff,#9b6bff);color:#fff;border:none;font-weight:600}.showcase-btn:hover{filter:brightness(1.07)}.showcase{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;flex-direction:column;background:#11151b;animation:showcase-in .35s ease}@keyframes showcase-in{0%{opacity:0}}.showcase-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 16px;background:#14181feb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.08);color:#e8eaed;z-index:2}.showcase-bar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.showcase-bar-right{position:relative;display:flex;align-items:center;gap:10px}.showcase-bar-divider{width:1px;height:22px;background:#ffffff24}.showcase-brand{display:flex;align-items:center;gap:10px;min-width:0}.showcase-brand-logo{width:20px;height:20px;display:block;flex:none}.showcase-theme-name{font-size:14px;font-weight:600;color:#eef0f2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.showcase-back{display:inline-flex;align-items:center;gap:6px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#e8eaed;border-radius:8px;padding:7px 13px 7px 10px;font-size:13px;cursor:pointer;transition:background .15s ease}.showcase-back:hover{background:#ffffff2e}.showcase-customize{display:inline-flex;align-items:center;gap:7px;background:#ffffff1a;border:1px solid rgba(255,255,255,.16);color:#eef0f2;border-radius:8px;padding:7px 14px 7px 11px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.showcase-customize:hover,.showcase-customize.is-open{background:linear-gradient(135deg,#4e9a5a,#84c265);border-color:transparent;color:#fff}.showcase-customize-wrap{position:relative}.showcase-share{display:inline-flex;align-items:center;gap:7px;background:#ffffff1a;border:1px solid rgba(255,255,255,.16);color:#eef0f2;border-radius:8px;padding:7px 14px 7px 11px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.showcase-share:hover{background:linear-gradient(135deg,#4e9a5a,#84c265);border-color:transparent;color:#fff}.embed-customize-wrap{position:absolute;top:12px;right:12px;z-index:15}.embed-customize{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#ffffff1a;border:1px solid rgba(255,255,255,.16);color:#eef0f2;border-radius:8px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.embed-customize:hover,.embed-customize.is-open{background:linear-gradient(135deg,#4e9a5a,#84c265);border-color:transparent;color:#fff}.embed-panel{position:absolute;top:calc(100% + 10px);right:0;width:320px;max-height:calc(100vh - 100px);overflow-y:auto;display:flex;flex-direction:column;gap:16px;padding:16px;background:#1a1f27fa;border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:0 18px 50px #00000080;z-index:20;animation:panel-pop .16s ease}.embed-panel-head{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#aeb4bb}.embed-panel-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:7px;background:transparent;color:#c4c9cf;cursor:pointer;transition:background .15s ease,color .15s ease}.embed-panel-close:hover{background:#ffffff1f;color:#fff}.showcase-panel{position:absolute;top:calc(100% + 10px);right:0;width:320px;max-height:calc(100vh - 90px);overflow-y:auto;display:flex;flex-direction:column;gap:16px;padding:16px;background:#1a1f27fa;border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:0 18px 50px #00000080;z-index:20;animation:panel-pop .16s ease}@keyframes panel-pop{0%{opacity:0;transform:translateY(-6px)}}.showcase-panel-head{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:#aeb4bb}.showcase-panel-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:7px;background:transparent;color:#c4c9cf;cursor:pointer;transition:background .15s ease,color .15s ease}.showcase-panel-close:hover{background:#ffffff1f;color:#fff}.panel-group{display:flex;flex-direction:column;gap:8px}.panel-group-title{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#8a9199}.panel-select{width:100%;background:#ffffff14;color:#eef0f2;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:8px 10px;font-size:13px;cursor:pointer}.panel-select option{color:#1f2933}.showcase-panel .shape-pick,.showcase-panel .label-pick{flex-wrap:wrap}.showcase-panel .animate-toggle{color:#d6d9dd}.showcase-themes{display:flex;gap:6px;flex-wrap:wrap}.theme-chip{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#d6d9dd;border-radius:20px;padding:6px 14px;font-size:13px;cursor:pointer;transition:background .15s ease,border-color .15s ease}.theme-chip:hover:not(.disabled){background:#ffffff24}.theme-chip.active{background:linear-gradient(135deg,#4e9a5a,#84c265);border-color:transparent;color:#fff;font-weight:600}.theme-chip.disabled{opacity:.4;cursor:not-allowed}.showcase-options{display:flex;align-items:center;gap:14px}.lens-pick{display:flex;align-items:center;gap:6px;cursor:pointer}.lens-label{font-size:12px;color:#aeb4bb}.lens-select{background:#ffffff14;color:#eef0f2;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:5px 8px;font-size:12px;cursor:pointer}.lens-select option{color:#1f2933}.shape-pick{display:flex;align-items:center;gap:5px}.shape-chip{padding:5px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#d6d9dd;font-size:12px;cursor:pointer;transition:background .15s ease,color .15s ease}.shape-chip:hover{background:#ffffff24}.shape-chip.active{background:linear-gradient(135deg,#4e9a5a,#84c265);border-color:transparent;color:#fff;font-weight:600}.shape-shuffle{padding:5px 11px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#eef0f2;font-size:12px;cursor:pointer;transition:background .15s ease}.shape-shuffle:hover{background:#ffffff2e}.label-pick{display:flex;align-items:center;gap:4px}.label-pick-caption{font-size:13px;color:#aeb4bb;margin-right:2px}.label-chip{min-width:26px;padding:4px 7px;border-radius:7px;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;color:#d6d9dd;font-size:12px;cursor:pointer;transition:background .15s ease,color .15s ease}.label-chip:hover{background:#ffffff24}.label-chip.active{background:linear-gradient(135deg,#4e9a5a,#84c265);border-color:transparent;color:#fff;font-weight:600}.palette-pick{display:flex;gap:6px}.palette-dot{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.25);cursor:pointer;padding:0}.palette-dot.active{border-color:#fff;box-shadow:0 0 0 2px #ffffff59}.bg-pick{display:flex;align-items:center;gap:6px;cursor:pointer}.bg-label{font-size:12px;color:#aeb4bb}.bg-select{background:#ffffff14;color:#eef0f2;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:5px 8px;font-size:12px;cursor:pointer}.bg-select option{color:#1f2933}.animate-toggle{display:flex;align-items:center;gap:5px;font-size:13px;color:#d6d9dd;cursor:pointer}.showcase-stage{position:relative;flex:1;overflow:hidden}.showcase-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#9aa3ad;text-align:center;padding:24px}.showcase-lens-note{position:absolute;top:16px;left:50%;transform:translate(-50%);max-width:420px;padding:9px 16px;background:#14181ed1;color:#e7eaee;border:1px solid rgba(255,255,255,.14);border-radius:10px;font-size:13px;text-align:center;z-index:6}.showcase-genderkey{position:absolute;top:14px;left:14px;display:flex;flex-direction:column;gap:5px;padding:10px 12px;background:#14181ec7;border:1px solid rgba(255,255,255,.14);border-radius:10px;z-index:6}.showcase-genderkey span{display:flex;align-items:center;gap:7px;font-size:12px;color:#e7eaee}.showcase-genderkey i{width:12px;height:12px;border-radius:50%;display:inline-block}.botanical-svg{display:block;width:100%;height:100%;cursor:grab}.botanical-svg:active{cursor:grabbing}.botanical-bg{fill:url(#bot-sky)}.bot-bd-halo,.bot-bd-rays,.bot-bd-meadow,.bot-bd-bokeh,.bot-bd-contours{pointer-events:none}.bot-bd-rays.is-animated{animation:bot-ray-pulse 9s ease-in-out infinite}@keyframes bot-ray-pulse{0%,to{opacity:.85}50%{opacity:1}}.bot-bd-bokeh.is-animated circle{animation:bot-bokeh-float 14s ease-in-out infinite}@keyframes bot-bokeh-float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@media(prefers-reduced-motion:reduce){.bot-bd-rays.is-animated,.bot-bd-bokeh.is-animated circle{animation:none}}.bot-ground{opacity:.9}.bot-trunk,.bot-branch{opacity:0;animation:branch-fade .7s ease forwards;transition:opacity .25s ease}.bot-trunk{animation-delay:0s;filter:drop-shadow(0 2px 3px rgba(0,0,0,.18))}.bot-trunk-streak{opacity:.35}.bot-branch.dim{opacity:.22}.bot-branch.lit{filter:drop-shadow(0 0 5px rgba(255,220,120,.85))}.bot-joint{transition:opacity .25s ease}.bot-joint.dim{opacity:.22}@keyframes branch-fade{0%{opacity:0}to{opacity:1}}.bot-pop{transform:scale(1);transform-box:fill-box;transform-origin:center;animation:node-pop .55s cubic-bezier(.34,1.56,.64,1) backwards;transition:transform .2s ease}@keyframes node-pop{0%{opacity:0;transform:scale(.1)}to{opacity:1;transform:scale(1)}}.bot-node{cursor:default;transition:opacity .25s ease}.bot-node.dim{opacity:.3}.bot-node.hover .bot-pop,.bot-node.sel .bot-pop{transform:scale(1.22)}.bot-sway{transform-box:fill-box;transform-origin:center bottom}.botanical-svg.animate .bot-sway{animation:bot-sway 5.5s ease-in-out infinite alternate}@keyframes bot-sway{0%{transform:rotate(-1.6deg)}to{transform:rotate(1.6deg)}}.bot-leaf{stroke:#0000000f;stroke-width:.4}.bot-leaf-vein{stroke:#00000024;stroke-width:.5;fill:none}.bot-fruit{stroke:#00000024;stroke-width:.8;filter:drop-shadow(0 1px 1.5px rgba(0,0,0,.25))}.bot-fruit-spec{opacity:.7}.bot-pill{stroke:#0000001f;stroke-width:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.25))}.bot-tag.sel .bot-pill,.bot-node.sel .bot-fruit{stroke:#ffd76a;stroke-width:2.5}.bot-node.sel .bot-leaf{stroke:#ffd76a;stroke-width:1.2}.bot-label{font-size:calc(12px * var(--bot-label-scale, 1));font-weight:600;paint-order:stroke;stroke:#ffffffeb;stroke-width:3px;stroke-linejoin:round;pointer-events:none;-webkit-user-select:none;user-select:none}.bot-label.kind-root{font-size:calc(14px * var(--bot-label-scale, 1));font-weight:700}.bot-label.kind-spine{font-size:calc(12px * var(--bot-label-scale, 1));font-weight:600}.bot-label.kind-fruit{font-size:calc(10.5px * var(--bot-label-scale, 1));font-weight:600;stroke-width:2.6px}.bot-label.kind-leaf{font-size:calc(10px * var(--bot-label-scale, 1));font-weight:500;stroke-width:2.6px}.botanical-svg.label-contrast .bot-label{stroke:#fffffffc;stroke-width:4.4px;font-weight:700;paint-order:stroke}.botanical-svg.label-contrast .bot-label.kind-fruit,.botanical-svg.label-contrast .bot-label.kind-leaf{stroke-width:3.6px}.bot-tag.dim{opacity:.45}.bot-labels{animation:branch-fade .6s ease .55s both}.bot-tag{cursor:pointer;transition:opacity .2s ease}.bot-medal{stroke:#00000038;stroke-width:1.6;filter:drop-shadow(0 1.5px 3px rgba(0,0,0,.3))}.bot-tag.sel .bot-medal{stroke:#ffd76a;stroke-width:2.5}.bot-tag-initial{font-weight:700;opacity:.75;pointer-events:none;-webkit-user-select:none;user-select:none}.bot-chip-bg{fill:#0000001a}.bot-tag image{pointer-events:none}.showcase-plaque{position:absolute;left:50%;bottom:20px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 28px;background:linear-gradient(135deg,#f3e2bd,#e7cf9a);border:1px solid #c9a86a;border-radius:12px;box-shadow:0 6px 22px #00000059;max-width:min(90%,520px)}.plaque-title{background:transparent;border:none;outline:none;text-align:center;font-size:24px;font-weight:700;color:#5a3a18;width:100%;font-family:Georgia,Times New Roman,serif}.plaque-subtitle{background:transparent;border:none;outline:none;text-align:center;font-size:14px;font-style:italic;color:#7a5a32;width:100%}.plaque-title::placeholder,.plaque-subtitle::placeholder{color:#5a3a1866}.showcase-detail{position:absolute;top:18px;right:18px;width:260px;background:#161a21f2;color:#e8eaed;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:16px 18px;box-shadow:0 10px 30px #00000073;animation:detail-in .25s ease}@keyframes detail-in{0%{opacity:0;transform:translateY(-6px)}}.showcase-detail h3{margin:0 0 4px;font-size:18px}.detail-life{margin:0 0 10px;color:#ffd76a;font-size:13px}.detail-row{margin:4px 0;font-size:13px;color:#c4c9cf}.detail-notes{margin:10px 0 0;font-size:13px;color:#aeb4bb;white-space:pre-wrap;border-top:1px solid rgba(255,255,255,.1);padding-top:8px}.detail-close{position:absolute;top:8px;right:10px;background:transparent;border:none;color:#9aa3ad;font-size:20px;line-height:1;cursor:pointer}.detail-close:hover{color:#fff}@media(prefers-reduced-motion:reduce){.bot-trunk,.bot-branch,.bot-pop,.botanical-svg.animate .bot-sway{animation:none}.bot-trunk,.bot-branch{opacity:1}}.person-card.has-photo{padding-left:56px}.card-photo{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;overflow:hidden;background:#fff9;border:2px solid rgba(255,255,255,.85);box-shadow:0 1px 3px #0000002e;pointer-events:none}.card-photo img{width:100%;height:100%;object-fit:cover;display:block}.photo-row{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border, #e4e7eb)}.photo-avatar{width:64px;height:64px;flex:0 0 auto;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--unknown);border:2px solid var(--unknown-border)}.photo-avatar.sex-M{background:var(--male);border-color:var(--male-border)}.photo-avatar.sex-F{background:var(--female);border-color:var(--female-border)}.photo-avatar img{width:100%;height:100%;object-fit:cover;display:block}.photo-placeholder{font-size:24px;color:#00000059}.photo-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.photo-actions button{font:inherit;font-size:13px;padding:5px 10px;border:1px solid #cbd2d9;border-radius:6px;background:#fff;cursor:pointer}.photo-actions button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.photo-actions button:disabled{opacity:.6;cursor:default}.photo-error{flex-basis:100%;font-size:12px;color:#c0392b}.detail-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;margin:0 0 10px;border:2px solid rgba(255,255,255,.25);box-shadow:0 4px 12px #00000059}.detail-photo img{width:100%;height:100%;object-fit:cover;display:block}.scroll-stage{position:absolute;top:0;right:0;bottom:0;left:0;overflow-y:auto;background:radial-gradient(ellipse at 50% 0%,rgba(255,236,190,.06),transparent 60%),linear-gradient(180deg,#2c2115,#201811 55%,#191209);padding:36px 16px 56px;--scroll-ink: #3d2c17;--scroll-ink-soft: #7a5c39;--scroll-ink-faint: #8a6a44}.scroll-sheet{position:relative;max-width:780px;margin:0 auto;font-family:Palatino Linotype,Book Antiqua,Palatino,Georgia,serif;color:var(--scroll-ink)}.scroll-roller{position:relative;height:30px;margin:0 -26px;border-radius:15px;background:linear-gradient(180deg,#8a6642,#5f4327 45%,#3f2c18);box-shadow:0 4px 12px #0000008c,inset 0 1px #ffe2b259;z-index:1}.scroll-roller:before,.scroll-roller:after{content:"";position:absolute;top:50%;transform:translateY(-50%);width:20px;height:38px;border-radius:8px;background:linear-gradient(180deg,#55391f,#33200f);box-shadow:inset 0 1px #ffe2b240}.scroll-roller:before{left:-12px}.scroll-roller:after{right:-12px}.scroll-parchment{position:relative;margin:-8px 0;padding:46px 48px 52px;background:radial-gradient(ellipse at 18% 12%,rgba(139,104,55,.1),transparent 42%),radial-gradient(ellipse at 84% 30%,rgba(139,104,55,.08),transparent 38%),radial-gradient(ellipse at 40% 78%,rgba(139,104,55,.09),transparent 45%),linear-gradient(90deg,#d9c493,#f0e2bd 7%,#f5ead0,#f0e2bd 93%,#d9c493);box-shadow:inset 0 14px 22px -14px #3f2b128c,inset 0 -14px 22px -14px #3f2b128c,0 8px 30px #00000073}.scroll-sheet.animate .scroll-gen{animation:scroll-ink-in .7s ease both}@keyframes scroll-ink-in{0%{opacity:0;transform:translateY(8px)}}.scroll-ornament{text-align:center;font-size:26px;color:var(--scroll-ink-faint);margin-bottom:6px}.scroll-ornament-end{margin:26px 0 0}.scroll-title,.scroll-subtitle{display:block;width:100%;text-align:center;background:transparent;border:none;outline:none;font-family:inherit;color:var(--scroll-ink)}.scroll-title{font-size:calc(30px * var(--scroll-scale, 1));font-weight:700;font-variant:small-caps;letter-spacing:3px}.scroll-subtitle{font-size:calc(15px * var(--scroll-scale, 1));font-style:italic;color:var(--scroll-ink-soft);margin-top:2px}input.scroll-title:focus,input.scroll-subtitle:focus{box-shadow:0 1px 0 var(--scroll-ink-faint)}input.scroll-title::placeholder,input.scroll-subtitle::placeholder{color:#7a5c3980}.scroll-gen{margin-top:30px}.scroll-gen-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}.scroll-gen-rule{flex:1;height:3px;border-top:1px solid var(--scroll-ink-faint);border-bottom:1px solid var(--scroll-ink-faint);opacity:.55}.scroll-gen-label{font-variant:small-caps;letter-spacing:3px;font-size:calc(13px * var(--scroll-scale, 1));color:var(--scroll-ink-soft);white-space:nowrap}.scroll-people{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 14px}.scroll-person{display:flex;flex-direction:column;align-items:center;width:150px;padding:10px 8px;background:transparent;border:none;border-radius:10px;font-family:inherit;color:inherit;cursor:pointer;transition:background .15s}.scroll-person:hover{background:#7a5c391a}.scroll-person.selected{background:#7a5c3924;outline:2px solid var(--scroll-ink-faint)}.scroll-portrait{width:54px;height:54px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#e8d6ab;border:2px double var(--scroll-ink-faint);box-shadow:inset 0 0 6px #3f2b1240;margin-bottom:7px}.scroll-portrait img{width:100%;height:100%;object-fit:cover;display:block;filter:sepia(.25) contrast(.98)}.scroll-initial{font-size:22px;font-variant:small-caps;color:var(--scroll-ink-soft)}.scroll-name{font-size:calc(15px * var(--scroll-scale, 1));font-weight:700;line-height:1.25}.scroll-life{font-size:calc(12px * var(--scroll-scale, 1));color:var(--scroll-ink-soft);margin-top:1px}.scroll-partner{font-size:calc(11.5px * var(--scroll-scale, 1));font-style:italic;color:var(--scroll-ink-faint);margin-top:2px}.scroll-person.founder{width:200px}.scroll-person.founder .scroll-portrait{width:74px;height:74px}.scroll-person.founder .scroll-name{font-size:calc(19px * var(--scroll-scale, 1));font-variant:small-caps;letter-spacing:1px}@media(max-width:640px){.scroll-parchment{padding:34px 22px 40px}.scroll-person{width:128px}}@media(prefers-reduced-motion:reduce){.scroll-sheet.animate .scroll-gen{animation:none}}
