*,*:before,*:after{box-sizing:border-box}body{margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0f1e;--surface: #111827;--border: #1f2d45;--primary: #1d6fb5;--primary-h:#2483d4;--accent: #f59e0b;--text: #e8edf5;--muted: #6b7a99;--danger: #ef4444;--success: #22c55e;--radius: 12px;--shadow: 0 4px 24px rgba(0,0,0,.4);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.5}body{background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;min-height:100dvh;max-width:520px;margin:0 auto;padding:0 16px 32px}.app-header{text-align:center;padding:24px 0 16px;border-bottom:1px solid var(--border);margin-bottom:24px}.app-header h1{font-size:2rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}.tagline{color:var(--accent);font-size:.9rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.app-main{flex:1}.btn,button{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;border-radius:var(--radius);border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s,transform .1s;text-decoration:none;-webkit-tap-highlight-color:transparent}button:disabled{opacity:.45;cursor:not-allowed}button:active:not(:disabled){transform:scale(.97)}.btn.primary,button.primary{background:var(--primary);color:#fff;width:100%}.btn.primary:hover:not(:disabled),button.primary:hover:not(:disabled){background:var(--primary-h)}.btn.secondary,button.secondary{background:transparent;color:var(--text);border:1.5px solid var(--border);width:100%}.btn.secondary:hover:not(:disabled){background:var(--surface)}.btn.ghost,button.ghost{background:transparent;color:var(--muted);width:100%;font-weight:400}.btn.ghost:hover{color:var(--text)}.upload-panel{display:flex;flex-direction:column;gap:16px}.mode-tabs{display:flex;gap:8px;background:var(--surface);padding:6px;border-radius:var(--radius)}.mode-tabs button{flex:1;padding:10px;font-size:.85rem;background:transparent;color:var(--muted);border-radius:8px;width:auto}.mode-tabs button.active{background:var(--primary);color:#fff}.file-upload-area{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius);padding:32px 20px;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}.file-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 28px;background:var(--primary);color:#fff;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.file-btn:hover{background:var(--primary-h)}.text-area-wrap{display:flex;flex-direction:column;gap:12px}textarea{width:100%;padding:14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;font-family:inherit;resize:vertical;min-height:180px;line-height:1.6}textarea:focus{outline:none;border-color:var(--primary)}textarea::placeholder{color:var(--muted)}.status{padding:10px 14px;background:var(--surface);border-radius:8px;font-size:.85rem;color:var(--muted);text-align:center}.status.loading{animation:pulse 1.5s ease-in-out infinite}.verify-steps{display:flex;flex-direction:column;gap:16px}.parse-header{background:var(--surface);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px}.parse-header h2{font-size:1.2rem}.route-meta{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;flex-wrap:wrap}.route-meta .arrow{color:var(--accent)}.route-meta .state{color:var(--muted);font-weight:400}.confidence{display:flex;flex-direction:column;gap:6px;font-size:.85rem}.confidence-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.confidence-fill{height:100%;background:var(--success);border-radius:2px;transition:width .4s ease}.steps-list{list-style:none;display:flex;flex-direction:column;gap:6px}.step-item{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:.9rem;flex-wrap:wrap}.step-seq{min-width:22px;height:22px;background:var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.step-action{font-size:.75rem;padding:2px 6px;border-radius:4px;font-weight:600;flex-shrink:0}.action-follow{background:#1e3a5f;color:#60a5fa}.action-exit{background:#3b1f00;color:var(--accent)}.action-merge{background:#1a3320;color:#4ade80}.action-turn{background:#2d1a3d;color:#c084fc}.action-continue{background:#1e3a5f;color:#60a5fa}.step-road{font-weight:700;font-family:SF Mono,Fira Code,monospace}.step-dir{background:var(--border);padding:1px 6px;border-radius:4px;font-size:.75rem;font-weight:700}.step-exit{font-size:.8rem;color:var(--accent);font-weight:600}.step-toward{font-size:.8rem;color:var(--muted)}.step-remove{margin-left:auto;width:22px;height:22px;padding:0;background:transparent;color:var(--muted);border-radius:50%;font-size:1rem;line-height:1;flex-shrink:0}.step-remove:hover{color:var(--danger);background:#ef44441a}.empty-steps{text-align:center;color:var(--muted);padding:24px}.verify-actions{display:flex;gap:10px}.verify-actions .secondary{flex:0 0 auto;width:auto;padding:12px 20px}.verify-actions .primary{flex:1}.route-output{display:flex;flex-direction:column;gap:20px}.route-header{background:linear-gradient(135deg,var(--primary) 0%,#0d3a6e 100%);border-radius:var(--radius);padding:20px;text-align:center}.route-header h2{font-size:1.4rem;margin-bottom:6px}.waypoint-count{color:#ffffffb3;font-size:.85rem}.waypoints-list{list-style:none;display:flex;flex-direction:column;gap:4px;counter-reset:wp}.waypoint-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface);border-radius:8px;font-size:.85rem}.wp-num{min-width:22px;height:22px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0}.wp-label{flex:1;font-weight:600}.wp-coords{color:var(--muted);font-family:monospace;font-size:.75rem}.cta-buttons{display:flex;flex-direction:column;gap:10px}.cta-buttons .btn.primary{font-size:1.1rem;padding:16px}.hint{text-align:center;color:var(--muted);font-size:.8rem}.generating-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:48px 20px;text-align:center;min-height:50vh}.generating-screen h2{font-size:1.4rem}.error-icon{font-size:3rem}.error-message{color:var(--muted);max-width:340px}.inline-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;color:var(--muted);font-size:.9rem}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.spinner.large{width:56px;height:56px;border-width:4px}
