:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}h1{font-size:1.8em;line-height:1.2}.app{width:100%;height:100vh;overflow:hidden;position:relative}.github-banner{position:fixed;top:0;right:0;z-index:90;width:200px;height:200px;overflow:hidden;pointer-events:none}.github-banner span{display:flex;align-items:center;justify-content:center;gap:.35rem;position:absolute;width:280px;top:42px;right:-60px;transform:rotate(45deg);background:#24292e;color:#fff;text-decoration:none;font-size:.8rem;font-weight:600;padding:.4rem 0;box-shadow:0 2px 6px #0000004d;pointer-events:auto}.github-banner:hover span{background:#444d56}.github-banner .github-icon{width:16px;height:16px;fill:#fff;flex-shrink:0}.centered{max-width:600px;margin:2rem auto;padding:1rem;text-align:center}.file-loader{margin:2rem 0;display:flex;flex-direction:column;align-items:center}.file-loader label{display:flex;flex-direction:column;align-items:center;gap:.75rem;font-size:1.1rem;cursor:pointer}.file-loader input[type=file]{display:none}.file-loader .file-loader-btn{display:inline-block;padding:.6rem 1.5rem;font-size:1rem;font-weight:600;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#334155;cursor:pointer;transition:background .15s,border-color .15s}.file-loader .file-loader-btn:hover{background:#f8fafc;border-color:#94a3b8}.new-tree-divider{color:#94a3b8;font-size:.9rem;margin:1rem 0}.btn-new-tree{padding:.6rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;background:#4285f4;color:#fff;cursor:pointer;transition:background .15s}.btn-new-tree:hover{background:#3367d6}.person-picker{display:flex;flex-direction:column;gap:.5rem}.person-search{padding:.5rem;font-size:1rem;border:1px solid #ccc;border-radius:4px}.person-list{max-height:60vh;overflow-y:auto;border:1px solid #eee;border-radius:4px}.person-item{display:flex;justify-content:space-between;width:100%;padding:.5rem .75rem;border:none;border-bottom:1px solid #f0f0f0;background:#fff;cursor:pointer;text-align:left;font-size:.9rem}.person-item:hover,.person-item.active{background:#f0f7ff}.person-name{font-weight:500}.person-dates{color:#888;font-size:.85rem}.person-count{color:#666;font-size:.85rem}.pedigree-chart{width:100%;height:100vh;display:flex;flex-direction:column}.chart-toolbar{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#f8f8f8;border-bottom:1px solid #ddd;flex-shrink:0}.chart-toolbar button{padding:.4rem .8rem;cursor:pointer}.chart-toolbar label{display:flex;align-items:center;gap:.3rem}.pedigree-svg{flex:1}.person-detail-panel{position:fixed;top:0;right:0;width:360px;height:100vh;background:#fff;box-shadow:-2px 0 12px #00000026;z-index:100;overflow-y:auto;padding:1.25rem;box-sizing:border-box;animation:pdp-slide-in .2s ease-out}@keyframes pdp-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.pdp-header{position:relative;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e5e7eb}.pdp-close{position:absolute;top:0;right:0;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;line-height:1;padding:0 .25rem}.pdp-close:hover{color:#222}.pdp-name{font-size:1.2rem;font-weight:600;color:#222d38;padding-right:2rem}.pdp-gender{margin-right:.4rem}.pdp-gramps-id{font-size:.8rem;color:#94a3b8;margin-top:.2rem}.pdp-lock-icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;font-size:1rem;border-radius:4px;border:1px solid #d1d5db;box-sizing:border-box}.pdp-lock-icon.pdp-lock-closed{background:#fef3c7;border-color:#fcd34d}.pdp-lock-icon.pdp-lock-open{background:#ecfdf5;border-color:#6ee7b7}.pdp-section{margin-bottom:1rem}.pdp-section h3{font-size:.85rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin:0 0 .4rem}.pdp-event{margin-bottom:.5rem;font-size:.9rem;color:#334155}.pdp-event.pdp-muted{color:#94a3b8;font-style:italic}.pdp-place{font-size:.82rem;color:#64748b;margin-top:.1rem}.pdp-desc{font-size:.82rem;color:#64748b;font-style:italic;margin-top:.1rem}.person-link{background:none;border:none;color:#2563eb;cursor:pointer;font-size:.9rem;padding:0;text-decoration:underline;text-decoration-color:transparent}.person-link:hover{text-decoration-color:#2563eb}.pdp-family-unit{margin-bottom:.6rem;padding-left:.5rem;border-left:2px solid #e5e7eb}.pdp-children{margin-top:.25rem}.pdp-child{padding-left:.75rem}.pdp-header-actions{display:flex;align-items:center;gap:.5rem;margin-top:.4rem}.pdp-edit-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;font-size:1rem;border-radius:4px;border:1px solid #d1d5db;background:#f0f7ff;color:#2563eb;cursor:pointer;transition:background .15s,border-color .15s;box-sizing:border-box}.pdp-edit-btn:hover{background:#dbeafe;border-color:#93c5fd}.pdp-edit-form{display:flex;flex-direction:column;gap:.25rem}.pdp-edit-section{margin-bottom:.75rem}.pdp-edit-section h3{font-size:.85rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin:0 0 .4rem}.pdp-edit-field{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.5rem}.pdp-edit-field span{font-size:.78rem;color:#64748b;font-weight:500}.pdp-edit-field input,.pdp-edit-field select{padding:.35rem .5rem;font-size:.9rem;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#334155;transition:border-color .15s}.pdp-edit-field input:focus,.pdp-edit-field select:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 2px #4285f426}.pdp-alt-name{font-size:.9rem;color:#334155;margin-bottom:.35rem}.pdp-alt-name-label{font-size:.78rem;color:#94a3b8;font-style:italic;margin-right:.4rem}.pdp-alt-name-edit{margin-bottom:.75rem;padding:.5rem;border:1px solid #e5e7eb;border-radius:6px;background:#fafbfc}.pdp-alt-name-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.pdp-alt-name-type{padding:.25rem .4rem;font-size:.82rem;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#334155}.pdp-alt-name-remove{background:none;border:none;font-size:1.2rem;color:#94a3b8;cursor:pointer;padding:0 .3rem;line-height:1}.pdp-alt-name-remove:hover{color:#ef4444}.pdp-btn-add-alt{display:inline-flex;align-items:center;padding:.3rem .6rem;font-size:.82rem;border:1px dashed #d1d5db;border-radius:4px;background:none;color:#64748b;cursor:pointer;transition:background .15s,color .15s}.pdp-btn-add-alt:hover{background:#f0f7ff;color:#2563eb;border-color:#93c5fd}.pdp-edit-checkbox{display:flex;align-items:center;gap:.4rem;margin-bottom:.5rem;cursor:pointer}.pdp-edit-checkbox input[type=checkbox]{width:1rem;height:1rem;accent-color:#4285f4;cursor:pointer}.pdp-edit-checkbox span{font-size:.9rem;color:#334155}.pdp-edit-actions{display:flex;gap:.5rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid #e5e7eb}.pdp-btn-save{flex:1;padding:.45rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:6px;background:#4285f4;color:#fff;cursor:pointer;transition:background .15s}.pdp-btn-save:hover{background:#3367d6}.pdp-btn-cancel{flex:1;padding:.45rem 1rem;font-size:.9rem;font-weight:500;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#64748b;cursor:pointer;transition:background .15s}.pdp-btn-cancel:hover{background:#f8fafc}.pdp-children-family{margin-bottom:.5rem}.pdp-children-spouse-label{font-size:.78rem;color:#94a3b8;font-style:italic;margin-bottom:.25rem}.pdp-child-item{display:flex;align-items:center;justify-content:space-between;padding:.2rem .4rem;margin-bottom:.15rem;border-radius:4px;background:#fafbfc}.pdp-child-name{font-size:.88rem;color:#334155}.pdp-child-remove{background:none;border:none;font-size:1.2rem;color:#94a3b8;cursor:pointer;padding:0 .3rem 0 .6rem;line-height:1}.pdp-child-remove:hover{color:#ef4444}.person-select{margin-bottom:8px}.ps-label{display:block;font-size:.82rem;color:#64748b;margin-bottom:2px}.ps-control{display:flex;align-items:center;justify-content:space-between;gap:6px;min-height:28px}.ps-selected{font-size:.9rem;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.ps-empty{font-size:.9rem;color:#94a3b8;font-style:italic;flex:1}.ps-buttons{display:flex;gap:4px;flex-shrink:0}.ps-btn-change{font-size:.78rem;padding:2px 8px;border:1px solid #cbd5e1;border-radius:4px;background:#f8fafc;cursor:pointer;color:#475569}.ps-btn-change:hover{background:#e2e8f0}.ps-btn-clear{font-size:.9rem;padding:0 5px;border:none;background:none;cursor:pointer;color:#94a3b8;line-height:1}.ps-btn-clear:hover{color:#ef4444}.ps-dropdown{margin-top:4px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;overflow:hidden}.ps-search{display:block;width:100%;padding:5px 8px;border:none;border-bottom:1px solid #e2e8f0;font-size:.85rem;outline:none;box-sizing:border-box}.ps-search:focus{background:#f8fafc}.ps-list{max-height:200px;overflow-y:auto}.ps-item{display:flex;align-items:center;gap:6px;width:100%;padding:4px 8px;border:none;background:none;cursor:pointer;text-align:left;font-size:.83rem}.ps-item:hover,.ps-item.active{background:#eff6ff}.ps-item-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ps-item-dates{font-size:.75rem;color:#94a3b8;flex-shrink:0}.ps-no-results,.ps-truncated{padding:8px;font-size:.8rem;color:#94a3b8;text-align:center}.fab-add-person{position:fixed;bottom:2rem;right:2rem;z-index:90;width:56px;height:56px;border-radius:50%;border:none;background:#4285f4;color:#fff;font-size:2rem;font-weight:300;line-height:1;cursor:pointer;box-shadow:0 4px 12px #4285f466;transition:background .15s,box-shadow .15s,transform .15s;display:flex;align-items:center;justify-content:center}.fab-add-person:hover{background:#3367d6;box-shadow:0 6px 16px #4285f480;transform:scale(1.05)}
