:root{--bg: #0f1115;--panel: #1a1d24;--panel-2: #232730;--border: #2e333d;--text: #e6e8ec;--text-dim: #9aa0aa;--accent: #e63946;--accent-hover: #ff4d5e;--ok: #4ade80}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;height:100%}#app{display:grid;grid-template-rows:auto 1fr auto;height:100vh}header{padding:12px 20px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:16px}header h1{margin:0;font-size:20px;color:var(--accent);letter-spacing:-.02em}.subtitle{color:var(--text-dim);font-size:13px}main{display:grid;grid-template-columns:1fr 340px;grid-template-rows:1fr 1fr;gap:1px;background:var(--border);overflow:hidden}#map-section{grid-row:1 / 3;position:relative;background:var(--panel);display:flex;flex-direction:column}#map{flex:1;min-height:0;position:relative}#search-box{position:absolute;top:12px;left:12px;z-index:100;width:320px;max-width:calc(100% - 100px);font-family:inherit}#search-input{width:100%;padding:10px 36px 10px 14px;background:#0f1115eb;color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:13px;box-shadow:0 2px 8px #0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}#search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #e6394633,0 2px 8px #0006}#search-clear{position:absolute;right:8px;top:6px;width:22px;height:22px;border-radius:50%;background:var(--border);border:none;color:var(--text);padding:0;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center}#search-clear[hidden],#search-results[hidden]{display:none}#search-clear:hover{background:var(--accent);color:#fff}#search-results{margin-top:4px;background:#0f1115f2;border:1px solid var(--border);border-radius:4px;box-shadow:0 4px 16px #00000080;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);max-height:360px;overflow-y:auto}.search-result{padding:8px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;border-bottom:1px solid var(--border);font-size:13px}.search-result:last-child{border-bottom:none}.search-result:hover,.search-result.active{background:var(--panel-2)}.search-result .icon{font-size:18px;flex-shrink:0;width:22px;text-align:center}.search-result .body{flex:1;min-width:0}.search-result .name{color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result .name b{color:var(--accent);font-weight:600}.search-result .name i{color:var(--text-dim);font-style:normal;font-size:11px;margin-right:4px}.search-result .sub{color:var(--text-dim);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-status{padding:10px 14px;color:var(--text-dim);font-size:12px;text-align:center}.map-toolbar{padding:8px 12px;background:var(--panel-2);border-top:1px solid var(--border);display:flex;gap:8px;align-items:center}#controls{background:var(--panel);padding:16px;overflow-y:auto;border-left:1px solid var(--border)}#preview{background:var(--panel);padding:16px;display:flex;flex-direction:column;min-height:0}.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.preview-header h2{margin:0}.btn-icon{background:var(--panel-2);border:1px solid var(--border);color:var(--text);width:28px;height:28px;padding:0;font-size:16px;line-height:1;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--border);color:var(--accent)}#preview-canvas{flex:1;background:#0a0c10;border-radius:4px;min-height:200px;position:relative}#preview-canvas:fullscreen,#preview-canvas:-webkit-full-screen{background:#0a0c10;width:100vw;height:100vh;border-radius:0}h2{margin:16px 0 8px;font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-weight:600}h2:first-child{margin-top:0}.control-row{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.control-row.indent{padding-left:22px}label{color:var(--text-dim);font-size:12px}input[type=number],select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-family:inherit;font-size:13px}input[type=checkbox]{accent-color:var(--accent);margin-right:6px}button{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:6px 12px;cursor:pointer;font-family:inherit;font-size:13px;transition:background .1s}button:hover:not(:disabled){background:var(--border)}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600;padding:10px 16px;width:100%}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.bbox-info{color:var(--text-dim);font-size:12px;font-family:monospace;margin-left:auto}.hint{color:var(--text-dim);font-size:11px;margin-top:4px;line-height:1.5}.progress{margin-top:12px;background:var(--panel-2);border-radius:4px;overflow:hidden;position:relative;height:32px}#progress-bar{background:var(--accent);height:100%;width:0%;transition:width .2s}#progress-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;text-shadow:0 0 2px black}.output{margin-top:12px;display:flex;flex-direction:column;gap:6px}.output a{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;padding:8px 12px;color:var(--ok);text-decoration:none;font-size:12px;display:flex;align-items:center;gap:8px}.output a:hover{background:var(--border)}footer{padding:8px 20px;background:var(--panel);border-top:1px solid var(--border);font-size:11px;color:var(--text-dim)}footer a{color:var(--text-dim)}.ol-control button{background:#0009!important;color:#fff!important}.draw-rect{cursor:crosshair!important}:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}
