@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-family:"Outfit", sans-serif;--bg-primary:#08090d;--bg-secondary:#0f111a;--panel-bg:#121420a6;--border-color:#ffffff14;--border-glow:#6366f126;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent:#6366f1;--accent-hover:#4f46e5;--accent-glow:#6366f166;--male-color:#3b82f6;--male-bg:#3b82f61a;--male-border:#3b82f64d;--male-glow:#3b82f633;--female-color:#ec4899;--female-bg:#ec48991a;--female-border:#ec48994d;--female-glow:#ec489933;--other-color:#8b5cf6;--other-bg:#8b5cf61a;--other-border:#8b5cf64d;--other-glow:#8b5cf633;--danger:#ef4444;--danger-hover:#dc2626;--backdrop-blur:blur(16px);--shadow-lg:0 10px 25px -5px #00000080, 0 8px 10px -6px #00000080;--glass-shadow:0 8px 32px 0 #0000005e;--transition-fast:.15s ease;--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--panel-solid-bg:#0f111af5;--popover-bg:#0f111af5;--overlay-bg:#00000080;--footer-bg:#0f111a66;--slider-bg:#ffffff1a;--control-bg:#121420d9;--cropper-overlay-bg:#08090db3;--bg-panel:#1e293b;--bg-input:#0f172a}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;width:100vw;height:100dvh;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0000001a}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.hidden{display:none!important}.btn{font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;border-radius:8px;outline:none;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:500;display:inline-flex}.btn-primary{background-color:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.btn-primary:hover{background-color:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-primary);background-color:#ffffff0d}.btn-secondary:hover{background-color:#ffffff1a}.btn-danger{color:var(--danger);background-color:#ef44441a;border:1px solid #ef44444d}.btn-danger:hover{background-color:var(--danger);color:#fff;box-shadow:0 0 15px #ef44444d}.btn-icon{border:1px solid var(--border-color);width:36px;height:36px;color:var(--text-secondary);background-color:#ffffff0a;border-radius:8px;padding:0}.btn-icon:hover{color:var(--text-primary);background-color:#ffffff14}.glass-panel{background:var(--panel-bg);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--border-color);box-shadow:var(--glass-shadow);border-radius:16px}.auth-container{background:radial-gradient(circle at 100% 0,#6366f11f,#0000 45%),radial-gradient(circle at 0 100%,#ec489914,#0000 40%),#07080c;justify-content:center;align-items:center;width:100vw;height:100dvh;padding:20px;display:flex}.auth-card{width:100%;max-width:400px;padding:40px;animation:.5s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.auth-logo{text-align:center;margin-bottom:30px}.auth-logo .icon-glow{background:linear-gradient(135deg, var(--accent), #f43f5e);color:#fff;width:54px;height:54px;box-shadow:0 0 20px var(--accent-glow);border-radius:12px;justify-content:center;align-items:center;margin-bottom:12px;display:inline-flex}.auth-logo h2{letter-spacing:-.5px;font-size:24px;font-weight:600}.auth-logo p{color:var(--text-secondary);margin-top:4px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:500;display:block}.form-control{border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-family);transition:all var(--transition-fast);background:#00000040;border-radius:8px;padding:12px 16px;font-size:14px}.form-control:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #6366f133}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:13px}.auth-footer a{color:var(--accent);transition:color var(--transition-fast);font-weight:500;text-decoration:none}.auth-footer a:hover{color:#818cf8}.auth-error{color:#f87171;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:12px 16px;font-size:13px;animation:.4s shake;display:none}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.guest-divider{text-align:center;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;align-items:center;margin:20px 0;font-size:11px;display:flex}.guest-divider:before,.guest-divider:after{content:"";border-bottom:1px solid var(--border-color);flex:1}.guest-divider:not(:empty):before{margin-right:.5em}.guest-divider:not(:empty):after{margin-left:.5em}.app-shell{background:var(--bg-primary);grid-template-rows:68px 1fr;width:100vw;max-width:100vw;height:100dvh;display:grid;overflow:hidden}.app-header{min-width:0;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border-bottom:1px solid var(--border-color);z-index:110;background:#0f111acc;justify-content:space-between;align-items:center;gap:16px;padding:0 24px;display:flex}.app-brand{flex:none;align-items:center;gap:10px;min-width:0;display:flex}.app-brand-logo{background:linear-gradient(135deg, var(--accent), #f43f5e);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.app-brand h1{letter-spacing:-.3px;font-size:18px;font-weight:600}.app-header-controls{overscroll-behavior-x:contain;scrollbar-width:thin;flex:auto;justify-content:flex-start;align-items:center;gap:10px;min-width:0;max-width:100%;display:flex;overflow:auto hidden}.app-header-controls>*{flex:none}.header-menu{display:inline-flex;position:relative}.header-menu-toggle{gap:6px}.header-menu-caret{transition:transform var(--transition-fast);margin-left:2px}.header-menu.open .header-menu-caret{transform:rotate(180deg)}.header-menu-panel{background:var(--popover-bg);border:1px solid var(--border-color);min-width:220px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);z-index:200;border-radius:12px;flex-direction:column;gap:4px;padding:8px;display:none;position:absolute;top:calc(100% + 6px);right:0}.header-menu.open .header-menu-panel{display:flex}.header-menu-panel .btn{justify-content:flex-start;width:100%;margin:0}.menu-group-header{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);-webkit-user-select:none;user-select:none;padding:6px 8px 2px;font-size:10.5px;font-weight:700}.menu-divider{background:var(--border-color);height:1px;margin:4px 6px}.tree-dropdown-wrapper{position:relative}.user-profile-btn{border:1px solid var(--border-color);background:#ffffff0a;border-radius:8px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;display:flex}.user-profile-btn .avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:600;display:flex}.app-body{grid-template-columns:280px minmax(0,1fr) 340px;min-width:0;max-width:100vw;height:100%;display:grid;overflow:hidden}.home-dashboard{background:radial-gradient(circle at 12% 10%, var(--accent-glow), transparent 32%), var(--bg-primary);min-width:0;display:none;overflow-y:auto}.app-body.home-mode{max-width:100vw;display:block;overflow:hidden auto}.app-body.home-mode .home-dashboard{min-height:100%;display:block}.app-body.home-mode>.sidebar-left,.app-body.home-mode>.viewport-center,.app-body.home-mode>.sidebar-right{display:none!important}.home-dashboard-inner{width:min(1080px,100% - 48px);margin:0 auto;padding:64px 0 80px}.home-hero{max-width:720px;margin-bottom:44px}.home-eyebrow{color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;font-size:12px;font-weight:700}.home-hero h2{color:var(--text-primary);letter-spacing:-.04em;margin-bottom:12px;font-size:clamp(30px,5vw,48px)}.home-hero>p:last-child,.home-section-heading p{color:var(--text-secondary);line-height:1.65}.home-section-heading{justify-content:space-between;align-items:end;gap:20px;min-width:0;margin-bottom:18px;display:flex}.home-section-heading h3{color:var(--text-primary);margin-bottom:4px;font-size:20px}.home-tree-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;display:grid}.home-tree-card{background:var(--panel-bg);border:1px solid var(--border-color);min-height:190px;transition:transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:16px;flex-direction:column;padding:22px;display:flex;box-shadow:0 8px 24px #00000029}.home-tree-card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.home-tree-card-top{justify-content:space-between;align-items:start;gap:12px;display:flex}.home-tree-card h4{color:var(--text-primary);font-size:17px;line-height:1.35}.home-tree-role{color:var(--accent);background:var(--accent-glow);letter-spacing:.04em;text-transform:uppercase;border-radius:999px;flex:none;padding:4px 8px;font-size:10px;font-weight:700}.home-tree-meta{color:var(--text-secondary);margin:14px 0 22px;font-size:13px}.home-tree-card .btn{width:100%;margin-top:auto}.home-empty-state{color:var(--text-secondary);text-align:center;background:var(--panel-bg);border:1px dashed var(--border-color);border-radius:16px;grid-column:1/-1;padding:42px 24px}.app-brand-home{color:inherit;cursor:pointer;background:0 0;border:0}.node-album-btn{justify-content:center;gap:8px;width:100%;margin-bottom:22px}.stewardship-modal-card{width:min(680px,100vw - 32px);max-height:min(820px,100dvh - 32px);overflow-y:auto}.stewardship-heading-row,.stewardship-preview-row,.stewardship-list-item{justify-content:space-between;align-items:center;gap:14px;display:flex}.stewardship-default-summary{color:var(--text-secondary);background:var(--accent-glow);border:1px solid var(--border-glow);border-radius:10px;margin:12px 0;padding:12px 14px;font-size:13px}.stewardship-notice{color:var(--text-secondary);background:#f59e0b1a;border:1px solid #f59e0b59;border-radius:10px;margin:12px 0;padding:11px 13px;font-size:12px;line-height:1.45}#claim-auth-notice{margin:0 0 16px}.stewardship-advanced{border:1px solid var(--border-color);border-radius:10px;margin:12px 0;padding:12px 14px}.stewardship-advanced summary{color:var(--text-primary);cursor:pointer;font-weight:600}.stewardship-option{color:var(--text-secondary);align-items:center;gap:9px;margin:14px 0;font-size:13px;display:flex}.stewardship-hint{color:var(--text-secondary);font-size:11px;line-height:1.45}.stewardship-checklist{background:var(--control-bg);border:1px solid var(--border-color);border-radius:8px;gap:4px;max-height:190px;margin-top:8px;padding:6px;display:grid;overflow-y:auto}.stewardship-checklist label{color:var(--text-secondary);cursor:pointer;border-radius:6px;align-items:flex-start;gap:8px;padding:7px 8px;font-size:12px;line-height:1.35;display:flex}.stewardship-checklist label:hover{color:var(--text-primary);background:var(--accent-glow)}.stewardship-checklist input{margin-top:2px}.stewardship-preview-row{min-height:38px;color:var(--text-secondary);justify-content:flex-start;margin:12px 0;font-size:13px}.stewardship-preview-people{flex-wrap:wrap;gap:6px;margin:-4px 0 12px;padding:0;list-style:none;display:flex}.stewardship-preview-people li{color:var(--text-secondary);background:var(--control-bg);border:1px solid var(--border-color);border-radius:999px;padding:5px 8px;font-size:11px}.stewardship-submit{justify-content:center;width:100%}.stewardship-list{gap:9px;display:grid}.stewardship-list-item{background:var(--control-bg);border:1px solid var(--border-color);border-radius:10px;padding:12px}.stewardship-list-copy{min-width:0}.stewardship-list-copy strong,.stewardship-list-copy span{display:block}.stewardship-list-copy span{color:var(--text-secondary);margin-top:3px;font-size:12px}.stewardship-list-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.node-access-note{color:var(--text-secondary);background:var(--accent-glow);border:1px solid var(--border-glow);border-radius:8px;margin-bottom:12px;padding:9px 11px;font-size:12px}.sidebar-left{border-right:1px solid var(--border-color);background:#0a0b1266;flex-direction:column;min-width:0;display:flex;overflow:hidden}.sidebar-section{border-bottom:1px solid var(--border-color);padding:18px}.sidebar-title{text-transform:uppercase;color:var(--text-muted);letter-spacing:.7px;margin-bottom:12px;font-size:11px;font-weight:600}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.stat-item{border:1px solid var(--border-color);text-align:center;background:#ffffff05;border-radius:8px;padding:10px}.stat-val{color:var(--accent);font-size:18px;font-weight:700}.stat-lbl{color:var(--text-secondary);margin-top:2px;font-size:10px}.search-wrapper{position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{border:1px solid var(--border-color);width:100%;color:var(--text-primary);font-family:var(--font-family);background:#0003;border-radius:8px;padding:10px 10px 10px 36px;font-size:13px}.members-list-container{flex:1;padding:14px 18px;overflow-y:auto}.member-row{cursor:pointer;transition:background var(--transition-fast);border:1px solid #0000;border-radius:8px;align-items:center;gap:12px;margin-bottom:6px;padding:10px;display:flex}.member-row:hover{background:#ffffff08;border-color:#ffffff0d}.member-row.active{background:#6366f114;border-color:#6366f133}.member-row-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.member-row-info{flex:1;min-width:0}.member-row-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.member-row-dates{color:var(--text-secondary);margin-top:1px;font-size:11px}.viewport-center{background-image:radial-gradient(var(--border-color) 1.2px, transparent 1.2px), radial-gradient(var(--border-color) 1.2px, transparent 1.2px);background-position:0 0,16px 16px;background-size:32px 32px;outline:none;width:100%;min-width:0;height:100%;position:relative;overflow:hidden}#tree-svg{-webkit-user-select:none;user-select:none;width:100%;height:100%}.tree-connection{stroke-dasharray:none;transition:stroke var(--transition-normal), stroke-width var(--transition-normal)}.spouse-connection{stroke:var(--accent);stroke-dasharray:4 4}.parent-connection{stroke:#fff3}.descending-connection,.child-connection,.sibling-connection{stroke:#ffffff26}.node-card-wrapper:hover~.connections-layer path{opacity:.3}.node-card-wrapper{overflow:visible}.family-node-card{background:var(--panel-bg);-webkit-backdrop-filter:var(--backdrop-blur);border:1.5px solid var(--border-color);cursor:grab;width:100%;height:100%;transition:transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);-webkit-user-select:none;user-select:none;border-radius:12px;align-items:center;gap:12px;padding:12px 14px;display:flex;position:relative;box-shadow:0 4px 15px #0006}.family-node-card:active{cursor:grabbing}.family-node-card:hover{border-color:#fff3;transform:scale(1.03);box-shadow:0 8px 24px #00000080}.gender-male{border-left:4px solid var(--male-color)}.gender-male:hover{border-color:var(--male-border);box-shadow:0 4px 20px var(--male-glow)}.gender-female{border-left:4px solid var(--female-color)}.gender-female:hover{border-color:var(--female-border);box-shadow:0 4px 20px var(--female-glow)}.gender-other{border-left:4px solid var(--other-color)}.gender-other:hover{border-color:var(--other-border);box-shadow:0 4px 20px var(--other-glow)}.family-node-card.active-selected{border:2px solid var(--accent);box-shadow:0 0 16px var(--accent-glow)!important}.family-node-card.focus-glow{border-color:var(--accent);box-shadow:0 0 18px var(--accent-glow);animation:3s infinite alternate pulseGlow}@keyframes pulseGlow{0%{box-shadow:0 0 10px #6366f133}to{box-shadow:0 0 24px #6366f180}}.avatar-circle{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:15px;font-weight:700;display:flex;box-shadow:inset 0 2px 4px #0003}.node-details{flex:1;min-width:0}.node-fullname{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13.5px;font-weight:600;overflow:hidden}.node-lifespan{color:var(--text-secondary);align-items:center;gap:4px;margin-top:3px;font-size:11px;display:flex}.node-lifespan svg{color:var(--text-muted)}.node-occupation{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:4px;margin-top:2px;font-size:10px;display:flex;overflow:hidden}.node-tag{letter-spacing:.3px;text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:8.5px;font-weight:600;position:absolute;top:-8px;right:12px}.focus-tag{background:var(--accent);color:#fff;box-shadow:0 2px 5px var(--accent-glow)}.spouse-tag{color:var(--text-secondary);border:1px solid var(--border-color);background:#ffffff1a}.canvas-controls{z-index:40;flex-direction:column;gap:8px;display:flex;position:absolute;bottom:24px;left:24px}.canvas-controls .btn-icon.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.canvas-controls-horizontal{z-index:40;gap:8px;display:flex;position:absolute;top:24px;left:24px}.sidebar-right{border-left:1px solid var(--border-color);z-index:10;background:#0a0b1266;flex-direction:column;min-width:0;display:flex;overflow:hidden}.editor-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px;display:flex}.editor-header h3{font-size:15px;font-weight:600}.editor-body{flex:1;padding:20px;overflow-y:auto}.editor-section-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;margin:22px 0 12px;font-size:11px;font-weight:600;display:flex}.editor-section-divider:after{content:"";border-bottom:1px solid var(--border-color);flex:1;margin-left:10px}.editor-row{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.birthday-row{grid-template-columns:65px 1fr 85px;gap:8px;display:grid}.profile-photo-container{justify-content:center;margin-top:10px;margin-bottom:22px;display:flex}.profile-photo-wrapper{flex-direction:column;align-items:center;gap:12px;display:flex;position:relative}.avatar-circle-large{color:#fff;border:2px solid var(--border-color);width:96px;height:96px;transition:transform .3s cubic-bezier(.34, 1.56, .64, 1), border-color var(--transition-fast), box-shadow var(--transition-fast);background:#ffffff0d 50%/cover no-repeat;border-radius:50%;justify-content:center;align-items:center;font-size:32px;font-weight:700;display:flex;overflow:hidden;box-shadow:0 8px 32px #0006,inset 0 2px 4px #0003}.avatar-circle-large:hover{border-color:var(--accent);box-shadow:0 0 15px var(--accent-glow);transform:scale(1.05)}.avatar-circle-large img{object-fit:cover;width:100%;height:100%}.photo-controls{align-items:center;gap:8px;display:flex}.btn-sm{border-radius:6px;justify-content:center;align-items:center;gap:4px;height:28px;padding:4px 10px;font-size:11px;display:inline-flex}.switch-wrapper{border:1px solid var(--border-color);background:#00000026;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:10px 14px;display:flex}.switch-label{color:var(--text-secondary);font-size:13px;font-weight:500}.switch{width:44px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;border:1px solid var(--border-color);background-color:#ffffff1a;border-radius:24px;transition:all .3s;position:absolute;inset:0}.slider:before{content:"";background-color:var(--text-secondary);border-radius:50%;width:16px;height:16px;transition:all .3s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--accent);border-color:var(--accent)}input:checked+.slider:before{background-color:#fff;transform:translate(20px)}.quick-add-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px;display:grid}.editor-footer{border-top:1px solid var(--border-color);background:var(--footer-bg);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.editor-footer .btn{flex:1}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;opacity:0;pointer-events:none;transition:opacity var(--transition-normal);background:#040508bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-backdrop.active{opacity:1;pointer-events:auto}.modal-card{width:100%;max-width:440px;transition:transform var(--transition-normal);padding:30px;animation:.3s cubic-bezier(.34,1.56,.64,1) modalEnter;transform:scale(.95)}@keyframes modalEnter{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-card.active{transform:scale(1)}.modal-title{margin-bottom:8px;font-size:18px;font-weight:600}.modal-desc{color:var(--text-secondary);margin-bottom:24px;font-size:13px}.modal-actions{justify-content:flex-end;align-items:center;gap:12px;margin-top:24px;display:flex}.help-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:20px 0 8px;font-size:12px;font-weight:600}.help-list{flex-direction:column;gap:8px;margin:0;padding-left:20px;display:flex}.help-list li{color:var(--text-secondary);font-size:14px;line-height:1.5}.help-key{color:var(--text-primary);background:var(--control-bg);border:1px solid var(--border-color);white-space:nowrap;border-radius:6px;margin-right:4px;padding:1px 7px;font-size:12.5px;font-weight:600;display:inline-block}.memory-card{background:var(--bg-input);border:1px solid var(--border-color);transition:transform var(--transition-fast), border-color var(--transition-fast);border-radius:10px;flex-direction:column;gap:8px;padding:14px;display:flex}.memory-card:hover{border-color:var(--accent)}.memory-card-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.memory-badge{text-transform:uppercase;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.memory-badge.story{color:var(--accent);background:#6366f11a;border:1px solid #6366f133}.memory-badge.photo{color:#10b981;background:#10b9811a;border:1px solid #10b98133}.memory-badge.transcription{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b33}.memory-title{color:var(--text-primary);font-size:15px;font-weight:600}.memory-text{color:var(--text-secondary);white-space:pre-wrap;font-size:13.5px;line-height:1.5}.memory-attachment{color:var(--text-muted);align-items:center;gap:6px;margin-top:4px;font-size:12px;display:flex}.memory-attachment-link{color:var(--accent);cursor:pointer;font-weight:500;text-decoration:none}.memory-attachment-link:hover{text-decoration:underline}.memory-photo-preview{object-fit:cover;border:1px solid var(--border-color);border-radius:6px;max-width:120px;max-height:120px;margin-top:4px}.crop-viewport-container{justify-content:center;margin:20px 0;display:flex}.crop-viewport{border:1.5px solid var(--border-color);-webkit-user-select:none;user-select:none;background:#0006;border-radius:12px;width:280px;height:280px;position:relative;overflow:hidden;box-shadow:inset 0 0 20px #0009}#crop-image{cursor:move;-webkit-user-select:none;user-select:none;touch-action:none;transform-origin:50%;will-change:transform;position:absolute}.crop-frame-overlay{pointer-events:none;z-index:5;width:200px;height:200px;transition:border-color var(--transition-fast);border:2px dashed #ffffffd9;border-radius:50%;position:absolute;top:40px;left:40px;box-shadow:0 0 0 280px #08090db3}.crop-viewport:hover .crop-frame-overlay{border-color:var(--accent)}.zoom-slider-wrapper{align-items:center;gap:12px;margin:15px 0;padding:0 4px;display:flex}.zoom-slider-wrapper .slider-icon{color:var(--text-secondary);opacity:.7;transition:opacity var(--transition-fast), color var(--transition-fast)}.zoom-slider-wrapper:hover .slider-icon{color:var(--accent);opacity:1}#crop-zoom-slider{-webkit-appearance:none;cursor:pointer;height:6px;transition:background var(--transition-fast);background:#ffffff1a;border-radius:3px;outline:none;flex:1}#crop-zoom-slider:hover{background:#ffffff2e}#crop-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);width:16px;height:16px;box-shadow:0 0 10px var(--accent-glow);cursor:pointer;border:2px solid #fff;border-radius:50%;transition:transform .1s,background-color .1s}#crop-zoom-slider::-webkit-slider-thumb:hover{border-color:var(--accent);background:#fff;transform:scale(1.2)}#crop-zoom-slider::-moz-range-thumb{background:var(--accent);width:16px;height:16px;box-shadow:0 0 10px var(--accent-glow);cursor:pointer;border:2px solid #fff;border-radius:50%;transition:transform .1s,background-color .1s}#crop-zoom-slider::-moz-range-thumb:hover{border-color:var(--accent);background:#fff;transform:scale(1.2)}.empty-state-card{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;padding:40px 20px;display:flex}.empty-state-card svg{color:var(--text-muted);margin-bottom:14px}.empty-state-card h4{color:var(--text-primary);margin-bottom:4px;font-size:14px}.empty-state-card p{max-width:220px;font-size:12px;line-height:1.5}.role-badge{text-transform:uppercase;letter-spacing:.3px;border:1px solid #0000;border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:10px;font-weight:700;display:inline-flex}.role-badge.owner{color:#10b981;background:#10b9811a;border-color:#10b9814d}.role-badge.editor{color:#3b82f6;background:#3b82f61a;border-color:#3b82f64d}.role-badge.reader{color:#a78bfa;background:#a78bfa1a;border-color:#a78bfa4d}.share-user-list{flex-direction:column;gap:8px;max-height:200px;margin-top:12px;padding-right:4px;display:flex;overflow-y:auto}.share-user-item{border:1px solid var(--border-color);transition:all var(--transition-fast);background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;display:flex}.share-user-item:hover{background:#ffffff0f}.share-user-info{align-items:center;gap:10px;display:flex}.share-user-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:flex}.share-user-details{flex-direction:column;display:flex}.share-user-name{color:var(--text-primary);font-weight:500}.share-user-role-text{color:var(--text-secondary);font-size:10px}.share-user-actions{align-items:center;gap:8px;display:flex}.share-role-select{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;background:#0000004d;border-radius:6px;padding:4px 8px;font-size:11px}.share-role-select:focus{border-color:var(--accent);outline:none}.share-remove-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.share-remove-btn:hover{color:var(--danger);background:#ef44441a}.share-add-group{grid-template-columns:1fr 110px auto;gap:8px;margin-bottom:18px;display:grid}.ui-locked-overlay{z-index:10;pointer-events:none;border-radius:inherit;background:#08090d66;position:absolute;inset:0}.form-control:disabled,select:disabled,textarea:disabled{opacity:.65;cursor:not-allowed;background:#00000026!important;border-color:#ffffff0a!important}.tree-dropdown-badge{align-items:center;margin-left:6px;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.tree-actions-row{align-items:center;gap:12px;display:flex}.mobile-only{display:none!important}@media (width<=1024px){.mobile-only{display:inline-flex!important}.desktop-only{display:none!important}.app-body{grid-template-columns:1fr;position:relative}.home-dashboard-inner{width:min(100% - 32px,760px);padding:40px 0 64px}.home-section-heading{flex-direction:column;align-items:flex-start;gap:14px}#home-create-tree-btn{justify-content:center;align-self:stretch;width:100%}.sidebar-left{z-index:80;width:280px;height:calc(100dvh - 68px);transition:transform var(--transition-normal);-webkit-backdrop-filter:var(--backdrop-blur);position:fixed;top:68px;left:0;transform:translate(-100%);box-shadow:10px 0 30px #00000080;background:var(--panel-solid-bg)!important}.sidebar-left.open{transform:translate(0)}.sidebar-right{z-index:80;width:100%;max-width:380px;height:calc(100dvh - 68px);transition:transform var(--transition-normal);-webkit-backdrop-filter:var(--backdrop-blur);position:fixed;top:68px;right:0;transform:translate(100%);box-shadow:-10px 0 30px #00000080;background:var(--panel-solid-bg)!important}.sidebar-right.hidden{pointer-events:none;opacity:0;transform:translate(100%);display:block!important}.sidebar-right:not(.hidden){opacity:1;transform:translate(0)}.mobile-overlay{-webkit-backdrop-filter:blur(4px);z-index:75;opacity:0;pointer-events:none;transition:opacity var(--transition-normal);background:#00000080;position:fixed;inset:68px 0 0}.mobile-overlay.active{opacity:1;pointer-events:auto}.app-header{padding:0 16px}.app-header-controls{background:var(--popover-bg);width:240px;-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--border-color);box-shadow:var(--glass-shadow);z-index:95;overscroll-behavior:contain;opacity:0;pointer-events:none;max-height:calc(100dvh - 84px);transition:transform var(--transition-normal), opacity var(--transition-normal);border-radius:12px;flex-direction:column;align-items:stretch;gap:12px;padding:16px;position:absolute;top:68px;right:16px;overflow-y:auto;transform:translateY(-10px)}.app-header-controls.open{opacity:1;pointer-events:auto;transform:translateY(0)}#mobile-menu-toggle{z-index:100;position:relative}.app-header-controls select,.app-header-controls button,.app-header-controls .user-profile-btn{justify-content:flex-start;width:100%;margin-right:0!important}.user-profile-btn{padding:10px 14px}.app-header-controls>div[style*="width: 1px"]{display:none!important}.app-header-controls .header-menu{flex-direction:column;width:100%}.app-header-controls .header-menu-panel{width:100%;min-width:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:none;padding:6px 0 0;display:flex;position:static}.app-header-controls .header-menu-caret{display:none}.canvas-controls-horizontal{top:24px;left:auto;right:24px}.tree-actions-row{justify-content:space-between;gap:8px;width:100%;display:flex}.tree-actions-row button{flex:1;height:44px;justify-content:center!important;width:auto!important}.canvas-controls{bottom:40px;left:24px}}@media (width<=768px){.sidebar-right{max-width:100%}.app-brand #storage-status-badge{display:none!important}.app-brand h1{font-size:15px}}.readable-container{background-color:var(--bg-secondary);color:var(--text-primary);z-index:45;flex-direction:column;animation:.3s ease-out fadeIn;display:flex;position:absolute;inset:0;overflow:hidden}.readable-content{flex:1;width:100%;max-width:720px;margin:0 auto;padding:24px 16px 40px;position:relative;overflow-y:auto}@media (width>=600px){.readable-content{padding:32px 24px 48px}}.readable-search-section{margin-bottom:24px;position:relative}.readable-search-input{width:100%;font-size:18px;font-family:var(--font-family);border:2px solid var(--border-color);color:var(--text-primary);transition:all var(--transition-fast);background:#00000040;border-radius:12px;outline:none;padding:16px 20px}.readable-search-input:focus{border-color:var(--accent);box-shadow:0 0 16px var(--accent-glow);background:#00000059}.readable-search-results{-webkit-backdrop-filter:var(--backdrop-blur);border:2px solid var(--border-color);z-index:90;background:#0f111afa;border-radius:12px;width:100%;max-height:250px;margin-top:6px;position:absolute;overflow-y:auto;box-shadow:0 10px 30px #0009}.readable-search-result-row{cursor:pointer;border-bottom:1px solid var(--border-color);transition:background var(--transition-fast);align-items:center;gap:16px;padding:14px 20px;display:flex}.readable-search-result-row:last-child{border-bottom:none}.readable-search-result-row:hover{background:#6366f11a}.readable-search-result-avatar{color:#fff;background-position:50%;background-size:cover;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex}.readable-search-result-info{flex:1;min-width:0}.readable-search-result-name{color:var(--text-primary);font-size:16px;font-weight:600}.readable-search-result-dates{color:var(--text-secondary);margin-top:1px;font-size:13px}.readable-profile-card{background:var(--panel-bg);-webkit-backdrop-filter:var(--backdrop-blur);border:2px solid var(--border-color);text-align:center;box-shadow:var(--glass-shadow);border-radius:16px;flex-direction:column;align-items:center;margin-bottom:32px;padding:24px 20px;display:flex}@media (width>=600px){.readable-profile-card{padding:32px}}.readable-profile-photo{border:3px solid var(--border-color);color:#fff;width:120px;height:120px;transition:transform var(--transition-fast);background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;font-size:38px;font-weight:700;display:flex;position:relative;box-shadow:0 10px 25px #0006}.readable-profile-photo:hover{transform:scale(1.04)}.readable-profile-photo.is-editable{appearance:none;cursor:pointer;padding:0;font-family:inherit}.readable-profile-photo.is-editable:focus-visible{outline:3px solid var(--accent);outline-offset:4px}.readable-avatar-edit-badge{border:3px solid var(--bg-secondary);background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex;position:absolute;bottom:1px;right:1px;box-shadow:0 4px 10px #0f172a47}.readable-profile-name{color:var(--text-primary);flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin-bottom:6px;font-size:26px;font-weight:700;display:flex}.readable-profile-dates{color:var(--text-secondary);margin-bottom:12px;font-size:20px;font-weight:600}.readable-profile-details{color:var(--text-secondary);flex-direction:column;align-items:center;gap:6px;width:100%;margin-bottom:20px;font-size:15px;display:flex}.readable-detail-badge{border:1px solid var(--border-color);background:#ffffff0a;border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:13px;font-weight:500;display:inline-flex}.readable-profile-bio{color:var(--text-primary);border:1.5px solid var(--border-color);text-align:left;background:#0003;border-radius:12px;width:100%;margin-top:10px;padding:18px 20px;font-size:17px;line-height:1.6}.readable-section-title{text-transform:uppercase;color:var(--accent);letter-spacing:.8px;border-left:4px solid var(--accent);align-items:center;margin-bottom:14px;padding-left:10px;font-size:16px;font-weight:700;display:flex}.readable-grid-relatives{grid-template-columns:1fr;gap:12px;margin-bottom:28px;display:grid}@media (width>=600px){.readable-grid-relatives{grid-template-columns:repeat(2,1fr)}}.readable-relative-btn{border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);text-align:left;-webkit-user-select:none;user-select:none;background:#ffffff08;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;display:flex}.readable-relative-btn:hover{border-color:var(--accent);background:#6366f10f;transform:translateY(-2px);box-shadow:0 6px 15px #6366f11f}.readable-relative-btn:active{transform:translateY(0)}.readable-relative-avatar{color:#fff;background-position:50%;background-size:cover;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:14px;font-weight:700;display:flex}.readable-relative-info{flex:1;min-width:0}.readable-relative-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.3px;margin-bottom:1px;font-size:11px;font-weight:700}.readable-relative-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:17px;font-weight:600;overflow:hidden}.readable-relative-dates{color:var(--text-secondary);margin-top:1px;font-size:13px}.readable-empty-relative{color:var(--text-muted);border:1px dashed var(--border-color);background:#ffffff03;border-radius:10px;margin-bottom:28px;padding:10px 14px;font-size:15px;font-style:italic}.readable-nav-bar{width:100%;max-width:720px;-webkit-backdrop-filter:var(--backdrop-blur);border-top:2px solid var(--border-color);z-index:50;background:#0f111af2;justify-content:space-between;align-items:center;gap:12px;margin:0 auto;padding:16px;display:flex}@media (width>=600px){.readable-nav-bar{padding:16px 24px}.readable-nav-btn{flex:1 1 0;max-width:320px}}.readable-nav-btn{cursor:pointer;transition:all var(--transition-fast);border:1.5px solid var(--border-color);color:var(--text-primary);text-align:center;-webkit-user-select:none;user-select:none;background:#ffffff0d;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:8px;height:48px;padding:14px 20px;font-size:16px;font-weight:600;display:inline-flex}.readable-nav-btn:hover{background:#ffffff1a;border-color:#fff3}.readable-nav-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.readable-nav-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 10px var(--accent-glow)}.readable-nav-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 4px 18px var(--accent-glow)}.readable-edit-btn{width:100%;max-width:240px;height:44px;margin-top:20px;padding:8px 16px;font-size:15px}#btn-readable-edit.readable-nav-btn.primary,#btn-readable-locate.readable-nav-btn.primary{background:var(--accent);background-color:var(--accent);border-color:var(--accent);color:#fff}.mobile-sidebar-toggle-fab{z-index:55;background:var(--control-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:none;position:absolute;bottom:40px;right:24px;box-shadow:0 4px 15px #0006}.crop-viewport{border:1.5px solid var(--border-color);-webkit-user-select:none;user-select:none;background:#0000004d;border-radius:12px;width:280px;height:280px;position:relative;overflow:hidden}.crop-frame-overlay{width:200px;height:200px;box-shadow:0 0 0 280px var(--cropper-overlay-bg);pointer-events:none;z-index:5;border:2px dashed #fffc;border-radius:50%;position:absolute;top:40px;left:40px}#crop-zoom-slider{background:var(--slider-bg);-webkit-appearance:none;cursor:pointer;border-radius:3px;outline:none;flex:1;height:6px}.status-badge{border:1px solid var(--border-color);color:var(--text-primary);background:#ffffff14;border-radius:20px;align-items:center;gap:4px;margin-left:12px;padding:4px 8px;font-size:11px;font-weight:600;display:flex}[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#f1f5f9;--panel-bg:#ffffffbf;--border-color:#0f172a14;--border-glow:#6366f114;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent:#4f46e5;--accent-hover:#3730a3;--accent-glow:#4f46e526;--male-color:#2563eb;--male-bg:#2563eb0d;--male-border:#2563eb40;--male-glow:#2563eb1a;--female-color:#db2777;--female-bg:#db27770d;--female-border:#db277740;--female-glow:#db27771a;--other-color:#7c3aed;--other-bg:#7c3aed0d;--other-border:#7c3aed40;--other-glow:#7c3aed1a;--danger:#dc2626;--danger-hover:#b91c1c;--shadow-lg:0 10px 25px -5px #94a3b826, 0 8px 10px -6px #94a3b826;--glass-shadow:0 8px 32px 0 #94a3b81f;--panel-solid-bg:#f8fafcf5;--popover-bg:#fffffff5;--overlay-bg:#0f172a66;--footer-bg:#0f172a0a;--slider-bg:#0f172a1a;--control-bg:#ffffffd9;--cropper-overlay-bg:#f8fafcbf;--bg-panel:#fff;--bg-input:#f1f5f9}[data-theme=light] .form-control{color:#0f172a;background:#fffc;border-color:#0f172a26}[data-theme=light] .form-control:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px #6366f126}[data-theme=light] .btn-secondary{color:var(--text-primary);background-color:#0f172a0a;border-color:#0f172a14}[data-theme=light] .btn-secondary:hover{background-color:#0f172a14}[data-theme=light] .btn-icon{color:var(--text-secondary);background-color:#0f172a08;border-color:#0f172a14}[data-theme=light] .btn-icon:hover{color:var(--text-primary);background-color:#0f172a0f}[data-theme=light] .auth-container{background:radial-gradient(circle at 100% 0,#6366f10f,#0000 45%),radial-gradient(circle at 0 100%,#ec48990a,#0000 40%),#f8fafc}[data-theme=light] .member-row:hover{background:#0f172a05;border-color:#0f172a0a}[data-theme=light] .member-row.active{background:#6366f10f;border-color:#6366f126}[data-theme=light] .stat-item{background:#0f172a03}[data-theme=light] .search-input{color:var(--text-primary);background:#0f172a0a}[data-theme=light] .sidebar-left,[data-theme=light] .sidebar-right{background:#fff6}[data-theme=light] .app-header{background:#fffc}[data-theme=light] .modal-backdrop{background:#0f172a73}[data-theme=light] .parent-connection{stroke:#0f172a2e}[data-theme=light] .descending-connection,[data-theme=light] .child-connection,[data-theme=light] .sibling-connection{stroke:#0f172a26}[data-theme=light] .family-node-card{box-shadow:0 4px 12px #0f172a14}[data-theme=light] .family-node-card:hover{border-color:#0f172a26;box-shadow:0 8px 20px #0f172a1f}[data-theme=light] .readable-search-input{background:#fffc;border-color:#0f172a26}[data-theme=light] .readable-search-input:focus{box-shadow:0 0 16px var(--accent-glow);background:#fffffff2}[data-theme=light] .readable-search-results{background:#fffffffa;box-shadow:0 10px 30px #0f172a1f}[data-theme=light] .readable-search-result-row:hover{background:#6366f10f}[data-theme=light] .readable-profile-photo{box-shadow:0 10px 25px #0f172a1a}[data-theme=light] .readable-profile-bio,[data-theme=light] .readable-relative-btn{background:#0f172a08}[data-theme=light] .readable-relative-btn:hover{background:#6366f10d}[data-theme=light] .readable-empty-relative{background:#0f172a03}[data-theme=light] .readable-nav-bar{background:#fffffff2;border-top-color:#0f172a14}[data-theme=light] .readable-nav-btn{background:#0f172a0a;border-color:#0f172a14}[data-theme=light] .readable-nav-btn:hover{background:#0f172a14;border-color:#0f172a26}[data-theme=light] .readable-nav-btn.primary{background:var(--accent);background-color:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 10px var(--accent-glow)}[data-theme=light] .readable-nav-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 4px 18px var(--accent-glow)}.form-control option{background-color:var(--bg-secondary);color:var(--text-primary)}[data-theme=light] .crop-viewport{background:#0f172a0d}[data-theme=light] .crop-frame-overlay{border-color:#0f172a99}[data-theme=light] .status-badge{background:#0f172a0d}.album-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;padding:4px;display:grid;overflow-y:auto}.album-card{border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);background:#ffffff05;border-radius:12px;flex-direction:column;gap:8px;min-height:180px;padding:10px;display:flex}.album-card:hover{border-color:var(--accent);background:#ffffff0d;transform:translateY(-2px);box-shadow:0 4px 15px #6366f126}.album-card-img-wrapper{aspect-ratio:1;background:#0003;border-radius:8px;width:100%;overflow:hidden}.album-card-img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-normal)}.album-card:hover .album-card-img{transform:scale(1.05)}.album-card-caption{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.album-card-meta{color:var(--text-muted);font-size:10px}.upload-dropzone{border:2px dashed var(--border-color);text-align:center;cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary);background:#ffffff03;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:24px;font-size:13px;display:flex}.upload-dropzone:hover,.upload-dropzone.dragover{border-color:var(--accent);color:var(--text-primary);background:#6366f10d}.tag-checkbox-list{border:1px solid var(--border-color);background:#00000026;border-radius:8px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px;max-height:140px;padding:10px;display:grid;overflow-y:auto}.tag-checkbox-item{color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast);border-radius:4px;align-items:center;gap:8px;padding:4px 6px;font-size:13px;display:flex}.tag-checkbox-item:hover{color:var(--text-primary);background:#ffffff08}.tag-checkbox-item input[type=checkbox]{accent-color:var(--accent);cursor:pointer}.tagged-member-pill{border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;background:#ffffff0a;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;display:inline-flex}.tagged-member-pill:hover{border-color:var(--accent);background:#6366f114;transform:translateY(-1px);box-shadow:0 2px 8px #6366f126}.tagged-member-pill .pill-avatar{color:#fff;background-position:50%;background-size:cover;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex}[data-theme=light] .album-card{background:#0f172a05;border-color:#0f172a14}[data-theme=light] .album-card:hover{background:#0f172a0a}[data-theme=light] .upload-dropzone{background:#0f172a03;border-color:#0f172a1a}[data-theme=light] .upload-dropzone:hover{background:#6366f108}[data-theme=light] .tag-checkbox-list{background:#0f172a08;border-color:#0f172a1a}[data-theme=light] .tagged-member-pill{background:#0f172a08;border-color:#0f172a14}[data-theme=light] .tagged-member-pill:hover{background:#6366f10d}.tour-highlight{pointer-events:none;position:relative;z-index:11999!important;box-shadow:0 0 0 9999px #00000073, 0 0 15px var(--accent)!important;border-color:var(--accent)!important}.relation-combobox{position:relative}.relation-select-hidden{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.relation-combobox-list{z-index:60;background:var(--popover-bg,var(--bg-secondary,#1e1e2a));border:1px solid var(--border-color);max-height:240px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border-radius:10px;padding:4px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.relation-combobox-list[hidden]{display:none}.relation-combobox-option{cursor:pointer;color:var(--text-primary);border-radius:7px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:flex}.relation-combobox-option:hover,.relation-combobox-option.is-active{background:var(--accent-soft,#6366f129)}.relation-combobox-option .opt-sub{color:var(--text-secondary);margin-left:auto;font-size:11px}.relation-combobox-empty{color:var(--text-secondary);text-align:center;padding:10px;font-size:12px}.relation-children-list{flex-direction:column;gap:6px;display:flex}.relation-child-row{border:1px solid var(--border-color);background:var(--bg-secondary,#ffffff08);border-radius:8px;align-items:center;gap:8px;padding:7px 10px;font-size:13px;display:flex}.relation-child-row .child-name{text-overflow:ellipsis;white-space:nowrap;cursor:pointer;flex:auto;overflow:hidden}.relation-child-row .child-sub{color:var(--text-secondary);font-size:11px}.relation-child-detach{width:24px;height:24px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:none;justify-content:center;align-items:center;line-height:1;display:inline-flex}.relation-child-detach:hover{color:#ef4444;background:#ef444426}.relation-children-empty{color:var(--text-secondary);padding:2px 2px 4px;font-size:12px}#edit-add-child-combobox{margin-top:8px}
