.password-modal{z-index:10000;background:var(--bg,#1a1a1a);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.password-modal-content{background:var(--surface,#242424);color:var(--text,#e8e8e8);text-align:center;border-radius:12px;width:90%;max-width:380px;padding:40px 36px;box-shadow:0 8px 32px #0006}.password-modal-content h2{margin:0 0 8px;font-size:22px}.password-modal-content p{opacity:.7;margin:0 0 20px;font-size:14px}.password-modal-content input{border:1px solid var(--border,#3a3a3a);background:var(--bg,#1a1a1a);width:100%;color:var(--text,#e8e8e8);box-sizing:border-box;border-radius:6px;outline:none;margin-bottom:12px;padding:10px 14px;font-size:15px}.password-modal-content input:focus{border-color:var(--primary,#60a5fa)}.password-modal-content .btn{width:100%;padding:10px;font-size:15px}.password-error{color:var(--danger,#ef4444);min-height:18px;margin-bottom:10px;font-size:13px}:root{--bg:#1a1a1a;--surface:#242424;--surface-hover:#2e2e2e;--text:#e8e8e8;--text-secondary:#999;--primary:#60a5fa;--primary-hover:#3b82f6;--danger:#ef4444;--danger-hover:#dc2626;--border:#3a3a3a;--shadow:0 1px 4px #0006;--radius:8px;--card-bg:#2a2a2a;--card-principal-bg:#4a4520;--card-principal-border:#e8d54e}[data-theme=light]{--bg:#f0f2f5;--surface:#fff;--surface-hover:#f5f5f5;--text:#1a1a1a;--text-secondary:#666;--primary:#3b82f6;--primary-hover:#2563eb;--danger:#ef4444;--danger-hover:#dc2626;--border:#ddd;--shadow:0 1px 3px #0000001a;--card-bg:#fff;--card-principal-bg:#fdf0b0;--card-principal-border:#b8a829}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;transition:background .3s,color .3s;overflow:hidden}#app{flex-direction:column;height:100vh;display:flex}#toolbar{background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);z-index:100;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;transition:background .3s,border-color .3s;display:flex}.toolbar-actions{flex-wrap:wrap;align-items:center;gap:6px;margin-left:auto;display:flex}.app-logo{flex-shrink:0;height:40px}[data-theme=dark] .app-logo{filter:brightness(0)invert()}.app-title{white-space:nowrap;text-align:center;flex:auto;min-width:0;margin:0;font-family:Pacifico,cursive;font-size:28px;font-weight:400}.member-count{color:var(--text-secondary);white-space:nowrap;font-size:14px}.member-count strong{color:var(--text);font-weight:600}.principal-selector{flex-shrink:1;align-items:center;gap:8px;min-width:0;display:flex}.principal-selector label{color:var(--text-secondary);white-space:nowrap;font-size:14px}.custom-select{flex-shrink:1;min-width:120px;max-width:250px;position:relative}.custom-select-trigger{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);cursor:pointer;justify-content:space-between;align-items:center;gap:8px;padding:6px 12px;font-size:14px;transition:background .3s,border-color .3s,color .3s;display:flex}.custom-select-trigger:hover{background:var(--surface-hover)}.custom-select-value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.custom-select-arrow{color:var(--text-secondary);flex-shrink:0;font-size:10px;transition:transform .2s}.custom-select.open .custom-select-arrow{transform:rotate(180deg)}.custom-select-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);z-index:500;flex-direction:column;width:100%;min-width:240px;max-height:280px;display:flex;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden;box-shadow:0 8px 24px #0000004d}.custom-select:not(.open) .custom-select-menu{display:none}.custom-select.open .custom-select-menu{display:flex}.custom-select-search{border:none;border-bottom:1px solid var(--border);background:var(--bg);color:var(--text);outline:none;flex-shrink:0;padding:8px 12px;font-size:13px}.custom-select-search::placeholder{color:var(--text-secondary)}.custom-select-options{flex:1;margin:0;padding:4px 0;list-style:none;overflow-y:auto}.custom-select-options li{cursor:pointer;white-space:nowrap;text-overflow:ellipsis;padding:7px 12px;font-size:13px;transition:background .1s;overflow:hidden}.custom-select-options li:hover,.custom-select-options li.highlighted{background:var(--surface-hover)}.custom-select-options li.selected{color:var(--primary);font-weight:600}.custom-select-options li.hidden{display:none}.theme-toggle{border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:background .2s,border-color .2s;display:flex}.theme-toggle:hover{background:var(--surface-hover)}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;padding:7px 16px;font-size:13px;font-weight:500;transition:background .15s,transform .1s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-small{padding:4px 10px;font-size:12px}#viewerMode{background:var(--bg);flex:1;min-height:0;position:relative;overflow:hidden}#FamilyChart{width:100%;height:100%}#FamilyChart.f3.f3-cont{height:100%!important;max-height:100%!important}.f3{--background-color:var(--bg);--text-color:var(--text)}.f3 div.mini-tree{cursor:pointer;opacity:.7;transition:opacity .2s}.f3 div.mini-tree:hover{opacity:1}[data-theme=light] .f3 div.mini-tree svg line{stroke:#666}.f3-form-cont,.f3-nav-cont,.f3-modal,.f3-popup,.f3-kinship-labels-toggle,.f3-autocomplete-toggle,.fit_screen_icon{display:none!important}.f3 .link{stroke:var(--text-secondary);stroke-width:2px}.f3 .link.f3-path-to-main{stroke:#fbbf24;stroke-width:4px}.f3 div.card-inner.f3-trace-endpoint{outline:4px solid #fff!important}[data-theme=light] .f3{--background-color:var(--bg);--male-color:#b0cedb;--female-color:#e6b2ba}[data-theme=light] .f3 .link{stroke:#888}[data-theme=light] .f3 .link.f3-path-to-main{stroke:#d35400;stroke-width:3px}.card-inner{border-radius:var(--radius);background:var(--card-bg);border:2px solid var(--border);height:100%;color:var(--text);align-items:stretch;transition:border-color .2s,background .3s,box-shadow .2s;display:flex;overflow:hidden}.card-inner:hover{box-shadow:0 2px 8px #00000026}[data-theme=dark] .card-inner:hover{box-shadow:0 2px 12px #ffffff1a}.card-inner[data-gender=male]{border-left:4px solid #789fac}[data-theme=dark] .card-inner[data-gender=male]{border-left:4px solid #a0c8d7}.card-inner[data-gender=female]{border-left:4px solid #c48a92}[data-theme=dark] .card-inner[data-gender=female]{border-left:4px solid #e1aab4}.card-inner.card-principal{border:3px solid var(--card-principal-border);background:var(--card-principal-bg);box-shadow:0 0 10px 3px #e8d54e66}[data-theme=light] .card-inner.card-principal{box-shadow:0 0 8px 2px #b8a82959}.card-avatar-wrap{flex-shrink:0;justify-content:center;align-items:center;width:60px;padding:4px;display:flex}.card-avatar{object-fit:cover;border-radius:50%;width:48px;height:48px}.card-inner[data-gender=male] .card-avatar circle,.card-inner[data-gender=male] .card-avatar ellipse{fill:#789fac}.card-inner[data-gender=female] .card-avatar circle,.card-inner[data-gender=female] .card-avatar ellipse{fill:#c48a92}[data-theme=dark] .card-inner[data-gender=male] .card-avatar circle,[data-theme=dark] .card-inner[data-gender=male] .card-avatar ellipse{fill:#a0c8d7}[data-theme=dark] .card-inner[data-gender=female] .card-avatar circle,[data-theme=dark] .card-inner[data-gender=female] .card-avatar ellipse{fill:#e1aab4}.card-info{flex-direction:column;flex:1;justify-content:center;min-width:0;padding:6px 8px;display:flex;overflow:hidden}.card-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.card-birthday{color:#fff9;margin-top:1px;font-size:10px}[data-theme=light] .card-birthday{color:#666}.card-relation{flex-direction:column;gap:0;margin-top:2px;display:flex}.card-relation-self{align-items:flex-start}.relation-te{color:#fff;text-shadow:0 1px 2px #0006;text-transform:capitalize;font-size:12px;font-weight:600}.relation-path{white-space:nowrap;text-overflow:ellipsis;flex-wrap:nowrap;align-items:center;gap:1px;font-size:8px;display:flex;overflow:hidden}.relation-path .path-state{color:#ffffffb3}.relation-path .path-hop{color:#ffffff59;font-size:7px;font-style:italic}.relation-path .path-hop:before{content:"›";margin-right:1px}.relation-path .path-hop:after{content:"›";margin-left:1px}[data-theme=light] .relation-te{color:#1a1a1a;text-shadow:none}[data-theme=light] .relation-path .path-state{color:#333}[data-theme=light] .relation-path .path-hop{color:#888}#editorPanel{top:var(--toolbar-height,53px);background:var(--surface);border-left:1px solid var(--border);z-index:90;width:340px;padding:16px;transition:background .3s,border-color .3s;position:fixed;bottom:0;right:0;overflow-y:auto;box-shadow:-2px 0 8px #0003}.editor-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.editor-header h2{font-size:16px;font-weight:600}.editor-header-actions{gap:6px;margin-bottom:12px;display:flex}.editor-header-actions .btn{flex:1}#qualityPanel{top:var(--toolbar-height,53px);background:var(--surface);border-left:1px solid var(--border);z-index:89;width:320px;padding:16px;transition:background .3s,border-color .3s;position:fixed;bottom:0;right:340px;overflow-y:auto;box-shadow:-2px 0 8px #0003}.quality-item{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:space-between;align-items:flex-start;margin-bottom:8px;padding:10px 12px;transition:background .15s;display:flex}.quality-item:hover{background:var(--surface-hover)}.quality-item-name{margin-bottom:4px;font-size:13px;font-weight:600}.quality-item-tags{flex-wrap:wrap;gap:4px;display:flex}.quality-tag{background:var(--danger);color:#fff;border-radius:4px;padding:2px 6px;font-size:11px;display:inline-block}.quality-summary{color:var(--text-secondary);margin-bottom:12px;font-size:13px}.form-group{margin-bottom:12px}.form-group label{color:var(--text-secondary);margin-bottom:4px;font-size:12px;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text);padding:7px 10px;font-size:13px;transition:background .3s,border-color .3s,color .3s}.rel-picker{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);transition:background .3s,border-color .3s}.rel-picker-search{border:none;border-bottom:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;width:100%;color:var(--text);box-sizing:border-box;background:0 0;outline:none;padding:6px 10px;font-size:12px}.rel-picker-search:focus{border-bottom-color:var(--primary)}.rel-picker-list{max-height:120px;margin:0;padding:0;list-style:none;overflow-y:auto}.rel-picker-list li{cursor:pointer;align-items:center;gap:6px;padding:4px 10px;font-size:12px;transition:background .1s;display:flex}.rel-picker-list li:hover{background:var(--surface-hover)}.rel-picker-list li.hidden{display:none}.rel-picker-list li input[type=checkbox]{width:auto;accent-color:var(--primary);cursor:pointer;margin:0}.rel-picker-list li span{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px}.form-actions{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.person-list-item{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 0;display:flex}.person-list-name{flex:1;font-size:14px;font-weight:500}.person-list-rel{color:#777;font-size:12px;font-weight:600}.rel-picker-list li .rel-picker-kinship{color:#777;font-size:11px;font-weight:600}.person-list-id{color:var(--text-secondary);font-size:11px}#personList h3{margin-top:20px;margin-bottom:8px;font-size:14px;font-weight:600}.info-modal{z-index:200;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.info-modal-content{background:var(--surface);color:var(--text);border-radius:var(--radius);width:90%;max-width:520px;max-height:85vh;padding:24px 28px;transition:background .3s,color .3s;position:relative;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.info-modal-content h3{margin-bottom:14px;font-size:16px;font-weight:600}.info-modal-content ul{padding:0;list-style:none}.info-modal-content li{border-left:2px solid var(--border);margin-bottom:10px;padding-left:12px;font-size:13px;line-height:1.5}.info-modal-content code{background:var(--bg);border-radius:3px;padding:1px 5px;font-size:12px}.info-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:22px;line-height:1;position:absolute;top:12px;right:16px}.info-close:hover{color:var(--text)}.json-editor-content{max-width:700px}#jsonEditorArea,#exportJsonArea{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;height:400px;color:var(--text);resize:vertical;tab-size:2;padding:12px;font-family:Menlo,Monaco,Courier New,monospace;font-size:12px;line-height:1.5}.json-error{color:var(--danger);min-height:18px;margin-top:6px;font-size:12px}.diff-view{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;height:400px;color:var(--text);font-family:Menlo,Monaco,Courier New,monospace;font-size:12px;line-height:1.5;overflow:auto}.diff-line{white-space:pre;padding:0 8px}.diff-line-same{color:var(--text-secondary)}.diff-line-add{color:#3fb950;background:#2ea04333}.diff-line-remove{color:#f85149;background:#f8514933}[data-theme=light] .diff-line-add{color:#1a7f37;background:#2ea04326}[data-theme=light] .diff-line-remove{color:#cf222e;background:#f8514926}.confirm-modal{z-index:10000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-modal-content{background:var(--surface);color:var(--text);border-radius:var(--radius);width:90%;max-width:400px;padding:28px 32px;box-shadow:0 8px 32px #0006}.confirm-modal-content h3{margin-bottom:10px;font-size:16px;font-weight:600}.confirm-modal-content p{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:8px;display:flex}.toast-container{z-index:11000;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{border-radius:var(--radius);opacity:0;pointer-events:auto;padding:10px 20px;font-size:13px;font-weight:500;transition:opacity .3s,transform .3s;transform:translateY(12px);box-shadow:0 4px 16px #0000004d}.toast-visible{opacity:1;transform:translateY(0)}.toast-success{color:#fff;background:#16a34a}.toast-error{background:var(--danger);color:#fff}.search-panel{z-index:90;width:320px;max-width:90%;position:absolute;top:16px;left:50%;transform:translate(-50%)}.search-input-wrap{align-items:center;display:flex;position:relative}.search-shortcut{border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);pointer-events:none;opacity:.7;border-radius:4px;padding:2px 6px;font-family:system-ui,sans-serif;font-size:10px;line-height:1.3;position:absolute;right:10px}.search-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;color:var(--text);outline:none;padding:10px 60px 10px 14px;font-size:14px;transition:border-color .2s;box-shadow:0 4px 16px #00000040}.search-input:focus{border-color:var(--primary)}.search-results{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);max-height:240px;margin:4px 0 0;padding:4px 0;list-style:none;display:none;overflow-y:auto;box-shadow:0 4px 16px #00000040}.search-results.has-results{display:block}.search-results li{cursor:pointer;white-space:nowrap;text-overflow:ellipsis;padding:8px 14px;font-size:13px;transition:background .1s;overflow:hidden}.search-results li:hover{background:var(--surface-hover)}.search-results li .search-result-relation{color:var(--text-secondary);margin-left:8px;font-size:11px}@keyframes card-pulse{0%{box-shadow:0 0 #3b82f699}50%{box-shadow:0 0 0 8px #3b82f600}to{box-shadow:0 0 #3b82f600}}.card-highlight{animation:.6s ease-out 3 card-pulse}#proposePwModal .confirm-modal-content input,#proposeNameModal .confirm-modal-content input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);box-sizing:border-box;border-radius:6px;outline:none;margin-bottom:12px;padding:10px 14px;font-size:14px}#proposePwModal .confirm-modal-content input:focus,#proposeNameModal .confirm-modal-content input:focus{border-color:var(--primary)}.propose-progress-content{max-width:440px}.propose-steps{margin:0 0 16px;padding:0;list-style:none}.propose-step{color:var(--text-secondary);align-items:center;gap:10px;padding:8px 0;font-size:14px;transition:color .2s;display:flex}.propose-step.step-active{color:var(--primary);font-weight:500}.propose-step.step-done{color:#16a34a}.propose-step.step-error{color:var(--danger)}.step-icon{flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;display:inline-flex}.step-active .step-icon{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.propose-result{word-break:break-all;min-height:20px;font-size:14px;line-height:1.6}.propose-result a{color:var(--primary);text-decoration:underline}.propose-success{color:#16a34a;font-weight:600}.propose-error{color:var(--danger);font-weight:500}@media (width<=900px){.principal-selector label,.app-title{display:none}}@media (width<=640px){#toolbar{gap:6px;padding:6px 10px}.app-logo{height:32px}.member-count{display:none}.custom-select{min-width:100px}.btn{padding:6px 10px;font-size:13px}#editorPanel{border-left:none;border-top:1px solid var(--border);width:100%;height:60%;top:auto;bottom:0}}@media (width<=400px){#toolbar{gap:4px;padding:4px 8px}.toolbar-actions{gap:4px}.btn{padding:5px 8px;font-size:12px}.theme-toggle{width:30px;height:30px;font-size:14px}}.f3{--female-color:#c48a92;--male-color:#789fac;--genderless-color:lightgray;--background-color:#212121;--text-color:#fff;font-family:Roboto,sans-serif}.f3 *{box-sizing:border-box}.f3 .cursor-pointer{cursor:pointer}.f3 svg.main_svg{width:100%;height:100%}.f3 svg.main_svg text{fill:currentColor}.f3 rect.card-female,.f3 .card-female .card-body-rect,.f3 .card-female .text-overflow-mask{fill:var(--female-color)}.f3 rect.card-male,.f3 .card-male .card-body-rect,.f3 .card-male .text-overflow-mask{fill:var(--male-color)}.f3 .card-genderless .card-body-rect,.f3 .card-genderless .text-overflow-mask{fill:var(--genderless-color)}.f3 .card_add .card-body-rect{fill:#3b5560;stroke-width:4px;stroke:#fff;cursor:pointer}.f3 g.card_add text{fill:#fff}.f3 .card-main-outline{stroke:currentColor;stroke-width:3px}.f3 .card_family_tree rect{transition:all .3s}.f3 .card_family_tree:hover rect{transform:scale(1.1)}.f3 .card_add_relative{cursor:pointer;color:#fff;transition:all .3s}.f3 .card_add_relative circle{fill:#0000}.f3 .card_add_relative:hover{color:#000}.f3 .card_edit.pencil_icon{color:#fff;transition:all .3s}.f3 .card_edit.pencil_icon:hover{color:#000}.f3 .card_break_link,.f3 .link_upper,.f3 .link_lower,.f3 .link_particles{transform-origin:50%;transition:all 1s}.f3 .card_break_link{color:#fff}.f3 .card_break_link.closed .link_upper{transform:translate(-140.5px,655.6px)}.f3 .card_break_link.closed .link_upper g{transform:rotate(-58deg)}.f3 .card_break_link.closed .link_particles{transform:scale(0)}.f3 .input-field input{height:2.5rem!important}.f3 .input-field>label:not(.label-icon).active{transform:translateY(-8px)scale(.8)}.f3.f3-cont{background-color:var(--background-color);width:100%;height:900px;max-height:70vh;color:var(--text-color)}.f3{display:flex;position:relative}.f3-form input[type=text],.f3-form textarea,.f3-form select{box-sizing:border-box;background:var(--background-color);color:currentColor;border:1px solid #ddd;border-radius:4px;width:100%;margin:8px 0;padding:8px 12px;font-size:14px}.f3-form input[type=text]:focus,.f3-form textarea:focus,.f3-form select:focus{box-shadow:0 0 5px #4caf5033}.f3-form button{cursor:pointer;border:none;border-radius:4px;margin:10px 0;padding:10px 20px;font-size:14px;transition:background-color .3s ease-in-out,border-color .3s ease-in-out,color .3s ease-in-out}.f3-form button[type=submit]{color:#fff;background-color:#4caf50}.f3-cancel-btn{background-color:#ccc}.f3-form .f3-delete-btn{color:#f44336;background-color:#0000;border:1px solid #f44336;width:100%;padding:5px 10px}.f3-delete-btn:hover{color:#fff;background-color:#da190b;border-color:#da190b}.f3-delete-btn:disabled{opacity:.5;color:#f44336;cursor:not-allowed;background-color:#0000}.f3-form .f3-remove-relative-btn{color:currentColor;background-color:#0000;border:1px solid;width:100%;padding:5px 10px}.f3-remove-relative-btn:hover,.f3-remove-relative-btn.active{background-color:var(--text-color);border-color:var(--text-color);color:var(--background-color)}.f3-radio-group{margin:15px 0}.f3-radio-group label{cursor:pointer;margin-right:15px}.f3-radio-group input[type=radio]{margin-right:5px}.f3-info-field-label,.f3-form-field label{opacity:.8;font-size:12px;font-weight:700;display:block}.f3-info-field-value{border:none;border-bottom:1px solid #fff3;outline:none;min-height:18px;margin-bottom:10px;padding-bottom:1px;font-weight:400;display:block}.f3-form-buttons{text-align:right}.f3-form-title{text-align:center}.f3-form.non-editable .f3-form-buttons,.f3-form.non-editable .f3-delete-btn,.f3-form.non-editable .f3-remove-relative-btn,.f3-form.non-editable .f3-link-existing-relative{display:none}.f3-close-btn{cursor:pointer;color:var(--text-color);font-size:30px;position:absolute;top:8px;left:10px}.f3-edit-btn{cursor:pointer;width:24px;height:24px;display:inline-block;position:relative;top:-1px}.f3-add-relative-btn{cursor:pointer;width:27px;height:27px;margin-right:5px;display:inline-block}.f3 div.card{cursor:pointer;color:var(--text-color);line-height:1.2;position:relative}.f3 div.card-image-circle{border-radius:50%;width:90px;height:90px;padding:5px}.f3 div.card-image-circle div.card-label{text-align:center;text-overflow:ellipsis;white-space:nowrap;background-color:#00000080;border-radius:3px;max-width:150%;min-height:22px;padding:0 5px;position:absolute;bottom:-10px;left:50%;overflow:hidden;transform:translate(-50%,50%)}.f3 div.card-image-circle svg{object-fit:cover;border-radius:50%;width:100%;height:100%;padding:5px}.f3 div.card-image-circle img{object-fit:cover;border-radius:50%;width:100%;height:100%}.f3 div.card-rect{text-align:center;border-radius:3px;flex-direction:column;justify-content:center;width:120px;min-height:70px;padding:5px;display:flex;overflow:hidden}.f3 div.card-image-rect{border-radius:5px;align-items:center;width:200px;min-height:70px;display:flex}.f3 div.card-image-rect .person-icon{object-fit:cover;flex:none;width:70px;height:70px;margin-right:10px;padding:5px}.f3 div.card-image-rect img{object-fit:cover;border-radius:8px;flex:none;width:70px;height:70px;margin-right:10px;padding:5px}.f3 div.card-image-rect svg{object-fit:cover;border-radius:7px;width:100%;height:100%;padding:5px}.f3 div.card-image-rect div.card-label{flex-direction:column;justify-content:center;height:100%;display:flex;overflow:hidden}.f3 div.mini-tree{text-align:right;z-index:-1;position:absolute;top:-15px;right:-2px}.f3 div.mini-tree svg{width:55px}.f3 .f3-card-duplicate-tag{color:#fffbdc;background-color:#fffbdc00;border-radius:50%;padding:2px;transition:color .2s ease-in-out,background-color .2s ease-in-out;position:absolute;top:2px;right:2px}.f3 .f3-card-duplicate-hover div.card-inner{outline:4px solid #fffbdc;transform:translateY(-2px)}.f3 .f3-card-duplicate-hover .f3-card-duplicate-tag{color:#000;background-color:#fffbdccc}.f3 .f3-remove-relative-active .card{background-color:var(--background-color)}.f3 .f3-remove-relative-active .card-inner{opacity:.75;transition:border .2s ease-in-out,opacity .2s ease-in-out,transform .2s ease-in-out}.f3 .f3-remove-relative-active .card:hover .card-inner{opacity:.25}.f3 .f3-remove-relative-active .card-male.card-depth--1:hover .card-inner{transform:translate(-8px,-8px)}.f3 .f3-remove-relative-active .card.card-female.card-depth--1:hover .card-inner{transform:translate(8px,-8px)}.f3 .f3-remove-relative-active .card.card-female.card-depth-0:hover .card-inner{transform:translate(8px)}.f3 .f3-remove-relative-active .card.card-male.card-depth-0:hover .card-inner{transform:translate(-8px)}.f3 .f3-remove-relative-active .card.card-depth-1:hover .card-inner{transform:translateY(8px)}.f3 .f3-remove-relative-active .card.card-main .card-inner{opacity:1!important;transform:translate(0)!important}.f3 div.card>div{transition:transform .2s ease-in-out;box-shadow:0 0 #000c}.f3 .card-inner{outline:0 solid #fff;transition:outline .5s ease-in-out}.f3 div.card-female .card-inner,.f3 div.card-female .person-icon svg{background-color:var(--female-color)}.f3 div.card-male .card-inner,.f3 div.card-male .person-icon svg{background-color:var(--male-color)}.f3 div.card-genderless .card-inner,.f3 div.card-genderless .person-icon svg{background-color:var(--genderless-color)}.f3 div.card-new-rel .card-inner,.f3 div.card-new-rel .person-icon svg{background-color:var(--background-color)}.f3 div.card-to-add .card-inner{background-color:var(--background-color);border:1px solid}.f3 div.card-to-add .card-inner .card-label{margin:0 auto}.f3 div.card-to-add .person-icon{display:none}.f3 div.card-new-rel.card-female .card-inner,.f3 div.card-to-add.card-female .card-inner{border-color:var(--female-color);color:var(--female-color)}.f3 div.card-new-rel.card-male .card-inner,.f3 div.card-to-add.card-male .card-inner{color:var(--male-color);border-color:var(--male-color)}.f3 div.card-unknown .card-inner{background-color:var(--background-color);border:1px solid}.f3 div.card-unknown .card-inner .card-label{margin:0 auto}.f3 div.card-unknown .person-icon{display:none}.f3 div.card-new-rel .card-inner{border-style:dashed;border-width:1px;outline:0!important}.f3 div.card-new-rel.card-female .card-inner,.f3 div.card-unknown.card-female .card-inner{border-color:var(--female-color);color:var(--female-color)}.f3 div.card-new-rel.card-male .card-inner,.f3 div.card-unknown.card-male .card-inner{color:var(--male-color);border-color:var(--male-color)}.f3 div.card:hover>div{transform:translateY(-2px)}.f3 div.card-main .card-inner,.f3 div.card:hover .card-inner{box-shadow:0 0 20px #000c}.f3 div.card-main .card-inner{outline:4px solid #dcdcdc}.f3 div.card-inner.f3-path-to-main{outline:4px solid #fff}.f3 .link{transition:stroke-width .2s ease-in-out}.f3 .link.f3-path-to-main{stroke-width:4px}.f3-form-cont{z-index:6;background-color:var(--background-color);flex:none;width:0;height:100%;position:relative;top:0;right:0;overflow:auto;box-shadow:0 0 10px #00000080}.f3-form-cont.opened{width:350px}.f3-form{padding:20px}.f3-form hr{opacity:.15;border-style:solid;border-width:thin 0 0}.f3-nav-cont{width:100%;display:flex;position:absolute;top:0;left:0}.f3-history-controls{z-index:2;padding:8px 5px 7px 9px;display:inline-block;position:relative}.f3-back-button,.f3-forward-button{cursor:pointer;color:currentColor;background-color:#0000;border:none;width:30px;height:30px;margin-right:10px;transition:opacity .3s;display:inline-block}.f3-history-controls svg{height:100%}.f3-back-button.disabled,.f3-forward-button.disabled{opacity:.5}.f3-modal{z-index:10;background-color:#0006;width:100%;height:100%;display:none;position:absolute;top:0;left:0;overflow:auto}.f3-modal-content{background-color:var(--background-color);border:1px solid #888;border-radius:5px;width:500px;max-width:90%;margin:15% auto;padding:20px;position:relative}.f3-modal-close{color:#aaa;font-size:28px;font-weight:700;position:absolute;top:7px;right:10px}.f3-modal-close:hover,.f3-modal-close:focus{color:#000;cursor:pointer;text-decoration:none}.f3-popup{position:fixed;box-shadow:0 0 10px #000c}.f3-popup-content{background-color:var(--background-color);border:1px solid #888;border-radius:5px;width:100%;height:100%;position:relative;overflow:hidden}.f3-popup-nav{height:20px}.f3-popup-content-inner{width:100%;height:100%}.f3-popup-close{color:#aaa;z-index:4;font-size:28px;font-weight:700;line-height:1;position:absolute;top:1px;right:6px}.f3-popup-close:hover,.f3-popup-close:focus{color:#000;cursor:pointer;text-decoration:none}.f3-btn{cursor:pointer;background-color:var(--text-color);color:var(--background-color);border-width:0;border-radius:3px;outline:none;padding:5px 10px;font-size:14px;transition:background-color .3s;position:relative;overflow:hidden;box-shadow:0 1px 4px #0009}.f3-btn:hover,.f3-btn:focus{background-color:var(--background-color);color:var(--text-color)}.f3-female-bg{background-color:var(--female-color)}.f3-male-bg{background-color:var(--male-color)}.f3-genderless-bg{background-color:var(--genderless-color)}.f3-female-color{color:var(--female-color)}.f3-male-color{color:var(--male-color)}.f3-genderless-color{color:var(--genderless-color)}.f3-autocomplete-cont{z-index:2;width:200px;font-size:14px;display:inline-block;position:relative}.f3-autocomplete input{background-color:var(--background-color);color:var(--text-color);border:1px solid #fff3;width:100%;padding:10px}.f3-autocomplete input:focus{outline:none}.f3-autocomplete-toggle{cursor:pointer;color:var(--text-color);width:20px;transition:color .3s ease-in-out;position:absolute;top:10px;right:10px}.f3-autocomplete-items{background-color:var(--background-color);border:1px solid #fff3;border-top:none;max-height:0;transition:max-height .3s ease-in-out;overflow-y:auto}.f3-autocomplete.active .f3-autocomplete-items{max-height:300px}.f3-autocomplete-item>div{cursor:pointer;background-color:var(--background-color);border-bottom:1px solid #fff3;padding:10px;transition:background-color .3s ease-in-out,color .3s ease-in-out}.f3-autocomplete-item>div:hover,.f3-autocomplete-item.f3-selected>div{background-color:var(--text-color);color:var(--background-color)}.f3-autocomplete-active{color:#fff;background-color:#1e90ff!important}.f3-kinship-info{padding:10px 20px}.f3-kinship-info .f3-info-field{color:#b3b01e}.f3-kinship-info-icon{cursor:pointer;color:#04a4f4;width:18px;height:18px;display:inline-block;position:relative;top:4px;left:2px}.f3-kinship-info .f3{color:#fff;background-color:#212121;width:100%;height:100%;position:relative}.f3 .f3-kinship-info .card-kinship-self{color:#437fae;border:3px solid;border-radius:50%;width:60px;height:60px;min-height:0;font-weight:700;background-color:var(--background-color)!important}.f3 .f3-kinship-info .card-kinship-self.f3-real-label{border-radius:50px;width:150px;height:50px}.f3 .f3-kinship-info .card-kinship-rel{border-radius:50px;width:150px;height:50px;min-height:0;font-weight:700;background-color:#1d3456!important}.f3 .f3-kinship-info .card-kinship-default{border:1px solid;border-radius:50px;width:150px;height:50px;min-height:0;background-color:var(--background-color)!important}.f3-kinship-labels-toggle{z-index:10;font-size:12px;position:absolute;top:0;left:0}.f3-kinship-labels-toggle label{cursor:pointer;color:#fff;text-align:center;padding:2px 5px;font-weight:700}.f3-kinship-labels-toggle input[type=checkbox]{cursor:pointer;margin:5px}
