.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}:root{--primary-blue: #2563eb;--primary-blue-hover: #1d4ed8;--bg-gray: #f0f2f5;--glass-bg: rgba(255, 255, 255, .9);--border-glass: rgba(255, 255, 255, .5);--text-main: #1f2937;--text-muted: #64748b;--line-family: #64748b;--line-spouse: #f59e0b;--panel-border: rgba(148, 163, 184, .24);color:var(--text-main);font-family:Inter,Outfit,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-gray)}*{box-sizing:border-box}body{margin:0;background-color:var(--bg-gray);color:var(--text-main);-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}.glass,.tree-panel,.loading-panel,.drawer,.auth-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-glass)}.glass-card,.person-card,.results button,.picker-results,.search-box{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.55);border-radius:1.2rem}.app-shell{display:grid;grid-template-columns:380px 1fr;min-height:100vh}.sidebar{display:flex;flex-direction:column;gap:16px;padding:24px;overflow-y:auto;background:#fff;box-shadow:2px 0 18px #0f172a0f;z-index:3}.brand{display:flex;align-items:center;gap:10px;color:#0f172a;font-size:23px;font-weight:800}.search-box{display:flex;align-items:center;gap:8px;padding:11px 13px;background:#f8fafc;border-color:#e2e8f0}.search-box input,.panel-form input,.panel-form select,.panel-form textarea,.nested-panel-form input,.nested-panel-form select,.nested-panel-form textarea,.auth-card input,.drawer-form input,.drawer-form textarea{width:100%;border:1px solid #dbe4f0;border-radius:.9rem;padding:11px 13px;background:#ffffffe0;color:var(--text-main);outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.search-box input{border:0;padding:0;background:transparent}input:focus,select:focus,textarea:focus{border-color:#2563eba6;box-shadow:0 0 0 4px #2563eb1f}.results{display:grid;gap:8px}.results button{display:grid;gap:4px;padding:11px 13px;text-align:left;color:var(--text-main);cursor:pointer;box-shadow:0 8px 18px #0f172a0a;transition:all .25s cubic-bezier(.4,0,.2,1)}.results button:hover{transform:translateY(-2px);box-shadow:0 16px 22px #0f172a14}.results span,.saved,dt{color:var(--text-muted);font-size:13px}.panel-form{display:grid;gap:10px;padding-top:16px;border-top:1px solid #eef2f7}.compact-panel{gap:8px}.panel-toggle{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;border:1px solid #dbe4f0;border-radius:.9rem;padding:11px 13px;background:#fff;color:#0f172a;font-weight:900;cursor:pointer}.panel-toggle span,.file-field,.tiny-action,.guide-entry{display:inline-flex;align-items:center;gap:8px}.panel-toggle svg:last-child{transition:transform .2s ease}.panel-toggle svg.is-open{transform:rotate(180deg)}.nested-panel-form{display:grid;gap:10px}.file-field{justify-content:center;min-height:42px;border:1px dashed #bfdbfe;border-radius:.9rem;padding:10px 12px;background:#eff6ff;color:var(--primary-blue);font-weight:900;cursor:pointer}.file-field input{display:none}.panel-form h2{display:flex;align-items:center;gap:8px;margin:0;color:#0f172a;font-size:16px}.person-picker{position:relative;display:grid;gap:6px}.person-picker label,.check-row{color:#475569;font-size:13px;font-weight:700}.tiny-clear{position:absolute;top:30px;right:7px;border:0;border-radius:.65rem;padding:4px 8px;background:#eff6ff;color:var(--primary-blue);font-size:12px;font-weight:700;cursor:pointer}.check-row{display:flex;align-items:center;gap:8px}.check-row input{width:auto}.picker-results{position:absolute;top:calc(100% + 6px);right:0;left:0;display:grid;max-height:210px;overflow-y:auto;background:#fffffff5;box-shadow:0 18px 36px #0f172a24;z-index:30}.picker-results button{display:grid;gap:2px;border:0;border-bottom:1px solid #eef2f7;padding:10px 12px;text-align:left;background:transparent;cursor:pointer}.picker-results button:hover{background:#eff6ff;color:var(--primary-blue)}.picker-results span{color:var(--text-muted);font-size:12px}.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:8px}.primary,.btn-primary{border:0;border-radius:.9rem;padding:11px 15px;background:var(--primary-blue);color:#fff;font-weight:800;cursor:pointer;transition:all .3s ease}.primary:hover,.btn-primary:hover{background:var(--primary-blue-hover);transform:translateY(-1px);box-shadow:0 8px 16px #2563eb38}.secondary{border:1px solid #dbe4f0;border-radius:.9rem;padding:10px 13px;background:#fff;color:var(--primary-blue);font-weight:800;cursor:pointer;transition:all .2s ease}.secondary:hover{background:#eff6ff}.graph-panel{position:relative;min-height:100vh;background:linear-gradient(90deg,rgba(37,99,235,.045) 1px,transparent 1px),linear-gradient(rgba(37,99,235,.045) 1px,transparent 1px),radial-gradient(circle at 18% 8%,rgba(37,99,235,.1),transparent 30%),var(--bg-gray);background-size:32px 32px,32px 32px,auto,auto}.empty-state{display:flex;height:100%;align-items:center;justify-content:center;gap:10px;color:#475569;font-weight:800}.react-flow__node-person{width:230px;border:0;background:transparent;box-shadow:none}.react-flow__node-junction{width:16px;height:16px;border:0;background:transparent}.family-junction{position:relative;width:16px;height:16px;border:2px solid var(--line-family);border-radius:999px;background:#fff}.family-junction:before{content:"";position:absolute;left:50%;top:-86px;height:84px;border-left:2px solid var(--line-family);transform:translate(-50%)}.junction-handle{width:2px;height:2px;opacity:0}.auth-logo{max-width:100%;height:auto;max-height:200px;display:block;margin:0 auto 10px;object-fit:contain}.auth-card{box-sizing:border-box;display:flex;flex-direction:column;align-items:center}.person-card{display:grid;grid-template-columns:46px 1fr;align-items:center;gap:12px;min-height:86px;padding:12px 14px;color:#0f172a;box-shadow:0 14px 28px #0f172a14;transition:all .25s cubic-bezier(.4,0,.2,1)}@media(min-width:768px){.person-card:hover{transform:translateY(-5px);box-shadow:0 20px 25px -5px #0f172a1a}}.person-card.is-center{border-color:#2563eb8c;background:#eff6ffeb;box-shadow:0 0 0 4px #2563eb1f,0 18px 32px #2563eb29}.person-card.is-spouse{border-color:#f59e0b8c;background:#fffbebeb}.person-card.is-ancestor{border-color:#64748b57}.person-card.is-descendant{border-color:#2563eb47}.person-card.is-sibling{border-color:#7c3aed57}.person-avatar{display:grid;width:46px;height:46px;place-items:center;overflow:hidden;border-radius:999px;background:#eff6ff;color:var(--primary-blue);font-weight:900}.person-avatar img{width:100%;height:100%;object-fit:cover}.person-copy{display:grid;gap:4px;min-width:0}.person-copy strong{overflow:hidden;font-size:15px;line-height:1.2;text-overflow:ellipsis}.person-copy span{color:var(--text-muted);font-size:13px}.family-handle{width:7px;height:7px;border:1px solid #64748b;background:#fff}.family-handle.side{opacity:0}.family-edge path{stroke-width:2}.parent-edge path,.parent-to-junction path,.junction-to-child path{stroke:var(--line-family)}.parent-edge marker path,.junction-to-child marker path{fill:var(--line-family);stroke:var(--line-family)}.spouse-edge path{stroke:var(--line-spouse);stroke-dasharray:7 5;stroke-width:2.2}.tree-panel,.loading-panel{display:grid;gap:2px;padding:11px 13px;border-radius:1rem;color:#0f172a;box-shadow:0 12px 26px #0f172a14}.tree-panel span{color:var(--text-muted);font-size:12px}.loading-panel{display:flex;align-items:center;gap:8px;font-weight:800}.loading-panel svg{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.drawer{position:fixed;top:0;right:0;width:min(440px,100vw);height:100vh;overflow-y:auto;padding:26px;box-shadow:-22px 0 48px #0f172a29;z-index:10}.drawer::-webkit-scrollbar,.sidebar::-webkit-scrollbar,.picker-results::-webkit-scrollbar{width:6px}.drawer::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb,.picker-results::-webkit-scrollbar-thumb{background-color:#e2e8f0;border-radius:10px}.drawer img{width:100%;aspect-ratio:16 / 10;object-fit:cover;border-radius:1.25rem}.drawer-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.drawer-form{display:grid;gap:9px;margin:12px 0 18px}.drawer-form.compact{margin-top:0}.drawer-form textarea{min-height:76px;resize:vertical}.icon-button{float:right;display:inline-grid;width:36px;height:36px;place-items:center;border:1px solid #dbe4f0;border-radius:.9rem;background:#fff;color:#475569;cursor:pointer}dl{display:grid;grid-template-columns:1fr 1fr;gap:10px}dd{margin:2px 0 0;font-weight:800}.relationship-list{display:grid;gap:10px;padding:0;list-style:none}.relationship-list li{display:grid;gap:3px;border-top:1px solid #eef2f7;padding-top:10px}.drawer-section{margin-top:22px}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.section-heading h3{margin:0}.tiny-action{border:1px solid #dbe4f0;border-radius:.75rem;padding:7px 9px;background:#fff;color:var(--primary-blue);font-size:12px;font-weight:900;cursor:pointer;white-space:nowrap}.quiet-list{margin-top:0}.empty-inline{color:var(--text-muted);font-weight:700}.document-library-results{display:grid;gap:7px;max-height:190px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:.9rem;padding:8px;background:#f8fafc}.document-library-results button{display:grid;gap:3px;border:1px solid #e2e8f0;border-radius:.75rem;padding:9px 10px;background:#fff;text-align:left;cursor:pointer}.document-library-results button:hover{border-color:#bfdbfe;background:#eff6ff}.document-library-results span{color:var(--text-muted);font-size:12px}.relationship-list a{display:inline-flex;align-items:center;gap:6px;color:var(--primary-blue);font-weight:800;text-decoration:none}.auth-screen{display:grid;min-height:100vh;place-items:center;background:radial-gradient(circle at 20% 10%,rgba(37,99,235,.14),transparent 32%),var(--bg-gray)}.auth-card{display:grid;width:min(430px,calc(100vw - 32px));gap:12px;padding:28px;border-radius:1.5rem;box-shadow:0 24px 60px #0f172a1f}.auth-card h1{margin:0 0 6px;color:#0f172a}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px;border-radius:1rem;background:#eef2ff}.segmented button{border:0;border-radius:.85rem;padding:10px;background:transparent;cursor:pointer}.segmented .active{background:#fff;color:var(--primary-blue);font-weight:900}.error{color:#dc2626;font-weight:800}.auth-note{margin:0 0 6px;color:var(--text-muted)}.admin-entry{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #bfdbfe;border-radius:.9rem;padding:10px 13px;background:#eff6ff;color:var(--primary-blue);font-weight:900;cursor:pointer}.guide-entry{justify-content:center;border:1px solid #dbe4f0;border-radius:.9rem;padding:10px 13px;background:#fff;color:#475569;font-weight:900;cursor:pointer}.guide-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#0f172a57;z-index:40}.guide-card{width:min(560px,100%);border:1px solid #e2e8f0;border-radius:1rem;padding:24px;background:#fff;box-shadow:0 28px 80px #0f172a38}.guide-card h2{margin:0 0 12px}.guide-card ol{display:grid;gap:11px;margin:0 0 18px;padding-left:22px;color:#334155}.admin-page{min-height:100vh;padding:28px;background:#f8fafc}.admin-header,.admin-actions,.admin-tabs,.admin-create-user h2,.admin-table a{display:flex;align-items:center}.admin-header{justify-content:space-between;gap:18px;margin-bottom:18px}.admin-header h1{margin:4px 0 0;color:#0f172a}.admin-header span,.admin-create-user h2{gap:8px;color:var(--primary-blue);font-size:14px;font-weight:900}.admin-actions{gap:10px}.admin-actions .secondary,.admin-table a{gap:7px}.admin-tabs{gap:8px;margin-bottom:16px;overflow-x:auto}.admin-tabs button{border:1px solid #dbe4f0;border-radius:.8rem;padding:9px 12px;background:#fff;color:#475569;font-weight:800;cursor:pointer}.admin-tabs .active{border-color:var(--primary-blue);background:#eff6ff;color:var(--primary-blue)}.admin-create-user{display:grid;grid-template-columns:repeat(5,minmax(140px,1fr));gap:10px;margin-bottom:18px;padding:14px;border:1px solid #e2e8f0;border-radius:.9rem;background:#fff}.admin-create-user h2{grid-column:1 / -1;margin:0}.admin-create-user input{width:100%;border:1px solid #dbe4f0;border-radius:.8rem;padding:10px 12px}.admin-table-wrap{overflow-x:auto;border:1px solid #e2e8f0;border-radius:.9rem;background:#fff}.admin-table{width:100%;border-collapse:collapse;min-width:760px}.admin-table th,.admin-table td{border-bottom:1px solid #eef2f7;padding:12px 14px;text-align:left;vertical-align:top}.admin-table th{color:#475569;font-size:13px;text-transform:uppercase}.admin-table td{color:#0f172a}.danger-icon{display:inline-grid;width:34px;height:34px;place-items:center;border:1px solid #fecaca;border-radius:.75rem;background:#fff1f2;color:#dc2626;cursor:pointer}.empty-cell,.admin-error{margin:0 0 14px}@keyframes pulse-custom{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse-custom 2s cubic-bezier(.4,0,.6,1) infinite}@media(max-width:860px){.app-shell{grid-template-columns:1fr;height:100vh;overflow:hidden}.sidebar{position:absolute;top:0;left:0;width:100%;max-height:60px;padding:10px 15px;flex-direction:row;align-items:center;justify-content:space-between;overflow:hidden;transition:max-height .3s ease;z-index:100}.sidebar.is-open{max-height:100vh;flex-direction:column;overflow-y:auto;background:#fff}.brand{font-size:18px}.graph-panel{height:100vh;margin-top:0}.drawer{width:100%!important;border-radius:20px 20px 0 0;top:10%;height:90vh}.two-cols,.admin-create-user{grid-template-columns:1fr}.primary,.secondary,.panel-toggle{min-height:48px}}@media(max-width:860px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-100%;top:0;bottom:0;z-index:1000;width:85%;transition:left .3s ease;box-shadow:5px 0 15px #0003}.sidebar.is-open{left:0}.drawer{width:100%;right:0;border-left:none;height:80vh;top:auto;bottom:0;border-radius:20px 20px 0 0}.mobile-menu-trigger{display:flex!important;position:fixed;bottom:20px;right:20px;z-index:999;background:var(--primary);color:#fff;padding:15px;border-radius:50%;border:none;box-shadow:0 4px 12px #0000004d}.hidden-mobile{display:none}}.mobile-toggle,.menu-backdrop{display:none}@media(max-width:860px){html,body,#root{min-height:100%}body{overflow:hidden}.app-shell{display:block;width:100vw;height:100dvh;min-height:100dvh;overflow:hidden}.mobile-toggle{position:fixed;top:max(12px,env(safe-area-inset-top));left:12px;z-index:1200;display:inline-grid!important;width:46px;height:46px;place-items:center;border:1px solid #dbe4f0;border-radius:999px;background:#fff;color:#0f172a;box-shadow:0 14px 30px #0f172a29}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;display:block;border:0;background:#0f172a52}.sidebar{position:fixed;top:0;bottom:0;left:0;z-index:1000;display:flex;width:min(88vw,380px);max-height:none;padding:calc(68px + env(safe-area-inset-top)) 16px 18px;overflow-y:auto;transform:translate(-104%);transition:transform .24s ease;box-shadow:18px 0 40px #0f172a33}.sidebar.is-open{left:0;max-height:none;flex-direction:column;overflow-y:auto;transform:translate(0)}.brand{font-size:18px;line-height:1.2}.graph-panel{width:100vw;height:100dvh;min-height:100dvh;margin:0}.empty-state{min-height:100dvh;padding:96px 24px 24px;text-align:center}.tree-panel{max-width:calc(100vw - 84px);margin-left:54px;padding:9px 10px}.tree-panel strong{font-size:13px}.tree-panel span{display:none}.react-flow__controls{transform:scale(.9);transform-origin:bottom left}.drawer{top:auto;right:0;bottom:0;width:100vw;height:min(86dvh,760px);padding:18px 16px calc(22px + env(safe-area-inset-bottom));border-radius:18px 18px 0 0;box-shadow:0 -18px 48px #0f172a33}.drawer img{max-height:210px}.drawer h2{margin-top:10px;padding-right:44px}.drawer-actions,.two-cols,dl{grid-template-columns:1fr}.section-heading{align-items:stretch;flex-direction:column}.tiny-action{justify-content:center;min-height:42px}.guide-overlay{align-items:end;padding:14px}.guide-card{max-height:86dvh;overflow-y:auto;padding:20px}.auth-screen{padding:16px}.auth-card{width:100%;padding:22px}.admin-page{padding:16px;overflow-x:hidden}.admin-header{align-items:stretch;flex-direction:column}.admin-actions{display:grid;grid-template-columns:1fr 1fr}.admin-tabs{margin-right:-16px;margin-left:-16px;padding:0 16px 8px}.admin-create-user{grid-template-columns:1fr}.admin-table-wrap{margin-right:-16px;margin-left:-16px;border-right:0;border-left:0;border-radius:0}.primary,.secondary,.panel-toggle,.admin-entry,.guide-entry,.file-field{min-height:46px}}@media(max-width:520px){.person-card{grid-template-columns:40px 1fr;gap:10px;min-height:78px;padding:10px 12px}.person-avatar{width:40px;height:40px}.person-copy strong{font-size:14px}.person-copy span{font-size:12px}.react-flow__node-person{width:220px}}
