:root{--bg: #f3f4f6;--dot: #d3d6dc;--ink: #1f2329;--muted: #8b909a;--accent: #4f46e5;--frame-border: #e2e4e9;--label: #6b7280}*{box-sizing:border-box}[hidden]{display:none!important}html,body{margin:0;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink)}#viewport{position:fixed;top:0;right:0;bottom:0;left:260px;overflow:hidden;cursor:grab;background-color:var(--bg);background-image:radial-gradient(circle,var(--dot) 1px,transparent 1px);background-size:24px 24px;background-position:0 0}#viewport.panning{cursor:grabbing}#world{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform}.node{position:absolute;background:#fff;border:1px solid var(--frame-border);border-radius:12px;box-shadow:0 1px 3px #1018280f,0 8px 24px #1018280f;overflow:hidden}.node-label{position:absolute;left:2px;bottom:100%;margin-bottom:6px;font-size:12px;font-weight:500;color:var(--label);white-space:nowrap;transform-origin:left bottom;pointer-events:none;-webkit-user-select:none;user-select:none}.node-content{width:100%;height:100%;overflow:hidden}#hud{position:fixed;left:276px;bottom:16px;background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--frame-border);border-radius:10px;padding:10px 12px;font-size:12px;line-height:1.6;box-shadow:0 4px 16px #10182814;z-index:10}.hud-row{display:flex;gap:8px;align-items:center}.muted{color:var(--muted)}#hud button{font:inherit;border:1px solid var(--frame-border);background:#fff;border-radius:6px;padding:2px 8px;cursor:pointer}#hud button:hover{border-color:var(--accent);color:var(--accent)}#zoomLabel{font-variant-numeric:tabular-nums;min-width:38px;display:inline-block}.present-fab{position:fixed;top:16px;right:16px;z-index:20;box-sizing:border-box;height:38px;font:inherit;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:8px;padding:0 14px;cursor:pointer;box-shadow:0 4px 16px #1018281f}.present-fab:hover{filter:brightness(1.06)}.comment-fab{position:fixed;top:16px;right:124px;z-index:20;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--frame-border);background:#fff;color:var(--ink);border-radius:8px;cursor:pointer;box-shadow:0 4px 16px #1018281a}.comment-fab:hover{border-color:var(--accent);color:var(--accent)}.comment-fab.active{background:var(--accent);border-color:var(--accent);color:#fff}#commentLayer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:16}.comment-pin{position:fixed;pointer-events:auto;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:0;background:#fff;border:1px solid var(--frame-border);border-radius:999px 999px 999px 5px;padding:3px;box-shadow:0 3px 10px #10182847;cursor:pointer}.comment-pin.resolved{opacity:.7}.comment-pin .cp-dot{width:20px;height:20px;border-radius:50%;border:1.5px solid #fff;background:var(--accent);color:#fff;font-size:10px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center}.comment-pin .cp-dot+.cp-dot{margin-left:-7px}.comment-pin .cp-more{background:#eef0ff;color:var(--accent)}.comment-pin.resolved .cp-dot{background:#9aa0aa}.comment-pin.resolved .cp-more{background:#eee;color:#9aa0aa}.comment-pin .cp-count{position:absolute;top:-7px;right:-7px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--accent);color:#fff;border:1.5px solid #fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.comment-pin.resolved .cp-count{background:#9aa0aa}.comment-pin .cp-check{position:absolute;top:-7px;right:-7px;width:16px;height:16px;border-radius:999px;background:#16a34a;color:#fff;border:1.5px solid #fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}.comment-pin:hover{filter:brightness(1.02);box-shadow:0 4px 14px #10182857}.comment-panel{position:fixed;z-index:210;background:#fff;border:1px solid var(--frame-border);border-radius:12px;box-shadow:0 12px 40px #1018282e;padding:10px;width:290px;display:flex;flex-direction:column;gap:8px}.cc-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.cc-head>span{font-size:12px;color:var(--muted);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cc-close{font-size:18px;line-height:1;width:22px;height:22px;border:none;background:none;color:var(--muted);cursor:pointer;border-radius:6px;flex-shrink:0}.cc-close:hover{background:#f1f1f4;color:var(--ink)}.cp-threads{display:flex;flex-direction:column;gap:10px;max-height:340px;overflow-y:auto}.ct-thread{display:flex;flex-direction:column;gap:6px;padding:10px;border:1px solid var(--frame-border);border-radius:10px;background:#fafafb}.ct-thread.resolved{opacity:.72}.ct-resolved-tag{font-size:11px;font-weight:700;color:#16a34a}.ct-msgs{display:flex;flex-direction:column;gap:8px}.ct-msg{display:flex;gap:8px;position:relative}.ct-msg-av{position:relative;z-index:1;flex-shrink:0;width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}.ct-thread.resolved .ct-msg-av{background:#9aa0aa}.ct-msg-c{display:flex;flex-direction:column;gap:1px;min-width:0}.ct-msg.targeted .ct-msg-c{background:color-mix(in srgb,var(--accent) 12%,transparent);border-radius:7px;padding:3px 7px;margin:-3px -7px}.ct-msg-acts{display:flex;gap:12px;margin-top:2px}.ct-replylink{background:none;border:none;padding:0;font:inherit;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer}.ct-replylink:hover{color:var(--accent)}.ct-resolvelink:hover{color:#16a34a}.ct-msg.msg-resolved .ct-msg-av{background:#16a34a}.ct-msg.msg-resolved .ct-author,.ct-msg.msg-resolved .ct-body{color:var(--muted)}.ct-msg.msg-resolved .ct-body{text-decoration:line-through}.ct-target{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);background:color-mix(in srgb,var(--accent) 10%,transparent);border-radius:7px;padding:4px 8px}.ct-target b{color:var(--ink)}.ct-target-x{margin-left:auto;background:none;border:none;cursor:pointer;font-size:15px;line-height:1;color:var(--muted);padding:0 2px}.ct-target-x:hover{color:var(--ink)}.ct-author{font-size:12px;font-weight:700;color:var(--ink)}.cp-new{display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--frame-border);padding-top:8px}.cp-new textarea,.ct-reply{font:inherit;font-size:13px;resize:none;border:1px solid var(--frame-border);border-radius:8px;padding:7px;outline:none;color:var(--ink)}.cp-new textarea:focus,.ct-reply:focus{border-color:var(--accent)}.ct-meta{font-size:12px;color:var(--muted);font-weight:600}.ct-actions{display:flex;gap:6px;justify-content:flex-end}.ct-actions button{font:inherit;font-size:12px;font-weight:600;border:1px solid var(--frame-border);background:#fff;color:var(--ink);border-radius:7px;padding:4px 10px;cursor:pointer}.cc-send,.ct-reply-send{border-color:var(--accent)!important;background:var(--accent)!important;color:#fff!important;align-self:flex-end;font:inherit;font-size:12px;font-weight:600;border-radius:7px;padding:5px 12px;cursor:pointer;border:1px solid var(--accent)}.ct-body{font-size:14px;color:var(--ink);line-height:1.45;white-space:pre-wrap}.ct-actions{display:flex;gap:8px;justify-content:flex-end}.ct-actions button{background:#fff;color:var(--ink);border-color:var(--frame-border);font-weight:500}.ct-actions button:hover{border-color:var(--accent);color:var(--accent)}.ct-actions button.danger:hover{border-color:#dc2626;color:#dc2626}.present{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;flex-direction:column;background:#0f1115}.present-bar{display:flex;align-items:center;gap:12px;padding:9px 14px;background:#fff;border-bottom:1px solid var(--frame-border);flex-shrink:0}.present-back{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--frame-border);background:#fff;border-radius:8px;cursor:pointer;color:var(--muted);flex-shrink:0}.present-back:hover{border-color:var(--accent);color:var(--accent)}.present-title{font-weight:600;color:var(--ink)}.present-hint{font-size:12px;color:var(--muted)}.present-spacer{margin-left:auto}.present-close{font-size:22px;line-height:1;width:34px;height:34px;border:1px solid var(--frame-border);background:#fff;border-radius:8px;cursor:pointer;color:var(--muted)}.present-close:hover{border-color:var(--accent);color:var(--accent)}.present-stage{flex:1;min-height:0;background:#fff}.present-iframe{width:100%;height:100%;border:0;display:block;background:#fff}#authgate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:none;align-items:center;justify-content:center;background:#fff}#authgate.show{display:flex}.gate-card{display:flex;flex-direction:column;align-items:center;text-align:center;color:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:24px}.gate-logo{width:clamp(200px,24vw,360px);height:auto;display:block}.gate-tagline{font-size:15px;color:#6b7280;margin:4px 0 32px}#signinBtn{display:inline-flex;align-items:center;gap:10px;font:inherit;font-weight:600;font-size:15px;color:#fff;background:#000;border:1px solid #000;border-radius:999px;padding:13px 22px;cursor:pointer;transition:opacity .12s ease,transform .08s ease}#signinBtn:hover{opacity:.85;transform:translateY(-1px)}#signinBtn:active{transform:translateY(0)}.g-icon{width:17px;height:17px;flex-shrink:0}.gate-err{color:#b91c1c;font-size:13px;margin-top:14px;min-height:16px}#panel{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:20;background:#fff;border-right:1px solid var(--frame-border);display:flex;flex-direction:column;font-size:13px}.panel-head{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--frame-border);overflow:hidden}.panel-logo{width:18px;height:18px;flex-shrink:0;object-fit:contain}.panel-title{font-weight:600;color:var(--ink);flex-shrink:0}.panel-board{margin-left:auto;flex:0 1 auto;min-width:0;font-size:13px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-left:10px}.panel-board:hover{color:var(--ink)}.tree{flex:1;overflow-y:auto;padding:6px 0}.tree-row{display:flex;align-items:center;gap:9px;height:30px;margin:0 8px;padding:0 8px;border-radius:8px;cursor:pointer;white-space:nowrap;color:#374151;-webkit-user-select:none;user-select:none}.tree-row:hover{background:#f4f4f6}.tree-row.selected{background:#eef0ff;color:var(--accent)}.tree-caret{width:16px;flex-shrink:0;text-align:center;color:var(--muted);font-size:10px;transition:transform .12s ease}.tree-caret.spacer{visibility:hidden}.tree-row.open>.tree-caret{transform:rotate(90deg)}.tree-tag{color:var(--muted);font-size:11px;flex-shrink:0}.tree-label{overflow:hidden;text-overflow:ellipsis}.tree-children{display:none}.tree-node.open>.tree-children{display:block}#gotobar{position:fixed;top:14px;left:260px;right:0;z-index:15;display:flex;justify-content:center;pointer-events:none}.goto-wrap{pointer-events:auto;display:flex;align-items:center;gap:8px;width:min(520px,60%);background:#fffffff5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--frame-border);border-radius:10px;padding:9px 12px;box-shadow:0 4px 16px #10182814}.goto-wrap:focus-within{border-color:var(--accent)}.goto-icon{color:var(--muted);flex-shrink:0}#gotoInput{flex:1;border:none;outline:none;font:inherit;font-size:13px;color:var(--ink);background:transparent}#selbox{position:fixed;z-index:14;border:2px solid var(--accent);border-radius:3px;pointer-events:none}#ctxmenu{position:fixed;z-index:30;min-width:180px;background:#fff;border:1px solid var(--frame-border);border-radius:8px;padding:4px;box-shadow:0 8px 28px #10182829;font-size:13px}.ctx-head{padding:6px 8px 7px;margin-bottom:4px;border-bottom:1px solid var(--frame-border);color:var(--muted);font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.ctx-item{display:block;width:100%;text-align:left;font:inherit;font-size:13px;color:var(--ink);background:none;border:none;border-radius:5px;padding:7px 8px;cursor:pointer}.ctx-item:hover{background:#f4f4f6;color:var(--accent)}#dashboard{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;background:#fff;color:var(--ink);font-size:14px}.db-side{width:240px;flex-shrink:0;border-right:1px solid var(--frame-border);display:flex;flex-direction:column;padding:14px 12px}.db-brand{display:flex;align-items:center;gap:9px;padding:6px 8px 16px}.db-brand-logo{width:22px;height:22px;object-fit:contain}.db-brand-name{font-weight:700;font-size:15px;color:var(--ink)}.db-side-foot{margin-top:auto}.db-user{display:flex;align-items:center;gap:9px;padding:8px 10px}.db-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:600}.db-user-name{color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-agents{display:block;text-decoration:none;cursor:pointer;margin:0 2px 10px;padding:14px;border:1px solid #e4e6ee;border-radius:12px;background:linear-gradient(160deg,#f7f8fd,#eef0f8);color:#374151;transition:border-color .15s ease,transform .15s ease}.db-agents:hover{border-color:#4f46e5;transform:translateY(-1px)}.db-agents-head{display:flex;align-items:center;gap:8px}.db-agents-title{font-size:14px;font-weight:600;color:#1f2430}.db-agents-ic{margin-left:auto;font-size:13px;color:#6366f1}.db-agents-sub{margin:7px 0 12px;font-size:12.5px;line-height:1.45;color:#6b7280}.db-agents-cta{display:inline-flex;align-items:center;gap:4px;width:100%;justify-content:center;padding:8px 12px;background:#fff;border:1px solid #d9dce6;border-radius:9px;font-size:13px;font-weight:600;color:#374151;transition:background .15s ease,border-color .15s ease,color .15s ease}.db-agents:hover .db-agents-cta{background:#4f46e5;border-color:#4f46e5;color:#fff}.db-agents-arrow{font-size:14px}.db-main{flex:1;min-width:0;padding:28px 36px;overflow-y:auto}.db-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;gap:16px;flex-wrap:wrap}.db-head h1{font-size:26px;font-weight:700;margin:0}.db-actions{display:flex;align-items:center;gap:10px}.db-tabs{display:flex;background:#f3f4f6;border-radius:9px;padding:3px}.db-tabs button{font:inherit;font-size:13px;border:none;background:none;color:#6b7280;padding:5px 12px;border-radius:7px;cursor:pointer}.db-tabs button.active{background:#fff;color:var(--ink);box-shadow:0 1px 2px #00000014}.db-search{display:flex;align-items:center;gap:7px;border:1px solid var(--frame-border);border-radius:9px;padding:7px 11px;color:var(--muted)}.db-search:focus-within{border-color:var(--accent)}.db-search input{border:none;outline:none;font:inherit;font-size:13px;background:transparent;width:150px;color:var(--ink)}.db-new{font:inherit;font-weight:600;font-size:13px;color:#fff;background:#000;border:none;border-radius:9px;padding:9px 15px;cursor:pointer}.db-new:hover{opacity:.85}.db-thead,.db-row{display:grid;grid-template-columns:1fr 160px 160px 180px 70px;align-items:center;gap:12px}.db-thead{padding:0 12px 10px;border-bottom:1px solid var(--frame-border);color:var(--muted);font-size:12px;font-weight:500}.db-row{padding:9px 12px;border-radius:10px;cursor:pointer;position:relative}.db-row:hover{background:#f7f7f8}.db-name{display:flex;align-items:center;gap:12px;min-width:0}.db-thumb{width:44px;height:34px;border-radius:6px;flex-shrink:0;background:linear-gradient(135deg,#eef0ff,#e9e6ff);border:1px solid var(--frame-border)}.db-name-text{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-muted{color:var(--muted);font-size:13px}.db-by{color:#374151;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.db-row-actions{display:flex;gap:4px;justify-content:flex-end;opacity:0;transition:opacity .1s}.db-row:hover .db-row-actions{opacity:1}.db-iconbtn{font:inherit;font-size:13px;width:28px;height:28px;border:1px solid var(--frame-border);background:#fff;border-radius:7px;cursor:pointer;color:#374151}.db-iconbtn:hover{border-color:var(--accent);color:var(--accent)}.db-rename{font:inherit;font-weight:500;font-size:14px;border:1px solid var(--accent);border-radius:6px;padding:3px 7px;outline:none;min-width:200px}.db-empty{padding:40px 12px;color:var(--muted);text-align:center}#emptyHint{position:fixed;left:260px;right:0;top:0;bottom:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--muted);font-size:14px;pointer-events:none;text-align:center}.empty-title{font-size:17px;font-weight:600;color:var(--ink)}.empty-sub{font-size:13px;color:var(--muted)}.empty-cta{pointer-events:auto;margin-top:14px;font:inherit;font-size:14px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:9px;padding:10px 18px;cursor:pointer;transition:background .12s,transform .08s}.empty-cta:hover{background:#4338ca;transform:translateY(-1px)}.empty-cta:active{transform:translateY(0)}#toast{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:120;background:#1f2329;color:#fff;font-size:13px;padding:10px 16px;border-radius:10px;box-shadow:0 8px 28px #10182840;max-width:80vw}.db-ws-label{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:0 10px 6px}.db-ws-rows{display:flex;flex-direction:column;gap:2px}.db-ws-row{display:flex;align-items:center;gap:9px;width:100%;text-align:left;font:inherit;color:#374151;background:none;border:none;padding:8px 10px;border-radius:8px;cursor:pointer}.db-ws-row:hover{background:#f4f4f6}.db-ws-row.active{background:#f3f4f6}.db-ws-avatar{flex-shrink:0;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:700;letter-spacing:.02em;color:#fff;box-shadow:inset 0 0 0 1px #0000000f}.db-ws-body{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.db-ws-rowname{font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-ws-row.active .db-ws-rowname{font-weight:600}.db-ws-meta{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-ws-edit{opacity:.5;flex-shrink:0;font:inherit;font-size:13px;border:none;background:none;color:var(--muted);cursor:pointer;border-radius:5px;padding:3px 6px;transition:opacity .12s ease,background .12s ease,color .12s ease}.db-ws-row:hover .db-ws-edit{opacity:.85}.db-ws-edit:hover{opacity:1;background:#e7e7ea;color:var(--accent)}.db-ws-rename{font:inherit;font-size:14px;min-width:0;flex:1;border:1px solid var(--accent);border-radius:6px;padding:2px 6px;outline:none}.db-ws-new{margin:8px 2px 0;padding:8px 10px;text-align:left;font:inherit;font-size:13px;font-weight:500;color:var(--accent);background:none;border:none;border-radius:8px;cursor:pointer}.db-ws-new:hover{background:#f4f4f6}.page-group{position:absolute;background:#fbfbfc;border:1px solid #d2d6dd;border-radius:18px;padding:14px 16px 18px;box-shadow:0 1px 3px #1018280d}.page-group.selected{border-color:var(--accent);box-shadow:0 0 0 2px #4f46e540,0 8px 24px #10182814}.page-group-head{display:flex;align-items:baseline;gap:8px;margin:0 2px 12px}.pg-title{font-weight:700;font-size:15px;color:var(--ink)}.pg-meta{color:var(--muted);font-size:12px}.page-group-body{display:flex;gap:24px;align-items:flex-start}.frame{display:flex;flex-direction:column;gap:6px}.frame-label{font-size:11px;font-weight:600;color:#374151}.frame-label span{color:#9aa0aa;font-weight:400}.slot{background:#fff;border:1px solid var(--frame-border);border-radius:10px;overflow:hidden;box-shadow:0 8px 24px #1018280f}.slot-scale{transform-origin:top left}.preview-iframe{width:100%;height:100%;border:0;display:block;background:#fff}.tree-section{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:10px 16px 6px}.tree-ic{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}.tree-row.selected .tree-ic{color:var(--accent)}.gate-form{display:flex;flex-direction:column;gap:10px;width:min(320px,80vw);margin-bottom:10px}.gate-form input{font:inherit;font-size:14px;padding:11px 14px;border:1px solid var(--frame-border);border-radius:10px;outline:none}.gate-form input:focus{border-color:#000}#emailBtn{font:inherit;font-weight:600;font-size:15px;color:#fff;background:#000;border:1px solid #000;border-radius:10px;padding:12px;cursor:pointer;transition:opacity .12s}#emailBtn:hover{opacity:.85}.gate-toggle{font-size:13px;color:var(--muted);margin-bottom:16px}.gate-toggle button{font:inherit;font-size:13px;color:#000;background:none;border:none;cursor:pointer;text-decoration:underline;padding:0;font-weight:600}.gate-or{display:flex;align-items:center;gap:10px;width:min(320px,80vw);color:var(--muted);font-size:12px;margin-bottom:14px}.gate-or:before,.gate-or:after{content:"";height:1px;background:var(--frame-border);flex:1}#signinBtn{background:#fff;color:#1f2329;border:1px solid var(--frame-border)}#signinBtn:hover{opacity:1;border-color:#000;transform:translateY(-1px)}.db-user{position:relative}.db-signout{margin-left:auto;font:inherit;font-size:15px;line-height:1;width:28px;height:28px;border:1px solid transparent;background:none;color:var(--muted);border-radius:7px;cursor:pointer}.db-signout:hover{background:#f0f0f2;color:#b91c1c;border-color:var(--frame-border)}.slot{position:relative}.slot-cover{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;background:transparent}#world.prototype-mode .slot-cover{pointer-events:none}.pg-tabs{display:flex;gap:4px;margin:0 2px 10px}.pg-tab{font:inherit;font-size:12px;font-weight:500;color:#6b7280;background:#f1f2f4;border:1px solid transparent;border-radius:7px;padding:5px 12px;cursor:pointer}.pg-tab:hover{color:var(--ink)}.pg-tab.active{background:#fff;color:var(--accent);border-color:var(--frame-border);box-shadow:0 1px 2px #0000000f}.pg-content{position:relative;display:flex;align-items:flex-start;justify-content:center;overflow-x:hidden;overflow-y:auto}.pg-skel{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;display:flex;flex-direction:column;gap:14px;align-items:center;justify-content:center;background:#fbfbfc}.pg-skel-name{font-size:14px;font-weight:600;color:var(--muted)}.pg-skel-bars{display:flex;flex-direction:column;gap:9px;width:42%}.pg-skel-bars span{height:10px;border-radius:6px;background:linear-gradient(90deg,#ececf0 25%,#f5f5f8 37%,#ececf0 63%);background-size:400% 100%;animation:pg-skel-shimmer 1.4s ease-in-out infinite}.pg-skel-bars span:nth-child(2){width:80%}.pg-skel-bars span:nth-child(3){width:60%}@keyframes pg-skel-shimmer{0%{background-position:100% 0}to{background-position:0 0}}@media (prefers-reduced-motion: reduce){.pg-skel-bars span{animation:none}}.pg-frame{display:flex}.pg-spec{display:none;width:100%;height:100%}.pg-spec-input{width:100%;height:100%;resize:none;border:1px solid var(--frame-border);border-radius:10px;padding:16px;font:inherit;font-size:14px;line-height:1.6;color:var(--ink);background:#fff;outline:none}.pg-spec-input:focus{border-color:var(--accent)}.mention-menu{position:fixed;z-index:40;min-width:180px;max-height:240px;overflow:auto;background:#fff;border:1px solid var(--frame-border);border-radius:10px;padding:4px;box-shadow:0 8px 28px #1018282e}.mention-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;font:inherit;font-size:13px;color:var(--ink);background:none;border:none;border-radius:6px;padding:7px 8px;cursor:pointer}.mention-item:hover{background:#f4f4f6}.mention-item .mk{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--muted);background:#f1f2f4;border-radius:4px;padding:1px 5px}#ctxmenu{max-height:360px;overflow-y:auto}.ctx-sep{height:1px;background:var(--frame-border);margin:4px 0}.ctx-sublabel{font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);padding:6px 8px 2px}.ctx-item.ctx-accent{color:var(--accent);font-weight:600}.pg-title{cursor:text;border-radius:4px;padding:0 3px;margin:0 -3px}.pg-title:hover{background:#eef0ff}.pg-title-input{font:inherit;font-weight:700;font-size:15px;color:var(--ink);border:1px solid var(--accent);border-radius:6px;padding:1px 5px;outline:none;width:200px}.page-group{transition:left .28s ease,top .28s ease}.ctx-conn{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:5px;font-size:13px;color:var(--ink)}.ctx-conn:hover{background:#f4f4f6}.ctx-conn-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ctx-conn-tag{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--muted);background:#f1f2f4;border-radius:4px;padding:1px 5px}.ctx-conn-x{font:inherit;font-size:11px;color:var(--muted);background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:4px}.ctx-conn-x:hover{background:#fee2e2;color:#b91c1c}.ctx-none{font-size:12px;color:var(--muted);padding:5px 8px;font-style:italic}.pg-backref{margin-left:10px;font:inherit;font-size:12px;font-weight:500;color:var(--accent);background:#eef0ff;border:1px solid #dfe1fb;border-radius:999px;padding:2px 10px;cursor:pointer;white-space:nowrap}.pg-backref:hover{background:#e0e3ff}.ctx-conn.go{cursor:pointer}.pg-backref{margin-left:0;margin-right:8px}#selfwd{position:absolute;top:-26px;right:0;pointer-events:auto;font:inherit;font-size:12px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:999px;padding:3px 10px;cursor:pointer;white-space:nowrap;box-shadow:0 2px 8px #4f46e566}#selfwd:hover{background:#4338ca}.pg-building{position:absolute;top:-36px;left:0;display:inline-flex;align-items:center;gap:9px;padding:6px 12px;border-radius:999px;background:linear-gradient(100deg,#6d5efc,var(--accent) 55%,#a78bfa);background-size:220% 100%;color:#fff;font-size:12px;font-weight:600;box-shadow:0 6px 20px #4f46e573;opacity:0;transform:translateY(4px);transition:opacity .2s ease,transform .2s ease;pointer-events:none;z-index:7;white-space:nowrap;animation:pg-pill-shimmer 2.6s linear infinite}.pg-building-label:before{content:"✦ "}.page-group.building .pg-building{opacity:1;transform:translateY(0)}@keyframes pg-pill-shimmer{to{background-position:-220% 0}}.global-busy{position:fixed;top:72px;left:50%;transform:translate(-50%,-8px);display:inline-flex;align-items:center;gap:8px;padding:7px 15px;border-radius:999px;background:linear-gradient(100deg,#6d5efc,var(--accent) 55%,#a78bfa);background-size:220% 100%;color:#fff;font-size:12.5px;font-weight:600;letter-spacing:.01em;box-shadow:0 10px 30px #4f46e56b;opacity:0;pointer-events:none;z-index:50;white-space:nowrap;transition:opacity .25s ease,transform .25s ease;animation:pg-pill-shimmer 2.6s linear infinite}.global-busy.show{opacity:1;transform:translate(-50%)}.global-busy .gb-label:before{content:"✦ "}.global-busy .gb-dots{display:inline-flex;gap:3px}.global-busy .gb-dots span{width:4px;height:4px;border-radius:50%;background:#fff;opacity:.4;animation:pg-twinkle 1.05s ease-in-out infinite}.global-busy .gb-dots span:nth-child(2){animation-delay:.18s}.global-busy .gb-dots span:nth-child(3){animation-delay:.36s}@media (prefers-reduced-motion: reduce){.global-busy,.global-busy .gb-dots span{animation:none}}.pg-build-count{font-size:11px;font-weight:600;color:#ffffffeb;white-space:nowrap}.pg-build-count:before{content:"· ";opacity:.6}.pg-build-bar{width:46px;height:4px;border-radius:999px;background:#ffffff47;overflow:hidden;flex-shrink:0}.pg-build-bar-fill{display:block;height:100%;border-radius:999px;background:#fff;width:0;transition:width .35s ease}.pg-dots{display:inline-flex;gap:4px}.pg-dot{width:5px;height:5px;border-radius:50%;background:#fff;opacity:.35;animation:pg-twinkle 1.05s ease-in-out infinite}.pg-dot:nth-child(2){animation-delay:.15s}.pg-dot:nth-child(3){animation-delay:.55s}.pg-dot:nth-child(4){animation-delay:.3s}.pg-dot:nth-child(5){animation-delay:.8s}.pg-dot:nth-child(6){animation-delay:.1s}@keyframes pg-twinkle{0%,to{opacity:.35;transform:scale(.7)}50%{opacity:1;transform:scale(1.2)}}.page-group.building{box-shadow:0 0 0 1.5px #7c6cfc73,0 12px 36px #4f46e533;animation:pg-glow-pulse 2.6s ease-in-out infinite}@keyframes pg-glow-pulse{0%,to{box-shadow:0 0 0 1.5px #7c6cfc61,0 10px 28px #4f46e526}50%{box-shadow:0 0 0 1.5px #7c6cfc9e,0 16px 40px #4f46e542}}.pg-conjure{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;pointer-events:none;overflow:hidden;opacity:0;transition:opacity .5s ease}.page-group.building .pg-conjure{opacity:1}.pg-aurora{position:absolute;top:-25%;right:-25%;bottom:-25%;left:-25%;filter:blur(8px);background:radial-gradient(40% 40% at 30% 28%,rgba(124,108,252,.15),transparent 70%),radial-gradient(45% 45% at 72% 60%,rgba(56,189,248,.11),transparent 70%),radial-gradient(35% 35% at 52% 82%,rgba(167,139,250,.13),transparent 70%);animation:pg-aurora-drift 6s ease-in-out infinite alternate}@keyframes pg-aurora-drift{0%{transform:translate(-3%,-2%) scale(1)}to{transform:translate(3%,2%) scale(1.08)}}.pg-sweep{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.22) 48%,rgba(199,210,254,.26) 50%,rgba(255,255,255,.22) 52%,transparent 62%);background-size:260% 260%;animation:pg-sweep-move 2.6s ease-in-out infinite}@keyframes pg-sweep-move{0%{background-position:0% 0%}to{background-position:100% 100%}}.pg-stars{position:absolute;top:0;right:0;bottom:0;left:0}.pg-star{position:absolute;color:#fff;line-height:1;text-shadow:0 0 7px rgba(124,108,252,.95);opacity:0;transform:translate(-50%,-50%) scale(.3);animation:pg-star-pop 1.7s ease-in-out infinite}@keyframes pg-star-pop{0%,to{opacity:0;transform:translate(-50%,-50%) scale(.3) rotate(0)}50%{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(90deg)}}@media (prefers-reduced-motion: reduce){.pg-building,.pg-dot,.page-group.building,.pg-aurora,.pg-star{animation:none}.pg-sweep{display:none}}.page-group-head{display:flex;align-items:center;gap:8px}.pg-head-actions{margin-left:auto;flex-shrink:0;display:inline-flex;align-items:center;gap:2px}.pg-start{flex-shrink:0;color:#eab308;font-size:14px;line-height:1;margin-right:2px}.pg-act,.pg-kebab{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid transparent;background:none;color:var(--muted);border-radius:7px;cursor:pointer;opacity:.5;transition:opacity .12s,background .12s,color .12s,border-color .12s}.page-group:hover .pg-act,.page-group:hover .pg-kebab{opacity:.85}.pg-act:hover,.pg-kebab:hover{background:#f1f1f4;border-color:#e6e6ea;color:#111;opacity:1}.pg-kebab-menu{position:fixed;z-index:1000;min-width:168px;padding:6px;background:#fff;border:1px solid #e6e6ea;border-radius:10px;box-shadow:0 8px 28px #00000029;font-size:13px}.pg-kebab-label{padding:4px 8px 6px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em}.pg-kebab-moves{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:0 2px 2px}.pg-move-btn{height:30px;border:1px solid #e6e6ea;background:#fafafb;color:#333;border-radius:7px;cursor:pointer;font-size:15px;line-height:1}.pg-move-btn:hover{background:#eef0ff;border-color:#c8ccff;color:#3b34b8}.pg-kebab-sep{height:1px;background:#eee;margin:6px 2px}.pg-kebab-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 8px;border:none;background:none;border-radius:7px;cursor:pointer;color:#222;text-align:left}.pg-kebab-item:hover{background:#f3f3f6}.pg-kebab-item.danger{color:#b91c1c}.pg-kebab-item.danger:hover{background:#fee2e2}.view-switch{display:flex;gap:4px;margin:10px 8px 4px;padding:3px;background:#f1f1f4;border-radius:9px}.view-btn{flex:1;padding:6px 8px;border:none;background:none;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--muted);border-radius:7px;transition:background .12s,color .12s}.view-btn:hover{color:var(--ink)}.view-btn.active{background:#fff;color:var(--ink);box-shadow:0 1px 3px #1018281a}.world-layer{position:absolute;left:0;top:0}.comp-card{position:absolute;width:528px;background:var(--surface, #fff);border:1px solid var(--frame-border);border-radius:14px;padding:16px;box-shadow:0 8px 24px #1018280f}.comp-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px #4f46e540,0 8px 24px #10182814}.comp-card-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}.comp-title{font-weight:700;font-size:15px;color:var(--ink)}.comp-link{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;background:none;color:var(--muted);border-radius:7px;cursor:pointer;margin-left:auto;opacity:0;transition:opacity .12s,background .12s,color .12s}.comp-card:hover .comp-link{opacity:1}.comp-link:hover{background:#eef0ff;color:var(--accent)}.comp-kind{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:#f1f1f4;padding:2px 7px;border-radius:999px}.comp-tabs{display:flex;gap:4px;margin:6px 0 10px}.comp-tab{font:inherit;font-size:12px;font-weight:500;color:#6b7280;background:#f1f2f4;border:1px solid transparent;border-radius:7px;padding:5px 12px;cursor:pointer}.comp-tab:hover{color:var(--ink)}.comp-tab.active{background:#fff;color:var(--accent);border-color:var(--frame-border);box-shadow:0 1px 2px #0000000f}.comp-desc{color:var(--muted);font-size:12.5px;line-height:1.4;margin-bottom:10px;cursor:text;border-radius:6px;padding:2px 4px;margin-left:-4px}.comp-desc:hover{background:#f4f4f6}.comp-desc.empty{font-style:italic;opacity:.8}.comp-desc-input{width:100%;box-sizing:border-box;margin-bottom:10px;padding:6px 8px;font:inherit;font-size:12.5px;line-height:1.4;color:var(--ink);border:1px solid var(--accent);border-radius:6px;outline:none;resize:vertical}.comp-props{display:flex;flex-wrap:wrap;gap:5px;min-height:0}.comp-prop{font-size:11px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:#4f46e5;background:#eef0ff;border:1px solid #e0e3ff;padding:1px 7px;border-radius:6px}.comp-frame{position:relative;padding:12px;background:#f3f4f6;border:1px solid var(--frame-border);border-radius:12px}.comp-frame[hidden]{display:none}.comp-screen{position:relative;width:100%;height:100%;overflow:hidden;border-radius:7px;background:#fff;box-shadow:inset 0 0 0 1px #1018280d}.comp-frame .preview-iframe{width:100%;height:100%;border:0;display:block;background:#fff}.comp-info-panel{box-sizing:border-box;padding:13px;overflow-y:auto;background:#fff;border:1px solid var(--frame-border);border-radius:10px}.comp-info-panel[hidden]{display:none}.cj-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#10182873;animation:cj-fade .12s ease}.cj-modal{width:min(440px,calc(100vw - 32px));background:#fff;border-radius:14px;padding:22px 22px 18px;box-shadow:0 24px 60px #10182847;animation:cj-pop .14s cubic-bezier(.2,.8,.3,1)}.cj-modal-title{margin:0 0 8px;font-size:17px;font-weight:700;color:var(--ink, #1f2330)}.cj-modal-msg{margin:0 0 20px;font-size:14px;line-height:1.5;color:var(--muted, #6b7280)}.cj-modal-btn{font:inherit;font-size:14px;font-weight:600;padding:9px 16px;border-radius:9px;cursor:pointer;border:1px solid transparent;transition:background .12s,border-color .12s,color .12s}.cj-modal-ghost{background:#fff;color:#374151;border-color:#e1e3ea}.cj-modal-ghost:hover{background:#f4f4f6}.cj-modal-primary{background:var(--accent, #4f46e5);color:#fff}.cj-modal-primary:hover{background:#4338ca}.cj-modal-danger{background:#dc2626;color:#fff}.cj-modal-danger:hover{background:#b91c1c}.cj-modal-btn:focus-visible{outline:2px solid var(--accent, #4f46e5);outline-offset:2px}@keyframes cj-fade{0%{opacity:0}to{opacity:1}}@keyframes cj-pop{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}.cj-modal-label{display:block;margin:0 0 16px;font-size:13px;font-weight:600;color:var(--ink, #1f2330)}.cj-modal-label:last-of-type{margin-bottom:20px}.cj-modal-input{width:100%;box-sizing:border-box;margin:0 0 20px;padding:10px 12px;font:inherit;font-size:14px;font-weight:400;color:var(--ink, #1f2330);border:1px solid #d8dae2;border-radius:9px;outline:none;background:#fff}.cj-modal-label>.cj-modal-input{display:block;margin:6px 0 0}.cj-modal-input:focus{border-color:var(--accent, #4f46e5);box-shadow:0 0 0 3px #4f46e526}.cj-modal-btn:disabled{opacity:.5;cursor:not-allowed}.pg-add{position:absolute;z-index:7;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;font-weight:400;color:var(--accent);background:#fff;border:1px solid #d7dae3;cursor:pointer;box-shadow:0 2px 6px #1018281f;opacity:0;transition:opacity .12s ease,background .12s,color .12s,transform .08s}.page-group.selected .pg-add{opacity:1}.pg-add:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.pg-add:active{transform:scale(.92)}.pg-add-top{top:-34px;left:50%;transform:translate(-50%)}.pg-add-bottom{bottom:-34px;left:50%;transform:translate(-50%)}.pg-add-left{left:-34px;top:50%;transform:translateY(-50%)}.pg-add-right{right:-34px;top:50%;transform:translateY(-50%)}.pg-add-top:active,.pg-add-bottom:active{transform:translate(-50%) scale(.92)}.pg-add-left:active,.pg-add-right:active{transform:translateY(-50%) scale(.92)}.page-group.no-add-right .pg-add-right,.page-group.no-add-left .pg-add-left,.page-group.no-add-top .pg-add-top,.page-group.no-add-bottom .pg-add-bottom{display:none}.pg-add:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);white-space:nowrap;background:#1f2329;color:#fff;font-size:11px;font-weight:500;padding:4px 8px;border-radius:6px;opacity:0;pointer-events:none;transition:opacity .1s}.pg-add:hover:after{opacity:1}.cj-modal-select{cursor:pointer;height:40px;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;background:#fff}.panel-foot{border-top:1px solid var(--frame-border);padding:8px}#membersLink{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;font:inherit;font-size:13px;font-weight:500;color:#374151;background:none;border:none;border-radius:8px;cursor:pointer}#membersLink:hover{background:#f4f4f6;color:var(--ink)}#membersLink svg{color:var(--muted)}.cj-members{width:min(520px,calc(100vw - 32px))}.cj-members-list{display:flex;flex-direction:column;gap:6px;margin:14px 0 20px;max-height:50vh;overflow-y:auto}.cj-member{display:flex;align-items:center;gap:12px;padding:8px;border-radius:10px}.cj-member:hover{background:#f7f7f9}.cj-member-av{flex:0 0 auto;width:34px;height:34px;border-radius:50%;background:#e0e3ff;color:#4338ca;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;overflow:hidden}.cj-member-av img{width:100%;height:100%;object-fit:cover}.cj-member-info{flex:1;min-width:0}.cj-member-name{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cj-member-email{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cj-member-role{font:inherit;font-size:13px;padding:5px 8px;border:1px solid #d8dae2;border-radius:7px;background:#fff;cursor:pointer}.cj-member-rolebadge{font-size:11px;font-weight:600;text-transform:capitalize;color:var(--muted);background:#f1f1f4;padding:3px 9px;border-radius:999px}.cj-member-remove{flex:0 0 auto;width:28px;height:28px;border:1px solid transparent;background:none;color:var(--muted);border-radius:7px;cursor:pointer;font-size:13px}.cj-member-remove:hover{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.cj-modal-actions{display:flex;justify-content:flex-end;gap:10px}.connect-wrap{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:auto}.connect-card{width:min(420px,92vw);margin:32px;background:#fff;border:1px solid var(--frame-border);border-radius:16px;box-shadow:0 12px 40px #1018281f;padding:28px;display:flex;flex-direction:column;gap:12px;text-align:center}.connect-logo{width:150px;height:auto;align-self:center;margin-bottom:4px}.connect-title{font-size:19px;font-weight:700;color:var(--ink)}.connect-sub{font-size:13.5px;color:var(--muted);margin-bottom:8px;line-height:1.45}.connect-google{display:inline-flex;align-items:center;justify-content:center;gap:10px;font:inherit;font-weight:600;font-size:14px;color:#fff;background:#000;border:1px solid #000;border-radius:999px;padding:11px 18px;cursor:pointer}.connect-google:hover{opacity:.88}.connect-google .g-icon{width:16px;height:16px}.connect-or{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px}.connect-or:before,.connect-or:after{content:"";flex:1;height:1px;background:var(--frame-border)}.connect-form{display:flex;flex-direction:column;gap:8px}.connect-form input{font:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--frame-border);border-radius:9px;outline:none}.connect-form input:focus{border-color:var(--accent)}.connect-form button{font:inherit;font-weight:600;font-size:14px;color:#fff;background:var(--accent);border:none;border-radius:9px;padding:11px;cursor:pointer}.connect-link{background:none;border:none;color:var(--accent);font:inherit;font-size:12.5px;cursor:pointer}.connect-boards{display:flex;flex-direction:column;gap:8px;margin:4px 0}.connect-board{display:flex;align-items:center;justify-content:space-between;gap:8px;font:inherit;font-size:14px;padding:12px 14px;background:#fafafb;border:1px solid var(--frame-border);border-radius:10px;cursor:pointer;text-align:left}.connect-board:hover{border-color:var(--accent);background:#f5f4ff}.connect-board:disabled{opacity:.5;cursor:default}.cb-name{font-weight:600;color:var(--ink)}.cb-go{color:var(--accent);font-size:12.5px;font-weight:600;flex-shrink:0}.connect-empty{color:var(--muted);font-size:13px;padding:12px}.connect-signed{color:var(--muted);font-size:12px}.connect-status{font-size:12.5px;color:var(--muted);min-height:16px}.connect-status.err{color:#b91c1c}.ds-editor{padding:6px 12px 16px}.ds-section{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin:14px 0 8px}.ds-section:first-child{margin-top:4px}.ds-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ds-label{flex:1;min-width:0;font-size:13px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ds-hex{width:78px;flex-shrink:0;font:inherit;font-size:12px;font-family:ui-monospace,Menlo,monospace;padding:5px 7px;border:1px solid #d8dae2;border-radius:7px;outline:none}.ds-hex:focus{border-color:var(--accent)}.ds-color{flex-shrink:0;width:28px;height:28px;padding:0;border:1px solid #d8dae2;border-radius:7px;background:none;cursor:pointer}.ds-color::-webkit-color-swatch-wrapper{padding:2px}.ds-color::-webkit-color-swatch{border:none;border-radius:4px}.ds-text{width:120px;flex-shrink:0;font:inherit;font-size:12px;padding:5px 7px;border:1px solid #d8dae2;border-radius:7px;outline:none}.ds-text:focus{border-color:var(--accent)}.ds-reset{margin-top:14px;width:100%;font:inherit;font-size:13px;font-weight:600;color:#374151;background:#f4f4f6;border:1px solid #e1e3ea;border-radius:8px;padding:8px;cursor:pointer}.ds-reset:hover{background:#ececef}.ds-select{width:140px;flex-shrink:0;font:inherit;font-size:12px;padding:5px 7px;border:1px solid #d8dae2;border-radius:7px;background:#fff;cursor:pointer;outline:none}.ds-select:focus{border-color:var(--accent)}.cj-fontpicker{width:min(440px,calc(100vw - 32px))}.cj-font-search{margin:12px 0 10px!important}.cj-font-list{display:flex;flex-direction:column;max-height:50vh;overflow-y:auto;margin:0 -6px}.cj-font-item{display:block;width:100%;text-align:left;font:inherit;font-size:14px;color:var(--ink);background:none;border:none;padding:9px 12px;border-radius:8px;cursor:pointer}.cj-font-item:hover{background:#f3f3f6}.cj-font-use{color:var(--accent);font-weight:600}.md-page{position:fixed;top:0;right:0;bottom:0;left:0;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg);color:var(--ink)}.md-topbar{display:flex;align-items:center;justify-content:space-between;max-width:820px;margin:0 auto;padding:18px 24px}.md-brand img{height:26px;width:auto;display:block}.md-back{font-size:13px;color:var(--muted);text-decoration:none}.md-back:hover{color:var(--accent)}.md-main{max-width:820px;margin:0 auto;padding:20px 24px 80px}.md-eyebrow{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:#eef0ff;border-radius:999px;padding:4px 11px;margin-bottom:14px}.md-title{font-size:38px;font-weight:700;margin:0 0 14px;letter-spacing:-.02em}.md-lede{font-size:16.5px;line-height:1.6;color:#4b5160;margin:0 0 8px;max-width:660px}.md-section{margin-top:44px}.md-section h2{font-size:19px;font-weight:650;margin:0 0 12px}.md-text{font-size:14.5px;line-height:1.6;color:#4b5160;margin:0 0 12px}.md-note{font-size:13px;line-height:1.55;color:var(--muted);margin:10px 0 0}.md-link{color:var(--accent);text-decoration:none;font-weight:600;border-bottom:1px solid color-mix(in srgb,var(--accent) 35%,transparent)}.md-link:hover{border-bottom-color:var(--accent)}.md-text code,.md-note code,.md-feature-d code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:#eceef2;border-radius:5px;padding:1px 5px;color:#2b3040}.md-code{position:relative;background:#14161c;border-radius:12px;margin:4px 0 0;overflow:hidden}.md-code pre{margin:0;padding:16px 18px;overflow-x:auto}.md-code code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.6;color:#e7e9ee;white-space:pre}.md-code-lang{position:absolute;top:10px;left:16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#6b7180}.md-code:has(.md-code-lang) pre{padding-top:32px}.md-copy{position:absolute;top:9px;right:9px;font:inherit;font-size:12px;font-weight:600;color:#cdd1da;background:#2a2e38;border:1px solid #3a3f4b;border-radius:7px;padding:4px 10px;cursor:pointer;transition:all .15s ease}.md-copy:hover{background:#3a3f4b;color:#fff}.md-copy.done{background:#4f46e5;border-color:#4f46e5;color:#fff}.md-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.md-tab{display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:13.5px;font-weight:500;color:#4b5160;background:#fff;border:1px solid var(--frame-border);border-radius:999px;padding:7px 14px;cursor:pointer;transition:all .15s ease}.md-tab:hover{border-color:#c7cad2}.md-tab.active{color:#fff;background:var(--ink);border-color:var(--ink)}.md-tab-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:#fff;background:var(--accent);border-radius:999px;padding:2px 6px}.md-tab.active .md-tab-badge{background:#4f46e5}.md-panel{display:none}.md-panel.active{display:block}.md-steps{list-style:none;counter-reset:step;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.md-steps li{position:relative;counter-increment:step;padding-left:42px;min-height:28px}.md-steps li:before{content:counter(step);position:absolute;left:0;top:0;width:28px;height:28px;border-radius:50%;background:var(--ink);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.md-step-t{font-size:14.5px;font-weight:600;margin-bottom:3px;padding-top:4px}.md-step-d{font-size:13.5px;line-height:1.55;color:#4b5160}.md-step-d code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:#eceef2;border-radius:5px;padding:1px 5px;color:#2b3040}.md-features{display:grid;grid-template-columns:1fr 1fr;gap:12px}.md-feature{border:1px solid var(--frame-border);border-radius:12px;padding:16px;background:#fff}.md-feature-t{font-size:14.5px;font-weight:600;margin-bottom:5px}.md-feature-d{font-size:13px;line-height:1.5;color:#4b5160}.md-cta{margin-top:44px}.md-cta-btn{display:inline-flex;align-items:center;font-size:14.5px;font-weight:600;color:#fff;background:var(--accent);border-radius:10px;padding:12px 20px;text-decoration:none}.md-cta-btn:hover{opacity:.9}.md-panel-btn{display:inline-flex;align-items:center;margin-top:14px;font-size:13.5px;font-weight:600;color:var(--accent);background:#fff;border:1px solid #e6e8f0;border-radius:9px;padding:9px 16px;text-decoration:none}.md-panel-btn:hover{border-color:var(--accent)}@media (max-width: 640px){.md-title{font-size:30px}.md-features{grid-template-columns:1fr}}
