*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#f7f8fa;--surface:#fff;--surface-alt:#f1f3f7;--text:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--border:#e5e7eb;--border-light:#f3f4f6;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#eff6ff;--accent-border:#bfdbfe;--danger:#ef4444;--success:#10b981;--radius:8px;--radius-sm:6px;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);--shadow-lg:0 4px 12px rgba(0,0,0,.08);--mono:"SF Mono","Fira Code","Cascadia Code",Consolas,monospace;--font:-apple-system,BlinkMacSystemFont,"Segoe UI","Inter",Roboto,Helvetica,Arial,sans-serif}body{font-family:var(--font);height:100vh;overflow:hidden;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.config-header,body{display:flex;flex-direction:column}.config-header{background:var(--surface);box-shadow:var(--shadow);position:relative;z-index:10}.api-key-bar{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid var(--border-light)}.api-key-bar label{color:var(--text-muted);font-size:12px;font-weight:500;white-space:nowrap;letter-spacing:.02em}.api-key-bar input[type=password]{flex:1 1;max-width:300px;padding:7px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:13px;font-family:var(--mono);transition:border-color .15s,box-shadow .15s}.api-key-bar input[type=password]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.12)}.api-key-bar button{padding:7px 16px;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.api-key-bar .btn-set{background:var(--accent);color:#fff}.api-key-bar .btn-set:hover{background:var(--accent-hover)}.api-key-bar .btn-clear{background:var(--surface-alt);color:var(--text-secondary);border:1px solid var(--border)}.api-key-bar .btn-clear:hover{background:var(--border-light)}.api-key-bar .status{font-size:12px;color:var(--success);font-weight:500}.api-key-bar select{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:13px;cursor:pointer;transition:border-color .15s}.api-key-bar select:focus{outline:none;border-color:var(--accent)}.segment-control{display:flex;background:var(--surface-alt);border-radius:var(--radius-sm);padding:2px;gap:2px}.segment-control button{padding:5px 14px;border:none;border-radius:5px;background:transparent;color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.segment-control button:hover{color:var(--text-secondary)}.segment-control button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.debug-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:12px;color:var(--text-secondary);font-weight:500;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}.debug-toggle input{position:absolute;opacity:0;width:0;height:0}.toggle-track{position:relative;width:32px;height:18px;background:#d1d5db;border-radius:9px;transition:background .2s;flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.15)}.debug-toggle input:checked+.toggle-track{background:var(--accent)}.debug-toggle input:checked+.toggle-track:after{transform:translateX(14px)}.dc-panel{padding:12px 20px 14px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:12px;background:var(--surface)}.dc-row{gap:8px 16px}.dc-row,.dc-section{display:flex;align-items:center;flex-wrap:wrap}.dc-section{gap:10px}.dc-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);width:56px;flex-shrink:0}.dc-select{display:flex;align-items:center;gap:5px}.dc-select-label{font-size:11px;color:var(--text-muted);font-weight:500}.dc-select select{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:12px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.dc-select select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.dc-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:12px;color:var(--text-secondary);font-weight:500;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}.dc-toggle input{position:absolute;opacity:0;width:0;height:0}.dc-toggle .toggle-track{width:28px;height:16px;border-radius:8px}.dc-toggle .toggle-track:after{width:12px;height:12px}.dc-toggle input:checked+.toggle-track{background:var(--accent)}.dc-toggle input:checked+.toggle-track:after{transform:translateX(12px)}.dc-pills{display:flex;flex-wrap:wrap;gap:6px}.dc-pill{padding:4px 14px;border:1px solid var(--border);border-radius:16px;background:var(--surface);color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;text-transform:capitalize;-webkit-user-select:none;-moz-user-select:none;user-select:none}.dc-pill-active,.dc-pill:hover{border-color:var(--accent-border);color:var(--accent)}.dc-pill-active{background:var(--accent-light)}.dc-input{display:flex;align-items:center;gap:5px}.dc-input-label{font-size:11px;color:var(--text-muted);font-weight:500;white-space:nowrap}.dc-input input{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:12px;font-family:var(--mono);transition:border-color .15s,box-shadow .15s}.dc-input input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.dc-input input::placeholder{color:var(--text-muted);font-family:var(--font)}.dc-input-wide input{width:120px}.dc-input-sm input{width:68px}.dc-input-num input{width:52px}.dc-sep{width:1px;height:20px;background:var(--border);flex-shrink:0}.dc-truck-section{padding-top:10px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:10px}.main-content{display:flex;flex:1 1;height:0}.left-column{flex:1 1;display:flex;flex-direction:column;min-width:0}.map-wrapper{flex:1 1;position:relative;min-height:300px}.map-wrapper .map-placeholder{height:100%;color:var(--text-muted);font-size:14px;background:var(--surface-alt)}.map-wrapper .map-placeholder,.marker-label{display:flex;align-items:center;justify-content:center}.marker-label{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;border:2.5px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.25);cursor:pointer;transition:transform .15s}.marker-label:hover{transform:scale(1.1)}.points-panel{width:300px;background:var(--surface);border-left:1px solid var(--border-light);display:flex;flex-direction:column;overflow:hidden}.points-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-light)}.points-panel-header h3{font-size:13px;font-weight:600;color:var(--text)}.points-panel-header .badge{background:var(--accent);color:#fff;font-size:10px;padding:1px 8px;border-radius:10px;margin-left:8px;font-weight:600}.points-panel-header button{font-size:12px;color:var(--danger);background:none;border:none;cursor:pointer;font-weight:500;transition:opacity .15s}.points-panel-header button:hover{opacity:.7}.points-list{flex:1 1;overflow-y:auto;padding:10px}.points-list .empty-msg{padding:24px 16px;color:var(--text-muted);font-size:13px;text-align:center}.point-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-light);border-radius:var(--radius);margin-bottom:6px;background:var(--surface);transition:border-color .15s,box-shadow .15s}.point-card:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.point-card .point-badge{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.point-card .point-coords{flex:1 1;min-width:0}.point-card .point-coords span{display:block;font-size:12px;font-family:var(--mono);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.point-card .point-coords .snap-detail{color:var(--text-muted);font-family:var(--font);font-size:11px}.point-card .point-remove{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:2px 4px;line-height:1;transition:color .15s;border-radius:4px}.point-card .point-remove:hover{color:var(--danger);background:rgba(239,68,68,.06)}.edge-info-section{border-top:1px solid var(--border-light);display:flex;flex-direction:column;max-height:50%;overflow:hidden}.edge-info-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#fef3c7;border-bottom:1px solid #fde68a;flex-shrink:0}.edge-info-header h3{font-size:13px;font-weight:600;color:#92400e}.edge-info-header .badge{background:#f59e0b;color:#fff;font-size:10px;padding:1px 7px;border-radius:10px;margin-left:6px;font-weight:600}.edge-info-header button{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1;transition:color .15s}.edge-info-header button:hover{color:var(--danger)}.edge-info-body{flex:1 1;overflow-y:auto;padding:8px 10px}.edge-details{font-size:12px}.edge-field{display:flex;justify-content:space-between;padding:4px 6px;border-radius:4px}.edge-field:hover{background:var(--surface-alt)}.edge-field-label{color:var(--text-muted);font-size:11px;text-transform:capitalize}.edge-field-value{font-family:var(--mono);font-size:11px;color:var(--text);text-align:right;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edge-field-num{color:#059669}.edge-field-bool{color:var(--accent)}.edge-field-null{color:var(--text-muted);font-style:italic}.edge-field-group{margin:4px 0}.edge-field-group-label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);padding:3px 6px 2px;text-transform:capitalize}.edge-field-group-body{padding-left:10px;border-left:2px solid var(--border-light);margin-left:6px}.json-panel{border-top:1px solid var(--border);display:flex;flex-direction:column}.json-panel,.json-panel-resize{background:#0f172a;flex-shrink:0}.json-panel-resize{height:4px;cursor:ns-resize;border-bottom:1px solid #1e293b;transition:background .15s}.json-panel-resize:hover{background:var(--accent)}.json-panel-header{display:flex;align-items:center;justify-content:space-between;padding:0 14px 0 0;background:#0f172a;border-bottom:1px solid #1e293b;flex-shrink:0}.json-panel-tabs{display:flex;gap:0}.json-panel-tab{font-size:12px;padding:8px 16px;background:none;color:#64748b;cursor:pointer;border:none;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;font-weight:500}.json-panel-tab:hover{color:#94a3b8}.json-panel-tab.active{color:#e2e8f0;border-bottom-color:var(--accent)}.json-panel-header button{font-size:12px;padding:4px 10px;border:1px solid #1e293b;border-radius:var(--radius-sm);background:#1e293b;color:#94a3b8;cursor:pointer;font-weight:500;transition:all .15s}.json-panel-header button:hover{background:#334155;color:#e2e8f0}.json-panel-body{flex:1 1;overflow:auto;padding:12px 16px}.json-panel-body pre{font-size:12px;font-family:var(--mono);color:#cbd5e1;white-space:pre-wrap;word-break:break-all;line-height:1.6}.json-panel-body .empty-msg{color:#475569;font-size:13px;padding:12px 0}.json-panel-body .loading-msg{color:var(--accent);font-size:13px}.json-panel-body .error-msg{color:#f87171;font-size:13px}.json-panel-actions{display:flex;gap:4px}.json-tree{font-family:var(--mono);font-size:12px;line-height:1.6}.jt-line{white-space:nowrap;padding-left:4px}.jt-node>.jt-children{padding-left:20px;border-left:1px solid #1e293b;margin-left:7px}.jt-toggle{all:unset;cursor:pointer;width:14px;display:inline-block;text-align:center;color:#475569;font-size:8px;vertical-align:middle;margin-right:2px}.jt-toggle:hover{color:#94a3b8}.jt-arrow{display:inline-block;transition:transform .1s}.jt-arrow-down{transform:rotate(90deg)}.jt-key{color:#7dd3fc}.jt-punct{color:#475569}.jt-str{color:#fda4af}.jt-num{color:#86efac}.jt-bool,.jt-null{color:#93c5fd}.jt-collapsed,.jt-null{font-style:italic}.jt-collapsed{color:#475569;cursor:pointer;font-size:11px;padding:0 4px}.jt-collapsed:hover{color:#94a3b8}.request-display{font-family:var(--mono);font-size:12px;line-height:1.6}.request-method{display:inline-block;background:#059669;color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:4px;margin-bottom:8px}.request-url{color:#7dd3fc;word-break:break-all;margin-bottom:12px}.request-params{border-top:1px solid #1e293b;padding-top:8px}.request-params-title{font-size:10px;color:#64748b;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-family:var(--font);font-weight:600}.request-param{display:flex;justify-content:space-between;padding:2px 6px;border-radius:4px}.request-param:hover{background:hsla(0,0%,100%,.04)}.request-param-key{color:#7dd3fc;flex-shrink:0;margin-right:12px}.request-param-value{color:#fda4af;text-align:right;word-break:break-all;min-width:0}.nav-legs-section{border-top:1px solid var(--border-light);display:flex;flex-direction:column}.nav-legs-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#ecfdf5;border-bottom:1px solid #a7f3d0;flex-shrink:0}.nav-legs-header h3{font-size:13px;font-weight:600;color:#065f46}.nav-legs-summary{font-size:12px;color:var(--text-secondary);font-weight:500}.nav-legs-body{padding:8px 10px}.nav-leg-card{margin-bottom:4px;border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}.nav-leg-toggle{all:unset;display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:var(--surface-alt);cursor:pointer;font-size:12px;box-sizing:border-box;transition:background .15s}.nav-leg-toggle:hover{background:var(--border-light)}.nav-leg-arrow{color:var(--text-muted);font-size:14px;width:16px;flex-shrink:0;font-weight:700}.nav-leg-title{font-weight:600;color:var(--text)}.nav-leg-meta{flex:1 1;color:var(--text-muted);font-size:11px}.nav-leg-steps{border-top:1px solid var(--border-light)}.nav-step-card{border-bottom:1px solid var(--border-light)}.nav-step-card:last-child{border-bottom:none}.nav-step-main{display:flex;align-items:flex-start;gap:8px;padding:7px 10px;cursor:pointer;transition:background .15s}.nav-step-main:hover{background:var(--surface-alt)}.nav-step-index{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.nav-step-info{flex:1 1;min-width:0}.nav-step-instruction{display:block;font-size:12px;color:var(--text);line-height:1.3}.nav-step-meta{display:block;font-size:11px;color:var(--text-muted);margin-top:2px}.nav-step-road{color:var(--text-secondary)}.nav-step-expand{color:var(--text-muted);font-size:14px;font-weight:700;flex-shrink:0;margin-top:1px;width:16px;text-align:center}.nav-step-details{padding:6px 10px 8px 40px;background:var(--surface-alt);border-top:1px solid var(--border-light)}.nav-step-group{margin:4px 0}.nav-step-group-label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);padding:3px 0 2px}.nav-step-field{display:flex;justify-content:space-between;padding:2px 6px;border-radius:4px;font-size:11px}.nav-step-field:hover{background:var(--border-light)}.nav-step-field-label{color:var(--text-muted);flex-shrink:0;margin-right:8px}.nav-step-field-value{font-family:var(--mono);font-size:11px;color:var(--text);text-align:right;word-break:break-all;min-width:0}.nav-intersection{margin-left:6px;border-left:2px solid var(--border);padding-left:8px;margin-bottom:2px}.nav-intersection-toggle{all:unset;display:flex;justify-content:space-between;width:100%;font-size:12px;color:var(--text-secondary);cursor:pointer;padding:2px 4px;border-radius:4px;box-sizing:border-box;font-weight:500}.nav-intersection-toggle:hover{background:var(--border-light);color:var(--text)}.nav-intersection-body{padding:2px 0 4px}