html,body,#root{height:100%;overflow:hidden}body{margin:0}:root{--bg-base:#141414;--bg-elevated:#1c1c1e;--bg-surface:#2c2c2e;--bg-surface-hover:#3a3a3c;--bg-inset:#161616;--border:#ffffff17;--border-strong:#ffffff24;--text:#f5f5f7;--text-secondary:#98989d;--text-tertiary:#636366;--accent:#e5e5ea;--accent-dim:#ffffff1a;--accent-strong:#fff;--danger:#ff6b6b;--success:#30d158;--shadow:0 8px 32px #0006;--radius:12px;--radius-sm:8px;--header-h:65px;color:var(--text);background:var(--bg-base);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,system-ui,sans-serif;line-height:1.5}*{box-sizing:border-box}body{background:var(--bg-base)}.app{background:var(--bg-base);flex-direction:column;height:100%;display:flex;overflow:hidden}.app-header{-webkit-backdrop-filter:blur(20px)saturate(120%);border-bottom:1px solid var(--border);color:var(--text);background:#1c1c1eeb;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.9rem 1.25rem;display:flex}.app-header h1{letter-spacing:-.02em;margin:0;font-size:1.25rem;font-weight:600}.subtitle{color:var(--text-secondary);margin:.2rem 0 0;font-size:.86rem}.header-actions{flex-wrap:wrap;align-items:center;gap:.65rem;display:flex}.layer-toggle{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-sm);gap:2px;padding:2px;display:inline-flex;overflow:hidden}.layer-toggle button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.38rem .7rem;font-size:.82rem;font-weight:500;transition:background .15s,color .15s}.layer-toggle button:hover{color:var(--text)}.layer-toggle button.active{background:var(--accent-dim);color:var(--accent-strong);box-shadow:inset 0 0 0 1px var(--border-strong)}.btn-secondary{border:1px solid var(--border-strong);background:var(--bg-surface);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;padding:.42rem .85rem;font-size:.84rem;font-weight:500;transition:background .15s}.btn-secondary:hover{background:var(--bg-surface-hover)}.welcome{flex:1;grid-template-columns:1fr minmax(280px,380px);align-content:start;gap:1rem;width:100%;max-width:1200px;min-height:0;margin:0 auto;padding:1rem 1.25rem 1.25rem;display:grid;overflow:auto}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--radius);background:var(--bg-elevated);text-align:center;cursor:pointer;padding:3rem 2rem;transition:border-color .15s,background .15s,box-shadow .15s}.dropzone:hover,.dropzone.drag-over{background:var(--bg-surface);box-shadow:var(--shadow);border-color:#ffffff47}.dropzone.loading{opacity:.65;pointer-events:none}.dropzone-icon{color:var(--text-secondary);opacity:.9;margin-bottom:.5rem;font-size:2.25rem}.dropzone-title{color:var(--text);margin:0 0 .35rem;font-size:1.05rem;font-weight:600}.dropzone-hint{color:var(--text-secondary);margin:0}.dropzone-error{color:var(--danger);margin-top:1rem}.info-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem}.info-panel h2{color:var(--text);margin-top:0;font-size:1rem;font-weight:600}.info-panel ul{color:var(--text-secondary);padding-left:1.2rem}.info-panel p,.muted{color:var(--text-secondary)}.small{font-size:.85rem}.workspace{background:var(--bg-base);flex:1;grid-template-columns:1fr minmax(320px,420px);min-height:0;display:grid;overflow:hidden}.map-wrap{background:var(--bg-inset);height:100%;min-height:0;position:relative;overflow:hidden}.map-container{width:100%;height:100%}.map-loading{height:100%;color:var(--text-secondary);background:var(--bg-inset);place-items:center;display:grid}.file-badge{z-index:1000;-webkit-backdrop-filter:blur(12px);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow);background:#2c2c2eeb;padding:.35rem .65rem;font-size:.78rem;position:absolute;top:12px;left:52px}.sidebar{overscroll-behavior:contain;background:var(--bg-elevated);border-left:1px solid var(--border);height:100%;min-height:0;overflow:hidden auto}.panel{border-bottom:1px solid var(--border);padding:1rem 1.1rem}.panel h2,.panel h3,.panel h4{color:var(--text);letter-spacing:-.01em;margin:0 0 .65rem;font-size:.95rem;font-weight:600}.route-caption{color:var(--text-secondary);margin:0 0 .75rem;font-size:.9rem;line-height:1.45}.stats-grid{grid-template-columns:1fr 1fr;gap:.5rem 1rem;margin:0;display:grid}.stats-grid dt{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}.stats-grid dd{color:var(--text);margin:0;font-size:.88rem;font-weight:500}.waypoint-list{color:var(--text-secondary);flex-direction:column;gap:.65rem;margin:0;padding-left:1.2rem;display:flex}.waypoint-list li{flex-direction:column;gap:.15rem;display:flex}.waypoint-list strong{color:var(--text);font-weight:600}.coords{color:var(--text-tertiary);font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.78rem}.panel-detail{background:var(--bg-surface)}.detail-list{gap:.45rem;margin:0 0 .75rem;display:grid}.detail-list dt{color:var(--text-tertiary);font-size:.72rem}.detail-list dd{color:var(--text);margin:0;font-size:.88rem}.summary-text{color:var(--text-secondary);background:var(--bg-inset);border-radius:var(--radius-sm);border:1px solid var(--border);padding:.6rem;font-size:.84rem;line-height:1.45}.bridge-table{border-collapse:collapse;width:100%;font-size:.76rem}.bridge-table th,.bridge-table td{border:1px solid var(--border);text-align:left;padding:.35rem .4rem}.bridge-table th{background:var(--bg-inset);color:var(--text-secondary);font-weight:500}.bridge-table td{color:var(--text)}.panel-segments{padding-bottom:2rem}.panel-header-row{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.segment-search{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-inset);width:120px;color:var(--text);outline:none;padding:.35rem .55rem;font-size:.84rem;transition:border-color .15s,box-shadow .15s}.segment-search::placeholder{color:var(--text-tertiary)}.segment-search:focus{border-color:var(--border-strong);box-shadow:0 0 0 3px var(--accent-dim)}.segment-list{flex-direction:column;gap:.45rem;display:flex}.segment-card{text-align:left;border:1px solid var(--border);background:var(--bg-surface);cursor:pointer;color:var(--text);border-radius:10px;padding:.65rem .75rem;transition:border-color .15s,background .15s,box-shadow .15s}.segment-card:hover{border-color:var(--border-strong);background:var(--bg-surface-hover)}.segment-card.selected{background:var(--accent-dim);border-color:#ffffff38;box-shadow:inset 0 0 0 1px #ffffff14}.segment-card-header{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.segment-index{color:var(--text-tertiary);font-size:.72rem}.segment-road{background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-strong);border-radius:5px;padding:.12rem .42rem;font-size:.72rem;font-weight:500}.segment-name{color:var(--text);margin:0 0 .35rem;font-size:.86rem;font-weight:600}.segment-meta{color:var(--text-secondary);justify-content:space-between;font-size:.76rem;display:flex}.segment-badge{color:var(--text-tertiary);margin-top:.35rem;font-size:.7rem;display:inline-block}.endpoint-marker{background:0 0;border:none}.endpoint-dot{border:2px solid #ffffffe6;border-radius:50%;width:14px;height:14px;box-shadow:0 2px 8px #00000073}.endpoint-dot.start{background:var(--success)}.endpoint-dot.end{background:#aeaeb2}code{background:var(--bg-inset);color:var(--text);border:1px solid var(--border);border-radius:5px;padding:.12rem .35rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.86em}@media (width<=900px){.welcome{grid-template-columns:1fr}.workspace{grid-template-rows:minmax(45vh,1fr) auto;grid-template-columns:1fr;overflow:hidden auto}.map-wrap{height:auto;min-height:45vh}.sidebar{border-left:none;border-top:1px solid var(--border);height:auto;max-height:none;overflow:visible}}
