body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg:#1a0e0e;--bg-elevated:#2a1818;--bg-elevated-2:#1f1010;--gold:#c9a24c;--gold-bright:#f0c068;--red:#8b1e1e;--red-bright:#c43e3e;--red-soft:#e85a5a;--leaf:#6fcf6f;--leaf-bright:#9be09b;--text:#f5e6d3;--text-muted:#b8a890;--line:#6b4520;--border:#4a2a1a;--parchment:#efdcae;--parchment-shadow:#c9a36e;--ink:#3b2410;--ink-faded:#6b4a2c}*{box-sizing:border-box}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#1a0e0e;background:var(--bg);color:#f5e6d3;color:var(--text);font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;overflow:hidden;overscroll-behavior:none}.app{background:radial-gradient(circle at 20% 0,#c43e3e1f,#0000 55%),radial-gradient(circle at 80% 100%,#d4a24c14,#0000 55%),#1a0e0e;background:radial-gradient(circle at 20% 0,#c43e3e1f,#0000 55%),radial-gradient(circle at 80% 100%,#d4a24c14,#0000 55%),var(--bg);display:flex;flex-direction:column;height:100vh;height:100dvh}.app-header{flex-shrink:0;padding:18px 16px 10px;position:relative;text-align:center}.back-btn{align-items:center;background:linear-gradient(180deg,#8b1e1e66,#460c0c66);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:999px;color:#f0c068;color:var(--gold-bright);cursor:pointer;display:inline-flex;font-family:inherit;font-size:11.5px;font-weight:600;gap:6px;left:16px;letter-spacing:.08em;max-width:calc(100% - 32px);overflow:hidden;padding:7px 14px;position:absolute;text-overflow:ellipsis;top:16px;transition:all .15s;white-space:nowrap;z-index:5}.back-btn:hover{background:linear-gradient(180deg,#8b1e1e,#6a1414);background:linear-gradient(180deg,var(--red),#6a1414);border-color:#f0c068;border-color:var(--gold-bright);box-shadow:0 0 12px #d4a24c4d}.back-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.app-header h1{color:#f0c068;color:var(--gold-bright);font-family:Playfair Display,"Noto Serif",Georgia,serif;font-size:36px;font-weight:700;letter-spacing:.04em;margin:0;text-shadow:0 2px 12px #c43e3e4d}.tagline{color:#b8a890;color:var(--text-muted);font-size:11px;letter-spacing:.32em;margin:4px 0 0;text-transform:uppercase}.tree-viewport{cursor:grab;flex:1 1;overflow:hidden;position:relative;touch-action:none;user-select:none;-webkit-user-select:none}.tree-viewport.dragging{cursor:grabbing}.tree-canvas{left:0;position:absolute;top:0;transform-origin:0 0;will-change:transform}.tree-canvas.transitioning{transition:transform .7s cubic-bezier(.22,1,.36,1)}.subtree{align-items:center;display:flex;flex-direction:column}.children,.marriages{align-items:flex-start;display:flex;justify-content:center;padding-top:22px;position:relative}.children:before,.marriages:before{background:#6b4520;background:var(--line);content:"";height:22px;left:50%;position:absolute;top:0;transform:translateX(-1px);width:2px}.child,.marriage-branch{align-items:center;display:flex;flex-direction:column;padding:22px 14px 0;position:relative}.child:before,.marriage-branch:before{height:2px;left:0;right:0}.child:after,.child:before,.marriage-branch:after,.marriage-branch:before{background:#6b4520;background:var(--line);content:"";position:absolute;top:0}.child:after,.marriage-branch:after{height:22px;left:50%;transform:translateX(-1px);width:2px}.child:first-child:before,.marriage-branch:first-child:before{left:50%}.child:last-child:before,.marriage-branch:last-child:before{right:50%}.child:only-child:before,.marriage-branch:only-child:before{display:none}.subtree-card-row{align-items:center;display:flex;gap:6px}.sibling-insert-btn{align-items:center;background:#2a1818;background:var(--bg-elevated);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:50%;color:#f0c068;color:var(--gold-bright);cursor:pointer;display:flex;flex:0 0 24px;font-size:16px;font-weight:700;height:24px;justify-content:center;line-height:1;opacity:.5;padding:0;transition:opacity .15s,transform .15s,background .15s,box-shadow .15s;width:24px}.subtree-card-row:hover .sibling-insert-btn{opacity:.95}.sibling-insert-btn:hover{background:linear-gradient(180deg,#c43e3e,#8b1e1e);background:linear-gradient(180deg,var(--red-bright),var(--red));box-shadow:0 0 12px #d4a24c66;opacity:1;transform:scale(1.15)}.app.mode-view .sibling-insert-btn,.tree-canvas.lod-dot .sibling-insert-btn,.tree-canvas.lod-mid .sibling-insert-btn{display:none}.card{background:linear-gradient(180deg,#2a1818,#1f1010);background:linear-gradient(180deg,var(--bg-elevated) 0,var(--bg-elevated-2) 100%);border:1px solid #4a2a1a;border-top:2px solid #c9a24c;border:1px solid var(--border);border-radius:10px;border-top:2px solid var(--gold);box-shadow:0 6px 20px #00000080,inset 0 0 0 1px #d4a24c0f;padding:12px 14px;position:relative;width:200px}.spouse-card{margin-top:8px}.spouse-card:before{background:#6b4520;background:var(--line);content:"";height:8px;left:50%;position:absolute;top:-8px;transform:translateX(-1px);width:2px}.card-icon-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#b8a890;color:var(--text-muted);cursor:pointer;display:flex;height:22px;justify-content:center;opacity:.45;padding:0;position:absolute;top:6px;transition:opacity .15s,color .15s,background .15s,transform .15s;width:22px;z-index:2}.card:hover .card-icon-btn{opacity:1}.card-icon-btn:focus-visible{opacity:1;outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:1px}.heart-btn{left:6px}.leaf-btn{left:30px}.key-btn{right:30px}.card.person-card .card-icon-btn.key-btn:last-of-type,.delete-btn{right:6px}.key-btn:hover{background:#d4a24c1f;color:#f0c068;color:var(--gold-bright)}.key-btn.has-auth{color:#c9a24c;color:var(--gold);filter:drop-shadow(0 0 3px rgba(212,162,76,.5));opacity:1}.heart-btn:hover{background:#c43e3e1f;color:#e85a5a;color:var(--red-soft)}.heart-btn.is-me{color:#c43e3e;color:var(--red-bright);filter:drop-shadow(0 0 4px rgba(196,62,62,.5));opacity:1}.leaf-btn:hover{background:#6fcf6f1f;color:#9be09b;color:var(--leaf-bright)}.leaf-btn.is-portal{animation:leaf-pulse 2.2s ease-in-out infinite;color:#6fcf6f;color:var(--leaf);opacity:1}.leaf-btn.is-portal:hover{background:#6fcf6f2e;color:#9be09b;color:var(--leaf-bright)}@keyframes leaf-pulse{0%,to{filter:drop-shadow(0 0 3px rgba(111,207,111,.4))}50%{filter:drop-shadow(0 0 9px rgba(111,207,111,.95)) drop-shadow(0 0 3px rgba(155,224,155,.6))}}.delete-btn:hover{background:#c43e3e26;color:#e85a5a;color:var(--red-soft)}.person-fields{align-items:center;display:flex;flex-direction:column;text-align:center}.photo-wrapper{cursor:pointer;display:block;margin-bottom:8px;position:relative}.photo-input{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute;width:100%}.photo{align-items:center;background:#2a1818;background:var(--bg-elevated);border:2px solid #c9a24c;border:2px solid var(--gold);border-radius:50%;color:#d4a24c8c;display:flex;height:64px;justify-content:center;object-fit:cover;transition:border-color .15s,box-shadow .15s;width:64px}.photo.placeholder{background:linear-gradient(135deg,#2a1818,#160a0a)}.photo-wrapper:hover .photo{border-color:#f0c068;border-color:var(--gold-bright);box-shadow:0 0 0 3px #f0c0682e}.photo.gender-male{border-color:#6c9ed4;box-shadow:0 0 0 1px #6c9ed440,0 0 8px #6c9ed438}.photo.gender-female{border-color:#d8a0b8;box-shadow:0 0 0 1px #d8a0b840,0 0 8px #d8a0b838}.photo-wrapper:hover .photo.gender-male{border-color:#8eb8e5;box-shadow:0 0 0 3px #6c9ed447}.photo-wrapper:hover .photo.gender-female{border-color:#f0bbd0;box-shadow:0 0 0 3px #d8a0b847}.name{background:#0000;border:none;border-bottom:1px solid #0000;color:#f5e6d3;color:var(--text);font-family:inherit;font-size:14px;font-weight:600;padding:3px 2px;text-align:center;transition:border-color .15s;width:100%}.name:focus{border-bottom-color:#c9a24c;border-bottom-color:var(--gold);outline:none}.name::placeholder{color:#b8a890;color:var(--text-muted);font-style:italic;font-weight:400;opacity:.7}.dates{display:flex;flex-direction:column;gap:2px;margin-top:4px;width:100%}.date{background:#0000;border:none;border-radius:3px;color:#b8a890;color:var(--text-muted);font-family:inherit;font-size:11px;padding:2px;text-align:center;width:100%}.date:focus{background:#d4a24c0f;color:#f5e6d3;color:var(--text);outline:none}.date::placeholder{color:#b8a89073}.marriage-pill{align-items:center;background:linear-gradient(180deg,#8b1e1e,#6a1414);background:linear-gradient(180deg,var(--red) 0,#6a1414 100%);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:999px;box-shadow:0 2px 8px #0006;color:#f0c068;color:var(--gold-bright);display:inline-flex;gap:6px;padding:4px 6px 4px 12px;position:relative;transition:background .25s,border-color .25s,box-shadow .25s,padding .25s;white-space:nowrap;z-index:1}.heart-glyph{line-height:1}.heart-glyph,.marriage-input{color:#f0c068;color:var(--gold-bright);font-size:11px}.marriage-input{background:#0000;border:none;font-family:inherit;font-weight:600;letter-spacing:.16em;padding:1px 2px;text-align:center;text-transform:uppercase;width:130px}.marriage-input::placeholder{color:#f0c06880}.marriage-input:focus{background:#0003;border-radius:3px;outline:none}.pill-delete-btn,.pill-ring-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#f0c0688c;cursor:pointer;display:flex;justify-content:center;margin-left:2px;padding:2px 4px;transition:color .15s,background .15s}.pill-delete-btn:hover,.pill-ring-btn:hover{background:#00000040;color:#f0c068;color:var(--gold-bright)}.pill-ring-btn.is-active{color:#f0c068;color:var(--gold-bright);filter:drop-shadow(0 0 2px rgba(240,192,104,.4))}.pill-ring-btn.is-ended{color:#b8a890b3}.marriage-branch.is-ended:after{background:linear-gradient(180deg,#8c82788c 50%,#0000 0);background-repeat:repeat-y;background-size:100% 6px}.marriage-branch.is-ended>.spouse-card:before{background:linear-gradient(180deg,#8c82788c 50%,#0000 0);background-repeat:repeat-y;background-size:100% 4px}.marriage-branch.is-ended>.marriage-pill{background:linear-gradient(180deg,#4a4540,#2a2520);border-color:#a0968c8c;box-shadow:0 2px 6px #00000059}.marriage-branch.is-ended>.marriage-pill .heart-glyph{color:#d4a24c73}.marriage-branch.is-ended>.marriage-pill .marriage-input{color:#d4c0a0b3;text-decoration:line-through;text-decoration-color:#d4c0a066}.marriage-branch.is-ended>.marriage-pill .marriage-input::placeholder{color:#d4c0a059}.marriage-branch.is-ended>.spouse-card{border-color:#968c82b3 #4a4038d9 #4a4038d9}.tree-canvas.lod-mid .marriage-branch.is-ended>.marriage-pill{animation:none;filter:grayscale(.7) opacity(.7)}.add-btn{background:linear-gradient(180deg,#8b1e1e8c,#460c0c8c);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:4px;color:#f0c068;color:var(--gold-bright);cursor:pointer;font-family:inherit;font-size:10.5px;font-weight:600;letter-spacing:.14em;margin-top:10px;padding:6px 8px;text-transform:uppercase;transition:all .15s ease;width:100%}.add-btn:hover{background:linear-gradient(180deg,#c43e3e,#8b1e1e);background:linear-gradient(180deg,var(--red-bright) 0,var(--red) 100%);box-shadow:0 0 14px #d4a24c47}.add-btn:active{transform:translateY(1px)}.add-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.add-child-row{display:flex;gap:6px;margin-top:10px}.add-child-row .add-btn{flex:1 1;font-size:10px;letter-spacing:.1em;margin-top:0;min-width:0;padding:6px 4px}.add-child-son{background:linear-gradient(180deg,#5082b473,#28508273);border-color:#6c9ed4;color:#d8e8fa}.add-child-son:hover{background:linear-gradient(180deg,#4f86c0,#2f5e94);border-color:#8eb8e5;box-shadow:0 0 12px #6c9ed459}.add-child-daughter{background:linear-gradient(180deg,#b46e9173,#8c466973);border-color:#d8a0b8;color:#f5dbe5}.add-child-daughter:hover{background:linear-gradient(180deg,#b8688f,#8e4a6f);border-color:#f0bbd0;box-shadow:0 0 12px #d8a0b859}.add-parents-btn{background:linear-gradient(180deg,#8b1e1e8c,#460c0c8c);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:999px;color:#f0c068;color:var(--gold-bright);cursor:pointer;font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.16em;margin-bottom:14px;padding:6px 16px;text-transform:uppercase;transition:all .15s ease;white-space:nowrap}.add-parents-btn:hover{background:linear-gradient(180deg,#c43e3e,#8b1e1e);background:linear-gradient(180deg,var(--red-bright) 0,var(--red) 100%);box-shadow:0 0 14px #d4a24c47}.add-parents-btn:active{transform:translateY(1px)}.add-parents-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.tree-canvas.lod-mid .add-btn,.tree-canvas.lod-mid .add-parents-btn,.tree-canvas.lod-mid .card-icon-btn:not(.leaf-btn.is-portal),.tree-canvas.lod-mid .dates,.tree-canvas.lod-mid .pill-delete-btn{display:none}.tree-canvas.lod-mid .photo{height:48px;width:48px}.tree-canvas.lod-mid .marriage-pill{animation:marriage-pulse 2s ease-in-out infinite;background:#0000;border:none;box-shadow:none;padding:2px 6px}.tree-canvas.lod-mid .marriage-pill .heart-glyph{color:#c43e3e;color:var(--red-bright);text-shadow:0 0 8px #c43e3e99}@keyframes marriage-pulse{0%,to{filter:drop-shadow(0 0 3px rgba(240,192,104,.4))}50%{filter:drop-shadow(0 0 10px rgba(240,192,104,.95)) drop-shadow(0 0 4px rgba(196,62,62,.7))}}.tree-canvas.lod-mid .marriage-input{font-size:13px;font-weight:700;letter-spacing:.14em;min-width:80px;width:auto}.tree-canvas.lod-dot .add-btn,.tree-canvas.lod-dot .add-parents-btn,.tree-canvas.lod-dot .card-icon-btn,.tree-canvas.lod-dot .dates,.tree-canvas.lod-dot .marriage-pill,.tree-canvas.lod-dot .photo-wrapper{display:none}.tree-canvas.lod-dot .card:has(.leaf-btn.is-portal){border-color:#6fcf6f99;box-shadow:0 0 8px #6fcf6f4d}.tree-canvas.lod-dot .card{border-radius:999px;border-top-width:1px;max-width:160px;min-width:90px;padding:6px 12px;width:auto}.tree-canvas.lod-dot .spouse-card{margin-top:10px}.tree-canvas.lod-dot .spouse-card:before{height:10px;top:-10px}.tree-canvas.lod-dot .name{font-size:13px;padding:0}.tree-canvas.lod-dot .children,.tree-canvas.lod-dot .marriages{padding-top:16px}.tree-canvas.lod-dot .children:before,.tree-canvas.lod-dot .marriages:before{height:16px}.tree-canvas.lod-dot .child,.tree-canvas.lod-dot .marriage-branch{padding:16px 8px 0}.tree-canvas.lod-dot .child:after,.tree-canvas.lod-dot .marriage-branch:after{height:16px}.floating-heart{animation:heart-pulse 1.4s ease-in-out infinite;background:#0000;border:none;color:#c43e3e;color:var(--red-bright);cursor:pointer;filter:drop-shadow(0 0 6px rgba(196,62,62,.5));padding:6px;pointer-events:auto;position:absolute;transform:translate(-50%,-100%) scale(1);transform-origin:center bottom;z-index:8}.floating-heart:hover{color:#e85a5a;color:var(--red-soft)}.floating-heart:focus-visible{border-radius:50%;outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}@keyframes heart-pulse{0%,to{filter:drop-shadow(0 0 6px rgba(196,62,62,.5));transform:translate(-50%,-100%) scale(1)}50%{filter:drop-shadow(0 0 16px rgba(196,62,62,.95)) drop-shadow(0 0 6px rgba(240,192,104,.55));transform:translate(-50%,-100%) scale(1.18)}}.tree-viewport.transitioning .floating-heart{transition:left .7s cubic-bezier(.22,1,.36,1),top .7s cubic-bezier(.22,1,.36,1)}.modal-backdrop{align-items:center;animation:modal-fade-in .15s ease-out;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#000000a6;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.modal{animation:modal-rise .2s cubic-bezier(.22,1,.36,1);background:linear-gradient(180deg,#2a1818,#1f1010);background:linear-gradient(180deg,var(--bg-elevated) 0,var(--bg-elevated-2) 100%);border:1px solid #c9a24c;border-top:3px solid #c43e3e;border:1px solid var(--gold);border-radius:12px;border-top:3px solid var(--red-bright);box-shadow:0 20px 60px #000000b3,inset 0 0 0 1px #d4a24c1a;max-width:380px;padding:24px;width:calc(100% - 32px)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-rise{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-message{color:#f5e6d3;color:var(--text);font-size:14px;line-height:1.5;margin:0 0 20px}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.modal-btn{border:1px solid;border-radius:6px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.12em;padding:8px 18px;text-transform:uppercase;transition:all .15s ease}.modal-cancel{background:#0000;border-color:#4a2a1a;border-color:var(--border);color:#b8a890;color:var(--text-muted)}.modal-cancel:hover{background:#d4a24c0f;border-color:#c9a24c;border-color:var(--gold);color:#f0c068;color:var(--gold-bright)}.modal-delete{background:linear-gradient(180deg,#c43e3e,#8b1e1e);background:linear-gradient(180deg,var(--red-bright) 0,var(--red) 100%);border-color:#c43e3e;border-color:var(--red-bright);box-shadow:0 2px 8px #c43e3e59;color:#f5e6d3;color:var(--text)}.modal-delete:hover{background:linear-gradient(180deg,#d54848,#c43e3e);background:linear-gradient(180deg,#d54848 0,var(--red-bright) 100%);box-shadow:0 0 16px #c43e3e80}.modal-actions-three{flex-wrap:wrap;gap:8px}.modal-discard{background:#0000;border-color:#4a2a1a;border-color:var(--border);color:#b8a890;color:var(--text-muted)}.modal-discard:hover{background:#c43e3e14;border-color:#c43e3e;border-color:var(--red-bright);color:#c43e3e;color:var(--red-bright)}.modal-save{background:linear-gradient(180deg,#f0c068,#c9a24c);background:linear-gradient(180deg,var(--gold-bright) 0,var(--gold) 100%);border-color:#c9a24c;border-color:var(--gold);box-shadow:0 2px 8px #d4a24c66;color:#1a0e0e;color:var(--bg)}.modal-save:hover{background:linear-gradient(180deg,#f5d080,#f0c068);background:linear-gradient(180deg,#f5d080 0,var(--gold-bright) 100%);box-shadow:0 0 14px #f0c0688c}.unsaved-backdrop{z-index:110}.modal-wide{max-width:480px}.modal-title{color:#f0c068;color:var(--gold-bright);font-family:Playfair Display,Georgia,serif;font-size:20px;font-weight:600;letter-spacing:.04em;margin:0 0 16px}.auth-form{gap:12px}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:4px}.auth-field span{color:#b8a890;color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase}.auth-field input,.auth-field select{background:#00000059;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:6px;color:#f5e6d3;color:var(--text);font-family:inherit;font-size:13px;outline:none;padding:8px 12px;transition:border-color .15s}.auth-field input:focus,.auth-field select:focus{border-color:#c9a24c;border-color:var(--gold)}.auth-phone-row{display:flex;gap:10px}.auth-field-cc{flex:0 0 130px}.auth-field-phone{flex:1 1}.auth-hint{background:#d4a24c0f;border-left:2px solid #c9a24c;border-left:2px solid var(--gold);border-radius:4px;color:#b8a890;color:var(--text-muted);font-size:12px;line-height:1.55;margin:4px 0 0;padding:10px 12px}.auth-hint code{background:#00000059;border-radius:3px;color:#f0c068;color:var(--gold-bright);font-size:12px;padding:1px 6px}.auth-error{color:#c43e3e;color:var(--red-bright);font-size:12px;font-style:italic;margin:0}.auth-perm-toggle{background:#00000059;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:999px;display:inline-flex;gap:2px;padding:2px;width:fit-content}.auth-perm-btn{background:#0000;border:none;border-radius:999px;color:#b8a890;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.04em;padding:6px 14px;transition:all .15s}.auth-perm-btn.active,.auth-perm-btn:hover{color:#f0c068;color:var(--gold-bright)}.auth-perm-btn.active{background:linear-gradient(180deg,#8b1e1e,#6a1414);background:linear-gradient(180deg,var(--red),#6a1414);box-shadow:0 0 0 1px #c9a24c;box-shadow:0 0 0 1px var(--gold)}.auth-tree-access-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto;padding:4px 2px}.auth-tree-access-row{align-items:center;display:flex;gap:12px;justify-content:space-between;padding:4px 2px}.auth-tree-access-label{color:#f5e6d3;color:var(--text);flex:1 1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-perm{background:#00000059;border-radius:999px;color:#b8a890;color:var(--text-muted);font-size:9.5px;letter-spacing:.1em;padding:2px 6px;text-transform:uppercase}.log-modal{display:flex;flex-direction:column;max-height:calc(100vh - 80px);max-width:640px}.log-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.log-list{background:#00000040;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:6px;list-style:none;margin:0;max-height:60vh;overflow-y:auto;padding:0}.log-entry{grid-gap:12px;border-bottom:1px solid #653d1e33;display:grid;font-size:12px;gap:12px;grid-template-columns:140px 120px 1fr;padding:8px 12px}.log-entry:last-child{border-bottom:none}.log-time{font-feature-settings:"tnum";color:#b8a890;color:var(--text-muted);font-variant-numeric:tabular-nums}.log-actor{color:#f0c068;color:var(--gold-bright);font-weight:600}.log-action{color:#f5e6d3;color:var(--text)}.log-target{color:#c9a24c;color:var(--gold)}.log-detail{color:#b8a890;color:var(--text-muted);font-style:italic}@media (max-width:600px){.log-entry{gap:2px;grid-template-columns:1fr}.header-right{gap:6px;right:8px;top:8px}.auth-link-btn{font-size:10.5px;padding:5px 10px}.session-pill{font-size:10.5px;padding:3px 4px 3px 10px}.session-name{max-width:80px}.session-logout{font-size:10px;padding:3px 8px}.auth-phone-row{flex-direction:column;gap:12px}.auth-field-cc{flex:1 1 auto}.session-perm{display:none}.audio-grid,.video-grid{gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.video-overlay-close{top:-36px}}.modal-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.zoom-controls{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#1a0e0ed9;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:999px;bottom:18px;box-shadow:0 8px 24px #0009;gap:8px;padding:6px 12px;position:absolute;right:18px;user-select:none;-webkit-user-select:none;z-index:10}.zoom-btn,.zoom-controls{align-items:center;display:flex}.zoom-btn{background:linear-gradient(180deg,#8b1e1e99,#460c0c99);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:50%;color:#f0c068;color:var(--gold-bright);cursor:pointer;flex-shrink:0;font-family:inherit;font-size:18px;font-weight:700;height:30px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;width:30px}.zoom-btn:hover{background:linear-gradient(180deg,#c43e3e,#8b1e1e);background:linear-gradient(180deg,var(--red-bright),var(--red));box-shadow:0 0 12px #d4a24c66}.zoom-btn:active{transform:translateY(1px)}.zoom-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.reset-btn{font-size:16px}.zoom-slider{appearance:none;background:#2a1818;background:var(--bg-elevated);border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:999px;cursor:pointer;height:4px;margin:0;outline:none;padding:0;width:130px}.zoom-slider::-webkit-slider-thumb{appearance:none;background:#f0c068;background:var(--gold-bright);border:1px solid #8b1e1e;border:1px solid var(--red);border-radius:50%;box-shadow:0 0 6px #f0c06899;cursor:pointer;height:14px;width:14px}.zoom-slider::-moz-range-thumb{background:#f0c068;background:var(--gold-bright);border:1px solid #8b1e1e;border:1px solid var(--red);border-radius:50%;box-shadow:0 0 6px #f0c06899;cursor:pointer;height:14px;width:14px}.zoom-readout{font-feature-settings:"tnum";color:#b8a890;color:var(--text-muted);font-size:11px;font-variant-numeric:tabular-nums;letter-spacing:.05em;min-width:38px;text-align:right}.zoom-divider{background:#4a2a1a;background:var(--border);height:22px;width:1px}@media (max-width:600px){.app-header{padding:44px 12px 6px}.app-header h1{font-size:26px}.tagline{font-size:10px;letter-spacing:.28em}.back-btn{font-size:10.5px;left:10px;letter-spacing:.06em;max-width:calc(100% - 20px);padding:5px 10px;top:10px}.add-parents-btn{font-size:10px;margin-bottom:10px;padding:5px 12px}.card{border-radius:8px;padding:10px;width:168px}.photo{height:52px;width:52px}.name{font-size:12.5px}.date{font-size:10px}.marriage-pill{padding:3px 4px 3px 8px}.marriage-input{font-size:10px;letter-spacing:.12em;width:100px}.add-btn{font-size:9.5px;letter-spacing:.1em;padding:5px 6px}.child,.marriage-branch{padding:22px 6px 0}.card-icon-btn{height:20px;opacity:.6;width:20px}.modal{padding:18px}.modal-message{font-size:13px}.modal-btn{font-size:11px;padding:7px 14px}.zoom-controls{bottom:12px;gap:6px;padding:4px 10px;right:12px}.zoom-btn{font-size:15px;height:26px;width:26px}.zoom-slider{width:80px}.zoom-readout{font-size:10px;min-width:32px}.mode-toggle{right:10px;top:10px}.media-icons{gap:4px;padding:6px 0 2px}.media-icon-btn{height:26px;width:26px}.media-modal{max-height:calc(100% - 16px);width:calc(100% - 16px)}.media-modal-header{gap:8px;padding:10px 12px}.media-modal-title{font-size:16px}.media-modal-body{padding:14px}.media-tab{font-size:10.5px;gap:4px;padding:6px 8px}.media-tab-label{display:none}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.parchment-page{padding:24px 18px}.parchment-content{font-size:16px}.toast{bottom:70px;left:12px;max-width:none;right:12px}}.header-right{align-items:center;display:flex;gap:10px;position:absolute;right:16px;top:14px;z-index:5}.auth-link-btn{align-items:center;background:#00000059;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:999px;color:#f0c068;color:var(--gold-bright);cursor:pointer;display:inline-flex;font-family:inherit;font-size:11.5px;font-weight:600;gap:6px;letter-spacing:.06em;padding:6px 12px;transition:all .15s}.auth-link-btn:hover{background:linear-gradient(180deg,#8b1e1e,#6a1414);background:linear-gradient(180deg,var(--red),#6a1414);border-color:#c9a24c;border-color:var(--gold);box-shadow:0 0 8px #d4a24c4d}.auth-link-btn.stale{position:relative}.auth-link-btn.stale:after{animation:backup-stale-pulse 2.5s ease-in-out infinite;background:#c43e3e;background:var(--red-bright);border-radius:50%;box-shadow:0 0 6px #c43e3ed9;content:"";height:7px;position:absolute;right:4px;top:4px;width:7px}@keyframes backup-stale-pulse{0%,to{opacity:.7}50%{opacity:1}}.session-pill{align-items:center;background:linear-gradient(180deg,#8b1e1e66,#460c0c66);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:999px;color:#f0c068;color:var(--gold-bright);display:inline-flex;font-family:inherit;font-size:11.5px;font-weight:600;gap:8px;padding:4px 4px 4px 12px}.session-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-logout{background:#00000059;border:none;border-radius:999px;color:#f0c068;color:var(--gold-bright);cursor:pointer;font-family:inherit;font-size:11px;letter-spacing:.05em;padding:4px 10px;transition:all .15s}.session-logout:hover{background:#c43e3e;background:var(--red-bright);color:#f5e6d3;color:var(--text)}.mode-toggle{align-items:center;background:#2a1818;background:var(--bg-elevated);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:999px;box-shadow:0 2px 8px #0006;cursor:pointer;display:flex;font-family:inherit;height:28px;justify-content:space-between;padding:0;position:relative;right:auto;top:auto;transition:border-color .15s,box-shadow .15s;width:60px;z-index:5}.mode-toggle:hover{border-color:#f0c068;border-color:var(--gold-bright);box-shadow:0 0 10px #d4a24c4d}.mode-toggle:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.mode-toggle-icon{align-items:center;display:inline-flex;height:28px;justify-content:center;pointer-events:none;transition:color .18s;width:28px;z-index:1}.mode-toggle-eye,.mode-toggle-pencil{color:#b8a890;color:var(--text-muted)}.mode-toggle.mode-toggle-edit .mode-toggle-pencil,.mode-toggle.mode-toggle-view .mode-toggle-eye{color:#1a0e0e;color:var(--bg)}.mode-toggle-thumb{background:linear-gradient(180deg,#f0c068,#c9a24c);background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-radius:50%;box-shadow:0 0 8px #f0c06873;height:26px;left:1px;position:absolute;top:1px;transition:transform .22s cubic-bezier(.22,1,.36,1);width:26px}.mode-toggle.mode-toggle-edit .mode-toggle-thumb{transform:translateX(31px)}.app.mode-view .add-btn,.app.mode-view .add-parents-btn,.app.mode-view .card-icon-btn:not(.leaf-btn.is-portal),.app.mode-view .photo-input,.app.mode-view .pill-delete-btn{display:none!important}.app.mode-view .photo-wrapper{cursor:default}.app.mode-view .marriage-pill{padding-right:12px}.app.mode-view .date,.app.mode-view .marriage-input,.app.mode-view .name{cursor:default}.app.mode-view .date:focus,.app.mode-view .marriage-input:focus,.app.mode-view .name:focus{background:#0000;border-bottom-color:#0000}.media-icons{gap:6px;margin-top:6px}.media-icon-btn,.media-icons{display:flex;justify-content:center}.media-icon-btn{align-items:center;background:#00000073;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:6px;color:#b8a890;color:var(--text-muted);cursor:pointer;font-family:inherit;height:24px;padding:0;position:relative;transition:all .15s;width:24px}.media-icon-btn:hover{background:#8b1e1e66;border-color:#c9a24c;border-color:var(--gold);box-shadow:0 0 8px #d4a24c40;color:#f0c068;color:var(--gold-bright)}.media-icon-btn.has-content{background:linear-gradient(180deg,#8b1e1e73,#460c0c73);border-color:#c9a24c;border-color:var(--gold);color:#c9a24c;color:var(--gold)}.media-icon-btn.has-content:hover{color:#f0c068;color:var(--gold-bright)}.media-icon-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.media-count{align-items:center;background:#c43e3e;background:var(--red-bright);border:1px solid #1a0e0e;border:1px solid var(--bg);border-radius:999px;color:#f5e6d3;color:var(--text);display:inline-flex;font-size:9px;font-weight:700;height:14px;justify-content:center;letter-spacing:0;line-height:1;min-width:14px;padding:1px 4px;position:absolute;right:-4px;top:-4px}.tree-canvas.lod-dot .media-icons,.tree-canvas.lod-mid .media-count{display:none}.person-media-btn{align-items:center;align-self:center;background:#0006;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:4px;color:#b8a890;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:18px;justify-content:center;margin-top:6px;padding:0;transition:all .15s;width:26px}.person-media-btn:hover{background:#8b1e1e66;border-color:#c9a24c;border-color:var(--gold);box-shadow:0 0 6px #d4a24c33;color:#f0c068;color:var(--gold-bright)}.person-media-btn.has-content{background:linear-gradient(180deg,#8b1e1e73,#460c0c73);border-color:#c9a24c;border-color:var(--gold);color:#c9a24c;color:var(--gold)}.person-media-btn.has-content:hover{color:#f0c068;color:var(--gold-bright)}.person-media-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.tree-canvas.lod-dot .person-media-btn,.tree-canvas.lod-mid .person-media-btn{display:none}.person-actions-row{align-items:center;display:flex;gap:6px;justify-content:center;margin-top:6px}.person-actions-row>.person-media-btn{margin-top:0}.memorial-btn{align-items:center;background:#00000073;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:4px;color:#b8a890;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:22px;justify-content:center;padding:0;transition:all .15s;width:26px}.memorial-btn:hover{background:linear-gradient(180deg,#8b1e1e80,#460c0c80);border-color:#c9a24c;border-color:var(--gold);box-shadow:0 0 8px #d4a24c4d;color:#f0c068;color:var(--gold-bright)}.memorial-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.tree-canvas.lod-dot .memorial-btn,.tree-canvas.lod-mid .memorial-btn{display:none}.gender-btn{align-items:center;background:#00000073;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:4px;color:#b8a890;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-family:inherit;font-size:13px;font-weight:600;height:22px;justify-content:center;line-height:1;padding:0;transition:all .15s;width:26px}.gender-btn:hover{background:#0009;border-color:#c9a24c;border-color:var(--gold)}.gender-btn-male{background:linear-gradient(180deg,#28508273,#14326473);border-color:#6c9ed48c;color:#d8e8fa}.gender-btn-male:hover{border-color:#8eb8e5;box-shadow:0 0 6px #6c9ed44d}.gender-btn-female{background:linear-gradient(180deg,#8c466973,#64324b73);border-color:#d8a0b88c;color:#f5dbe5}.gender-btn-female:hover{border-color:#f0bbd0;box-shadow:0 0 6px #d8a0b84d}.gender-btn:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.person-actions-row:empty,.tree-canvas.lod-dot .gender-btn,.tree-canvas.lod-mid .gender-btn{display:none}.memorial-backdrop{align-items:center;animation:memorial-fade-in .7s ease-out;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:radial-gradient(circle at 50% 40%,#140808eb 0,#000000fc 75%);display:flex;inset:0;justify-content:center;padding:40px 20px;position:fixed;z-index:250}@keyframes memorial-fade-in{0%{opacity:0}to{opacity:1}}.memorial-stage{align-items:center;animation:memorial-rise .8s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;max-width:100%;position:relative}@keyframes memorial-rise{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.memorial-close{align-items:center;background:#000000b3;border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:50%;color:#f0c068;color:var(--gold-bright);cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:0;top:-48px;transition:all .15s;width:36px;z-index:5}.memorial-close:hover{background:#c43e3e;background:var(--red-bright);box-shadow:0 0 14px #c43e3e80;color:#f5e6d3;color:var(--text);transform:scale(1.1)}.memorial-frame-outer{background:linear-gradient(135deg,#5a3a1a,#2a1a0a 50%,#5a3a1a);border-radius:4px;box-shadow:0 25px 60px #000000d9,0 0 80px #d4a24c2e,inset 0 0 0 1px #0009;padding:8px}.memorial-frame-mid{background:linear-gradient(135deg,#d4a24c,#f0c068 50%,#b88532);border-radius:2px;box-shadow:inset 0 0 0 1px #0006,inset 0 1px 2px #ffffff4d;padding:4px}.memorial-frame-inner{background:linear-gradient(180deg,#1f1010,#15080a);border-radius:1px;box-shadow:inset 0 0 80px #d4a24c0a,inset 0 0 0 1px #d4a24c26;padding:32px 40px 36px;position:relative}.memorial-frame-inner:after,.memorial-frame-inner:before{border:2px solid #d4a24cb3;content:"";height:26px;position:absolute;width:26px}.memorial-frame-inner:before{border-bottom:none;border-right:none;left:10px;top:10px}.memorial-frame-inner:after{border-left:none;border-top:none;bottom:10px;right:10px}.memorial-photo-wrap{background:#08040a;box-shadow:inset 0 0 0 1px #d4a24c33;display:flex;justify-content:center;margin:0 auto 18px;padding:8px}.memorial-photo{border:2px solid #1a0a05;display:block;filter:grayscale(.45) sepia(.18) brightness(.96);height:320px;object-fit:cover;width:240px}.memorial-photo-placeholder{align-items:center;background:linear-gradient(135deg,#2a1818,#1a0e0e);color:#d4a24c4d;display:flex;justify-content:center}.memorial-name{color:#f0c068;color:var(--gold-bright);font-family:Playfair Display,Cormorant Garamond,Georgia,serif;font-size:30px;font-weight:600;letter-spacing:.06em;margin:0 0 6px;text-align:center;text-shadow:0 1px 8px #0009}.memorial-dates{color:#b8a890;color:var(--text-muted);font-family:Cormorant Garamond,Georgia,serif;font-size:17px;font-style:italic;letter-spacing:.18em;margin:0;text-align:center}.memorial-dash{margin:0 4px;opacity:.7}.memorial-altar-row{align-items:flex-end;display:flex;gap:60px;justify-content:center;margin-top:-6px;padding:0 30px;position:relative}.memorial-altar-row:after{background:linear-gradient(180deg,#5a3a1a,#2a1a0a 70%);border-radius:2px;bottom:-6px;box-shadow:0 8px 24px #000000b3,inset 0 1px 2px #d4a24c33;content:"";height:16px;left:5%;position:absolute;right:5%;z-index:0}.memorial-candle{position:relative;width:70px;z-index:1}.candle-svg{display:block;height:auto;overflow:visible;width:100%}.memorial-incense-altar{position:relative;width:150px;z-index:1}.memorial-incense-svg{display:block;height:auto;overflow:visible;width:100%}.candle-flame-inner,.candle-flame-outer{transform-box:fill-box;transform-origin:center bottom}.candle-flame-outer{animation:candle-flicker-a .55s ease-in-out infinite}.candle-flame-inner{animation:candle-flicker-b .45s ease-in-out infinite}@keyframes candle-flicker-a{0%,to{transform:scaleY(1) scaleX(1)}25%{transform:scaleY(1.08) scaleX(.94)}50%{transform:scaleY(.95) scaleX(1.05)}75%{transform:scaleY(1.04) scaleX(.97)}}@keyframes candle-flicker-b{0%,to{transform:scaleY(1) scaleX(1)}30%{transform:scaleY(1.06) scaleX(.96)}60%{transform:scaleY(.96) scaleX(1.04)}}.candle-glow{animation:candle-glow-pulse 2.5s ease-in-out infinite;transform-box:fill-box;transform-origin:center}@keyframes candle-glow-pulse{0%,to{opacity:.55;transform:scale(.95)}50%{opacity:1;transform:scale(1.08)}}.memorial-candle-right .candle-flame-outer{animation-delay:.18s}.memorial-candle-right .candle-flame-inner{animation-delay:.07s}.memorial-candle-right .candle-glow{animation-delay:.4s}@media (max-width:700px){.memorial-frame-inner{padding:22px 24px 26px}.memorial-photo{height:240px;width:180px}.memorial-name{font-size:22px}.memorial-dates{font-size:14px;letter-spacing:.14em}.memorial-altar-row{gap:24px;padding:0 12px}.memorial-candle{width:50px}.memorial-incense-altar{width:110px}.memorial-close{top:-42px}}.card.is-deceased{border-color:#9a9a9a #4a4540 #4a4540}.card.is-deceased .photo{border-color:#8a8a8a;filter:grayscale(.75)}.card.is-deceased .name{color:#c0b8aa}.card.is-deceased .date{color:#8e8880}.card.is-deceased:after{background:#5050500f;border-radius:inherit;content:"";inset:0;pointer-events:none;position:absolute}.incense-svg{display:block;margin:4px auto 2px;overflow:visible}.incense-smoke{animation:incense-smoke 3s ease-out infinite;transform-box:fill-box;transform-origin:50% 100%}.incense-smoke-1{animation-delay:0s}.incense-smoke-2{animation-delay:1s}.incense-smoke-3{animation-delay:2s}@keyframes incense-smoke{0%{opacity:0;transform:translateY(8px)}20%{opacity:.75}to{opacity:0;transform:translateY(-14px)}}.incense-ember{animation:incense-ember 1.6s ease-in-out infinite}.incense-ember-1{animation-delay:0s}.incense-ember-2{animation-delay:.55s}.incense-ember-3{animation-delay:1.05s}@keyframes incense-ember{0%,to{opacity:.55}50%{opacity:1}}.tree-canvas.lod-dot .incense-svg,.tree-canvas.lod-mid .incense-svg{display:none}.media-modal{animation:modal-rise .22s cubic-bezier(.22,1,.36,1);background:linear-gradient(180deg,#2a1818,#1f1010);background:linear-gradient(180deg,var(--bg-elevated) 0,var(--bg-elevated-2) 100%);border:1px solid #c9a24c;border-top:3px solid #c43e3e;border:1px solid var(--gold);border-radius:14px;border-top:3px solid var(--red-bright);box-shadow:0 24px 70px #000000b3,inset 0 0 0 1px #d4a24c14;display:flex;flex-direction:column;max-height:calc(100vh - 40px);overflow:hidden;width:min(820px,100% - 40px)}.media-modal-story{background:#0000;border:none;box-shadow:none;width:min(720px,100% - 40px)}.media-modal-header{align-items:center;border-bottom:1px dashed #d4a24c4d;display:flex;flex-shrink:0;justify-content:space-between;padding:14px 20px}.media-modal-story .media-modal-header{background:#0000;border-bottom:none}.media-modal-title{color:#f0c068;color:var(--gold-bright);font-family:Playfair Display,Georgia,serif;font-size:20px;font-weight:600;letter-spacing:.04em;margin:0}.media-modal-tabs{background:#00000059;border-radius:999px;display:flex;flex:1 1 auto;gap:2px;min-width:0;padding:4px}.media-tab{align-items:center;background:#0000;border:none;border-radius:999px;color:#b8a890;color:var(--text-muted);cursor:pointer;display:inline-flex;flex:1 1;font-family:inherit;font-size:11.5px;font-weight:600;gap:6px;justify-content:center;letter-spacing:.06em;min-width:0;padding:7px 10px;transition:all .15s;white-space:nowrap}.media-tab:hover{background:#ffffff0a}.media-tab.active,.media-tab:hover{color:#f0c068;color:var(--gold-bright)}.media-tab.active{background:linear-gradient(180deg,#8b1e1e,#6a1414);background:linear-gradient(180deg,var(--red),#6a1414);box-shadow:0 0 0 1px #c9a24c,0 1px 4px #00000080;box-shadow:0 0 0 1px var(--gold),0 1px 4px #00000080}.media-tab:focus-visible{outline:2px solid #f0c068;outline:2px solid var(--gold-bright);outline-offset:2px}.media-modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#b8a890;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:color .15s,background .15s}.media-modal-close:hover{background:#d4a24c1a;color:#f0c068;color:var(--gold-bright)}.media-modal-body{flex:1 1 auto;overflow-y:auto;padding:20px}.media-modal-story .media-modal-body{overflow:visible;padding:0}.empty-note{color:#b8a890;color:var(--text-muted);font-style:italic;margin:0;padding:24px 12px;text-align:center}.photo-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.album-item{background:#00000040;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;overflow:hidden;position:relative}.album-photo{aspect-ratio:1/1;display:block;object-fit:cover;width:100%}.album-caption-input{background:#0000004d;border:none;border-top:1px solid #4a2a1a;border-top:1px solid var(--border);color:#f5e6d3;color:var(--text);font-family:inherit;font-size:12px;outline:none;padding:8px 10px;width:100%}.album-caption-input::placeholder{color:#b8a890;color:var(--text-muted);font-style:italic}.album-caption-input:focus{background:#d4a24c0f}.album-caption{border-top:1px solid #4a2a1a;border-top:1px solid var(--border);color:#b8a890;color:var(--text-muted);font-size:13px;font-style:italic;margin:0;padding:8px 10px}.album-remove-btn{align-items:center;background:#0009;border:none;border-radius:50%;color:#f5e6d3;color:var(--text);cursor:pointer;display:flex;height:24px;justify-content:center;opacity:0;position:absolute;right:6px;top:6px;transition:opacity .15s,background .15s;width:24px}.album-item:hover .album-remove-btn,.audio-card:hover .album-remove-btn,.video-card:hover .album-remove-btn{opacity:1}.album-remove-btn:hover{background:#c43e3e;background:var(--red-bright)}.media-list{display:flex;flex-direction:column;gap:14px}.media-list-item{background:#00000040;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:8px;padding:12px 14px;position:relative}.media-title{margin:0 0 8px}.media-title,.media-title-input{color:#f0c068;color:var(--gold-bright);font-size:14px;font-weight:600}.media-title-input{background:#0000;border:none;border-bottom:1px solid #0000;font-family:inherit;margin-bottom:8px;outline:none;padding:4px 0;width:100%}.media-title-input:focus{border-bottom-color:#c9a24c;border-bottom-color:var(--gold)}.media-title-input::placeholder{color:#f0c06880;font-style:italic}.media-audio-player{width:100%}.media-video-player{background:#000;border-radius:4px;max-height:60vh;width:100%}.media-video-iframe{aspect-ratio:16/9;border:none;height:auto}.audio-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.audio-card{align-items:stretch;background:#0000004d;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;gap:8px;padding:14px;position:relative}.audio-cover{align-items:center;background:linear-gradient(135deg,#8b1e1e66,#460c0c66);border-radius:8px;color:#c9a24c;color:var(--gold);display:flex;height:90px;justify-content:center}.audio-title{color:#f0c068;color:var(--gold-bright);font-size:13px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audio-title-input{margin-bottom:0}.audio-player-compact{height:32px;width:100%}.video-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.video-card{background:#0000004d;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px}.video-card,.video-thumb-btn{display:flex;overflow:hidden;position:relative}.video-thumb-btn{align-items:center;aspect-ratio:16/9;background:#000;border:none;cursor:pointer;justify-content:center;padding:0;width:100%}.video-thumb{display:block;height:100%;object-fit:cover;transition:transform .2s;width:100%}.video-thumb-btn:hover .video-thumb{transform:scale(1.04)}.video-thumb-placeholder{background:linear-gradient(135deg,#2a2a2a,#1a1a1a);color:#d4a24c80;height:100%;width:100%}.video-play-overlay,.video-thumb-placeholder{align-items:center;display:flex;justify-content:center}.video-play-overlay{background:#0000002e;inset:0;position:absolute;transition:background .15s}.video-thumb-btn:hover .video-play-overlay{background:#0000000d}.video-play-icon{align-items:center;background:#d4a24ceb;border-radius:50%;box-shadow:0 4px 14px #00000080;color:#1a0e0e;display:flex;font-size:18px;height:48px;justify-content:center;padding-left:4px;transition:transform .15s;width:48px}.video-thumb-btn:hover .video-play-icon{transform:scale(1.1)}.video-yt-badge{background:#c4302b;border-radius:3px;color:#fff;font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 6px;pointer-events:none;position:absolute;right:6px;top:6px}.video-card-title{color:#f5e6d3;color:var(--text);font-size:13px;font-weight:600;margin:0;overflow:hidden;padding:0 12px 12px;text-overflow:ellipsis;white-space:nowrap}.video-card .media-title-input{margin:0 12px 12px}.video-overlay-backdrop{background:#000000d9;z-index:120}.video-overlay-content{max-width:100%;position:relative;width:min(960px,calc(100vw - 32px))}.video-overlay-player{aspect-ratio:16/9;background:#000;border:none;border-radius:6px;display:block;width:100%}.video-overlay-title{color:#f5e6d3;color:var(--text);font-size:14px;font-style:italic;margin:12px 0 0;text-align:center}.video-overlay-close{background:#000000b3;border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:50%;color:#f0c068;color:var(--gold-bright);position:absolute;right:0;top:-42px}.video-overlay-close:hover{background:#c43e3e;background:var(--red-bright);color:#f5e6d3;color:var(--text)}.video-add-row{align-items:center;flex-wrap:wrap;gap:8px}.media-note{color:#b8a890;color:var(--text-muted);font-size:12px;font-style:italic;margin:0}.youtube-form{align-items:center;display:flex;flex:1 1 100%;flex-wrap:wrap;gap:8px;margin-top:4px}.youtube-input{background:#00000059;border:1px solid #4a2a1a;border:1px solid var(--border);border-radius:6px;color:#f5e6d3;color:var(--text);flex:1 1 240px;font-family:inherit;font-size:12px;outline:none;padding:8px 12px}.youtube-input::placeholder{color:#b8a890;color:var(--text-muted);font-style:italic}.youtube-input:focus{border-color:#c9a24c;border-color:var(--gold)}.youtube-error{color:#c43e3e;color:var(--red-bright);flex:1 1 100%;font-size:11px;font-style:italic}.media-list-remove{align-items:center;background:#00000080;border:none;border-radius:50%;color:#f5e6d3;color:var(--text);cursor:pointer;display:flex;height:24px;justify-content:center;opacity:0;position:absolute;right:8px;top:8px;transition:opacity .15s,background .15s;width:24px}.media-list-item:hover .media-list-remove{opacity:1}.media-list-remove:hover{background:#c43e3e;background:var(--red-bright)}.media-add-row{display:flex;justify-content:center;margin-top:18px}.media-add-btn{align-items:center;background:linear-gradient(180deg,#8b1e1e8c,#460c0c8c);border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:999px;color:#f0c068;color:var(--gold-bright);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12px;font-weight:600;gap:6px;letter-spacing:.1em;padding:8px 18px;text-transform:uppercase;transition:all .15s}.media-add-btn:hover{background:linear-gradient(180deg,#c43e3e,#8b1e1e);background:linear-gradient(180deg,var(--red-bright),var(--red));box-shadow:0 0 12px #d4a24c4d}.parchment-page{background:radial-gradient(ellipse at 30% 20%,#8b5a281a,#0000 40%),radial-gradient(ellipse at 80% 80%,#8b5a2814,#0000 50%),radial-gradient(ellipse at 60% 40%,#653d1e0f,#0000 35%),linear-gradient(135deg,#f4e2b6,#ecd49a 50%,#f4e2b6);border-radius:4px;box-shadow:0 12px 40px #0009,inset 0 0 60px #8b5a282e,inset 0 0 8px #653d1e40;clip-path:polygon(0 1%,1% 0,99% .5%,100% 2%,99.5% 99%,98% 100%,1% 99.5%,0 98%);color:#3b2410;color:var(--ink);font-family:Cormorant Garamond,EB Garamond,Playfair Display,Georgia,serif;max-height:80vh;min-height:50vh;overflow-y:auto;padding:48px 56px;position:relative}.parchment-toolbar{align-items:center;background:linear-gradient(180deg,#8b5a282e,#8b5a280f);border-bottom:1px dashed #653d1e66;display:flex;flex-wrap:wrap;gap:6px;margin:-48px -56px 24px;padding:12px 16px;position:sticky;top:-48px;z-index:2}.parchment-toolbar button{align-items:center;background:#fffae68c;border:1px solid #653d1e59;border-radius:6px;color:#3b2410;color:var(--ink);cursor:pointer;display:inline-flex;font-family:Cormorant Garamond,EB Garamond,Georgia,serif;font-size:14px;height:30px;justify-content:center;padding:0;transition:all .15s;width:30px}.parchment-toolbar button:hover{background:#fffae6f2;border-color:#3b2410;border-color:var(--ink);box-shadow:0 1px 4px #653d1e4d}.parchment-toolbar-divider{background:#653d1e4d;height:18px;margin:0 4px;width:1px}.parchment-lang-toggle{background:#fffae673;border:1px solid #653d1e66;border-radius:999px;display:inline-flex;gap:2px;padding:2px}.parchment-lang-btn{background:#0000!important;border:none!important;border-radius:999px!important;box-shadow:none!important;color:#6b4a2c!important;color:var(--ink-faded)!important;cursor:pointer;font-family:Cormorant Garamond,Georgia,serif!important;font-size:13px!important;font-weight:600!important;height:auto!important;padding:4px 10px!important;transition:all .15s;width:auto!important}.parchment-lang-btn:hover{background:#fffae6b3!important;color:#3b2410!important;color:var(--ink)!important}.parchment-lang-btn.active{background:#3b2410!important;background:var(--ink)!important;box-shadow:0 1px 3px #0000004d!important;color:#efdcae!important;color:var(--parchment)!important}.parchment-status{color:#6b4a2c;color:var(--ink-faded);font-family:Cormorant Garamond,Georgia,serif;font-size:12px;font-style:italic;padding:0 6px}.parchment-status.error{color:#8b1e1e}.parchment-select{background:#fffae68c;border:1px solid #653d1e66;border-radius:6px;color:#3b2410;color:var(--ink);cursor:pointer;font-family:Cormorant Garamond,Georgia,serif;font-size:13px;height:30px;outline:none;padding:4px 8px}.parchment-select:hover{background:#fffae6d9}.parchment-select:focus{border-color:#3b2410;border-color:var(--ink)}.parchment-color{background:#fffae68c;border:1px solid #653d1e66;border-radius:6px;cursor:pointer;height:30px;padding:2px;width:30px}.parchment-color::-webkit-color-swatch-wrapper{padding:0}.parchment-color::-webkit-color-swatch{border:none;border-radius:3px}.parchment-footer{border-top:1px dashed #653d1e59;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:18px}.parchment-btn{border-radius:6px;cursor:pointer;font-family:Cormorant Garamond,Georgia,serif;font-size:14px;font-weight:600;letter-spacing:.05em;padding:8px 22px;transition:all .15s ease}.parchment-btn:disabled{cursor:default;opacity:.45}.parchment-discard{background:#0000;border:1px solid #653d1e73;color:#6b4a2c;color:var(--ink-faded)}.parchment-discard:not(:disabled):hover{background:#fffae68c;border-color:#3b2410;border-color:var(--ink);color:#3b2410;color:var(--ink)}.parchment-save{background:#3b2410;background:var(--ink);border:1px solid #3b2410;border:1px solid var(--ink);box-shadow:0 1px 3px #0000004d;color:#efdcae;color:var(--parchment)}.parchment-save:not(:disabled):hover{background:#8b1e1e;background:var(--red);border-color:#8b1e1e;border-color:var(--red);box-shadow:0 2px 8px #c43e3e66}.parchment-btn:focus-visible{outline:2px solid #3b2410;outline:2px solid var(--ink);outline-offset:2px}.parchment-content{color:#3b2410;color:var(--ink);font-size:18px;line-height:1.75;min-height:200px;outline:none;text-shadow:0 .5px 0 #653d1e26}.parchment-content[contenteditable=true]:empty:before{color:#6b4a2c;color:var(--ink-faded);content:attr(data-placeholder);font-style:italic;opacity:.65}.parchment-content h1,.parchment-content h2{color:#3b2410;color:var(--ink);font-family:Playfair Display,Cormorant Garamond,Georgia,serif;font-weight:600;letter-spacing:.01em;margin:1.4em 0 .4em}.parchment-content h1{font-size:30px}.parchment-content h2{font-size:24px}.parchment-content p{margin:0 0 1em;text-indent:1.5em}.parchment-content p:first-of-type{text-indent:0}.parchment-content p:first-of-type:first-letter{color:#8b1e1e;color:var(--red);float:left;font-family:Playfair Display,Georgia,serif;font-size:2.4em;font-weight:700;line-height:.9;padding:4px 8px 0 0}.parchment-content em{color:#6b4a2c;color:var(--ink-faded)}.parchment-content strong{color:#3b2410;color:var(--ink);font-weight:700}.parchment-content ol,.parchment-content ul{margin:0 0 1em;padding-left:1.6em}.toast{align-items:center;animation:modal-rise .2s cubic-bezier(.22,1,.36,1);background:linear-gradient(180deg,#c43e3e,#8b1e1e);background:linear-gradient(180deg,var(--red-bright),var(--red));border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:8px;bottom:80px;box-shadow:0 8px 24px #0009;color:#f5e6d3;color:var(--text);cursor:pointer;display:flex;font-size:13px;gap:12px;left:50%;max-width:min(440px,calc(100% - 24px));padding:12px 18px;position:fixed;transform:translateX(-50%);z-index:200}.toast-dismiss{font-size:18px;font-weight:700;opacity:.7}.migration-pill{animation:modal-rise .2s cubic-bezier(.22,1,.36,1);background:#140e0eeb;border:1px solid #c9a24c;border:1px solid var(--gold);border-radius:999px;bottom:24px;box-shadow:0 4px 16px #00000080;color:#f0c068;color:var(--gold-bright);font-size:12px;font-weight:600;left:50%;letter-spacing:.06em;padding:8px 18px;position:fixed;transform:translateX(-50%);z-index:150}@media (max-width:768px){.card-icon-btn{height:28px;opacity:1;width:28px}.card-icon-btn:before{content:"";inset:-8px -8px -16px -8px;position:absolute}.pill-delete-btn,.pill-ring-btn{height:28px;width:28px}.pill-delete-btn:before,.pill-ring-btn:before{content:"";inset:-8px;position:absolute}.media-icon-btn{height:36px;width:36px}.media-icon-btn:before{content:"";inset:-6px;position:absolute}.sibling-insert-btn{flex:0 0 28px;height:28px;opacity:.85;width:28px}.tree-canvas.lod-dot .card,.tree-canvas.lod-dot .card.spouse-card{position:relative}.tree-canvas.lod-dot .card:after{content:"";inset:-14px;pointer-events:auto;position:absolute}.zoom-controls{align-items:stretch;background:#140e0ed9;border-radius:16px;bottom:18px;box-shadow:0 6px 20px #0000008c;flex-direction:column;gap:8px;padding:6px;position:fixed;right:18px;z-index:60}.zoom-btn{border-radius:12px;font-size:22px;height:52px;width:52px}.zoom-readout,.zoom-slider{display:none}.modal-backdrop:has(>.media-modal){align-items:flex-end}.media-modal{animation:sheet-rise .25s cubic-bezier(.22,1,.36,1);border:none;border-radius:18px 18px 0 0;border-top:1px solid #c9a24c;border-top:1px solid var(--gold);height:85vh;max-height:85vh;max-width:100%;transform:translateY(0);transform:translateY(var(--sheet-drag-y,0));transition:transform .15s ease-out;width:100%}.media-modal.is-dragging{transition:none}.media-modal-drag-handle{cursor:grab;display:flex;justify-content:center;padding:8px 0 4px;touch-action:none}.media-modal-drag-handle:before{background:#d4a24c66;border-radius:2px;content:"";height:4px;width:44px}}@media (min-width:769px){.media-modal-drag-handle{display:none}}@keyframes sheet-rise{0%{transform:translateY(100%)}to{transform:translateY(0)}}.auth-loading{background:#fbf6ec;inset:0;position:fixed}.login-page{align-items:center;background:#fbf6ec;display:flex;justify-content:center;min-height:100vh;padding:24px}.login-card{background:#fff;border:1px solid #d4a24c59;border-radius:14px;box-shadow:0 12px 40px #633c0c1f;max-width:420px;padding:28px 24px;width:100%}.login-card h1{color:#6b3a0e;font-size:28px;margin:0 0 4px;text-align:center}.login-tagline{color:#8a6a3c;font-size:14px;margin:0 0 18px;text-align:center}.login-error{color:#a33;font-size:14px;line-height:1.5;margin:12px 0 0}.login-error code{background:#f4ecd9;border-radius:3px;padding:1px 5px}.login-msg{color:#2c6a3a;font-size:14px;line-height:1.5;margin:12px 0 0}.login-google-btn{align-items:center;background:#fff;border:1px solid #dadce0;border-radius:8px;color:#3c4043;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:10px;justify-content:center;padding:10px 14px;transition:background .12s,box-shadow .12s;width:100%}.login-google-btn:hover:not(:disabled){background:#f8f9fa;box-shadow:0 1px 3px #3c404329}.login-google-btn:disabled{cursor:not-allowed;opacity:.55}.login-divider{align-items:center;color:#8a6a3c;display:flex;font-size:12px;gap:12px;margin:18px 0 14px}.login-divider:after,.login-divider:before{background:#d4a24c59;content:"";flex:1 1;height:1px}.login-magic-form{gap:10px}.login-field,.login-magic-form{display:flex;flex-direction:column}.login-field{color:#6b3a0e;font-size:13px;gap:4px}.login-field input{background:#fff;border:1px solid #d4a24c73;border-radius:6px;font-family:inherit;font-size:14px;outline:none;padding:9px 10px}.login-field input:focus{border-color:#d4a24c;box-shadow:0 0 0 3px #d4a24c2e}.login-magic-btn{background:#6b3a0e;border:0;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 14px;transition:background .12s}.login-magic-btn:hover:not(:disabled){background:#4a2606}.login-magic-btn:disabled{cursor:not-allowed;opacity:.55}.auth-account-pill{align-items:center;background:#d4a24c1f;border:1px solid #d4a24c59;border-radius:999px;color:#6b3a0e;display:inline-flex;font-size:12px;gap:8px;max-width:320px;padding:4px 6px 4px 12px}.auth-account-email{font-weight:500;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-manage-btn,.auth-signout-btn{background:#fff;border:1px solid #d4a24c66;border-radius:999px;color:#6b3a0e;cursor:pointer;font-size:11px;font-weight:600;padding:3px 10px}.auth-manage-btn:hover,.auth-signout-btn:hover{background:#f4ecd9}@media (max-width:768px){.auth-account-email{font-size:11px;max-width:90px}.auth-account-pill{gap:6px;padding:3px 5px 3px 10px}.auth-manage-btn,.auth-signout-btn{font-size:10px;padding:3px 8px}}.modal-delete-impact{max-width:460px}.modal-impact-title{color:#6b3a0e;font-weight:600;line-height:1.4;margin:0 0 12px}.modal-impact-list{color:#4a2e10;font-size:14px;line-height:1.6;margin:0 0 14px;padding-left:22px}.modal-impact-list li::marker{color:#c83a3a}.modal-impact-warning{color:#a33;font-size:13px;font-weight:500;margin:0 0 14px}.modal-impact-typebox{color:#4a2e10;display:flex;flex-direction:column;font-size:13px;gap:6px;margin-bottom:14px}.modal-impact-typebox input{border:1px solid #d4a24c8c;border-radius:6px;font-family:inherit;font-size:14px;letter-spacing:.06em;outline:none;padding:8px 10px;text-transform:uppercase}.modal-impact-typebox input:focus{border-color:#c83a3a;box-shadow:0 0 0 3px #c83a3a26}.modal-btn:disabled{cursor:not-allowed;opacity:.45}.modal-spouse-action-buttons{display:flex;flex-direction:column;gap:8px;margin:14px 0 8px}.modal-spouse-edit,.modal-spouse-remove,.modal-spouse-replace{background:#fff;border:1px solid #d4a24c73;border-radius:8px;color:#6b3a0e;cursor:pointer;font-size:14px;font-weight:600;padding:10px 14px;text-align:center;width:100%}.modal-spouse-replace{background:#6b3a0e;border-color:#6b3a0e;color:#fff}.modal-spouse-replace:hover{background:#4a2606}.modal-spouse-edit:hover{background:#f4ecd9}.modal-spouse-remove{border-color:#c83a3a73;color:#c83a3a}.modal-spouse-remove:hover{background:#fbeaea}.undo-toast{align-items:center;background:#2a1a08;border-radius:999px;bottom:24px;box-shadow:0 8px 28px #00000059;color:#fff;display:flex;font-size:14px;gap:12px;left:50%;max-width:calc(100vw - 32px);padding:10px 14px 10px 18px;position:fixed;transform:translateX(-50%);z-index:200}.undo-toast-label{max-width:60vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.undo-toast-btn{background:#d4a24c;border:0;border-radius:999px;color:#2a1a08;cursor:pointer;font-size:13px;font-weight:700;padding:6px 14px}.undo-toast-btn:hover{background:#e4b25c}@media (max-width:768px){.undo-toast{bottom:16px;font-size:13px;padding:8px 10px 8px 14px}.undo-toast-label{max-width:50vw}}
/*# sourceMappingURL=main.ab9d2433.css.map*/