.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}:root{--bg:#fafafa;--bg-panel:#fff;--text:#1a1a1a;--text-muted:#666;--accent:#2563eb;--accent-hover:#1d4ed8;--border:#e2e2e2;--danger:#dc2626;--danger-hover:#b91c1c;--success:#16a34a;--radius:6px;--shadow:0 1px 3px #00000014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;color:var(--text);background:var(--bg);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}#app{flex-direction:column;height:100vh;display:flex;overflow:hidden}#header{background:var(--bg-panel);border-bottom:1px solid var(--border);z-index:10;flex-shrink:0;align-items:center;gap:12px;padding:8px 16px;display:flex}#header .logo{white-space:nowrap;color:var(--text);font-size:16px;font-weight:700}#search-wrapper{flex:0 280px;margin-left:auto;position:relative}#search-input{border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:6px 10px;font-size:13px}#search-input:focus{border-color:var(--accent)}#search-results{background:var(--bg-panel);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);z-index:100;max-height:300px;box-shadow:var(--shadow);border-top:none;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}#search-results.open{display:block}.search-result{cursor:pointer;padding:8px 10px;font-size:13px}.search-result:hover{background:#f0f4ff}.search-result .search-result-name{font-weight:500}.header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.menu-wrapper{position:relative}.menu-toggle{padding:6px 8px;line-height:1}.menu-backdrop{z-index:99;position:fixed;inset:0}.menu-dropdown{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow);z-index:100;padding:4px 0;position:absolute;top:calc(100% + 4px);right:0}.menu-item{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;padding:8px 14px;font-size:13px;display:block}.menu-item:hover{background:var(--bg-hover,#f0f4ff)}.menu-divider{border:none;border-top:1px solid var(--border);margin:4px 0}.menu-item-danger{color:var(--danger,#d32f2f)}.upload-overlay{z-index:9999;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.upload-card{background:var(--bg-panel);border-radius:var(--radius);min-width:280px;box-shadow:var(--shadow);text-align:center;padding:24px 32px}.migration-card{background:var(--bg-panel);border-radius:var(--radius);max-width:480px;box-shadow:var(--shadow);text-align:left;padding:24px 32px}.migration-card h3{margin:0 0 8px}.migration-card p{color:var(--text-muted);margin:0 0 12px;font-size:.9rem}.migration-list{color:var(--text-muted);margin:0 0 16px;padding-left:20px;font-size:.85rem}.migration-list li{margin-bottom:4px}.migration-actions{justify-content:flex-end;gap:8px;display:flex}.upload-progress-bar{background:var(--border);border-radius:3px;height:6px;overflow:hidden}.upload-progress-fill{background:var(--accent);border-radius:3px;width:40%;height:100%;animation:1.2s ease-in-out infinite upload-slide}@keyframes upload-slide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.upload-status{color:var(--text);margin:12px 0 0;font-size:14px}.btn{border:1px solid var(--border);background:var(--bg-panel);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:6px 14px;font-size:13px;transition:background .15s,border-color .15s;display:inline-flex}.btn:hover{background:#f0f0f0;border-color:#ccc}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#fef2f2}.btn-sm{padding:3px 10px;font-size:12px}.btn-link{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:13px}.btn-link:hover{text-decoration:underline}#main{flex:1;grid-template-columns:1fr;display:grid;position:relative;overflow:hidden}#main.has-panel{grid-template-columns:1fr 380px}#chart-container{position:relative;overflow:hidden}#chart-container .f3{touch-action:none;width:100%;height:100%}.f3{--background-color:#fafafa;--text-color:var(--text);--male-color:#93c5fd;--female-color:#f9a8d4;--genderless-color:#e5e7eb}.f3 .main_svg{background:var(--background-color)}.f3 .card_inner{border-radius:8px;box-shadow:0 1px 4px #0000001a}.f3 .card-inner.card-rect{box-sizing:border-box;width:100%;padding:6px 10px}.f3 .person-icon{visibility:hidden}.card-name{font-weight:500}.card-life-years,.card-birth-date,.card-birth-place,.card-death-date,.card-death-place{color:var(--text-muted);margin-top:2px;font-size:11px}.card-life-years{margin-top:4px}.card-deceased .card-name{color:var(--text-muted)}.f3.hide-life-years .card-life-years,.f3.hide-birth-date .card-birth-date,.f3.hide-birth-place .card-birth-place,.f3.hide-death-date .card-death-date,.f3.hide-death-place .card-death-place{display:none}.f3 .link{stroke:#555;stroke-width:2px}.f3 .link.f3-path-to-main{stroke:var(--accent);stroke-width:3px}#empty-state{background:var(--bg);z-index:5;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:absolute;inset:0}#empty-state h2{font-size:20px;font-weight:600}#empty-state p{color:var(--text-muted);text-align:center;max-width:400px;line-height:1.5}#empty-state .empty-actions{gap:12px;margin-top:8px;display:flex}.hidden{display:none!important}#panel{background:var(--bg-panel);border-left:1px solid var(--border);flex-direction:column;display:none;overflow-y:auto}#main.has-panel #panel{display:flex}.panel-header{padding:20px 20px 4px}.panel-header-top{justify-content:space-between;align-items:start;display:flex}.panel-name{color:var(--text);font-size:22px;font-weight:700;line-height:1.2}.panel-life-dates{color:var(--text-muted);margin-top:2px;font-size:15px}.gender-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.gender-dot.M{background:#3b82f6}.gender-dot.F{background:#ec4899}.gender-dot.U{background:#9ca3af}.panel-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 4px;font-size:20px;line-height:1}.panel-close:hover{color:var(--text)}.panel-edit-toggle{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:4px 12px;font-size:12px}.panel-edit-toggle:hover{border-color:var(--accent);color:var(--accent)}.panel-edit-toggle.active{background:var(--accent);border-color:var(--accent);color:#fff}.panel-alt-names{flex-wrap:wrap;align-items:center;gap:6px;padding:8px 20px 4px;display:flex}.alt-name-pill{color:var(--text-muted);background:#f3f4f6;border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.alt-name-type{color:#9ca3af;font-weight:600}.alt-name-remove{cursor:pointer;color:#9ca3af;background:0 0;border:none;padding:0 2px;font-size:12px;line-height:1}.alt-name-remove:hover{color:var(--danger)}.panel-section-title{text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;border-top:1px solid var(--border);padding:12px 20px 8px;font-size:12px;font-weight:700}.panel-events-list{flex-direction:column;gap:8px;padding:0 20px 8px;display:flex}.ev-card{background:#f9fafb;border-left:3px solid #e5e7eb;border-radius:8px;gap:10px;padding:10px 12px;display:flex}.ev-card.birth{border-left-color:#22c55e}.ev-card.death{border-left-color:#6b7280}.ev-card.marriage{border-left-color:#ec4899}.ev-card.census{border-left-color:#8b5cf6}.ev-card.occupation{border-left-color:#f59e0b}.ev-card.residence{border-left-color:#06b6d4}.ev-card.immigration,.ev-card.emigration{border-left-color:#10b981}.ev-card.burial{border-left-color:#78716c}.ev-card.naturalisation{border-left-color:#0ea5e9}.ev-card.divorce{border-left-color:#ef4444}.ev-card-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;display:flex}.ev-card-icon.birth{color:#22c55e;background:#dcfce7}.ev-card-icon.death{color:#6b7280;background:#f3f4f6}.ev-card-icon.marriage{color:#ec4899;background:#fce7f3}.ev-card-icon.census{color:#8b5cf6;background:#ede9fe}.ev-card-icon.occupation{color:#f59e0b;background:#fef3c7}.ev-card-icon.residence{color:#06b6d4;background:#cffafe}.ev-card-body{flex:1;min-width:0}.ev-card-top{justify-content:space-between;align-items:baseline;display:flex}.ev-card-type{color:#374151;text-transform:capitalize;font-size:13px;font-weight:600}.ev-card-date{color:var(--text-muted);font-size:13px}.ev-card-place,.ev-card-detail{color:var(--text-muted);margin-top:1px;font-size:13px}.ev-card-participants{color:#3b82f6;margin-top:2px;font-size:12px}.ev-card-participants span{cursor:pointer}.ev-card-participants span:hover{text-decoration:underline}.ev-card-citation{color:#9ca3af;margin-top:3px;font-size:11px;font-style:italic}.ev-card-citation a{color:#9ca3af}.ev-card-citation a:hover{color:var(--accent)}.ev-card-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.ev-card-actions button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:11px}.ev-card-actions button:hover{color:var(--accent)}.ev-card-actions .danger:hover{color:var(--danger)}.ev-card-gap{color:var(--accent);cursor:pointer;margin-top:3px;font-size:11px}.ev-card-gap:hover{text-decoration:underline}.panel-family{padding:0 20px 8px}.family-group{padding:4px 0}.family-group-label{color:#9ca3af;margin-bottom:4px;font-size:11px;font-weight:600}.family-group-with{color:#6b7280;align-items:center;gap:4px;margin:8px 0 4px;font-size:12px;display:flex}.family-chip{color:#3b82f6;cursor:pointer;background:#f9fafb;border:none;border-radius:8px;align-items:center;gap:4px;margin:2px 4px 2px 0;padding:5px 10px;font-size:14px;display:inline-flex}.family-chip:hover{background:#eff6ff}.family-chip-dates{color:#9ca3af;font-size:11px}.family-chip-remove{color:#9ca3af;cursor:pointer;background:0 0;border:none;margin-left:2px;padding:0 2px;font-size:12px}.family-chip-remove:hover{color:var(--danger)}.family-children{padding-left:16px}.panel-notes{color:var(--text-muted);padding:8px 20px 20px;font-size:14px;line-height:1.5}.panel-notes a{color:var(--accent)}.panel-participating{padding:0 20px 8px}.participating-item{color:var(--text-muted);border-bottom:1px solid #f5f5f5;padding:4px 0;font-size:13px}.participating-item:last-child{border-bottom:none}.participating-type{color:#374151;text-transform:capitalize;font-weight:600}.participating-role{color:#9ca3af}.participating-owner{color:#3b82f6;cursor:pointer}.participating-owner:hover{text-decoration:underline}.name-row{border-radius:var(--radius);background:#f9f9f9;flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;padding:8px;display:flex}.name-row select,.name-row input{border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:5px 8px;font-size:13px}.name-row select{width:auto}.name-row input{flex:1;min-width:80px}.wizard-panel{padding:16px}.wizard-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.wizard-header h3{margin:0;font-size:16px}.wizard-progress{color:var(--text-muted);border-bottom:1px solid var(--border);justify-content:space-between;margin-bottom:12px;padding:6px 0;font-size:13px;display:flex}.wizard-total{font-size:11px}.wizard-person h4{margin:0 0 12px}.wizard-issues{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.wizard-issue{border-radius:var(--radius);background:#f9f9f9;align-items:center;gap:8px;padding:8px;font-size:13px;display:flex}.wizard-issue-icon{color:var(--text-muted);font-size:14px}.wizard-issue-label{flex:1}.wizard-issue-done,.wizard-issue-done .wizard-issue-icon{color:var(--accent)}.wizard-nav{justify-content:space-between;gap:8px;display:flex}.wizard-loading,.wizard-complete{text-align:center;color:var(--text-muted);padding:24px 0}.wizard-complete h4{color:var(--text);margin-bottom:8px}.wizard-stats{margin-bottom:12px;font-size:12px}.spouse-suggestions{gap:6px;margin-bottom:6px;display:flex}.section-empty{color:var(--text-muted);padding:4px 0;font-size:13px;font-style:italic}.section-add-btn{margin-top:4px;font-size:12px}.modal-backdrop{z-index:1000;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-panel);border-radius:10px;flex-direction:column;width:90%;max-width:480px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 8px 30px #00000026}.modal.modal-wide{max-width:720px}.modal-header{border-bottom:1px solid var(--border);align-items:center;padding:14px 18px;display:flex}.modal-header h2{flex:1;font-size:16px;font-weight:600}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 4px;font-size:22px}.modal-close:hover{color:var(--text)}.modal-body{flex:1;padding:18px;overflow-y:auto}.form-group{flex-direction:column;gap:4px;margin-bottom:14px;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:12px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:7px 10px;font-family:inherit;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:60px}.form-hint{color:var(--text-muted);font-size:11px}.form-actions{justify-content:flex-end;gap:8px;margin-top:6px;display:flex}.person-picker{position:relative}.person-picker input{border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:7px 10px;font-size:14px}.person-picker input:focus{border-color:var(--accent)}.picker-results{background:var(--bg-panel);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);z-index:10;max-height:200px;box-shadow:var(--shadow);border-top:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.picker-result{cursor:pointer;padding:7px 10px;font-size:13px}.picker-result:hover{background:#f0f4ff}.picker-create{cursor:pointer;color:var(--accent);border-top:1px solid var(--border);padding:7px 10px;font-size:13px}.picker-create:hover{background:#f0f4ff}.place-suggestions{background:var(--bg-panel);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);z-index:10;max-height:200px;box-shadow:var(--shadow);border-top:none;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.place-suggestion{cursor:pointer;padding:7px 10px;font-size:13px}.place-suggestion:hover{background:#f0f4ff}.place-suggestion-create{color:var(--primary);border-top:1px solid var(--border)}.places-page{min-height:200px}.place-tree{margin:0;padding-left:16px;list-style:none}.place-tree-item{margin:0}.place-tree-row{align-items:center;gap:6px;padding:5px 0;font-size:13px;display:flex}.place-tree-row:hover{border-radius:var(--radius);background:#f8f8f8}.place-toggle{cursor:pointer;text-align:center;width:14px;color:var(--text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:10px}.place-toggle-spacer{flex-shrink:0;width:14px}.place-tree-name{flex:1;min-width:0}.place-type-badge{color:var(--text-muted);text-transform:capitalize;background:#f0f0f0;border-radius:999px;flex-shrink:0;padding:1px 6px;font-size:10px}.place-tree-actions{opacity:0;flex-shrink:0;gap:4px;transition:opacity .15s;display:flex}.place-tree-row:hover .place-tree-actions{opacity:1}.place-events-toggle{color:var(--text-muted);margin-left:4px;font-size:11px}.place-events-list{padding:4px 0 4px 24px;font-size:13px}.place-event-row{align-items:center;gap:8px;padding:2px 0;display:flex}.place-event-type{color:var(--text-muted);text-transform:capitalize;min-width:60px;font-size:11px}.place-event-date{color:var(--text-muted);font-size:12px}.place-event-person{color:var(--accent);font-size:13px;text-decoration:none}.place-event-person:hover{text-decoration:underline}.organize-wizard{min-height:200px}.organize-progress{color:var(--text-muted);margin-bottom:12px;font-size:12px}.organize-card{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;padding:16px}.organize-card h3{margin-bottom:4px;font-size:16px}.organize-people{color:var(--accent);margin-bottom:8px;font-size:12px}.organize-count{color:var(--text-muted);margin-bottom:8px;font-size:13px}.organize-examples{border-radius:var(--radius);color:var(--text-muted);background:#f8f8f8;margin-bottom:12px;padding:6px 10px;font-size:12px}.organize-example{white-space:nowrap;text-overflow:ellipsis;padding:2px 0;overflow:hidden}.organize-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.organize-history{margin-top:12px}.organize-history summary{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:12px;font-weight:600}.organize-history-list{max-height:150px;margin-top:4px;overflow-y:auto}.organize-history-item{color:var(--text-muted);border-bottom:1px solid #f0f0f0;padding:2px 0;font-size:12px}.organize-finish-early{justify-content:flex-end;margin-top:8px;display:flex}.source-list{margin-top:8px}.source-entry{align-items:center;gap:6px;padding:4px 0;font-size:13px;display:flex}.source-entry-text{text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.participant-row{align-items:center;gap:8px;padding:4px 0;display:flex}.participant-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;overflow:hidden}.participant-role{border:1px solid var(--border);border-radius:var(--radius);padding:3px 6px;font-size:12px}.citation-row{border-radius:var(--radius);background:#f9f9f9;flex-direction:column;gap:6px;margin-top:8px;padding:8px;display:flex}.citation-source-row{align-items:center;gap:8px;display:flex}.citation-source-label{font-size:13px;font-weight:500}.citation-details-row{flex-direction:column;gap:6px;display:flex}.citation-details-row input,.citation-details-row select{border:1px solid var(--border);border-radius:var(--radius);box-sizing:border-box;outline:none;width:100%;padding:5px 8px;font-size:13px}.citation-details-row select{width:auto}.selected-place-row{align-items:center;gap:8px;display:flex}.selected-place-name{font-size:14px}.accessed-field{align-items:center;gap:4px;display:flex}.accessed-field input{flex:1}.citation-details-actions{justify-content:flex-end;display:flex}.citation-existing{flex-direction:row;justify-content:space-between;align-items:center}.citation-detail-label{color:var(--text-muted);font-size:13px}.citation-add-actions{gap:8px;display:flex}.sources-page{min-height:200px}.sources-stats{color:var(--text-muted);margin-bottom:12px;font-size:13px}.sources-repo-section{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}.sources-repo-header{cursor:pointer;align-items:center;gap:8px;padding:8px 12px;font-size:14px;display:flex}.sources-repo-name{font-weight:600}.sources-repo-type{color:var(--text-muted);background:var(--bg);border-radius:var(--radius);padding:1px 6px;font-size:11px}.sources-repo-url{color:var(--accent);margin-left:auto;font-size:11px;text-decoration:none}.sources-repo-count{color:var(--text-muted);font-size:12px}.sources-repo-actions{align-items:center;gap:4px;margin-left:8px;display:flex}.sources-add-btn{color:var(--accent);border-color:var(--accent);font-weight:600}.sources-list{padding:4px 12px 8px}.sources-source-row{align-items:center;gap:8px;padding:4px 0;font-size:13px;display:flex}.sources-source-title{flex:1}.sources-source-type{color:var(--text-muted);font-size:11px}.sources-source-url{color:var(--accent);font-size:11px}.sources-source-actions{gap:4px;display:flex}.source-citations-list{padding:4px 0 8px 24px;font-size:13px}.source-citation-row{align-items:center;gap:8px;padding:2px 0;display:flex}.source-citation-event{color:var(--text-muted);text-transform:capitalize;min-width:60px;font-size:11px}.source-citation-date{color:var(--text-muted);font-size:12px}.source-citation-person{color:var(--accent);font-size:13px;text-decoration:none}.source-citation-person:hover{text-decoration:underline}.source-citation-detail{color:var(--text-muted);font-size:12px;font-style:italic}.source-citation-url{color:var(--accent);font-size:11px}.import-stats{margin:12px 0}.import-stats dt{font-weight:600;display:inline}.import-stats dd{margin:0 12px 0 4px;display:inline}.import-warnings{max-height:120px;color:var(--text-muted);margin-top:12px;font-size:12px;overflow-y:auto}#toast-root{z-index:2000;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.toast{background:var(--text);color:#fff;opacity:0;pointer-events:auto;border-radius:999px;padding:8px 20px;font-size:13px;transition:opacity .2s,transform .2s;transform:translateY(8px)}.toast-visible{opacity:1;transform:translateY(0)}#tree-config{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);z-index:20;width:240px;max-height:calc(100% - 16px);font-size:13px;display:none;position:absolute;top:8px;left:8px;overflow-y:auto;box-shadow:0 4px 16px #0000001f}#tree-config.open{display:block}.tree-config-header{border-bottom:1px solid var(--border);align-items:center;padding:10px 12px;display:flex}.tree-config-header h3{flex:1;font-size:13px;font-weight:600}.tree-config-body{padding:10px 12px}.cfg-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.cfg-row label{color:var(--text-muted);flex:1;font-size:12px}.cfg-row input[type=color]{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;width:32px;height:24px;padding:1px}.cfg-section-label{text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-top:1px solid var(--border);margin:12px 0 6px;padding-top:8px;font-size:11px;font-weight:600}.cfg-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.cfg-row input[type=range]{min-width:60px;accent-color:var(--accent);flex:1}.cfg-value{color:var(--text-muted);text-align:right;min-width:28px;font-size:12px}.cfg-row select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-panel);outline:none;padding:4px 6px;font-family:inherit;font-size:13px}.cfg-actions{border-top:1px solid var(--border);justify-content:flex-end;margin-top:8px;padding-top:8px;display:flex}@media (width<=768px){#header{flex-wrap:wrap;gap:8px;padding:8px 12px}#search-wrapper{flex:1;margin-left:0}.header-actions{z-index:40;padding:8px 12px;padding-bottom:calc(8px + env(safe-area-inset-bottom));background:var(--bg-panel);border-top:1px solid var(--border);justify-content:center;gap:8px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #0000000f}.header-actions .btn{flex:1;justify-content:center}.menu-dropdown{top:auto;bottom:calc(100% + 4px)}#main{padding-bottom:56px}#main.has-panel{grid-template-columns:1fr}#panel{z-index:50;border-left:none;position:fixed;inset:0}#main.has-panel #panel{display:flex}.modal{border-radius:0;width:100%;max-width:100%;height:100%;max-height:100vh}.modal-backdrop{align-items:stretch}.btn{padding:8px 14px;font-size:14px}.btn-sm{padding:6px 10px;font-size:13px}.btn-link{padding:4px 6px;font-size:14px}.search-result,.picker-result,.picker-create{padding:10px 12px}.rel-item{padding:8px 0}.event-item{padding:10px 0}.form-group input,.form-group select,.form-group textarea,.person-picker input{padding:10px 12px;font-size:16px}#search-input{padding:8px 12px;font-size:16px}#tree-config{border:none;border-top:1px solid var(--border);z-index:60;border-radius:16px 16px 0 0;width:100%;max-height:70vh;transition:transform .25s;position:fixed;inset:auto 0 0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -4px 24px #00000026}#tree-config.open{display:block;transform:translateY(0)}.drawer-backdrop{z-index:55;background:#0000004d;position:fixed;inset:0}#toast-root{bottom:70px}#empty-state{padding:20px}#empty-state h2{font-size:18px}#empty-state .empty-actions{flex-direction:column;gap:8px}}.modal-backdrop.svelte-lce4ig{z-index:1000;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal.svelte-lce4ig{background:var(--bg-panel);border-radius:10px;flex-direction:column;width:90%;max-width:480px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 8px 30px #00000026}.modal.modal-wide.svelte-lce4ig{max-width:720px}.modal-header.svelte-lce4ig{border-bottom:1px solid var(--border);align-items:center;padding:14px 18px;display:flex}.modal-header.svelte-lce4ig h2:where(.svelte-lce4ig){flex:1;font-size:16px;font-weight:600}.modal-close.svelte-lce4ig{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 4px;font-size:22px}.modal-close.svelte-lce4ig:hover{color:var(--text)}.modal-body.svelte-lce4ig{flex:1;padding:18px;overflow-y:auto}@media (width<=768px){.modal.svelte-lce4ig{border-radius:0;width:100%;max-width:100%;height:100%;max-height:100vh}.modal-backdrop.svelte-lce4ig{align-items:stretch}}.person-picker.svelte-72eauo{position:relative}.person-picker.svelte-72eauo input:where(.svelte-72eauo){border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:7px 10px;font-size:14px}.person-picker.svelte-72eauo input:where(.svelte-72eauo):focus{border-color:var(--accent)}.picker-results.svelte-72eauo{background:var(--bg-panel);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);z-index:10;max-height:200px;box-shadow:var(--shadow);border-top:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.picker-result.svelte-72eauo{cursor:pointer;padding:7px 10px;font-size:13px}.picker-result.svelte-72eauo:hover{background:#f0f4ff}.picker-create.svelte-72eauo{cursor:pointer;color:var(--accent);border-top:1px solid var(--border);padding:7px 10px;font-size:13px}.picker-create.svelte-72eauo:hover{background:#f0f4ff}@media (width<=768px){.picker-result.svelte-72eauo,.picker-create.svelte-72eauo{padding:10px 12px}.person-picker.svelte-72eauo input:where(.svelte-72eauo){padding:10px 12px;font-size:16px}}.person-picker.svelte-12jfcd4{position:relative}.person-picker.svelte-12jfcd4 input:where(.svelte-12jfcd4){border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:7px 10px;font-size:14px}.person-picker.svelte-12jfcd4 input:where(.svelte-12jfcd4):focus{border-color:var(--accent)}.picker-results.svelte-12jfcd4{background:var(--bg-panel);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);z-index:10;max-height:200px;box-shadow:var(--shadow);border-top:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.picker-result.svelte-12jfcd4{cursor:pointer;padding:7px 10px;font-size:13px}.picker-result.svelte-12jfcd4:hover{background:#f0f4ff}.picker-create.svelte-12jfcd4{cursor:pointer;color:var(--accent);border-top:1px solid var(--border);padding:7px 10px;font-size:13px}.picker-create.svelte-12jfcd4:hover{background:#f0f4ff}@media (width<=768px){.picker-result.svelte-12jfcd4,.picker-create.svelte-12jfcd4{padding:10px 12px}.person-picker.svelte-12jfcd4 input:where(.svelte-12jfcd4){padding:10px 12px;font-size:16px}}.person-picker.svelte-q8fmy0{position:relative}.person-picker.svelte-q8fmy0 input:where(.svelte-q8fmy0){border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:7px 10px;font-size:14px}.person-picker.svelte-q8fmy0 input:where(.svelte-q8fmy0):focus{border-color:var(--accent)}.picker-results.svelte-q8fmy0{background:var(--bg-panel);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);z-index:10;max-height:200px;box-shadow:var(--shadow);border-top:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.picker-result.svelte-q8fmy0{cursor:pointer;padding:7px 10px;font-size:13px}.picker-result.svelte-q8fmy0:hover{background:#f0f4ff}.picker-create.svelte-q8fmy0{cursor:pointer;color:var(--accent);border-top:1px solid var(--border);padding:7px 10px;font-size:13px}.picker-create.svelte-q8fmy0:hover{background:#f0f4ff}@media (width<=768px){.picker-result.svelte-q8fmy0,.picker-create.svelte-q8fmy0{padding:10px 12px}.person-picker.svelte-q8fmy0 input:where(.svelte-q8fmy0){padding:10px 12px;font-size:16px}}.person-picker.svelte-1y7848k{position:relative}.person-picker.svelte-1y7848k input:where(.svelte-1y7848k){border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:7px 10px;font-size:14px}.person-picker.svelte-1y7848k input:where(.svelte-1y7848k):focus{border-color:var(--accent)}.picker-results.svelte-1y7848k{background:var(--bg-panel);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);z-index:10;max-height:200px;box-shadow:var(--shadow);border-top:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.picker-result.svelte-1y7848k{cursor:pointer;padding:7px 10px;font-size:13px}.picker-result.svelte-1y7848k:hover{background:#f0f4ff}.picker-empty.svelte-1y7848k{color:var(--text-muted);padding:7px 10px;font-size:13px}@media (width<=768px){.picker-result.svelte-1y7848k,.picker-empty.svelte-1y7848k{padding:10px 12px}.person-picker.svelte-1y7848k input:where(.svelte-1y7848k){padding:10px 12px;font-size:16px}}.toast.svelte-11kiomq{background:var(--text);color:#fff;opacity:0;pointer-events:auto;border-radius:999px;padding:8px 20px;font-size:13px;transition:opacity .2s,transform .2s;transform:translateY(8px)}.toast-visible.svelte-11kiomq{opacity:1;transform:translateY(0)}
