:root{--r-sm: 7px;--r-md: 10px;--r-lg: 14px;--r-xl: 22px;--font-sans: "Inter", ui-sans-serif, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--ease: cubic-bezier(.16, 1, .3, 1);--bg: #f4f5f9;--bg-soft: #eef0f6;--surface: #ffffff;--surface-2: #f7f8fc;--surface-3: #eef0f8;--border: rgba(28, 36, 68, .11);--border-strong: rgba(28, 36, 68, .22);--text: #171a26;--text-2: #3d4259;--muted: #6b7189;--faint: #9aa0b5;--accent: #5a50f5;--accent-strong: #4a40e8;--accent-soft: rgba(90, 80, 245, .1);--accent-text: #4a40e8;--shadow: 0 18px 50px -12px rgba(28, 32, 64, .22);--shadow-sm: 0 4px 16px -4px rgba(28, 32, 64, .1);--scrim: rgba(20, 24, 40, .32);--male: #3d7bd6;--female: #cf5b96}:root[data-theme=dark]{--bg: #0a0b0f;--bg-soft: #0f1118;--surface: #14161f;--surface-2: #1a1d29;--surface-3: #222637;--border: rgba(148, 158, 190, .13);--border-strong: rgba(148, 158, 190, .26);--text: #e8eaf2;--text-2: #b9bfd3;--muted: #828aa3;--faint: #5b6178;--accent: #6c63ff;--accent-strong: #5a50f5;--accent-soft: rgba(108, 99, 255, .14);--accent-text: #a8a3ff;--shadow: 0 18px 50px -12px rgba(0, 0, 0, .65);--shadow-sm: 0 4px 18px -4px rgba(0, 0, 0, .4);--scrim: rgba(5, 6, 10, .55);--male: #5b9bff;--female: #e87bb6}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);color:var(--text);background:var(--bg);font-size:13.5px;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}button{font-family:inherit}input,textarea,[contenteditable=true]{-webkit-user-select:text;user-select:text}.app{height:var(--app-h, 100vh);display:flex;flex-direction:column}.topbar{position:relative;height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 18px;background:var(--bg-soft);border-bottom:1px solid var(--border)}.topbar-right{display:flex;align-items:center;gap:10px}.people-count{color:var(--muted);font-size:12px;white-space:nowrap}.brand{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text);white-space:nowrap}.brand .leaf{font-size:18px}.tabs{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:3px}.tab{border:0;background:transparent;color:var(--muted);font-weight:600;font-size:12.5px;padding:6px 14px;border-radius:var(--r-sm);cursor:pointer;transition:all .15s ease}.tab:hover{color:var(--text-2)}.tab.active{background:var(--accent-soft);color:var(--accent-text)}.spacer{flex:1}.search-affordance{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;width:360px;max-width:36vw;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);color:var(--muted);cursor:pointer;transition:border-color .15s ease}.search-affordance:hover{border-color:var(--accent);color:var(--text-2)}.search-affordance .ph{flex:1;text-align:left}.kbd{font-family:var(--font-mono);font-size:10px;padding:2px 6px;border:1px solid var(--border);border-radius:5px;color:var(--faint)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);color:var(--text-2);cursor:pointer;font-size:15px;transition:all .15s ease}.icon-btn:hover{border-color:var(--accent);color:var(--accent-text)}.avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;cursor:pointer;border:none}.tweaks-wrap{position:relative}.tweaks-pop{position:absolute;right:0;top:calc(100% + 8px);z-index:80;width:220px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:12px}.tweaks-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin:2px 0 8px}.seg{display:flex;gap:4px}.seg button{flex:1;padding:7px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);border-radius:var(--r-sm);cursor:pointer;font-size:12px;transition:all .15s ease}.seg button.on{background:var(--accent-soft);color:var(--accent-text);border-color:transparent}.seg-wide button{padding:10px;font-size:13px;font-weight:600}.main{flex:1;min-height:0;position:relative}.placeholder-view{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted)}.placeholder-view .big{font-size:40px}.placeholder-view .pill{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--faint);border:1px solid var(--border);border-radius:999px;padding:4px 12px}.tree-wrap{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background-color:transparent;touch-action:none;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:22px 22px;cursor:grab}.tree-wrap:active{cursor:grabbing}.view-switch{position:absolute;top:14px;left:14px;z-index:6;display:flex;flex-direction:column;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);padding:4px}.view-switch button{width:32px;height:32px;border:0;background:transparent;color:var(--muted);border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.view-switch button:hover{background:var(--surface-3);color:var(--text)}.view-switch button.on{background:var(--accent-soft);color:var(--accent-text)}.canvas-controls{position:absolute;top:138px;left:14px;z-index:5;display:flex;flex-direction:column;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);padding:4px}.canvas-controls button{width:32px;height:32px;border:0;background:transparent;color:var(--muted);border-radius:var(--r-sm);cursor:pointer;font-size:16px;transition:all .15s ease}.canvas-controls button:hover{background:var(--surface-3);color:var(--text)}.canvas-add{position:absolute;top:14px;right:14px;z-index:5;background:var(--accent);color:#fff;border:0;border-radius:var(--r-md);padding:8px 14px;font-weight:600;font-size:12.5px;cursor:pointer;box-shadow:var(--shadow-sm)}.tree-layer{position:absolute;transform-origin:0 0}.tree-links{position:absolute;top:0;left:0;overflow:visible;pointer-events:none}.link.parent{fill:none;stroke:var(--border-strong);stroke-width:2}.link.spouse{stroke:var(--accent);stroke-width:2;stroke-dasharray:4 5;opacity:.7}.famlink path{fill:none;stroke:var(--border-strong);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.person-card{position:absolute;display:flex;flex-direction:column;align-items:center;text-align:center;gap:3px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:42px 12px 14px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.person-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.person-card.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft),var(--shadow-sm)}.person-card.blood{box-shadow:0 0 0 2px var(--accent),var(--shadow);z-index:2;opacity:.85}.person-card.focus{box-shadow:0 0 0 3px var(--accent),0 0 0 8px var(--accent-soft),var(--shadow);transform:translateY(-2px) scale(1.04);z-index:4;opacity:1}.person-card.dim{opacity:.26;filter:saturate(.45)}.tree-layer.smooth{transition:transform .4s var(--ease)}.person-card{transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,opacity .2s ease}.person-card.deceased{opacity:.92}.person-card .pavatar{position:absolute;top:-33px;left:50%;transform:translate(-50%);width:66px;height:66px;border-radius:50%;background:var(--surface-3);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:23px;overflow:hidden;border:3px solid var(--muted);box-shadow:var(--shadow-sm)}.person-card.male .pavatar{border-color:var(--male)}.person-card.female .pavatar{border-color:var(--female)}.person-card .pavatar img{width:100%;height:100%;object-fit:cover}.person-card .pname{font-weight:600;font-size:14px;line-height:1.2;color:var(--text)}.person-card .pyears{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.cmdk-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;background:var(--scrim);display:flex;align-items:flex-start;justify-content:center;padding-top:14vh}.cmdk-box{width:580px;max-width:calc(100vw - 32px);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden}.cmdk-input-row{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);color:var(--muted)}.cmdk-input{flex:1;border:0;background:transparent;outline:none;font-size:15px;color:var(--text);font-family:var(--font-sans)}.cmdk-body{padding:22px 16px;color:var(--faint);font-size:13px;text-align:center}.panel-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:var(--scrim);opacity:0;transition:opacity .3s var(--ease)}.panel-scrim.show{opacity:1}.side-panel{position:fixed;top:16px;bottom:16px;right:16px;z-index:95;width:calc(100% - 32px);max-width:560px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);display:flex;flex-direction:column;transform:translate(120%);opacity:0;transition:transform .3s var(--ease),opacity .3s var(--ease),max-width .25s var(--ease),inset .25s var(--ease)}.side-panel.show{transform:translate(0);opacity:1}.side-panel.large{top:32px;right:32px;bottom:32px;left:32px;max-width:none;width:auto}.side-panel.large .panel-body{padding:22px clamp(22px,7vw,140px)}.side-panel.large .media-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.panel-head{height:64px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 22px;border-bottom:1px solid var(--border)}.panel-head h3{margin:0;font-size:16px;font-weight:600;color:var(--text)}.panel-body{flex:1;overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column;gap:10px}.panel-body .row{display:flex;justify-content:space-between;font-size:13.5px}.panel-body .row .k{color:var(--muted)}.panel-body .row .v{color:var(--text);font-weight:500}.person-hero{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:6px}.person-hero .hero-avatar{width:84px;height:84px;border-radius:50%;overflow:hidden;background:var(--surface-3);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:30px;border:3px solid var(--muted)}.person-hero .hero-avatar.male{border-color:var(--male)}.person-hero .hero-avatar.female{border-color:var(--female)}.person-hero .hero-avatar img{width:100%;height:100%;object-fit:cover}.person-hero .hero-nick{color:var(--muted);font-size:13px}.person-hero .hero-avatar.big{width:112px;height:112px;font-size:40px}.person-hero .hero-name{font-size:17px;font-weight:700;color:var(--text);text-align:center}.hero-photo{position:relative;display:inline-block;margin-top:6px}.hero-photo.drop .hero-avatar{outline:2px dashed var(--accent);outline-offset:3px}.person-hero .hero-avatar.big img{transform-origin:center}.hero-photo-tools{position:absolute;top:-4px;right:-10px;display:flex;align-items:center;gap:1px;padding:3px;border-radius:999px;background:var(--accent);border:2px solid var(--surface);box-shadow:var(--shadow-sm);opacity:0;transform:scale(.9);transform-origin:top right;transition:opacity .12s ease,transform .12s ease}.hero-photo:hover .hero-photo-tools{opacity:1;transform:scale(1)}.hero-photo-tools button{width:24px;height:24px;border:0;background:transparent;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.hero-photo-tools button:hover{background:#ffffff38}.link-name{border:0;background:transparent;color:var(--accent);font:inherit;cursor:pointer;padding:0}.link-name:hover{text-decoration:underline}.panel-body .row .v{text-align:right}.panel-bio{color:var(--text-2);font-size:13.5px;line-height:1.5;margin:4px 0 0}.panel-sec{margin-top:8px;padding-top:10px;border-top:1px solid var(--border)}.panel-sec .sec-title{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin-bottom:6px}.panel-sec .sec-item{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text);padding:3px 0}.panel-sec .sec-item svg{color:var(--muted);flex-shrink:0}.panel-sec .sec-item span{flex:1}.sec-del{margin-left:auto;border:0;background:transparent;color:var(--faint);cursor:pointer;padding:2px;border-radius:5px;display:flex;opacity:0;transition:opacity .12s ease}.panel-sec .sec-item:hover .sec-del{opacity:1}.sec-del:hover{color:#e0586e;background:var(--surface-3)}.media-cell{position:relative}.media-del{position:absolute;top:4px;right:4px;width:20px;height:20px;border:0;border-radius:50%;background:#0000008c;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .12s ease}.media-cell:hover .media-del{opacity:1}.panel-tabs{display:flex;gap:2px;padding:0 10px;border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}.panel-tabs button{border:0;background:transparent;color:var(--muted);padding:11px 9px;font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}.panel-tabs button:hover{color:var(--text)}.panel-tabs button.on{color:var(--accent);border-bottom-color:var(--accent)}.tab-add{margin-bottom:12px}.add-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;border:1px dashed var(--border-strong);background:transparent;color:var(--text-2);border-radius:var(--r-md);padding:9px 12px;font:inherit;font-size:13px;font-weight:600;cursor:pointer}.add-btn:hover{border-color:var(--accent);color:var(--accent)}.tab-empty{color:var(--muted);font-size:13px;padding:8px 2px}.timeline{padding-left:4px}.tl-item{position:relative;padding:0 22px 16px 20px;border-left:2px solid var(--border)}.tl-item:last-child{border-left-color:transparent;padding-bottom:2px}.tl-dot{position:absolute;left:-6px;top:2px;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--surface)}.tl-year{font-size:11.5px;color:var(--accent);font-weight:700}.tl-title{font-size:13.5px;color:var(--text)}.tl-sub{color:var(--muted);font-weight:400}.tl-head{display:flex;align-items:center;gap:6px;width:100%;padding:0 16px 0 0;background:transparent;border:0;cursor:pointer;text-align:left;color:var(--text)}.tl-head .tl-title{font-weight:600}.tl-head.static{cursor:default}.tl-chev{margin-left:auto;color:var(--muted);flex-shrink:0;transition:transform .15s ease}.tl-chev.rot{transform:rotate(180deg)}.tl-detail{margin-top:6px;padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;display:grid;gap:4px}.tl-detail .tl-row{display:flex;justify-content:space-between;gap:12px;font-size:12.5px}.tl-detail .tl-row .k{color:var(--muted)}.tl-detail .tl-row .v{color:var(--text);text-align:right}.tl-item .sec-del{position:absolute;right:0;top:0;opacity:0}.tl-item .sec-edit{position:absolute;right:22px;top:0;opacity:0;border:0;background:transparent;color:var(--faint);cursor:pointer;padding:2px;border-radius:5px;display:flex;transition:opacity .12s ease}.tl-item .sec-edit:hover{color:var(--accent);background:var(--surface-3)}.tl-item:hover .sec-del,.tl-item:hover .sec-edit{opacity:1}.story-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;margin-bottom:8px}.story-head{display:flex;align-items:center;gap:7px;font-size:13.5px;color:var(--text)}.story-head svg{color:var(--muted);flex-shrink:0}.story-head .story-year{color:var(--accent);font-weight:700;font-size:12px}.story-head .sec-del{margin-left:auto;opacity:0}.story-card:hover .sec-del{opacity:1}.story-body{color:var(--text-2);font-size:13px;line-height:1.6;margin:6px 0 0}.story-body .msg-pill{font-size:12.5px;vertical-align:baseline}.story-transcript{margin-top:8px;font-size:12px;color:var(--muted)}.story-transcript summary{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-2)}.story-transcript[open]{line-height:1.5}.loc-kind{margin-left:auto;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.rel-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;border:0;background:transparent;color:var(--text);padding:8px;border-radius:var(--r-sm);font:inherit;font-size:13.5px;cursor:pointer}.rel-item:hover{background:var(--surface-3);color:var(--accent)}.rel-item svg{color:var(--muted)}.rel-item:hover svg{color:var(--accent)}.sselect{position:relative}.sselect-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;font:inherit;color:var(--text);cursor:pointer}.sselect-trigger .ph{color:var(--faint)}.sselect-trigger svg{color:var(--muted)}.sselect-pop{position:absolute;z-index:50;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow);overflow:hidden}.sselect-search{display:flex;align-items:center;gap:7px;padding:8px 10px;border-bottom:1px solid var(--border)}.sselect-search svg{color:var(--muted)}.sselect-search input{flex:1;border:0;background:transparent;outline:none;font:inherit;color:var(--text)}.sselect-list{max-height:220px;overflow-y:auto;padding:4px}.sselect-opt{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;border:0;background:transparent;color:var(--text);padding:8px 10px;border-radius:var(--r-sm);font:inherit;font-size:13px;cursor:pointer}.sselect-opt:hover{background:var(--surface-3)}.sselect-opt.on{color:var(--accent)}.sselect-opt.create{color:var(--accent);gap:7px;justify-content:flex-start;border-top:1px solid var(--border)}.sselect-opt svg{color:var(--accent)}.sselect-empty{padding:10px;color:var(--muted);font-size:13px;text-align:center}.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.media-grid img,.media-grid video{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border);display:block}.media-grid video{background:#000}.seg-toggle{display:flex;gap:4px}.seg-toggle button{flex:1;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);border-radius:var(--r-sm);padding:7px;font:inherit;font-size:13px;font-weight:600;cursor:pointer}.seg-toggle button.on{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.panel-foot{height:72px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 22px;border-top:1px solid var(--border)}.btn{border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);border-radius:var(--r-md);padding:9px 14px;font-weight:600;cursor:pointer;font-size:13px}.btn.primary{background:var(--accent);color:#fff;border-color:transparent}.btn.danger{background:transparent;color:#e0586e;border-color:#e0586e66}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--faint)}.field input,.field select,.field textarea{padding:9px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font:inherit;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field2{display:flex;gap:10px}.field2 .field{flex:1}.add-chips{display:flex;flex-wrap:wrap;gap:6px}.add-chips button{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);border-radius:var(--r-md);padding:6px 10px;font-size:12.5px;font-weight:600;cursor:pointer}.add-chips button.on{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.add-form{display:flex;flex-direction:column;gap:7px;margin-top:10px}.add-form input,.add-form select,.add-form textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;font:inherit;color:var(--text);resize:vertical}.add-form input:focus,.add-form select:focus,.add-form textarea:focus{outline:none;border-color:var(--accent)}.add-dates{display:flex;gap:6px}.add-dates select,.add-dates>.sselect{flex:1 1 0;min-width:0}.add-form select:disabled{opacity:.5;cursor:not-allowed}.add-actions{display:flex;gap:6px;justify-content:flex-end}.btn.ghost{background:transparent}.btn.primary{display:inline-flex;align-items:center;justify-content:center;gap:6px}.fab-cluster{position:fixed;bottom:24px;right:24px;z-index:60;display:flex;align-items:center}.chat-fab{position:relative;width:56px;height:56px;border-radius:50%;border:4px solid var(--bg);background:var(--text);color:var(--bg);box-shadow:var(--shadow);cursor:pointer;font-size:22px;display:flex;align-items:center;justify-content:center;transition:transform .15s ease}.chat-fab:hover{transform:scale(1.06)}.mic-slot{width:0;display:flex;align-items:center;justify-content:flex-start;transition:width .22s var(--ease)}.fab-cluster:hover .mic-slot,.fab-cluster.holding .mic-slot{width:64px}.fab-cluster .mic-fab{flex:none;width:52px;height:52px;border-radius:50%;border:4px solid var(--bg);background:var(--accent);color:#fff;box-shadow:var(--shadow);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.7);pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease)}.fab-cluster:hover .mic-fab,.fab-cluster.holding .mic-fab{opacity:1;transform:scale(1);pointer-events:auto}.chat-win{position:fixed;z-index:60;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;transform-origin:bottom right;transition:all .3s var(--ease)}.chat-win.closed{transform:scale(.9);opacity:0;pointer-events:none}.chat-win.floating{bottom:92px;right:24px;width:min(calc(100vw - 48px),400px);height:min(600px,80vh)}.chat-win.docked{bottom:16px;right:16px;width:min(calc(100vw - 32px),600px);height:calc(100vh - 32px)}.chat-win.large{top:32px;right:32px;bottom:32px;left:32px;width:auto;height:auto}.chat-head{height:60px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--border)}.chat-head .title{font-weight:600;display:flex;align-items:center;gap:8px}.chat-head .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}.chat-head .ctrls{display:flex;gap:2px}.chat-head .ctrls button{width:32px;height:32px;border:0;background:transparent;color:var(--muted);border-radius:var(--r-sm);cursor:pointer;font-size:15px;transition:all .15s ease}.chat-head .ctrls button:hover{background:var(--surface-3);color:var(--text)}.chat-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}.bubble{max-width:86%;padding:9px 13px;border-radius:var(--r-lg);font-size:13.5px;line-height:1.5;white-space:pre-wrap;box-shadow:var(--shadow-sm)}.bubble.user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:var(--r-sm)}.bubble.assistant{align-self:flex-start;background:var(--surface-2);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:var(--r-sm)}.bubble.error{align-self:flex-start;background:#e0586e1f;color:#e0586e;border:1px solid rgba(224,88,110,.3);border-radius:var(--r-md)}.bubble.typing{opacity:.6}.tool-pill{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent-text);border:1px solid var(--border)}.tool-foot{align-self:flex-start;margin:2px 0 2px 2px}.tool-foot-summary{display:inline-flex;align-items:center;gap:6px;border:0;background:transparent;color:var(--muted);font:inherit;font-size:11px;cursor:pointer;padding:3px 6px;border-radius:var(--r-sm)}.tool-foot-summary:hover{color:var(--text-2);background:var(--surface-3)}.tool-foot-summary>svg:first-child{color:#1ba94c}.tool-foot-summary .rot{transform:rotate(180deg)}.tool-foot-list{display:flex;flex-direction:column;align-items:flex-start;gap:3px;margin:4px 0 0 4px}@property --ft-angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}@keyframes ft-spin{to{--ft-angle: 360deg}}.chat-input{padding:12px;border-top:1px solid var(--border)}.chat-context-row{display:flex;flex-wrap:wrap;gap:5px;padding:0 2px 8px}.ctx-pill{display:inline-flex;align-items:center;gap:5px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:3px 6px 3px 10px;font-size:12px;font-weight:600;cursor:pointer}.ctx-pill.soft{background:var(--surface-2);color:var(--muted);border-color:var(--border);padding-right:10px}.ctx-pill button{display:flex;border:0;background:transparent;color:inherit;cursor:pointer;padding:1px;border-radius:50%}.ctx-pill button:hover{background:#00000024}.msg-pill{display:inline-flex;align-items:center;background:var(--accent-soft);color:var(--accent);border-radius:6px;padding:0 5px;font-weight:600;cursor:pointer;white-space:nowrap}.msg-pill:hover{text-decoration:underline}.bubble.user .msg-pill{background:#ffffff42;color:#fff}.msg-pill.pill-place{background:color-mix(in srgb,var(--female) 16%,transparent);color:var(--female)}.msg-pill.pill-event{background:color-mix(in srgb,var(--male) 16%,transparent);color:var(--male)}.msg-pill.static{cursor:default}.msg-pill.static:hover{text-decoration:none}.ctx-menu{position:fixed;z-index:200;min-width:174px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow);padding:5px;display:flex;flex-direction:column;gap:2px}.ctx-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:0;background:transparent;color:var(--text);padding:8px 10px;border-radius:var(--r-sm);font:inherit;font-size:13px;cursor:pointer}.ctx-item:hover{background:var(--surface-3)}.ctx-item.danger{color:#e0586e}.ctx-item svg{color:var(--muted)}.ctx-item.danger svg{color:#e0586e}.chat-input-box{position:relative;display:flex;align-items:flex-end;gap:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:5px 5px 5px 4px;transition:border-color .15s ease,box-shadow .15s ease}.chat-input-box:focus-within{border-color:var(--border-strong);box-shadow:0 0 0 2px var(--accent-soft)}.chat-input-box.thinking:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:calc(var(--r-lg) + 2px);padding:2px;background:conic-gradient(from var(--ft-angle),transparent 0deg,#3b82f6 70deg,#a855f7 150deg,transparent 220deg,transparent 360deg);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;animation:ft-spin 2.4s linear infinite;pointer-events:none}.chat-input-box textarea{flex:1;resize:none;height:40px;max-height:120px;background:transparent;border:0;outline:none;padding:8px;font:inherit;color:var(--text)}.chat-input-box .send{width:38px;height:38px;flex-shrink:0;border:0;border-radius:var(--r-md);background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.chat-input-box .send:disabled{background:var(--surface-3);color:var(--faint);cursor:default}@media(prefers-reduced-motion:reduce){.chat-input-box.thinking:before{animation-duration:8s}}.no-scrollbar::-webkit-scrollbar,.chat-log::-webkit-scrollbar,.panel-body::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}::-webkit-scrollbar-track{background:transparent}.voice-pick{display:flex;gap:8px;align-items:center}.voice-pick select{flex:1;padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font-size:13px;font-family:var(--font-sans);outline:none;cursor:pointer}.voice-pick select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.btn.icon-only{flex:none;display:inline-flex;align-items:center;justify-content:center;padding:8px 10px}.voice-neb{position:fixed;left:0;right:0;bottom:0;height:34%;overflow:hidden;pointer-events:none;z-index:-1;opacity:.7;animation:nebIn .6s var(--ease)}.vneb{position:absolute;border-radius:50%;filter:blur(46px);will-change:transform,opacity}.vneb.v1{width:46%;height:110%;left:27%;bottom:-55%}.vneb.v2{width:40%;height:100%;left:4%;bottom:-50%}.vneb.v3{width:40%;height:100%;right:4%;bottom:-50%}@keyframes nebIn{0%{opacity:0;transform:translateY(35%) scale(.85)}to{opacity:.7;transform:none}}.voice-bar{position:fixed;left:0;right:0;bottom:26px;z-index:70;display:flex;align-items:center;justify-content:center;gap:12px;padding:0 18px;animation:barIn .4s var(--ease)}.voice-bar>*{pointer-events:auto}@keyframes barIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}.vrb{width:56px;height:56px;flex:none;border-radius:50%;border:.5px solid rgba(255,255,255,.3);background:#ffffff1a;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center}.vrb:hover{background:#fff3}.vrb.on{background:#ef4444d9;border-color:#ef444499}.vstop{color:#ffc2c2;border-color:#ff787873}.vpill{flex:1;min-width:0;max-width:300px;height:56px;overflow:hidden;border-radius:18px;border:.5px solid rgba(255,255,255,.2);background:#080a148c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;cursor:pointer;padding:6px 14px;text-align:left}.vwin{display:flex;flex-direction:column;justify-content:center;height:100%;gap:1px;overflow:hidden}.vline{font-size:13px;line-height:1.35;color:#eef;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vline.cur{white-space:normal;text-overflow:clip;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.vline.you{color:#cdebff}.vline.agent{color:#f0e3ff}.vline.dim{color:#ffffff80}.vline.err{color:#ffb4b4;white-space:normal}.app-loading{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg)}.app-spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--accent-soft);border-top-color:var(--accent);animation:app-spin .8s linear infinite}@keyframes app-spin{to{transform:rotate(360deg)}}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:24px;background-color:var(--bg);background-image:radial-gradient(1100px 540px at 50% -10%,var(--accent-soft),transparent 70%),radial-gradient(var(--border) 1px,transparent 1px);background-size:auto,22px 22px}.auth-lang{position:absolute;top:18px;right:18px;display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:3px;box-shadow:var(--shadow-sm)}.auth-lang button{border:0;background:transparent;color:var(--muted);font-weight:600;font-size:12px;padding:5px 10px;border-radius:var(--r-sm);cursor:pointer}.auth-lang button.on{background:var(--accent-soft);color:var(--accent-text)}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);padding:30px 28px 26px;display:flex;flex-direction:column;gap:12px}.auth-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--text)}.auth-card h2{margin:6px 0 0;font-size:21px;font-weight:700;color:var(--text)}.auth-sub{margin:0 0 6px;color:var(--muted);font-size:13px;line-height:1.5}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-field span{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.auth-field input{padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font-size:14px;font-family:var(--font-sans);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.auth-error{background:#e0586e1a;border:1px solid rgba(224,88,110,.4);color:#e0586e;border-radius:var(--r-md);padding:8px 12px;font-size:12.5px}.auth-submit{margin-top:4px;width:100%;padding:11px;font-size:14px}.auth-submit:disabled{opacity:.65;cursor:default}.auth-hint{text-align:center;color:var(--faint);font-size:11.5px}.person-hero .hero-sub{color:var(--faint);font-size:12px}.btn-logout{display:inline-flex;align-items:center;gap:7px;color:#e0586e;border-color:#e0586e66;background:transparent}.btn-logout:hover{background:#e0586e1a}.tenant-pick{width:100%;max-width:760px;display:flex;flex-direction:column;gap:12px}.tenant-pick .auth-brand{justify-content:center}.tenant-pick h2{margin:6px 0 0;text-align:center;font-size:22px;font-weight:700;color:var(--text)}.tenant-pick .auth-sub{text-align:center}.picker-topright{position:absolute;top:18px;right:18px;display:flex;align-items:center;gap:8px}.auth-lang.static{position:static;top:auto;right:auto;box-shadow:none}.picker-gear{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;box-shadow:var(--shadow-sm)}.picker-gear:hover{color:var(--accent-text);border-color:var(--accent)}.tree-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-top:6px}.tree-card{position:relative;overflow:hidden;display:flex;flex-direction:column;aspect-ratio:7 / 4;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);cursor:pointer;font-family:var(--font-sans);transition:border-color .16s ease,transform .14s ease,box-shadow .14s ease}.tree-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow)}.tree-card-top{display:flex;align-items:center;justify-content:flex-end;gap:6px;min-height:28px}.perm-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px}.perm-owner{background:color-mix(in srgb,#2bb673 16%,transparent);color:#1f9d63}.perm-editor{background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--accent-text)}.perm-viewer{background:color-mix(in srgb,#f59e42 20%,transparent);color:#d97b1e}.tree-gear{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:0;background:transparent;color:var(--muted);cursor:pointer}.tree-gear:hover{color:var(--accent-text);background:var(--surface-3)}.tree-card-title{flex:1;display:flex;align-items:flex-end;justify-content:flex-start;text-align:left;font-weight:600;font-size:20px;letter-spacing:-.01em;color:var(--text);padding-bottom:12%}.tree-card-bottom{display:flex;align-items:center;justify-content:space-between}.avatar-row{display:flex;align-items:center}.mini-avatar{position:relative;display:inline-flex}.mini-avatar:not(:first-child){margin-left:-8px}.ma-init{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--surface-3);color:var(--text-2);border:2px solid var(--surface);font-size:12px;font-weight:700}.mini-avatar.more .ma-init{background:var(--surface-2);color:var(--muted)}.ma-pop{position:absolute;bottom:calc(100% + 8px);left:0;white-space:nowrap;background:var(--text);color:var(--surface);font-size:11px;font-weight:600;padding:4px 8px;border-radius:6px;opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .12s ease,transform .12s ease;z-index:20}.mini-avatar:hover .ma-pop{opacity:1;transform:translateY(0)}.card-share-flat{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:0;background:transparent;color:var(--muted);cursor:pointer;border-radius:8px}.card-share-flat:hover{color:var(--accent-text);background:var(--surface-3)}.role-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;background:var(--surface-3);color:var(--muted)}.role-badge.role-owner{background:var(--accent-soft);color:var(--accent-text)}.tree-add{align-items:center;justify-content:center;gap:8px;color:var(--muted);border-style:dashed;background:var(--surface);box-shadow:none}.tree-add:hover{color:var(--accent-text);border-color:var(--accent);box-shadow:var(--shadow-sm)}.tree-create{gap:8px;cursor:default;justify-content:center;background:var(--surface);box-shadow:var(--shadow-sm)}.tree-create input{width:100%;box-sizing:border-box;padding:9px 11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font-size:13px;font-family:var(--font-sans);outline:none}.tree-create input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.tenant-create-actions{display:flex;gap:6px;width:100%}.tenant-create-actions .btn{flex:1;padding:7px;font-size:12px}.canshare-toggle{display:inline-flex;align-items:center;gap:4px;margin-left:8px;font-size:11px;color:var(--muted);cursor:pointer}.canshare-toggle input{width:13px;height:13px;accent-color:var(--accent)}.tenant-logout{align-self:center;margin-top:8px;background:transparent;border:0;color:var(--muted);font-size:12.5px;cursor:pointer}.tenant-logout:hover{color:var(--text-2)}.admin-toggle{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--text);cursor:pointer;padding:4px 0}.admin-toggle input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.admin-field{display:flex;flex-direction:column;gap:4px;margin-bottom:9px}.admin-field label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.admin-field input,.admin-field select{padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font-size:13px;font-family:var(--font-sans);outline:none}.admin-field select{cursor:pointer}.admin-field input:focus,.admin-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.auth-toggle{background:transparent;border:0;color:var(--accent-text);font-size:12.5px;font-weight:600;cursor:pointer;padding:4px;text-align:center}.auth-toggle:hover{text-decoration:underline}.member-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}.member-row:last-child{border-bottom:0}.member-id{flex:1;min-width:0}.member-name{font-weight:600;font-size:13px;color:var(--text);display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-email{font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:4px}.you-tag{font-size:10px;font-weight:600;color:var(--accent-text);background:var(--accent-soft);border-radius:999px;padding:1px 7px}.role-select{padding:5px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-2);font-size:12px;font-family:var(--font-sans);cursor:pointer}.role-select:disabled{opacity:.6;cursor:default}.icon-btn.danger-ic{width:30px;height:30px}.icon-btn.danger-ic:hover{color:#e0586e;border-color:#e0586e66}.invite-form{display:flex;flex-direction:column;gap:8px}.invite-form input,.invite-row select{padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);font-size:13px;font-family:var(--font-sans);outline:none}.invite-form input:focus{border-color:var(--accent)}.invite-row{display:flex;gap:6px}.invite-row select{flex:1}.invite-row input[type=number]{width:64px}.invite-row .btn{white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.invite-hint{font-size:11px;color:var(--faint)}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}.tree-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:var(--surface);border:1px solid var(--border);border-radius:999px;color:var(--text-2);font-weight:600;font-size:12.5px;cursor:pointer;max-width:200px}.tree-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-chip:hover{border-color:var(--accent);color:var(--accent-text)}.family-nav{display:none;align-items:center;gap:4px}.family-nav button{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-2);cursor:pointer}.family-nav button:active{background:var(--surface-3)}@media(max-width:640px){.topbar{padding:0 10px;gap:8px}.topbar-left{gap:8px}.topbar-right{gap:6px}.brand span,.people-count,.search-affordance,.tree-chip{display:none}.family-nav{display:flex}.side-panel{top:0;bottom:auto;right:0;left:0;width:100%;max-width:100%;height:var(--app-h, 100dvh);border-radius:0}.chat-win.floating,.chat-win.docked,.chat-win.large{inset:auto;top:0;left:0;width:100%;height:var(--app-h, 100dvh);border-radius:0}.chat-modes{display:none}.voice-bar{padding:0 10px;gap:8px}.fab-cluster{bottom:18px;right:18px}}
