*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fff;--surface:#f8f9fa;--surface-hover:#f0f0f0;--border:#e0e0e0;--border-selected:#3b82f6;--text:#1a1a1a;--text-muted:#888;--accent:#3b82f6}html,body,#root{background:var(--bg);width:100%;height:100%;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;overflow:hidden}.app{flex-direction:column;height:100%;display:flex}.app-body{flex:1;min-height:0;display:flex;position:relative}.app-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.app-header-left{align-items:center;gap:12px;display:flex}.app-title{color:var(--text);font-size:16px;font-weight:600}.header-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:6px;padding:4px 12px;font-family:inherit;font-size:12px;transition:background .1s,color .1s}.header-btn:hover{background:var(--surface-hover);color:var(--text)}.header-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:12px;text-decoration:none;transition:background .1s,color .1s}.header-link:hover{background:var(--surface-hover);color:var(--text)}.header-link-empty{opacity:.6}.header-link-empty:hover{opacity:1}.header-link-group{align-items:center;gap:2px;display:inline-flex}.header-link-edit{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:11px;transition:opacity .1s,background .1s,color .1s}.header-link-group:hover .header-link-edit{opacity:1}.header-link-edit:hover{background:var(--surface-hover);color:var(--text)}.save-indicator{color:#10b981;opacity:0;font-size:11px;transition:opacity .3s}.save-indicator.visible{opacity:1}.app-header-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.sync-indicator{width:20px;height:20px;color:var(--text-muted);opacity:.55;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;line-height:1;display:inline-flex}.sync-indicator.auth-checking{display:none}.sync-indicator.sync-syncing{opacity:.65;animation:1.2s linear infinite sync-spin}.sync-indicator.sync-error{opacity:.8}@keyframes sync-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.presence-stack{align-items:center;display:inline-flex}.presence-avatar{color:#3730a3;-webkit-user-select:none;user-select:none;background:#e0e7ff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;margin-left:-6px;font-size:11px;font-weight:600;line-height:1;display:inline-flex}.presence-avatar:first-child{margin-left:0}.presence-more{color:#6b7280;-webkit-user-select:none;user-select:none;background:#f3f4f6;border:2px solid #fff;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;margin-left:-6px;padding:0 6px;font-size:11px;font-weight:500;display:inline-flex}.realtime-indicator{width:14px;color:var(--text-muted);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:10px;display:inline-flex}.realtime-indicator.realtime-connected{color:#10b981}.realtime-indicator.realtime-connecting,.realtime-indicator.realtime-reconnecting{color:#f59e0b;animation:1.2s linear infinite sync-spin}.realtime-indicator.realtime-offline{display:none}.map-list-wrapper{position:relative}.map-list-dropdown{background:var(--bg);border:1px solid var(--border);z-index:100;border-radius:10px;width:280px;max-height:400px;margin-top:4px;padding:4px;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 4px 20px #0000001f}.map-list-empty{text-align:center;color:var(--text-muted);padding:16px;font-size:13px}.map-list-item{cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;transition:background .1s;display:flex}.map-list-item:hover{background:var(--surface-hover)}.map-list-item.active{background:#3b82f614}.map-list-item-info{flex-direction:column;gap:2px;min-width:0;display:flex}.map-list-item-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.map-list-item-date{color:var(--text-muted);font-size:11px}.map-list-item-delete{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:background .1s,color .1s;display:flex}.map-list-item-delete:hover{color:#ef4444;background:#ef44441a}.header-help-btn{border:1px solid var(--border);background:var(--bg);width:26px;height:26px;color:var(--text-muted);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:13px;font-weight:700;transition:background .1s,color .1s,border-color .1s;display:inline-flex}.header-help-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.help-dialog{width:560px;max-width:calc(100vw - 32px);max-height:85vh;overflow-y:auto}.help-groups{flex-direction:column;gap:16px;display:flex}.help-group-title{color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px;font-size:12px;font-weight:700}.help-list{grid-template-columns:auto 1fr;align-items:center;gap:6px 12px;margin:0;padding:0;list-style:none;display:grid}.help-item{display:contents}.help-keys{white-space:nowrap;justify-self:end;align-items:center;gap:2px;display:inline-flex}.help-keys kbd{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;line-height:1.3;display:inline-block}.help-key-sep{color:var(--text-muted);margin:0 2px;font-size:11px}.help-desc{color:var(--text);font-size:12.5px}.mindmap-canvas{cursor:grab;flex:1;position:relative;overflow:hidden}.mindmap-canvas:active{cursor:grabbing}.mindmap-content{align-items:center;display:flex;position:absolute;top:0;left:0}.mindmap-content.animating{transition:transform .4s}.node-group{--node-font-size:18px;--node-font-weight:400;flex-direction:row;align-items:center;display:flex;position:relative}.node-group.depth-1{--node-font-size:22px;--node-font-weight:500}.node-group.depth-2{--node-font-size:17px;--node-font-weight:400}.node-group.depth-3,.node-group.depth-4{--node-font-size:15px;--node-font-weight:400}.node-self-area{flex-shrink:0;position:relative}.node-wrapper{cursor:pointer;border:2px solid #0000;border-radius:6px;outline:none;transition:border-color .15s,background .15s,border-width .15s}.node-wrapper:hover{background:#00000008}.node-wrapper.selected{border:3px solid var(--border-selected);background:#3b82f60a}.node-wrapper.selected.editing{border:1.5px solid var(--border-selected);background:#3b82f614}.node-wrapper{touch-action:none;position:relative}.node-wrapper:not(.editing):hover{cursor:grab}.node-group[data-drag-source=true]{opacity:.4;transition:opacity .1s ease-out}.node-group[data-drag-source=true]>.node-self-area>.node-wrapper{cursor:grabbing;background:#3b82f614;transition:transform .1s ease-out,box-shadow .1s ease-out;transform:scale(1.03);box-shadow:0 6px 16px #0000002e}body:has(.node-group[data-drag-source=true]){cursor:grabbing}body:has(.node-group[data-drag-source=true]) *{cursor:grabbing!important}.drag-ghost{pointer-events:none;z-index:9999;color:var(--text,#1a1a1a);border:1.5px solid var(--border-selected,#3b82f6);white-space:nowrap;text-overflow:ellipsis;opacity:.9;background:#fff;border-radius:8px;align-items:center;gap:6px;max-width:320px;padding:6px 12px;font-size:14px;font-weight:500;display:inline-flex;position:fixed;overflow:hidden;transform:translate(14px,14px);box-shadow:0 8px 24px #0000002e}.drag-ghost-emoji{font-size:14px}.drag-ghost-text{text-overflow:ellipsis;overflow:hidden}.drag-ghost-count{color:var(--border-selected,#3b82f6);background:#3b82f61f;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:600}.node-wrapper.drop-before:before,.node-wrapper.drop-after:after{content:"";background:var(--border-selected,#3b82f6);pointer-events:none;z-index:5;border-radius:2px;height:3px;position:absolute;left:0;right:0}.node-wrapper.drop-before:before{top:-3px}.node-wrapper.drop-after:after{bottom:-3px}.node-wrapper.drop-inside{border:2px dashed var(--border-selected,#3b82f6);background:#3b82f626}.node-self{cursor:pointer;align-items:center;gap:6px;min-width:40px;padding:4px;display:flex;position:relative}.node-self.root-node{padding:6px 10px}.node-self.root-node .node-input{font-size:30px;font-weight:700}.node-input-sizer{pointer-events:none;align-items:center;min-width:40px;display:inline-grid}.node-input-sizer:after{content:attr(data-value) "  ";visibility:hidden;white-space:pre;font:inherit;font-size:var(--node-font-size,18px);font-weight:var(--node-font-weight,400);grid-area:1/1}.root-node .node-input-sizer:after{font-size:30px;font-weight:700}.node-input-sizer.multiline{align-items:stretch;min-width:240px;max-width:640px}.node-input-sizer.multiline:after{white-space:pre-wrap;word-break:break-word;padding-right:2px}.node-input{color:var(--text);font-size:var(--node-font-size,18px);font-weight:var(--node-font-weight,400);pointer-events:none;cursor:pointer;background:0 0;border:none;outline:none;grid-area:1/1;width:100%;min-width:0;font-family:inherit}textarea.node-input{resize:none;white-space:pre-wrap;word-break:break-word;line-height:1.45;overflow:hidden}.node-wrapper.editing .node-input{pointer-events:auto;cursor:text}.node-input::placeholder{color:var(--text-muted)}.split-popup{background:var(--bg,#fff);border:1px solid var(--border,#d4d4d8);z-index:30;white-space:nowrap;border-radius:10px;flex-direction:column;gap:4px;padding:6px;display:flex;position:absolute;top:-12px;left:50%;transform:translate(-50%,-100%);box-shadow:0 8px 24px #0000001f}.split-popup-btn{appearance:none;color:var(--text,#1a1a1a);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;padding:8px 14px;font-family:inherit;font-size:14px}.split-popup-btn:hover{background:var(--hover,#f4f4f5)}.node-emoji{flex-shrink:0;font-size:16px}.collapse-btn{border:2px solid var(--border);background:var(--bg);cursor:pointer;z-index:2;width:20px;height:20px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:9px;transition:background .15s,transform .15s;display:flex;position:absolute;top:50%;right:-14px;transform:translateY(-50%)}.collapse-btn:hover{background:var(--surface-hover);transform:translateY(-50%)scale(1.1)}.add-child-handle{border:2px solid var(--accent);background:var(--bg);width:22px;height:22px;color:var(--accent);cursor:pointer;z-index:3;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;line-height:1;transition:background .15s,transform .15s;display:flex;position:absolute;top:50%;right:-14px;transform:translateY(-50%)}.add-child-handle:hover{background:var(--accent);color:#fff;transform:translateY(-50%)scale(1.15)}.add-sibling-btn{border:2px solid var(--accent);background:var(--bg);width:22px;height:22px;color:var(--accent);cursor:pointer;z-index:3;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:700;line-height:1;transition:background .15s,transform .15s;display:flex;position:absolute;bottom:-14px;left:50%;transform:translate(-50%)}.add-sibling-btn:hover{background:var(--accent);color:#fff;transform:translate(-50%)scale(1.15)}.node-toolbar{background:var(--bg);border:1px solid var(--border);z-index:50;white-space:nowrap;border-radius:10px;align-items:center;gap:2px;margin-bottom:6px;padding:4px 6px;display:flex;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 12px #0000001a}.toolbar-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:5px 8px;font-family:inherit;font-size:12px;transition:background .1s,color .1s;display:flex}.toolbar-btn:hover{background:var(--surface-hover);color:var(--text)}.toolbar-btn.danger:hover{color:#ef4444;background:#ef444426}.toolbar-btn svg{width:14px;height:14px}.toolbar-btn span{font-size:11px}.toolbar-divider{background:var(--border);width:1px;height:20px;margin:0 2px}.node-children{flex-direction:column;gap:10px;margin-left:48px;display:flex;position:relative}.node-group.depth-0>.node-children{gap:44px}.node-group.depth-1>.node-children{gap:8px}.node-group.depth-2>.node-children,.node-group.depth-3>.node-children,.node-group.depth-4>.node-children{gap:6px}.connector-svg{pointer-events:none;position:absolute;overflow:visible}.zoom-controls{background:var(--bg);border:1px solid var(--border);z-index:20;border-radius:8px;align-items:center;gap:2px;padding:2px;display:flex;position:absolute;bottom:16px;right:16px;box-shadow:0 2px 8px #00000014}.zoom-btn{width:32px;height:32px;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:18px;transition:background .1s;display:flex}.zoom-btn:hover{background:var(--surface-hover)}.zoom-label{min-width:48px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-family:inherit;font-size:12px;transition:background .1s;display:flex}.zoom-label:hover{background:var(--surface-hover);color:var(--text)}.node-image-container{flex-direction:column;gap:4px;display:flex}.node-image{object-fit:contain;border-radius:4px;max-width:200px;max-height:150px}.node-link-container{align-items:center;gap:6px;display:flex}.node-link-icon{flex-shrink:0;font-size:14px;text-decoration:none}.node-type-link .node-input{color:#3b82f6;cursor:pointer;text-decoration:underline}.emoji-picker{background:var(--surface);border:1px solid var(--border);z-index:100;border-radius:12px;flex-direction:column;width:320px;max-height:360px;margin-top:4px;display:flex;position:absolute;top:100%;left:0;overflow:hidden;box-shadow:0 8px 32px #0006}.emoji-search{background:var(--bg);color:var(--text);border:none;border-bottom:1px solid var(--border);outline:none;padding:8px 12px;font-family:inherit;font-size:13px}.emoji-search::placeholder{color:var(--text-muted)}.emoji-categories{border-bottom:1px solid var(--border);flex-shrink:0;gap:2px;padding:4px 6px;display:flex;overflow-x:auto}.emoji-cat-btn{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-family:inherit;font-size:11px}.emoji-cat-btn.active{background:var(--accent);color:#fff}.emoji-cat-btn:hover{background:var(--surface-hover)}.emoji-cat-btn.active:hover{background:var(--accent)}.emoji-grid{flex:1;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px;display:grid;overflow-y:auto}.emoji-btn{cursor:pointer;aspect-ratio:1;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;font-size:22px;transition:background .1s;display:flex}.emoji-btn:hover{background:var(--surface-hover)}.emoji-btn.emoji-btn-none{color:var(--text-muted);border:1px dashed var(--border)}.emoji-btn.emoji-btn-none:hover{color:var(--text);border-color:var(--text-muted);background:var(--surface-hover)}.emoji-remove-btn{border:none;border-top:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;padding:8px;font-family:inherit;font-size:12px}.emoji-remove-btn:hover{background:var(--surface-hover);color:var(--text)}.node-kind-icon{color:var(--kind-color);flex-shrink:0;justify-content:center;align-items:center;line-height:0;display:inline-flex}.node-kind-icon.inherited{opacity:.55}.node-task-checkbox{border:1.5px solid var(--text);color:#fff;cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;padding:0;line-height:0;transition:background .12s,transform .12s,border-color .12s;display:inline-flex}.node-task-checkbox:hover{transform:scale(1.08)}.node-self.task-done .node-task-checkbox{background:var(--text);border-color:var(--text)}.node-self.task-done .node-input,.node-self.task-done .node-input-sizer:after{color:var(--text-muted);text-decoration:line-through}.node-self.kind-inherited:not(.task-done) .node-task-checkbox{border-color:var(--text-muted)}.toolbar-btn.kind-btn{border:1px solid #0000;border-radius:6px;padding:5px;line-height:0;transition:background .12s,border-color .12s}.toolbar-btn.kind-btn:hover{background:color-mix(in srgb, currentColor 10%, transparent)}.toolbar-btn.kind-btn.active{background:color-mix(in srgb, currentColor 16%, transparent);border-color:color-mix(in srgb, currentColor 50%, transparent)}.kind-btn-icon{display:block}.toolbar-btn.kind-btn-none{color:var(--text-muted);padding:5px 8px}.kind-btn-none-label{font-size:11px;font-weight:500;line-height:1}.kind-dashboard{letter-spacing:.01em;align-items:center;gap:14px;margin-left:auto;margin-right:16px;font-size:12px;display:flex}.kind-dashboard-item{font-variant-numeric:tabular-nums;white-space:nowrap;align-items:center;gap:4px;font-weight:600;display:inline-flex}.sidebar-toggle{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:inline-flex}.sidebar-toggle:hover{background:var(--surface-hover);color:var(--text)}.sidebar{border-right:1px solid var(--border);background:var(--surface);flex-direction:column;flex-shrink:0;width:280px;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.sidebar-title{color:var(--text);letter-spacing:.02em;font-size:13px;font-weight:600}.sidebar-close{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s;display:inline-flex}.sidebar-close:hover{background:var(--surface-hover);color:var(--text)}.sidebar-copy{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:4px;margin-left:auto;padding:3px 8px;font-family:inherit;font-size:11px;transition:background .12s,color .12s,border-color .12s}.sidebar-copy:hover{background:var(--accent);border-color:var(--accent);color:#fff}.sidebar-copy+.sidebar-close{margin-left:4px}.template-edit-banner{color:#6b21a8;background:#8b5cf61f;border-bottom:1px solid #8b5cf659;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:8px 16px;font-size:13px;display:flex}.template-edit-banner strong{font-weight:700}.template-edit-banner-hint{color:var(--text-muted);margin-left:8px;font-size:11px}.template-edit-banner-actions{flex-shrink:0;gap:6px;display:flex}.template-manager-dialog{width:560px;max-width:calc(100vw - 32px);max-height:85vh;overflow-y:auto}.template-empty{color:var(--text-muted);background:var(--surface);border:1px dashed var(--border);border-radius:6px;padding:10px 12px;font-size:12px}.template-save-row{align-items:stretch;gap:8px;display:flex}.template-save-row .dialog-input{flex:1}.template-item-actions.always-visible{opacity:1!important}.template-manager-create-row{background:#3b82f60d;border:1px solid #3b82f640;border-radius:8px;align-items:center;gap:10px;margin-bottom:4px;padding:10px 12px;display:flex}.template-manager-create-hint{color:var(--text-muted);font-size:11.5px;line-height:1.4}.template-tips{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:12px;line-height:1.5}.template-tips-list{flex-direction:column;gap:4px;margin:6px 0 0;padding:0;list-style:none;display:flex}.template-tips-list li{grid-template-columns:auto 1fr auto auto;align-items:center;gap:8px;font-size:12px;display:grid}.template-tips-list code{background:var(--bg);border:1px solid var(--border);color:var(--text);white-space:nowrap;border-radius:4px;padding:1px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11.5px}.template-tips-label,.template-tips-arrow{color:var(--text-muted);font-size:11px}.template-tips-example{color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:11.5px}.sidebar-content{flex:1;padding:8px 0;overflow-y:auto}.sidebar-section{padding:6px 0}.sidebar-section+.sidebar-section{border-top:1px solid var(--border)}.sidebar-section-header{letter-spacing:.05em;text-transform:uppercase;align-items:center;gap:6px;padding:6px 16px;font-size:11px;font-weight:700;display:flex}.sidebar-section-label{flex:1}.sidebar-section-count{font-variant-numeric:tabular-nums;opacity:.8;font-size:11px;font-weight:600}.sidebar-list{margin:0;padding:0;list-style:none}.sidebar-item{cursor:pointer;align-items:flex-start;gap:8px;padding:7px 16px;transition:background 80ms;display:flex}.sidebar-item:hover{background:var(--surface-hover)}.sidebar-item.selected{background:#3b82f617;box-shadow:inset 2px 0 #3b82f6}.sidebar-checkbox{border:1.5px solid var(--text);color:#fff;cursor:pointer;background:0 0;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;margin-top:2px;padding:0;line-height:0;transition:background .12s,border-color .12s;display:inline-flex}.sidebar-checkbox:hover{background:var(--surface-hover)}.sidebar-item.done .sidebar-checkbox{background:var(--text);border-color:var(--text)}.sidebar-item-body{flex:1;min-width:0}.sidebar-item-text{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.sidebar-item.done .sidebar-item-text{color:var(--text-muted);text-decoration:line-through}.sidebar-item-placeholder{color:var(--text-muted);font-style:italic}.sidebar-item-path{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:10.5px;overflow:hidden}.sidebar-empty{text-align:center;color:var(--text-muted);padding:24px 16px;font-size:12px;line-height:1.5}.sidebar-empty-hint{opacity:.8;margin-top:8px;font-size:11px}.map-explorer{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;min-height:0;transition:width .15s;display:flex}.map-explorer.collapsed{justify-content:flex-start;align-items:center;width:28px;padding-top:8px}.map-explorer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.map-explorer-title{letter-spacing:.02em;color:var(--text-muted);text-transform:uppercase;font-size:12px;font-weight:600}.map-explorer-toggle{cursor:pointer;width:20px;height:20px;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:14px;line-height:1;display:inline-flex}.map-explorer-toggle:hover{background:var(--surface-hover);color:var(--text)}.map-explorer-body{flex:1;min-height:0;padding:6px 4px 12px;overflow-y:auto}.map-explorer-group{margin-bottom:2px}.map-explorer-group-header{color:var(--text);border-radius:4px;align-items:flex-start;gap:4px;padding:4px 6px;font-size:12.5px;display:flex;position:relative}.map-explorer-group-header:hover{background:var(--surface-hover)}.map-explorer-chev{cursor:pointer;width:16px;height:16px;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;line-height:1;display:inline-flex}.map-explorer-group-name{overflow-wrap:anywhere;word-break:break-word;cursor:pointer;-webkit-user-select:none;user-select:none;flex:1;min-width:0;padding:1px 0;font-weight:600;line-height:1.35}.map-explorer-rename-input{border:1px solid var(--border-selected);background:var(--bg);color:var(--text);border-radius:3px;outline:none;flex:1;min-width:0;padding:2px 4px;font-size:12.5px;font-weight:600}.map-explorer-count{display:none}.map-explorer-add,.map-explorer-menu-btn{width:20px;height:20px;color:var(--text-muted);cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;line-height:1;display:inline-flex}.map-explorer-group-header:hover .map-explorer-add,.map-explorer-group-header:hover .map-explorer-menu-btn,.map-explorer-group-header:hover .group-reorder-btns,.map-explorer-map:hover .map-explorer-menu-btn{opacity:1}.map-explorer-add:hover,.map-explorer-menu-btn:hover{background:var(--bg);color:var(--text)}.map-explorer-menu-wrapper{flex-shrink:0;position:relative}.map-explorer-menu{background:var(--bg);border:1px solid var(--border);z-index:50;border-radius:6px;min-width:160px;padding:4px;position:absolute;top:calc(100% + 2px);right:0;box-shadow:0 6px 24px #0000001f}.map-explorer-menu-heading{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:4px 8px;font-size:10.5px}.map-explorer-menu-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:6px 8px;font-size:12.5px}.map-explorer-menu-item:hover:not(:disabled){background:var(--surface-hover)}.map-explorer-menu-item:disabled{color:var(--text-muted);opacity:.5;cursor:default}.map-explorer-menu-item.danger{color:#dc2626}.map-explorer-menu-item.danger:hover{background:#fee2e2}.map-explorer-menu-sep{background:var(--border);height:1px;margin:4px 0}.map-explorer-menu-note{color:var(--text-muted);padding:6px 8px;font-size:11px}.map-explorer-maps{margin-left:16px;padding:2px 0}.map-explorer-map{border-radius:4px;align-items:center;gap:4px;margin:1px 0;padding:2px 4px;display:flex;position:relative}.map-explorer-map:hover{background:var(--surface-hover)}.map-explorer-map.active{background:#3b82f61a}.map-explorer-map.active .map-explorer-map-title{color:var(--accent);font-weight:600}.map-explorer-map-main{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:4px;flex-direction:column;flex:1;gap:1px;min-width:0;padding:4px 6px;display:flex}.map-explorer-map-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;overflow:hidden}.map-explorer-map-meta{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:10.5px;overflow:hidden}.map-explorer-empty-maps{color:var(--text-muted);padding:6px 10px;font-size:11px}.map-explorer-new-group-btn,.map-explorer-new-group-form{margin:8px 6px 0;display:block}.map-explorer-new-group-btn{border:1px dashed var(--border);width:calc(100% - 12px);color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border-radius:6px;padding:6px 8px;font-size:12px}.map-explorer-new-group-btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--text-muted)}.map-explorer-new-group-input{border:1px solid var(--border-selected);background:var(--bg);width:100%;color:var(--text);border-radius:6px;outline:none;padding:6px 8px;font-size:12.5px}.map-explorer-footer{border-top:1px solid var(--border);flex-shrink:0;padding:8px}.map-explorer-profile{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;width:100%;padding:6px 8px;display:flex}.map-explorer-profile:hover{background:var(--surface-hover)}.map-explorer-profile-avatar{background:var(--accent);color:#fff;text-transform:uppercase;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:inline-flex}.map-explorer-profile-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.map-explorer-profile-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;font-weight:600;overflow:hidden}.map-explorer-profile-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:10.5px;overflow:hidden}.map-explorer-profile-edit{color:var(--text-muted);flex-shrink:0;font-size:14px}.map-explorer-currentgroup{color:var(--text-muted);margin-top:6px;padding:0 8px;font-size:11px}.map-explorer-currentgroup strong{color:var(--text);font-weight:600}.dialog-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog{background:var(--bg);border-radius:12px;flex-direction:column;gap:14px;width:420px;max-width:calc(100vw - 32px);padding:24px;display:flex;box-shadow:0 8px 32px #00000026}.dialog-title{color:var(--text);font-size:18px;font-weight:700}.dialog-desc{color:var(--text-muted);font-size:13px;line-height:1.5}.dialog-field{flex-direction:column;gap:6px;display:flex}.dialog-label{color:var(--text-muted);font-size:12px;font-weight:600}.dialog-input{border:1px solid var(--border);color:var(--text);background:var(--bg);border-radius:6px;outline:none;padding:8px 10px;font-size:14px}.dialog-input:focus{border-color:var(--border-selected)}.dialog-check{color:var(--text);cursor:pointer;align-items:center;gap:8px;font-size:12.5px;display:flex}.dialog-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.dialog-btn{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:6px;padding:7px 14px;font-size:13px}.dialog-btn:hover:not(:disabled){background:var(--surface-hover)}.dialog-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.dialog-btn.primary:hover:not(:disabled){opacity:.92}.dialog-btn:disabled{opacity:.5;cursor:not-allowed}.new-map-dialog{width:520px}.new-map-blank-card{border:1px solid var(--border);background:var(--bg);cursor:pointer;text-align:left;border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px 14px;font-family:inherit;transition:background .1s,border-color .1s;display:flex}.new-map-blank-card:hover{background:var(--surface-hover);border-color:var(--accent)}.new-map-blank-icon{width:32px;height:32px;color:var(--accent);background:#3b82f61a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:inline-flex}.new-map-blank-body{flex-direction:column;gap:2px;min-width:0;display:flex}.new-map-blank-title{color:var(--text);font-size:13px;font-weight:600}.new-map-blank-desc{color:var(--text-muted);font-size:11.5px}.new-map-tpl-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.new-map-tpl-add{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:11.5px;transition:background .1s,color .1s,border-color .1s}.new-map-tpl-add:hover{background:var(--surface-hover);color:var(--text);border-color:var(--text-muted)}.dialog-section{flex-direction:column;gap:8px;display:flex}.dialog-select{border:1px solid var(--border);color:var(--text);background:var(--bg);border-radius:6px;outline:none;padding:8px 10px;font-family:inherit;font-size:13px}.dialog-select:focus{border-color:var(--border-selected)}.template-list{grid-template-columns:1fr 1fr;gap:8px;display:grid}.template-item{border:1px solid var(--border);background:var(--bg);cursor:pointer;text-align:left;border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;font-family:inherit;transition:background .1s,border-color .1s;display:flex;position:relative}.template-item:hover{background:var(--surface-hover)}.template-item.selected{border-color:var(--accent);background:#3b82f60f}.template-item-body{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.template-item-name{color:var(--text);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.template-item-badge{color:#8b5cf6;letter-spacing:.03em;background:#8b5cf61f;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}.template-item-owner{color:var(--text-muted);background:#0000000a;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:500}.template-group-section{margin-bottom:12px}.template-group-section:last-child{margin-bottom:0}.template-group-label{color:var(--text-muted);letter-spacing:.04em;margin-bottom:4px;padding-left:2px;font-size:11px;font-weight:600}.template-item-desc{color:var(--text-muted);font-size:11px;line-height:1.4}.template-item-rename{border:1px solid var(--border-selected);background:var(--bg);color:var(--text);border-radius:4px;outline:none;width:100%;padding:3px 6px;font-size:13px;font-weight:600}.template-item-actions{opacity:0;flex-shrink:0;gap:2px;transition:opacity .1s;display:flex}.template-item:hover .template-item-actions,.template-item.selected .template-item-actions{opacity:1}.template-item-action{width:22px;height:22px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:13px;line-height:1;display:inline-flex}.template-item-action:hover{background:var(--surface-hover);color:var(--text)}.template-item-action.danger:hover{color:#dc2626;background:#ef44441f}.template-preview{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:10px 12px}.template-preview-root{color:var(--text);font-size:14px;font-weight:700}.template-preview-children{flex-direction:column;gap:4px;margin:8px 0 0;padding:0 0 0 12px;list-style:none;display:flex}.template-preview-children li{color:var(--text);align-items:center;gap:6px;font-size:13px;display:flex}.template-preview-kind{letter-spacing:.03em;border-radius:3px;padding:1px 6px;font-size:10.5px;font-weight:700}.template-preview-kind.kind-goal{color:#3b82f6;background:#3b82f626}.template-preview-kind.kind-issue{color:#ef4444;background:#ef444426}.template-preview-kind.kind-task{color:#10b981;background:#10b98126}.template-preview-kind.kind-idea{color:#ca8a04;background:#eab30826}.template-preview-kind.kind-question{color:#8b5cf6;background:#8b5cf626}.template-preview-kind.kind-decision{color:#64748b;background:#64748b26}.group-mark{width:14px;height:14px;color:var(--text-muted);opacity:.55;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;line-height:1;display:inline-flex}.group-mark-private{font-size:9px}.group-mark-editor,.group-mark-viewer{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.group-members{flex-shrink:0;align-items:center;margin-left:4px;display:inline-flex}.group-member-avatar{background:var(--surface);width:16px;height:16px;color:var(--text-muted);border:1px solid var(--bg);box-shadow:0 0 0 1px var(--border);text-transform:uppercase;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;margin-left:-4px;font-size:9px;font-weight:600;display:inline-flex}.group-member-avatar:first-child{margin-left:0}.group-member-avatar.is-owner{background:var(--bg);color:var(--text)}.group-member-extra{background:var(--bg);color:var(--text-muted);width:auto;min-width:18px;padding:0 2px;font-size:8px;font-weight:700}.map-explorer-group-header.shared-header{border-top:1px solid var(--border);color:var(--text-muted);margin-top:4px;padding-top:10px}.shared-role-badge{letter-spacing:.02em;vertical-align:middle;border-radius:3px;margin-left:6px;padding:0 6px;font-size:10px;font-weight:600;display:inline-block}.shared-role-badge.role-editor{color:#166534;background:#22c55e26}.shared-role-badge.role-viewer{color:#475569;background:#64748b26}.shared-map-banner{border-bottom:1px solid;flex-shrink:0;align-items:center;padding:6px 16px;font-size:12px;display:flex}.shared-map-banner-editor{color:#166534;background:#22c55e14;border-bottom-color:#22c55e4d}.shared-map-banner-viewer{color:#475569;background:#64748b14;border-bottom-color:#64748b4d}.shared-map-banner strong{font-weight:600}.shared-map-banner-action{color:inherit;opacity:.85;background:#fff9;border:1px solid;border-radius:4px;margin-left:auto;padding:2px 10px;font-size:11.5px;text-decoration:none}.shared-map-banner-action:hover{opacity:1}.audit-log-dialog{width:520px}.audit-list{flex-direction:column;gap:2px;max-height:60vh;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.audit-item{border-bottom:1px solid var(--border);grid-template-columns:auto auto 1fr;align-items:baseline;gap:10px;padding:6px 8px;font-size:12px;display:grid}.audit-item:last-child{border-bottom:none}.audit-time{color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:11px}.audit-actor{color:var(--text);white-space:nowrap;font-weight:600}.audit-desc{color:var(--text)}.audit-item.audit-delete .audit-desc{color:#dc2626}.audit-item.audit-share_add .audit-desc,.audit-item.audit-share_update .audit-desc{color:#166534}.share-dialog{width:520px}.dialog-error{color:#dc2626;background:#ef444414;border:1px solid #ef44444d;border-radius:6px;padding:8px 10px;font-size:12.5px}.share-access-note{color:var(--text-muted);background:#eab30814;border:1px solid #eab3084d;border-radius:6px;margin-bottom:6px;padding:6px 8px;font-size:11px;line-height:1.5}.share-access-note strong{color:#a16207}.share-access-note a{color:var(--accent)}.share-link-row{align-items:stretch;gap:6px;display:flex}.share-link-row .dialog-input{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}.share-invite-row{align-items:stretch;gap:6px;display:flex}.share-invite-row .dialog-input{flex:1}.share-invite-row .dialog-select{flex-shrink:0;min-width:110px}.share-collab-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.share-collab-item{border:1px solid var(--border);background:var(--bg);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;display:flex}.share-collab-avatar{background:var(--surface);width:28px;height:28px;color:var(--text);text-transform:uppercase;border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.share-collab-email-sub{color:var(--text-muted);margin-left:4px;font-size:11px;font-weight:400}.share-collab-info{flex:1;min-width:0}.share-collab-email{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.share-collab-meta{color:var(--text-muted);margin-top:2px;font-size:11px}.share-collab-role{min-width:100px;font-size:12px}.share-collab-role-label{color:var(--text-muted);background:var(--surface);border-radius:4px;padding:3px 8px;font-size:11.5px}.share-collab-remove{border:1px solid var(--border);background:var(--bg);width:24px;height:24px;color:var(--text-muted);cursor:pointer;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:background .1s,color .1s,border-color .1s;display:inline-flex}.share-collab-remove:hover:not(:disabled){color:#dc2626;background:#ef44441a;border-color:#dc2626}.share-collab-remove:disabled{opacity:.5;cursor:not-allowed}.app-toast{color:#fff;z-index:200;pointer-events:none;background:#111827eb;border-radius:8px;padding:9px 16px;font-size:13px;animation:.2s ease-out toast-fade-in;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0003}@keyframes toast-fade-in{0%{opacity:0;transform:translate(-50%,4px)}to{opacity:1;transform:translate(-50%)}}
