:root{color-scheme:light;--node-width:128px;--avatar-size:92px;--avatar-center-y:calc(var(--avatar-size) / 2);--connect-ring-size:120px;--bg:#eef2f3;--surface:#ffffff;--ink:#1d2526;--muted:#66706c;--line:#d5dde0;--accent:#1f7a6d;--accent-dark:#145f55;--danger:#b43b37;--shadow:0 18px 50px rgb(36 41 38/14%)}*{box-sizing:border-box}body,html{height:100%}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--ink);background:var(--bg)}button,input,select,textarea{font:inherit}button{border:0;border-radius:8px;color:white;background:var(--accent);cursor:pointer;min-height:40px;padding:0 14px}button:hover{background:var(--accent-dark)}button:disabled{cursor:not-allowed;opacity:.45}button:disabled:hover{background:var(--accent)}.button-icon{width:19px;height:19px;display:block;flex:0 0 auto;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.chevron-icon{width:16px;height:16px}.button-label{min-width:0}.app{min-height:100%;display:grid;grid-template-rows:auto 1fr}.topbar{position:relative;z-index:40;min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 22px;border-bottom:1px solid var(--line);background:rgb(255 255 255/88%);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{min-width:180px}.topbar h1,.topbar p{margin:0}.topbar h1{font-size:24px;line-height:1.1}.topbar p{margin-top:4px;color:var(--muted)}.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.actions button,.mobile-panel-button,.view-switch button{display:inline-flex;align-items:center;justify-content:center;gap:7px;white-space:nowrap}.view-switch{position:relative;display:flex;gap:6px;padding:4px;border:1px solid var(--line);border-radius:8px;background:#f7faf9}.view-switch button{min-height:32px;color:var(--muted);background:transparent;padding:0 10px}.view-switch button.active{color:white;background:var(--accent)}.project-picker{position:relative;min-width:0}.project-picker-button{max-width:240px}.project-name-label{min-width:0;overflow:hidden;text-overflow:ellipsis}.project-dropdown{position:absolute;z-index:60;top:calc(100% + 8px);left:0;display:none;min-width:min(260px,calc(100vw - 24px));max-height:300px;overflow:auto;pointer-events:auto;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);padding:6px}.project-picker.open .project-dropdown{display:grid;grid-gap:4px;gap:4px}.project-option{display:flex;justify-content:flex-start;width:100%;min-height:36px;overflow:hidden;color:var(--ink);background:var(--surface);text-align:left;text-overflow:ellipsis;white-space:nowrap;padding:0 10px}.project-option.active,.project-option:hover{color:white;background:var(--accent)}.project-option.new-project-option{margin-top:4px;border-top:1px solid var(--line);border-radius:0;color:var(--accent-dark);background:#edf5f2}.project-option.new-project-option:hover{color:white;background:var(--accent)}.icon-action{display:grid;place-items:center;width:40px;padding:0}.account-menu-button,.mobile-panel-button,.mobile-panel-close{display:none}.auth-form{display:grid;grid-template-columns:170px 170px auto auto auto;align-items:center;justify-content:flex-end;grid-gap:8px;gap:8px;max-width:none}.auth-form input{width:100%;min-height:40px;padding:8px 10px}.auth-form button{min-height:40px;white-space:nowrap}.auth-form #signUpBtn{color:var(--accent-dark);background:#dcefe8}.auth-form #signUpBtn:hover{color:white;background:var(--accent-dark)}.auth-status{max-width:220px;overflow:hidden;color:var(--muted);font-size:12px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.auth-status:empty{display:none}.auth-form.signed-in{grid-template-columns:auto auto}.project-form{display:grid;grid-template-columns:170px 150px auto;align-items:center;grid-gap:8px;gap:8px}.project-form input,.project-form select{min-height:40px;padding:8px 10px}.project-form button{min-height:40px;white-space:nowrap}#projectForm{display:none}#connectBtn{color:var(--accent-dark);background:#dcefe8}#connectBtn.active{color:white;background:var(--accent-dark)}.workspace{min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 360px}.graph-shell{position:relative;overflow:hidden;min-height:calc(100vh - 78px);cursor:-webkit-grab;cursor:grab;touch-action:none;background:linear-gradient(90deg,rgb(29 37 38/6%) 1px,transparent 0),linear-gradient(rgb(29 37 38/6%) 1px,transparent 0);background-size:34px 34px}.people-list-shell{overflow:auto;min-height:calc(100vh - 78px);background:#f7faf9;padding:22px}.people-list-head{margin-bottom:16px}.people-list-head h2,.people-list-head p{margin:0}.people-list-head h2{font-size:20px}.people-list-head p{margin-top:4px;color:var(--muted)}.people-list{display:grid;grid-gap:8px;gap:8px}.people-list-item{display:grid;grid-template-columns:46px minmax(0,1fr);align-items:center;grid-gap:12px;gap:12px;min-height:62px;border:1px solid var(--line);border-radius:8px;color:var(--ink);background:var(--surface);text-align:left;padding:8px 10px}.people-list-item.selected,.people-list-item:hover{border-color:var(--accent);background:#edf5f2}.people-list-item img{width:46px;height:46px;border-radius:50%;object-fit:cover;background:#d5ddd7}.people-list-item span{min-width:0;display:grid;grid-gap:3px;gap:3px}.people-list-item small,.people-list-item strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.people-list-empty,.people-list-item small{color:var(--muted)}.people-list-empty{border:1px dashed var(--line);border-radius:8px;background:var(--surface);padding:18px}.edges,.nodes{position:absolute;inset:0;transform-origin:0 0}.nodes{pointer-events:none}.graph-shell.panning{cursor:-webkit-grabbing;cursor:grabbing}.edge-line{pointer-events:none;stroke:#76958d;stroke-width:2}.edge-hit-line{cursor:pointer;pointer-events:stroke;stroke:transparent;stroke-linecap:round;stroke-width:18}.draft-edge-line{stroke:var(--accent);stroke-dasharray:8 7;stroke-linecap:round;stroke-width:3}.edge.selected .edge-line{stroke:var(--accent);stroke-width:3}.edge-label rect{fill:var(--surface);stroke:var(--line);rx:6}.edge-label text{fill:var(--ink);font-size:13px;font-weight:650;text-anchor:middle;dominant-baseline:middle}.edge-comment-indicator{fill:var(--accent);stroke:var(--surface);stroke-width:2}.edge-label{cursor:text;pointer-events:auto}.edge-label:hover rect,.edge.selected .edge-label rect{stroke:var(--accent)}.relation-editor{z-index:4;height:30px;margin:0;border:1px solid var(--accent);border-radius:8px;background:var(--surface);box-shadow:0 0 0 3px rgb(31 122 109/12%);font-size:13px;font-weight:650;line-height:1;text-align:center;outline:none;padding:0 10px}.person-node,.relation-editor{position:absolute;color:var(--ink)}.person-node{pointer-events:auto;width:var(--node-width);height:146px;padding:0;background:transparent;transform:translate(calc(var(--node-width) / -2),calc(var(--avatar-center-y) * -1));cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.connect-port{position:absolute;z-index:2;top:50%;left:50%;width:var(--connect-ring-size);height:var(--connect-ring-size);cursor:crosshair;opacity:0;overflow:visible;pointer-events:none;transform:translate(-50%,-50%);transition:opacity .12s ease}.connect-port circle{fill:none;stroke:rgb(31 122 109/24%);stroke-width:16;pointer-events:stroke;transition:stroke .12s ease,stroke-width .12s ease}.person-node.relation-target .connect-port,.person-node:hover .connect-port{opacity:1}.connect-port:hover circle{stroke:rgb(31 122 109/38%);stroke-width:18}.person-node.relation-target .connect-port circle{stroke:rgb(31 122 109/48%);stroke-width:18}.person-node:hover{background:transparent}.person-node:active{cursor:-webkit-grabbing;cursor:grabbing}.avatar-wrap{margin:0 auto}.avatar,.avatar-wrap{position:relative;display:block;width:var(--avatar-size);height:var(--avatar-size)}.avatar{z-index:1;border:4px solid var(--surface);border-radius:50%;overflow:hidden;background:#d5ddd7;box-shadow:var(--shadow)}.avatar img{width:100%;height:100%;display:block;object-fit:cover;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.node-label{margin-top:8px;color:var(--ink);font-size:13px;font-weight:750}.node-label,.node-role{display:block;max-width:128px;overflow:hidden;line-height:1.15;text-align:center;text-overflow:ellipsis;white-space:nowrap}.node-role{margin-top:3px;color:var(--muted);font-size:12px;font-weight:650}.person-node.selected .avatar{border-color:var(--accent);box-shadow:0 0 0 6px rgb(31 122 109/16%),var(--shadow)}.person-node.pending .avatar{border-color:#d59d37}.goal-orb{position:relative;z-index:1;display:block;width:var(--avatar-size);height:var(--avatar-size);border:4px solid var(--surface);border-radius:50%;background:radial-gradient(circle at center,#ffffff 0 13px,#1f7a6d 14px 18px,transparent 19px),radial-gradient(circle at center,transparent 0 34px,#7ec4b3 35px 39px,transparent 40px),#dcefe8;box-shadow:var(--shadow)}.goal-orb.has-image{overflow:hidden;background:#d5ddd7}.goal-orb img{width:100%;height:100%;display:block;object-fit:cover;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.goal-node.selected .goal-orb{border-color:var(--accent);box-shadow:0 0 0 6px rgb(31 122 109/16%),var(--shadow)}.goal-node.pending .goal-orb{border-color:#d59d37}.panel{position:relative;overflow:auto;border-left:1px solid var(--line);background:var(--surface)}.empty-panel,.goal-form,.person-form,.relation-panel-form{padding:24px}.relation-panel-form h2{margin:0 0 14px;font-size:20px}.relation-summary{display:flex;align-items:center;gap:8px;margin-bottom:18px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:#f7faf9;font-size:13px;font-weight:700}.relation-summary span:first-child,.relation-summary span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-panel h2{margin:0 0 8px;font-size:20px}.empty-panel p{margin:0;color:var(--muted);line-height:1.45}.hidden{display:none}.profile-head{align-items:start}.goal-head,.profile-head{display:grid;grid-template-columns:86px 1fr;grid-gap:16px;gap:16px;margin-bottom:18px}.goal-head{align-items:center}.panel-image-button{position:relative;min-height:0;border:0;border-radius:50%;padding:0;cursor:pointer}.panel-image-button,.panel-image-button:hover{background:transparent}.panel-image-button:after{content:"Загрузить";position:absolute;inset:0;display:grid;place-items:center;border-radius:50%;color:white;background:rgb(29 37 38/58%);font-size:12px;font-weight:750;opacity:0;transition:opacity .14s ease}.panel-image-button:focus-visible:after,.panel-image-button:hover:after{opacity:1}.file-input{display:none}.goal-preview{display:block;width:72px;height:72px;border-radius:50%;overflow:hidden;background:radial-gradient(circle at center,#ffffff 0 10px,#1f7a6d 11px 15px,transparent 16px),radial-gradient(circle at center,transparent 0 27px,#7ec4b3 28px 31px,transparent 32px),#dcefe8}.goal-preview.has-image{background:#d5ddd7}.goal-preview img{width:100%;height:100%;display:none;object-fit:cover}.goal-preview.has-image img{display:block}.profile-head img{width:86px;height:86px;display:block;border-radius:50%;object-fit:cover;background:#d5ddd7}label{display:grid;grid-gap:7px;gap:7px;margin-bottom:14px;color:var(--muted);font-size:13px;font-weight:650}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;color:var(--ink);background:white;outline:none;padding:10px 11px}textarea{resize:vertical}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgb(31 122 109/12%)}.dialog-actions,.panel-actions{display:flex;gap:10px;justify-content:flex-end}.danger{color:var(--danger);background:#f4dfdc}.danger:hover{color:white;background:var(--danger)}dialog{width:min(420px,calc(100vw - 28px));border:1px solid var(--line);border-radius:8px;padding:0;background:var(--surface);box-shadow:var(--shadow)}dialog::-webkit-backdrop{background:rgb(29 37 38/28%)}dialog::backdrop{background:rgb(29 37 38/28%)}dialog form{padding:22px}dialog h2,dialog p{margin:0}dialog h2{font-size:20px}dialog p{margin:8px 0 18px;color:var(--muted)}.avatar-dialog{width:min(560px,calc(100vw - 28px))}.avatar-drop-zone{display:grid;justify-items:center;grid-gap:10px;gap:10px;margin:18px 0;border:2px dashed var(--line);border-radius:8px;background:#f7faf9;color:var(--muted);font-size:13px;font-weight:700;outline:none;padding:18px}.avatar-drop-zone.drag-over,.avatar-drop-zone:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgb(31 122 109/12%)}.avatar-drop-zone img{width:112px;height:112px;border-radius:50%;object-fit:cover;background:#d5ddd7}.avatar-tools{display:grid;grid-gap:16px;gap:16px}.avatar-tools section{display:grid;grid-gap:10px;gap:10px}.avatar-tools h3{margin:0;color:var(--muted);font-size:13px}.custom-emoji-row{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:8px;gap:8px}.custom-emoji-row input{font-size:22px;text-align:center}.emoji-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:8px;gap:8px;max-height:154px;overflow:auto}.emoji-grid button{min-height:42px;padding:0;color:var(--ink);background:#edf5f2;font-size:22px}.emoji-grid button:hover{background:#dcefe8}@media (max-width:820px){:root{--node-width:116px;--avatar-size:82px;--connect-ring-size:108px}.topbar{align-items:stretch;display:grid;grid-template-columns:42px minmax(120px,1fr) auto auto;grid-gap:10px;gap:10px;position:relative}.brand{min-width:0}.topbar h1{font-size:22px}.topbar p{font-size:14px}.actions,.auth-form,.project-form,.view-switch{width:100%}.brand{grid-column:1/-1}.account-menu-button{display:grid;grid-column:1/2;order:1;place-items:center;width:42px;min-height:42px;padding:0}.view-switch{grid-column:2/4;order:2}.mobile-panel-button{display:inline-grid;grid-column:4/5;order:3;place-items:center;min-width:42px;padding:0 12px;color:var(--accent-dark);background:#dcefe8}.mobile-panel-button.has-selection{color:white;background:var(--accent)}.actions{grid-column:1/-1;order:4}.auth-form{grid-column:1/-1;order:5}.actions button,.view-switch button{flex:1 1 auto}.auth-form{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.auth-form.signed-in{grid-template-columns:minmax(0,1fr) auto}.auth-status{max-width:none}.workspace{grid-template-columns:1fr;grid-template-rows:minmax(520px,62vh) auto}.graph-shell,.people-list-shell{min-height:520px}.panel{position:fixed;z-index:20;right:0;bottom:0;left:0;max-height:min(78dvh,680px);border-top:1px solid var(--line);border-left:0;border-radius:14px 14px 0 0;box-shadow:0 -18px 50px rgb(36 41 38/18%);transform:translateY(105%);transition:transform .18s ease}.app.mobile-panel-open .panel{transform:translateY(0)}.app.mobile-panel-open:after{content:"";position:fixed;z-index:19;inset:0;background:rgb(29 37 38/24%)}.mobile-panel-close{position:-webkit-sticky;position:sticky;z-index:2;top:0;left:auto;float:right;display:grid;place-items:center;width:40px;min-height:40px;margin:10px 10px 0 0;border-radius:50%;color:var(--ink);background:#edf5f2;font-size:26px;line-height:1}.mobile-panel-close:hover{color:white;background:var(--accent)}}@media (max-width:560px){:root{--node-width:108px;--avatar-size:76px;--connect-ring-size:100px}body{min-width:320px}.topbar{grid-template-columns:42px minmax(0,1fr);gap:8px;padding:8px 10px}.brand{display:none}.view-switch{grid-column:2/3;min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 42px;grid-gap:4px;gap:4px;padding:3px}.mobile-panel-button,.view-switch>button:not(.project-picker-button){width:42px;min-width:42px;min-height:38px;padding:0}.mobile-panel-button{grid-column:auto}#addGoalBtn .button-label,#addPersonBtn .button-label,#addPersonFromDbBtn .button-label,#connectBtn .button-label,#peopleViewBtn .button-label,.mobile-panel-button .button-label{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);-webkit-clip-path:inset(50%);clip-path:inset(50%);white-space:nowrap}.project-picker{min-width:0}.project-picker-button{width:100%;max-width:none;min-height:38px;justify-content:flex-start;padding:0 8px}.project-name-label{flex:1 1 auto;text-align:left}.project-dropdown{left:-50px;width:min(330px,calc(100vw - 20px));min-width:0;max-height:min(360px,calc(100dvh - 130px));padding:8px}.project-dropdown .project-option{width:100%;min-width:0;min-height:44px;justify-content:flex-start;border-radius:8px;font-size:15px;padding:0 12px}.project-option.new-project-option{margin-top:6px;border-top:0}.actions{grid-column:1/-1;width:100%;display:flex;flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;padding-bottom:2px}.actions:after{content:"";flex:1 1 auto}.actions button{flex:0 0 auto;min-width:0;padding:0 10px}#addGoalBtn,#addPersonBtn,#undoBtn{width:42px;padding:0}#addPersonFromDbBtn,#connectBtn{min-width:42px;width:42px;padding:0}.auth-form,.auth-form button,.auth-form input,.project-form,.project-form select{width:100%}.auth-form,.project-form{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.auth-form{position:absolute;z-index:30;top:calc(100% + 8px);left:10px;right:10px;display:none;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow);padding:10px}.topbar.account-menu-open .auth-form{display:grid}.auth-form.signed-in{grid-template-columns:1fr}.auth-status{display:none}.auth-form.signed-in #signOutBtn{width:100%}.workspace{grid-template-rows:minmax(calc(100dvh - 146px),1fr)}.graph-shell,.people-list-shell{min-height:calc(100dvh - 146px)}.empty-panel,.goal-form,.people-list-shell,.person-form,.relation-panel-form{padding:16px}.goal-head,.profile-head{grid-template-columns:72px minmax(0,1fr);gap:12px}.goal-preview,.goal-preview img,.panel-image-button img{width:72px;height:72px}.dialog-actions,.panel-actions{display:grid;grid-template-columns:1fr}.emoji-grid{grid-template-columns:repeat(5,1fr)}}