:root{--ink:#2d2b28;--muted:#79736c;--soft:#f5f4f1;--paper:#fbfaf7;--panel:#fff;--line:#e2dfda;--line-strong:#c8c3ba;--olive:#5c6f46;--olive-dark:#3f5231;--green:#008466;--blue:#3478f6;--pink:#f24fa3;--red:#ff343f;--avatar-blue:#407d92;--avatar-rose:#b95660;--shadow:0 12px 34px #2825211f;--font-main:"Aptos", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif}*{box-sizing:border-box}html{background:var(--soft)}body{color:var(--ink);background:var(--soft);font-family:var(--font-main);margin:0;font-size:16px;line-height:1.45}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.72}.app-shell{min-height:100vh;padding:10px}.security-shell{background:linear-gradient(90deg, #5c6f460f 1px, transparent 1px), linear-gradient(0deg, #5c6f460f 1px, transparent 1px), var(--soft);background-size:34px 34px;place-items:center;min-height:100vh;padding:24px;display:grid}.security-card{border:1px solid var(--line);background:var(--panel);width:min(100%,520px);box-shadow:var(--shadow);border-radius:8px;gap:24px;padding:34px;display:grid}.security-mark{border:1px solid var(--line);background:var(--soft);width:72px;height:72px;color:var(--olive-dark);border-radius:8px;place-items:center;display:grid}.security-copy{color:var(--muted);margin-bottom:0;font-size:17px;line-height:1.55}.token-form{gap:14px;display:grid}.token-form label{color:var(--ink);font-weight:750}.token-input{border:1px solid var(--line);height:54px;color:var(--olive-dark);background:#fff;border-radius:8px;align-items:center;gap:12px;padding:0 16px;display:flex}.token-input:focus-within{border-color:var(--olive);box-shadow:0 0 0 4px #5c6f4624}.token-input input{width:100%;color:var(--ink);background:0 0;border:0;outline:0}.security-message{border-left:3px solid var(--red);color:#8b3035;background:#fff4f4;margin-bottom:0;padding:10px 12px}h1,h2,h3,p{margin-top:0}h1{letter-spacing:0;margin-bottom:0;font-size:30px;font-weight:750;line-height:1}.status-pill{border:1px solid var(--line);background:var(--soft);color:#514d49;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;align-items:center;padding:6px 14px;font-size:12px;font-weight:800;display:inline-flex}.ghost-button,.primary-button,.zoom-tools button{border:1px solid var(--line);border-radius:8px;justify-content:center;align-items:center;gap:9px;min-height:52px;padding:0 18px;font-weight:800;display:inline-flex}.ghost-button{color:#514d49;background:#fff}.primary-button{border-color:var(--olive-dark);background:var(--olive);color:#fff;box-shadow:0 2px 0 var(--olive-dark)}.dashboard-layout{gap:22px;display:grid}.visual-column{min-width:0}.rail-dot{background:var(--red);background:var(--olive);border-radius:50%;flex:none;width:16px;height:16px;margin-top:7px;display:inline-block}.canvas-toolbar{border:1px solid var(--line);color:#5f5a54;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffcf7e0;border-bottom:0;border-radius:8px 8px 0 0;justify-content:space-between;align-items:center;gap:12px;min-height:50px;padding:10px 18px;font-size:15px;line-height:1.45;display:flex}.canvas-toolbar:before{content:none}.canvas-toolbar-brand{align-items:center;min-width:0;display:flex}.canvas-toolbar-brand img{width:min(150px,28vw);height:auto;display:block}.zoom-tools{align-items:center;gap:8px;display:flex}.zoom-tools button{background:var(--soft);width:36px;min-height:36px;color:var(--olive-dark);padding:0}.zoom-tools span{text-align:center;min-width:48px;font-weight:800}.family-canvas{border:1px solid var(--line);touch-action:none;background-color:#fff;background-image:linear-gradient(90deg,#5c6f460f 1px,#0000 1px),linear-gradient(0deg,#5c6f460f 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:34px 34px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border-radius:0 0 8px 8px;height:calc(100vh - 72px);min-height:620px;position:relative;overflow:hidden}.canvas-top-stack{z-index:40;pointer-events:none;flex-direction:column;align-items:flex-end;gap:12px;width:min(980px,100% - 36px);display:flex;position:absolute;top:16px;right:18px}.canvas-top-stack>*{pointer-events:auto}.canvas-analytics{z-index:30;width:100%;max-width:min(220px,100%);box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;touch-action:auto;background:0 0;border:0;border-radius:0;justify-content:flex-end;align-self:flex-end;padding:0;display:flex;position:static}.canvas-status-dock{z-index:40;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);touch-action:auto;background:#ffffffeb;border:1px solid #e2dfdaeb;border-radius:18px;align-items:center;gap:10px;width:100%;max-width:min(980px,100%);padding:10px 12px;transition:transform .18s,opacity .18s,padding .18s,border-radius .18s,max-width .18s;display:flex;position:static;box-shadow:0 12px 34px #28252124}.canvas-status-dock.is-expanded{flex-wrap:wrap;justify-content:flex-end;align-self:stretch}.canvas-status-dock.is-collapsed{border-radius:999px;width:auto;padding:12px}.canvas-status-dock-trigger{cursor:pointer;z-index:60;justify-content:center}.canvas-dock-primary{flex-wrap:wrap;flex:320px;align-items:flex-start;gap:10px;min-width:min(100%,320px);display:flex}.canvas-dock-actions{flex-wrap:wrap;flex:0 auto;justify-content:flex-end;gap:8px;display:flex}.canvas-dock-toggle{width:48px;height:48px;color:var(--olive-dark);cursor:pointer;background:linear-gradient(#fbfcf9 0%,#eef4e9 100%);border:1px solid #5c6f4638;border-radius:16px;flex:none;place-items:center;display:grid}.canvas-dock-toggle.compact{border-radius:999px;min-width:56px;min-height:56px}.canvas-search{border:1px solid var(--line);width:100%;height:42px;color:var(--olive-dark);background:#fff;border-radius:14px;align-items:center;gap:8px;padding:0 12px;display:flex}.canvas-search input{width:100%;color:var(--ink);background:0 0;border:0;outline:0;font-size:14px}.canvas-couple-select{border:1px solid var(--line);min-width:220px;height:42px;color:var(--olive-dark);background:#fff;border-radius:14px;flex:0 290px;align-items:center;gap:8px;padding:0 12px;display:flex}.canvas-couple-select select{width:100%;min-width:0;color:var(--ink);background:0 0;border:0;outline:0;font-size:14px;font-weight:750}.visually-hidden{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.canvas-icon-button{border:1px solid var(--line);width:42px;height:42px;color:var(--olive-dark);background:#fff;border-radius:14px;place-items:center;display:grid}.canvas-icon-button.warning{color:#8b3035;background:#fff4f4}.canvas-icon-button.danger{color:#a33439;background:#fff1f1;border-color:#c9696d}.canvas-icon-button.active{border-color:var(--olive);color:var(--olive-dark);background:#eef4e9}.canvas-legend{flex-direction:column;align-items:flex-start;gap:6px;display:flex}.canvas-legend-shell{z-index:50;flex-direction:column;align-items:flex-start;gap:6px;width:auto;display:inline-flex;position:relative}.canvas-legend-shell.is-expanded{width:min(220px,100%);padding-top:34px}.canvas-legend-shell.is-collapsed{align-self:flex-end;gap:0}.canvas-legend-toggle{width:40px;height:40px;color:var(--olive-dark);cursor:pointer;z-index:60;background:#ffffffe6;border:1px solid #5c6f462e;border-radius:999px;flex:none;place-items:center;display:grid;position:absolute;top:0;right:0;box-shadow:0 6px 14px #28252114}.canvas-legend-toggle.compact{align-items:center;gap:8px;width:auto;min-width:56px;height:44px;padding:0 14px;display:inline-flex;position:static}.legend-item{align-items:flex-start;gap:8px;width:auto;min-width:0;display:flex}.legend-icon{width:16px;height:16px;color:var(--olive-dark);flex:none;place-items:center;margin-top:2px;display:grid}.legend-copy{min-width:0;max-width:170px}.legend-copy strong,.legend-copy small{font-style:normal;line-height:1.2;display:block}.legend-copy strong{color:var(--ink);text-transform:capitalize;font-size:12px;font-weight:800}.legend-copy small{color:#605b55;font-size:11px;font-weight:700}.family-canvas.is-dragging{cursor:grabbing}.canvas-stage{transform-origin:0 0;transition:transform .12s;position:absolute;top:0;left:0}.family-canvas.is-dragging .canvas-stage{transition:none}.connector-layer{width:100%;height:100%;position:absolute;inset:0;overflow:visible}.tree-link{fill:none;stroke:#cfcac2;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.tree-link.marriage{stroke:#222;stroke-width:2.5px}.tree-link.marriage.dashed{stroke:#8f5c5c;stroke-width:2.75px}.tree-link.dashed{stroke-dasharray:10 7}.tree-node{background:var(--panel);width:178px;min-height:88px;color:var(--ink);text-align:left;border:2px solid #6f7f5e;border-radius:8px;align-items:center;gap:12px;padding:12px;transition:border-color .16s,box-shadow .16s,transform .16s;display:flex;position:absolute;box-shadow:0 5px 12px #28252114}.tree-node:hover,.tree-node.is-selected{border-color:var(--red);transform:translateY(-2px);box-shadow:0 13px 26px #2825212e}.tree-node.is-deceased{color:#7f7971;background:#f7f5f1;border-style:dashed}.tree-node.is-deceased .avatar{opacity:.76}.tree-node.is-deceased .node-copy{opacity:.8}.avatar,.profile-avatar,.mini-avatar{color:#fff;border-radius:50%;flex:none;place-items:center;font-weight:900;display:grid;overflow:hidden}.avatar img,.mini-avatar img,.profile-avatar img,.profile-photo img{object-fit:cover;width:100%;height:100%}.avatar{width:44px;height:44px}.male{background:var(--avatar-blue)}.female{background:var(--avatar-rose)}.node-copy{min-width:0}.node-copy strong,.node-copy small{display:block}.node-copy strong{overflow-wrap:anywhere;font-size:12px;font-weight:750;line-height:1.2}.node-copy small{color:var(--muted);font-size:10.5px;font-weight:600;line-height:1.45}.adopted-mark{color:#9b958d;font-size:10px;position:absolute;bottom:8px;right:8px}.canvas-empty{color:var(--muted);font-weight:800;position:absolute;top:32px;left:32px}.mini-avatar{width:38px;height:38px;font-size:14px}.muted,.spouse-card small{color:var(--muted)}.eyebrow{color:var(--olive);letter-spacing:.12em;text-transform:uppercase;margin-bottom:5px;font-size:12px;font-weight:750}h3{letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px;font-size:13px}.profile-overlay{z-index:50;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.profile-backdrop{background:#1817156b;border:0;position:absolute;inset:0}.profile-drawer{z-index:1;border:1px solid var(--line);background:#fff;border-radius:16px;grid-template-rows:auto minmax(0,1fr) auto;width:min(100%,720px);max-height:calc(100vh - 36px);display:grid;position:relative;overflow:hidden;box-shadow:0 24px 70px #1817153d}.drawer-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:20px;padding:16px 22px;display:flex}.drawer-head>div{color:var(--olive-dark);align-items:center;gap:12px;display:flex}.drawer-head h2{color:var(--ink);margin:0;font-size:20px;font-weight:800}.drawer-close,.danger-button{border-radius:8px;place-items:center;display:grid}.drawer-close{color:#9a948d;background:0 0;border:0;width:38px;height:38px}.drawer-body{padding:18px 22px 22px;overflow:auto}.profile-summary{border-bottom:1px solid var(--line);text-align:center;justify-items:center;gap:6px;margin-bottom:18px;padding:4px 0 20px;display:grid}.profile-photo{color:#fff;border:5px solid #f3f1ed;border-radius:50%;place-items:center;width:104px;height:104px;font-size:38px;font-weight:900;display:grid;overflow:hidden;box-shadow:0 6px 18px #2825211a}.profile-photo-trigger{background:0 0;border:0;padding:0}.photo-preview-overlay{z-index:70;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.photo-preview-backdrop{background:#131211cc;border:0;position:absolute;inset:0}.photo-preview-frame{z-index:1;border-radius:18px;width:min(100%,960px);margin:0;position:relative;overflow:hidden;box-shadow:0 26px 70px #00000057}.photo-preview-frame img{object-fit:contain;background:#0f0e0d;width:100%;max-height:calc(100vh - 80px);display:block}.photo-preview-close{z-index:2;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff24;border:0;border-radius:999px;place-items:center;width:42px;height:42px;display:grid;position:absolute;top:14px;right:14px}.profile-summary h3{text-transform:none;letter-spacing:0;margin:8px 0 0;font-size:23px;line-height:1.15}.profile-summary p{color:var(--muted);margin-bottom:3px;font-size:15px;font-weight:700}.profile-status{border:1px solid var(--line);background:var(--soft);border-radius:999px;padding:5px 11px;font-size:13px;font-weight:800}.drawer-section{margin-top:18px}.drawer-section h4{color:var(--ink);letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:12px;margin:0 0 10px;font-size:16px;display:flex}.drawer-section h4:before{content:"";background:var(--olive);width:5px;height:22px}.biodata-box{border:1px solid var(--ink);border-radius:10px;max-width:100%;padding:0 14px}.drawer-info{border-bottom:1px solid var(--ink);grid-template-columns:24px minmax(0,1fr);gap:10px;padding:10px 0;display:grid}.drawer-info:last-child{border-bottom:0}.drawer-info>span{color:#aaa39d;padding-top:6px}.drawer-info small,.family-link-card small,.spouse-card small{color:#aaa39d;font-size:12px;font-weight:750;display:block}.drawer-info strong{color:var(--ink);font-size:15px;display:block}.profile-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.family-link-card,.spouse-card{border:1px solid var(--line);color:var(--ink);text-align:left;background:#fff;border-radius:10px}.family-link-card{min-height:88px;padding:12px}.family-link-card strong{align-items:center;gap:8px;margin-top:8px;font-size:15px;display:flex}.family-link-card em{color:var(--muted);margin-top:6px;font-size:12px;display:block}.profile-list{gap:10px;display:grid}.spouse-card{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px;display:grid}.spouse-card strong{align-items:center;gap:8px;font-size:15px;display:flex}.spouse-card em{color:#c70000;background:#fff6f6;border:1px solid #ffc8c8;border-radius:999px;padding:4px 9px;font-size:11px;font-style:normal;font-weight:800}.drawer-actions{border-top:1px solid var(--line);background:#fff;grid-template-columns:minmax(0,1fr) minmax(0,2fr) auto;gap:9px;padding:14px 22px;display:grid}.drawer-actions .ghost-button,.drawer-actions .primary-button{min-height:44px;font-size:15px}.danger-button{width:48px;min-height:44px;color:var(--ink);background:#fff7f7;border:1px solid #ffd5d5}.edit-overlay{z-index:60;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.edit-modal{z-index:1;border:1px solid var(--line);background:#fff;border-radius:16px;grid-template-rows:auto minmax(0,1fr) auto;width:min(100%,980px);max-height:calc(100vh - 36px);display:grid;position:relative;overflow:hidden;box-shadow:0 24px 70px #1817153d}.edit-body{padding:26px 30px 30px;overflow:auto}.edit-draft-note{color:#526346;background:#f7fbf2;border:1px solid #dfe8d4;border-radius:12px;margin:0 0 18px;padding:10px 12px;font-size:13px;font-weight:700}.edit-section{border-bottom:1px solid var(--line);margin-bottom:24px;padding-bottom:24px}.edit-section:last-child{border-bottom:0;margin-bottom:0}.edit-section h3{color:var(--olive-dark);letter-spacing:.06em;margin:0 0 16px;font-size:18px}.edit-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.edit-field{gap:8px;display:grid}.edit-field>span,.photo-editor label{color:#77706a;letter-spacing:.05em;text-transform:uppercase;font-size:14px;font-weight:800}.edit-field input,.edit-field select,.edit-field textarea,.photo-editor input{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:10px;min-height:48px;padding:0 14px;font-size:16px}.edit-field textarea{resize:vertical;min-height:86px;padding-top:12px}.gender-toggle{grid-template-columns:1fr 1fr;gap:10px;display:grid}.gender-toggle button{border:1px solid var(--line);min-height:50px;color:var(--ink);background:#fff;border-radius:10px;font-weight:800}.gender-toggle button.active{border-color:var(--olive);background:#eef4e9;box-shadow:inset 0 0 0 1px #5c6f4638}.photo-editor{border:1px solid var(--ink);border-radius:14px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:20px;margin-top:22px;padding:18px;display:grid}.photo-editor-controls{gap:10px;display:grid}.photo-upload-row{flex-wrap:wrap;align-items:center;gap:10px 14px;display:flex}.photo-upload-button{border:1px solid var(--olive);min-height:44px;color:var(--olive-dark);letter-spacing:normal;text-transform:none;cursor:pointer;background:#eef4e9;border-radius:10px;justify-content:center;align-items:center;padding:0 16px;font-size:14px;font-weight:800;display:inline-flex;position:relative}.photo-upload-button input{opacity:0;cursor:pointer;position:absolute;inset:0}.photo-upload-hint{color:var(--muted);font-size:13px;font-weight:700}.edit-photo-preview{color:#fff;border:4px solid #f3f1ed;border-radius:50%;place-items:center;width:82px;height:82px;font-size:30px;font-weight:900;display:grid;overflow:hidden}.edit-photo-preview img{object-fit:cover;width:100%;height:100%}.edit-check{color:var(--ink);align-items:center;gap:12px;margin-top:18px;font-size:16px;font-weight:800;display:flex}.edit-check input{width:24px;height:24px}.edit-error{border-left:3px solid var(--red);color:#8b3035;background:#fff4f4;padding:10px 12px}.edit-actions{border-top:1px solid var(--line);background:#fff;justify-content:flex-end;gap:14px;padding:18px 30px;display:flex}.edit-actions .ghost-button,.edit-actions .primary-button{min-width:140px;min-height:54px;font-size:18px}@media (max-width:760px){.app-shell{padding:10px}.canvas-toolbar{gap:10px;padding-left:12px;padding-right:12px}.canvas-toolbar-brand img{width:min(118px,34vw)}.family-canvas{height:calc(100vh - 70px);min-height:470px}.canvas-analytics{width:100%;max-width:none}.canvas-top-stack{gap:10px;width:auto;top:10px;left:10px;right:10px}.canvas-status-dock{max-width:none}.canvas-status-dock.is-expanded{justify-content:stretch}.canvas-dock-primary,.canvas-dock-actions{width:100%}.canvas-dock-actions{justify-content:flex-start}.canvas-legend{gap:8px 12px}.canvas-legend-shell.is-expanded{padding-top:30px}.canvas-search{min-width:100%}.canvas-couple-select{flex-basis:100%;min-width:100%}.profile-drawer{width:min(100%,620px)}.drawer-head,.drawer-body,.drawer-actions{padding-left:22px;padding-right:22px}.profile-card-grid,.drawer-actions{grid-template-columns:1fr}.profile-photo{width:96px;height:96px;font-size:34px}.spouse-card{grid-template-columns:auto minmax(0,1fr)}.spouse-card em{grid-column:2;justify-self:start}.edit-grid,.photo-editor{grid-template-columns:1fr}.edit-body,.edit-actions{padding-left:18px;padding-right:18px}}@media print{@page{size:landscape;margin:8mm}body{background:#fff}.app-shell{padding:0}.canvas-toolbar,.canvas-status-dock,.canvas-analytics,.profile-overlay,.edit-overlay{display:none!important}.family-canvas{border:0;border-radius:0;height:100vh;min-height:0}.canvas-stage{transform-origin:0 0;transform:scale(.72)translate(0)!important}}
