html,body,#root{height:100%;margin:0}body{color:#e8e8e8;background:#202428;font-family:system-ui,sans-serif;overflow:hidden}.viewer-root{flex-direction:column;width:100%;height:100%;display:flex}.viewer-body{flex:1;min-height:0;display:flex}.admin-banner{letter-spacing:.08em;text-align:center;color:#ffe2a8;background:#7a4a12;border-bottom:1px solid #ffffff1f;flex:none;padding:4px 12px;font:600 12px system-ui,sans-serif}.viewer-canvas{flex:1;min-width:0;position:relative}.viewer-canvas canvas{touch-action:none;width:100%;height:100%;display:block}.layer-menu{box-sizing:border-box;background:#181b1e;border-right:1px solid #ffffff14;flex:0 0 240px;height:100%;padding:16px 12px;overflow-y:auto}.layer-menu-title{text-transform:uppercase;letter-spacing:.08em;opacity:.55;margin:0 4px 12px;font-size:12px;font-weight:600}.layer-menu-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.layer-menu-item{width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:6px;padding:10px 12px}.layer-menu-item:hover{background:#ffffff0f}.layer-menu-item.is-active{color:#fff;background:#2f6df0}.layer-menu-title:not(:first-child){margin-top:20px}.vector-layer-row{align-items:center;gap:6px;display:flex}.vector-layer-row .layer-menu-item{flex:1}.vector-layer-visible{accent-color:#2f6df0;cursor:pointer;flex:none}.vector-layer-delete{width:26px;color:inherit;font:inherit;cursor:pointer;opacity:.55;background:0 0;border:0;border-radius:6px;flex:none;padding:6px 0;line-height:1}.vector-layer-delete:hover{color:#ff6b6b;opacity:1;background:#f040402e}.vector-add{width:100%;color:inherit;font:inherit;cursor:pointer;background:0 0;border:1px dashed #ffffff40;border-radius:6px;margin-top:8px;padding:8px 12px}.vector-add:hover{background:#ffffff0f}.object-panel{box-sizing:border-box;background:#181b1e;border-left:1px solid #ffffff14;flex:0 0 240px;height:100%;padding:16px 12px;overflow-y:auto}.object-delete{color:#ff6b6b;width:100%;font:inherit;cursor:pointer;background:0 0;border:1px solid #ff6b6b80;border-radius:6px;margin-top:12px;padding:8px 12px}.object-delete:hover{background:#ff6b6b1f}.object-empty{opacity:.5;padding:4px 12px;font-size:13px}.object-name-input{box-sizing:border-box;width:100%;color:inherit;font:inherit;background:#ffffff0a;border:1px solid #ffffff26;border-radius:6px;padding:8px 10px}.object-name-input:focus{background:#2f6df01a;border-color:#2f6df0;outline:none}.object-props dd.object-name{text-align:left;font-family:inherit}.object-props dd.object-name .object-name-input{padding:4px 8px}.object-props{grid-template-columns:auto 1fr;gap:4px 12px;margin:0;padding:0 4px;font-size:13px;display:grid}.object-props dt{opacity:.6}.object-props dd{text-align:right;margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.object-props dd.object-color{justify-content:flex-end;display:flex}.object-props dd.object-color input[type=color]{cursor:pointer;background:0 0;border:1px solid #ffffff40;border-radius:3px;width:28px;height:18px;padding:0}.stats-overlay{pointer-events:none;-webkit-user-select:none;user-select:none;background:#0000008c;border-radius:6px;padding:8px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.5;position:absolute;top:8px;left:8px}.stats-error{color:#ff8080}.stats-hint{opacity:.6;margin-top:4px}.viewer-canvas canvas.tool-cursor{cursor:crosshair}.top-bar{box-sizing:border-box;-webkit-user-select:none;user-select:none;background:#181b1e;border-bottom:1px solid #ffffff14;align-items:center;gap:12px;width:100%;padding:8px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;display:flex}.top-bar-spacer{flex:1}.top-bar-hint{opacity:.6}.measure-buttons{gap:4px;display:flex}.top-bar button{color:#e8e8e8;font:inherit;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff26;border-radius:4px;padding:4px 10px}.top-bar button:hover{background:#ffffff1f}.top-bar button.tool-active{color:#4f8;border-color:#4f8}.top-bar button:disabled{opacity:.4;cursor:default}.vector-title{font-weight:600}.measure-readout{min-height:4.5em;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.5}.measure-segment,.measure-hint{opacity:.6;margin-top:4px}.profile-modal{color:#e8e8e8;background:#14171aeb;border:1px solid #ffffff26;border-radius:8px;width:540px;max-width:calc(100% - 32px);padding:12px 16px 16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 32px #00000080}.profile-header{justify-content:space-between;align-items:center;margin-bottom:8px;font-weight:600;display:flex}.profile-close{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:0;font-size:20px;line-height:1}.profile-close:hover{opacity:1}.profile-chart{width:100%;height:220px;display:block}.profile-axis{stroke:#ffffff40;stroke-width:1px}.profile-area{fill:#44ff8826;stroke:none}.profile-line{fill:none;stroke:#4f8;stroke-width:1.5px}.profile-ylabel,.profile-xlabel{fill:#e8e8e8b3;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px}.profile-ylabel,.profile-xlabel-end{text-anchor:end}.profile-stats{margin-top:12px}.poi-overlay{pointer-events:none;z-index:2;position:absolute;inset:0;overflow:hidden}.poi-connectors{pointer-events:none;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.poi-connector{stroke:#ffffff8c;stroke-width:1px;stroke-dasharray:3 3}.poi-box{box-sizing:border-box;color:#e8e8e8;pointer-events:auto;will-change:transform;background:#14171aeb;border:1px solid #ffffff2e;border-radius:8px;max-width:260px;max-height:220px;padding:8px 12px;font-size:13px;line-height:1.45;position:absolute;top:0;left:0;overflow:auto;box-shadow:0 6px 24px #00000080}.poi-box.is-editable{cursor:move}.markdown-body>:first-child{margin-top:0}.markdown-body>:last-child{margin-bottom:0}.markdown-body h1,.markdown-body h2,.markdown-body h3{margin:.4em 0 .3em;line-height:1.25}.markdown-body p,.markdown-body ul,.markdown-body ol,.markdown-body pre,.markdown-body table{margin:.4em 0}.markdown-body a{color:#6cb6ff}.markdown-body code{background:#ffffff1a;border-radius:4px;padding:.1em .3em;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em}.markdown-body pre{background:#00000059;border-radius:6px;padding:8px;overflow:auto}.markdown-body pre code{background:0 0;padding:0}.markdown-body table{border-collapse:collapse}.markdown-body th,.markdown-body td{border:1px solid #fff3;padding:2px 6px}.poi-editor{color:#e8e8e8;z-index:3;background:#14171af2;border:1px solid #ffffff26;border-radius:8px;width:720px;max-width:calc(100% - 32px);padding:12px 16px 16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 32px #00000080}.poi-editor-body{gap:12px;display:flex}.poi-editor-input,.poi-editor-preview{box-sizing:border-box;background:#0000004d;border:1px solid #ffffff26;border-radius:6px;flex:1 1 0;min-width:0;height:320px;padding:8px 10px}.poi-editor-input{resize:none;color:#e8e8e8;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.45}.poi-editor-input:focus{outline:1px solid #6cb6ff99}.poi-editor-preview{font-size:13px;line-height:1.45;overflow:auto}.poi-editor-actions{justify-content:flex-end;gap:8px;margin-top:12px;display:flex}.poi-editor-save{color:#fff;background:#2a6df0;border-color:#2a6df0}
