:root{--font-ui: "Hanken Grotesk", system-ui, -apple-system, sans-serif;--font-display: "Fraunces", Georgia, serif;--radius-sm: 7px;--radius: 10px;--radius-lg: 16px;--shadow-1: 0 1px 2px rgba(40, 33, 22, .06), 0 1px 1px rgba(40, 33, 22, .04);--shadow-2: 0 4px 14px rgba(40, 33, 22, .1), 0 1px 3px rgba(40, 33, 22, .06);--shadow-3: 0 14px 40px rgba(40, 33, 22, .16), 0 3px 10px rgba(40, 33, 22, .08);--ease: cubic-bezier(.22, .61, .36, 1)}:root[data-theme=light]{--canvas: #f0ece2;--canvas-dot: #d9d2c4;--surface: #fbfaf6;--surface-2: #f4f1ea;--surface-raised: #ffffff;--ink: #23201b;--ink-soft: #4f4a40;--ink-muted: #6a6354;--border: #e5dfd2;--border-strong: #d6cfbe;--accent: #2f6b4f;--accent-ink: #1f4d39;--accent-soft: #e3ede6;--danger: #a23b30;--focus: #2f6b4f;color-scheme:light}:root[data-theme=dark]{--canvas: #16140f;--canvas-dot: #2c281f;--surface: #211e18;--surface-2: #1b1813;--surface-raised: #2a261e;--ink: #ece7da;--ink-soft: #c3bcab;--ink-muted: #9b9483;--border: #353027;--border-strong: #45402f;--accent: #6cc79c;--accent-ink: #9ad9bb;--accent-soft: #21342a;--danger: #e08b80;--focus: #6cc79c;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-ui);color:var(--ink);background:var(--surface);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font:inherit;cursor:pointer}::selection{background:var(--accent-soft)}:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:4px}.app{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto 1fr;grid-template-areas:"topbar topbar topbar" "rail canvas assistant";height:100dvh;overflow:hidden;background:var(--surface)}.topbar{grid-area:topbar;display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border);background:var(--surface);z-index:5}.brand{display:flex;align-items:center;gap:9px;padding-right:12px;margin-right:4px;border-right:1px solid var(--border)}.brand-mark{width:26px;height:26px;flex:none}.brand-name{font-family:var(--font-display);font-size:19px;font-weight:600;letter-spacing:-.01em}.brand-name span{color:var(--accent)}.title-input{font:600 15px var(--font-ui);color:var(--ink);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:6px 9px;min-width:80px;max-width:320px}.title-input:hover{border-color:var(--border)}.title-input:focus{border-color:var(--accent);background:var(--surface-raised);outline:none}.spacer{flex:1}.toolgroup{display:flex;align-items:center;gap:2px;padding:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.btn{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface-raised);color:var(--ink-soft);font-weight:500;font-size:13.5px;transition:background .14s var(--ease),color .14s var(--ease),border-color .14s var(--ease),transform .06s var(--ease)}.btn:hover{color:var(--ink);border-color:var(--ink-muted)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fbfaf6}:root[data-theme=dark] .btn-primary{color:#16140f}.btn-primary:hover{background:var(--accent-ink);border-color:var(--accent-ink);color:#fbfaf6}:root[data-theme=dark] .btn-primary:hover{color:#16140f}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--ink-soft);transition:background .14s var(--ease),color .14s var(--ease)}.icon-btn:hover{background:var(--surface-2);color:var(--ink)}.icon-btn[aria-pressed=true],.icon-btn.active{background:var(--accent-soft);color:var(--accent-ink)}.icon-btn:disabled{opacity:.4;cursor:not-allowed;background:transparent}.icon-btn svg{width:18px;height:18px}.account-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:50%;background:transparent}.avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1.5px solid var(--border-strong)}.avatar.lg{width:36px;height:36px}.avatar-initial{display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fbfaf6;font-weight:600;font-size:13px}:root[data-theme=dark] .avatar-initial{color:#16140f}.account-btn:hover .avatar{border-color:var(--accent)}.account-menu{min-width:244px;padding:10px}.account-head{display:flex;align-items:center;gap:10px;padding:4px 4px 10px}.account-id{min-width:0}.account-name{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-email{font-size:12px;color:var(--ink-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-status{display:flex;align-items:center;gap:7px;padding:8px 4px;font-size:12.5px;color:var(--ink-soft)}.account-status .led{width:7px;height:7px;border-radius:50%;background:var(--ink-muted)}.account-status .led.ok{background:var(--accent)}.signin-pane{display:flex;flex-direction:column;gap:12px;padding:4px}.signin-copy{font-size:12.5px;line-height:1.5;color:var(--ink-soft)}.gbtn-host{min-height:40px;display:flex;justify-content:center}.signin-loading{font-size:12px;color:var(--ink-muted);text-align:center}.presence{position:relative}.presence-cluster{display:inline-flex;align-items:center;border:none;background:transparent;padding:2px 4px;cursor:pointer}.pa-wrap{margin-left:-8px;display:inline-flex}.pa-wrap:first-child{margin-left:0}.pa{border-radius:50%;border:2px solid var(--surface);object-fit:cover}.pa-initial{display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fbfaf6;font-weight:600;font-size:12px}:root[data-theme=dark] .pa-initial{color:#16140f}.pa-initial.guest{background:var(--ink-muted)}.pa-more{min-width:26px;height:26px;padding:0 5px;margin-left:-8px;border-radius:999px;background:var(--surface-2);border:2px solid var(--surface);color:var(--ink-soft);font-size:11px;font-weight:600;display:inline-flex;align-items:center;justify-content:center}.presence-menu{right:0;min-width:244px;max-height:60vh;overflow-y:auto}.presence-row{display:flex;align-items:center;gap:10px;padding:6px}.presence-id{min-width:0}.presence-name{font-size:13.5px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-tag{color:var(--ink-muted);font-weight:400}.guest-tag{margin-left:5px;font-size:10.5px;color:var(--ink-muted);border:1px solid var(--border);border-radius:999px;padding:0 6px}.presence-email{font-size:12px;color:var(--ink-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shared-badge{font-size:12px;color:var(--ink-soft);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:4px 11px;white-space:nowrap}.role-badge{font-size:10.5px;font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:999px;padding:1px 7px}.dialog{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:480px;max-width:calc(100% - 32px);max-height:calc(100% - 64px);overflow-y:auto;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);padding:20px 22px;z-index:40;animation:pop .15s var(--ease)}.dialog-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.dialog-head h2{margin:0;font-family:var(--font-display);font-size:18px;font-weight:600}.dialog-error{margin:8px 0;padding:8px 11px;font-size:13px;color:var(--danger);background:color-mix(in srgb,var(--danger) 9%,var(--surface));border:1px solid color-mix(in srgb,var(--danger) 30%,var(--border));border-radius:var(--radius-sm)}.share-section{padding:16px 0;border-top:1px solid var(--border)}.share-label{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:9px}.dialog input,.dialog select{font:14px var(--font-ui);color:var(--ink);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}.dialog input:focus,.dialog select:focus{outline:none;border-color:var(--accent);background:var(--surface-raised)}.email-add{display:flex;gap:8px}.email-add input{flex:1;min-width:0}.share-people{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.share-people li{display:flex;align-items:center;gap:9px}.who-avatar{width:26px;height:26px;border-radius:50%;flex:none;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent-ink);font-weight:600;font-size:12px}.who-email{flex:1;min-width:0;font-size:13.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-people select{padding:5px 7px;font-size:13px}.link-row{display:flex;align-items:center;gap:11px}.link-desc{font-size:13.5px;color:var(--ink-soft);flex:1}.link-row select{padding:5px 8px}.switch{position:relative;display:inline-flex;width:38px;height:22px;flex:none}.switch input{opacity:0;width:0;height:0}.switch .track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;background:var(--border-strong);transition:background .16s var(--ease)}.switch .track:before{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--shadow-1);transition:transform .16s var(--ease)}.switch input:checked+.track{background:var(--accent)}.switch input:checked+.track:before{transform:translate(16px)}.link-copy{display:flex;gap:8px;margin-top:10px}.link-copy input{flex:1;min-width:0;font-size:12.5px;font-family:var(--font-mono, ui-monospace, monospace)}.share-hint{margin-top:10px;font-size:12px;line-height:1.5;color:var(--ink-muted)}.menu-wrap{position:relative}.menu{position:absolute;top:calc(100% + 6px);right:0;min-width:184px;padding:6px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-3);z-index:30;animation:pop .12s var(--ease)}.menu button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 9px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--ink-soft);font-size:13.5px;text-align:left}.menu button:hover{background:var(--surface-2);color:var(--ink)}.menu button svg{width:16px;height:16px;color:var(--ink-muted)}.menu hr{border:none;border-top:1px solid var(--border);margin:5px 2px}@keyframes pop{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:none}}.rail{grid-area:rail;width:248px;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--surface-2);transition:width .2s var(--ease)}.rail.collapsed{width:0;overflow:hidden;border-right:none}.rail-head{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 8px}.rail-head h2{margin:0;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-muted)}.rail-list{flex:1;overflow-y:auto;padding:4px 8px 12px;display:flex;flex-direction:column;gap:2px}.map-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:var(--radius-sm);border:1px solid transparent;color:var(--ink-soft);background:transparent;text-align:left;width:100%}.map-item:hover{background:var(--surface)}.map-item.active{background:var(--surface-raised);border-color:var(--border);color:var(--ink);box-shadow:var(--shadow-1)}.map-item .dot{width:8px;height:8px;border-radius:50%;flex:none;background:var(--accent)}.map-item .meta{flex:1;min-width:0}.map-item .name{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-item .sub{font-size:11.5px;color:var(--ink-muted)}.map-item .meta{display:flex;flex-direction:column;gap:1px}.map-item .sub{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.folder-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px 1px 4px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--ink-muted);max-width:120px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.folder-badge svg{width:11px;height:11px;flex:none}.item-menu-btn{opacity:0;flex:none;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-muted);background:transparent;border:none;border-radius:6px}.item-menu-btn svg{width:16px;height:16px}.map-item:hover .item-menu-btn,.map-item.active .item-menu-btn,.folder-head:hover .item-menu-btn{opacity:1}.item-menu-btn:hover{color:var(--ink);background:var(--surface-2)}.rail-head-actions{display:flex;gap:2px}.rail-search{display:flex;align-items:center;gap:7px;margin:2px 12px 8px;padding:6px 9px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.rail-search:focus-within{border-color:var(--accent);background:var(--surface-raised)}.rail-search svg{width:15px;height:15px;color:var(--ink-muted);flex:none}.rail-search input{flex:1;min-width:0;border:none;outline:none;background:transparent;font:13px var(--font-ui);color:var(--ink)}.clear-search{border:none;background:transparent;color:var(--ink-muted);font-size:17px;line-height:1;cursor:pointer;padding:0 2px}.clear-search:hover{color:var(--ink)}.rail-empty{padding:14px 12px;font-size:12.5px;color:var(--ink-muted);text-align:center}.rail-section-label{padding:8px 10px 4px;font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted)}.rail-section-label.uncat{margin-top:6px}.folder{display:flex;flex-direction:column}.folder-head{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:var(--radius-sm);color:var(--ink-soft);cursor:pointer}.folder-head:hover{background:var(--surface)}.folder-caret{display:inline-flex;color:var(--ink-muted);transition:transform .14s var(--ease)}.folder-caret svg{width:14px;height:14px}.folder-caret.open{transform:rotate(90deg)}.folder-ic{width:15px;height:15px;flex:none;color:var(--ink-muted)}.folder-name{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-count{font-size:11px;font-variant-numeric:tabular-nums;color:var(--ink-muted);background:var(--surface-2);border-radius:999px;padding:1px 7px}.folder-head:hover .folder-count{display:none}.folder-body{display:flex;flex-direction:column;gap:2px;padding-left:14px}.folder-empty{padding:7px 10px;font-size:11.5px;color:var(--ink-muted);font-style:italic}.rename-input{width:100%;border:1px solid var(--accent);border-radius:5px;background:var(--surface-raised);color:var(--ink);font:500 13.5px var(--font-ui);padding:3px 6px;outline:none}.rail-menu{position:fixed;right:auto;top:auto;min-width:196px;max-height:72vh;overflow-y:auto}.menu .menu-label{padding:4px 9px 2px;font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted)}.menu .move-list{display:flex;flex-direction:column;max-height:40vh;overflow-y:auto}.menu button.sel{color:var(--accent-ink);background:var(--accent-soft)}.menu button.danger{color:var(--ink-soft)}.menu button.danger:hover{color:var(--danger);background:color-mix(in srgb,var(--danger) 8%,var(--surface))}.menu button.danger svg{color:inherit}.canvas-wrap{grid-area:canvas;position:relative;overflow:hidden;background-color:var(--canvas);background-image:radial-gradient(var(--canvas-dot) 1.3px,transparent 1.3px);background-size:22px 22px;touch-action:none}.canvas-svg{width:100%;height:100%;display:block;cursor:grab}.canvas-svg.panning{cursor:grabbing}.edge{fill:none;stroke-width:2;stroke-opacity:.5;transition:stroke-opacity .15s var(--ease)}.node{--c: var(--accent);position:relative;height:100%;display:flex;align-items:center;border-radius:var(--radius);border:1px solid color-mix(in srgb,var(--c) 38%,var(--border));background:color-mix(in srgb,var(--c) 9%,var(--surface-raised));box-shadow:var(--shadow-1);cursor:grab;-webkit-user-select:none;user-select:none;overflow:hidden;transition:box-shadow .15s var(--ease),border-color .15s var(--ease),transform .18s var(--ease),opacity .4s var(--ease)}.node:hover{box-shadow:var(--shadow-2)}.node.root{background:var(--ink);border-color:var(--ink);color:var(--surface)}.node.selected{border-color:var(--c);box-shadow:0 0 0 2px color-mix(in srgb,var(--c) 55%,transparent),var(--shadow-2)}.node.root.selected{box-shadow:0 0 0 2px var(--accent),var(--shadow-2)}.node.drop-target{border-color:var(--accent);box-shadow:0 0 0 2.5px var(--accent),var(--shadow-2)}.node.dragging{box-shadow:var(--shadow-3);cursor:grabbing;opacity:.95}.node .bar{width:3.5px;align-self:stretch;margin:6px 0;border-radius:2px;background:var(--c);flex:none}.node.root .bar{display:none}.node .label{flex:1;padding:9px 13px;font-size:15px;font-weight:500;line-height:20px;color:var(--ink);white-space:pre-wrap;word-break:break-word}.node.root .label{color:var(--surface);font-weight:600;font-size:17px}.node textarea.label{resize:none;border:none;outline:none;background:transparent;font-family:var(--font-ui);overflow:hidden}.node .note-dot{position:absolute;top:6px;right:7px;width:6px;height:6px;border-radius:50%;background:var(--c);opacity:.7}.collapse-toggle{position:absolute;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--surface-raised);border:1.5px solid color-mix(in srgb,var(--c) 45%,var(--border));color:var(--c);font-size:12px;font-weight:700;line-height:1;padding:0;z-index:2;box-shadow:var(--shadow-1)}.collapse-toggle:hover{background:var(--c);color:#fff}.inspector{position:absolute;top:14px;right:14px;width:308px;max-width:calc(100% - 28px);display:flex;flex-direction:column;gap:7px;padding:14px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);z-index:7;animation:slide-in .16s var(--ease)}.inspector-head{display:flex;align-items:center;gap:8px;margin-bottom:2px}.ins-dot{width:11px;height:11px;border-radius:50%;flex:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--ink) 6%,transparent)}.ins-kind{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted)}.ins-close{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:6px;background:transparent;color:var(--ink-muted)}.ins-close:hover{background:var(--surface-2);color:var(--ink)}.ins-close svg{width:15px;height:15px}.inspector label{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);margin-top:4px}.inspector label svg{width:14px;height:14px}.ins-title-row{display:flex;gap:6px}.ins-title-row .icon-btn{flex:none;width:36px;height:36px;border:1px solid var(--border)}.inspector input,.inspector textarea{width:100%;padding:8px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--ink);font:14px var(--font-ui);line-height:1.5}.inspector input:focus,.inspector textarea:focus{outline:none;border-color:var(--accent);background:var(--surface-raised)}.inspector textarea{min-height:104px;max-height:320px;resize:vertical}.ins-meta{font-size:11.5px;color:var(--ink-muted);margin-top:2px}@keyframes slide-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.ins-swatches{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.ins-swatches .swatch{width:22px;height:22px;border-radius:50%;padding:0;border:1.5px solid rgba(0,0,0,.12);display:inline-flex;align-items:center;justify-content:center;transition:transform .1s var(--ease)}.ins-swatches .swatch:hover{transform:scale(1.12)}.ins-swatches .swatch.sel{outline:2px solid var(--ink);outline-offset:2px}.ins-swatches .swatch.reset{background:var(--surface-2);color:var(--ink-muted);border-color:var(--border)}.ins-swatches .swatch.reset svg{width:13px;height:13px}.ins-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}.ins-delete{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--ink-muted);font-size:13px;font-weight:500}.ins-delete:hover{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,var(--border));background:color-mix(in srgb,var(--danger) 8%,var(--surface))}.ins-delete svg{width:15px;height:15px}.add-handle{position:absolute;width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--surface-raised);border:1.5px solid var(--accent);color:var(--accent);box-shadow:var(--shadow-2);z-index:6;transition:transform .12s var(--ease),background .12s var(--ease),color .12s var(--ease)}.add-handle:hover{background:var(--accent);color:var(--surface);transform:scale(1.14)}.add-handle:active{transform:scale(1.02)}.add-handle svg{width:15px;height:15px}.add-handle.ghost{width:21px;height:21px;opacity:.5;filter:blur(.5px);box-shadow:var(--shadow-1);border-style:dashed}.add-handle.ghost svg{width:12px;height:12px}.add-handle.ghost:hover{opacity:1;filter:none;border-style:solid;background:var(--accent);color:var(--surface);transform:scale(1.18)}@media (prefers-reduced-motion: reduce){.add-handle.ghost{filter:none}}.zoom-controls{position:absolute;left:16px;bottom:16px;display:flex;align-items:center;gap:4px;padding:4px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-2)}.zoom-controls .pct{min-width:46px;text-align:center;font-size:12.5px;font-variant-numeric:tabular-nums;color:var(--ink-muted)}.canvas-hint{position:absolute;right:16px;bottom:16px;font-size:12px;color:var(--ink-muted);background:color-mix(in srgb,var(--surface-raised) 80%,transparent);border:1px solid var(--border);padding:6px 10px;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none}.app.presenting{grid-template-columns:1fr;grid-template-rows:1fr;grid-template-areas:"canvas"}.canvas-wrap.presenting{background-image:none;background-color:var(--canvas)}.node.present{cursor:pointer}.node.present-dim{opacity:.28;filter:saturate(.7)}.node.present-focus{transform:scale(1.03);box-shadow:0 0 0 3px color-mix(in srgb,var(--c) 60%,transparent),var(--shadow-3)}.node.root.present-focus{box-shadow:0 0 0 3px var(--accent),var(--shadow-3)}.edge.dim{stroke-opacity:.08}.present-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:linear-gradient(to bottom,color-mix(in srgb,var(--surface) 80%,transparent),transparent);z-index:8}.present-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--ink)}.present-exit{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface-raised);color:var(--ink-soft);font-weight:500;font-size:13.5px;box-shadow:var(--shadow-1);transition:color .14s var(--ease),border-color .14s var(--ease)}.present-exit:hover{color:var(--ink);border-color:var(--ink-muted)}.present-exit svg{width:16px;height:16px}.present-bar{position:absolute;left:50%;bottom:22px;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:6px;background:var(--surface-raised);border:1px solid var(--border);border-radius:999px;box-shadow:var(--shadow-3);z-index:8}.present-bar .present-sep{width:1px;height:22px;background:var(--border);margin:0 2px}.present-count{min-width:56px;text-align:center;font-size:13.5px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);padding:0 4px}.present-count .of{color:var(--ink-muted);font-weight:500}.present-notes{position:absolute;top:64px;right:18px;width:330px;height:auto;min-width:260px;min-height:150px;max-width:calc(100% - 36px);max-height:calc(100% - 120px);display:flex;flex-direction:column;gap:8px;padding:18px;overflow:auto;resize:both;direction:rtl;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);z-index:8;animation:slide-in .18s var(--ease)}.present-notes>*{direction:ltr}.present-notes::-webkit-resizer{background:transparent}.pn-head{display:flex;align-items:center;gap:8px}.pn-dot{width:11px;height:11px;border-radius:50%;flex:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--ink) 6%,transparent)}.pn-kind{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted)}.pn-step{margin-left:auto;font-size:11.5px;font-variant-numeric:tabular-nums;color:var(--ink-muted)}.pn-crumbs{font-size:12px;color:var(--ink-muted);line-height:1.4}.pn-title{margin:2px 0 4px;font-family:var(--font-display);font-size:21px;font-weight:600;line-height:1.2;color:var(--ink)}.pn-empty{margin:2px 0;font-size:14px;color:var(--ink-muted);font-style:italic}.pn-note.md{font-size:14.5px;line-height:1.62;color:var(--ink);word-break:break-word}.pn-note.md>:first-child{margin-top:0}.pn-note.md>:last-child{margin-bottom:0}.pn-note.md h1,.pn-note.md h2,.pn-note.md h3,.pn-note.md h4,.pn-note.md h5,.pn-note.md h6{font-family:var(--font-display);font-weight:600;line-height:1.25;margin:14px 0 6px;color:var(--ink)}.pn-note.md h1{font-size:19px}.pn-note.md h2{font-size:17px}.pn-note.md h3{font-size:15.5px}.pn-note.md h4,.pn-note.md h5,.pn-note.md h6{font-size:14px}.pn-note.md p{margin:8px 0}.pn-note.md ul,.pn-note.md ol{margin:8px 0;padding-left:20px}.pn-note.md li{margin:3px 0}.pn-note.md li::marker{color:var(--ink-muted)}.pn-note.md a{color:var(--accent-ink);text-decoration:underline;text-underline-offset:2px}.pn-note.md code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;background:var(--surface-2);border:1px solid var(--border);padding:1px 5px;border-radius:5px}.pn-note.md pre{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;overflow:auto;margin:8px 0}.pn-note.md pre code{background:none;border:none;padding:0;font-size:12.5px;line-height:1.5}.pn-note.md blockquote{margin:8px 0;padding:4px 12px;border-left:3px solid color-mix(in srgb,var(--accent) 50%,var(--border));color:var(--ink-soft)}.pn-note.md hr{border:none;border-top:1px solid var(--border);margin:12px 0}.pn-note.md strong{font-weight:700}.pn-note.md em{font-style:italic}.pn-note.md del{opacity:.7}.pn-meta{margin-top:auto;padding-top:8px;font-size:12px;color:var(--ink-muted);border-top:1px solid var(--border)}@media (max-width: 620px){.present-notes{width:calc(100% - 36px);top:auto;bottom:86px;max-height:42%}}.assistant{grid-area:assistant;width:360px;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface);transition:width .2s var(--ease)}.assistant.collapsed{width:0;overflow:hidden;border-left:none}.assistant-head{display:flex;align-items:center;gap:8px;padding:13px 14px;border-bottom:1px solid var(--border)}.assistant-head>svg{width:20px;height:20px;flex:none;color:var(--accent)}.assistant-head h2{margin:0;font-family:var(--font-display);font-size:16px;font-weight:600}.assistant-head .status{font-size:11px;color:var(--ink-muted);display:flex;align-items:center;gap:5px;flex:none;max-width:120px;white-space:nowrap}.assistant-head .status .model{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.assistant-head .status .led{width:7px;height:7px;border-radius:50%;background:var(--ink-muted)}.assistant-head .status.ok .led{background:var(--accent)}.context-box{padding:12px 14px;border-bottom:1px solid var(--border)}.context-box label{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:6px}.context-box textarea{width:100%;min-height:58px;max-height:160px;padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--ink);font:13px var(--font-ui);line-height:1.45;resize:vertical}.context-box textarea:focus{outline:none;border-color:var(--accent);background:var(--surface-raised)}.thread{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.thread-empty{margin:auto 0;text-align:center;color:var(--ink-muted);padding:10px}.thread-empty .big{font-family:var(--font-display);font-size:16px;color:var(--ink-soft);margin-bottom:6px}.chips{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:14px}.chip{font-size:12.5px;color:var(--ink-soft);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:6px 11px;transition:border-color .14s var(--ease),color .14s var(--ease)}.chip:hover{border-color:var(--accent);color:var(--accent-ink)}.msg{display:flex;flex-direction:column;gap:4px;max-width:100%}.msg .who{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted)}.msg .bubble{padding:9px 12px;border-radius:var(--radius);font-size:13.5px;line-height:1.5}.msg.user{align-items:flex-end}.msg.user .bubble{background:var(--accent-soft);color:var(--accent-ink);border-bottom-right-radius:3px}.msg.assistant .bubble{background:var(--surface-2);border:1px solid var(--border);color:var(--ink);border-bottom-left-radius:3px}.msg.error .bubble{background:color-mix(in srgb,var(--danger) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--danger) 35%,var(--border));color:var(--danger)}.msg .undo-edit{font-size:12px;color:var(--ink-muted);background:none;border:none;padding:2px 0;text-decoration:underline;align-self:flex-start}.msg .undo-edit:hover{color:var(--ink)}.composer{padding:12px 14px 14px;border-top:1px solid var(--border)}.composer .row{display:flex;align-items:flex-end;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:6px 6px 6px 12px}.composer .row:focus-within{border-color:var(--accent);background:var(--surface-raised)}.composer textarea{flex:1;border:none;outline:none;background:transparent;resize:none;font:14px var(--font-ui);line-height:1.45;color:var(--ink);max-height:140px;padding:4px 0}.composer .send{flex:none;width:36px;height:36px;border-radius:8px;border:none;background:var(--accent);color:#fbfaf6;display:inline-flex;align-items:center;justify-content:center}:root[data-theme=dark] .composer .send{color:#16140f}.composer .send:disabled{opacity:.4;cursor:not-allowed}.composer .send svg{width:18px;height:18px}.composer .hint{margin-top:7px;font-size:11px;color:var(--ink-muted)}.dots{display:inline-flex;gap:4px;padding:4px 2px}.dots i{width:6px;height:6px;border-radius:50%;background:var(--ink-muted);animation:blink 1.2s infinite both}.dots i:nth-child(2){animation-delay:.18s}.dots i:nth-child(3){animation-delay:.36s}@keyframes blink{0%,60%,to{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%);background:var(--ink);color:var(--surface);padding:10px 16px;border-radius:var(--radius);box-shadow:var(--shadow-3);font-size:13px;z-index:60;animation:pop .15s var(--ease)}@media (max-width: 980px){.assistant{position:absolute;top:0;right:0;height:100%;z-index:20;box-shadow:var(--shadow-3)}.rail{position:absolute;top:0;left:0;height:100%;z-index:20;box-shadow:var(--shadow-3)}}@media (max-width: 620px){.assistant{width:100vw}.title-input{max-width:120px}.brand-name,.hide-sm{display:none}}.rot{transform:rotate(90deg)}.hide-lg{display:none}@media (max-width: 980px){.hide-lg{display:inline-flex}}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#14100a59;z-index:15;animation:fade .15s var(--ease)}@keyframes fade{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
