*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}#root{width:100vw;height:100vh}.app-container{display:flex;height:100vh;width:100vw}.map-container{flex:1;height:100%}.sidebar{width:320px;background:#f8f9fa;padding:20px;border-left:1px solid #dee2e6;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.sidebar h1{font-size:1.5rem;color:#212529;margin-bottom:8px}.sidebar p{font-size:.875rem;color:#6c757d;line-height:1.5}.section{background:#fff;padding:16px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.section h2{font-size:1rem;color:#495057;margin-bottom:12px}.status-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e9ecef}.status-item:last-child{border-bottom:none}.status-label{color:#6c757d;font-size:.875rem}.status-value{color:#212529;font-weight:500;font-size:.875rem}.status-value.success{color:#28a745}.status-value.warning{color:#ffc107}.status-value.error{color:#dc3545}.btn{width:100%;padding:12px 16px;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s}.btn:disabled{opacity:.4;cursor:not-allowed;background:#adb5bd;color:#6c757d}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#545b62}.btn-success{background:#28a745;color:#fff}.btn-success:hover:not(:disabled){background:#1e7e34}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn-group{display:flex;flex-direction:column;gap:8px}.error-message{background:#f8d7da;color:#721c24;padding:12px;border-radius:6px;font-size:.875rem}.loading-message{background:#d1ecf1;color:#0c5460;padding:12px;border-radius:6px;font-size:.875rem;display:flex;align-items:center;gap:8px}.spinner{width:16px;height:16px;border:2px solid #0c5460;border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stat-item{background:#e9ecef;padding:12px;border-radius:6px;text-align:center}.stat-value{font-size:1.25rem;font-weight:600;color:#212529}.stat-label{font-size:.75rem;color:#6c757d;margin-top:4px}.instructions{background:#e7f1ff;padding:12px;border-radius:6px;font-size:.813rem;color:#004085;line-height:1.6}.instructions ol{margin-left:16px}.instructions li{margin-bottom:4px}.search-box-container{position:absolute;top:10px;right:10px;z-index:1000;width:300px}.search-input{width:100%;padding:10px 14px;font-size:14px;border:2px solid rgba(0,0,0,.2);border-radius:4px;background:#fff;box-shadow:0 2px 6px #00000026;outline:none}.search-input:focus{border-color:#007bff}.search-input::placeholder{color:#999}.search-loading{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#666}.search-results{list-style:none;margin:4px 0 0;padding:0;background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 12px #00000026;max-height:250px;overflow-y:auto}.search-result-item{padding:10px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid #eee;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#f0f7ff}.route-legend{background:#fff;padding:12px;border-radius:6px;margin-top:8px}.route-legend-title{font-size:.875rem;font-weight:600;margin-bottom:8px}.route-legend-item{display:flex;align-items:center;gap:8px;font-size:.75rem;margin-bottom:4px}.route-legend-color{width:24px;height:4px;border-radius:2px}.route-legend-gradient{width:60px;height:8px;border-radius:2px;background:linear-gradient(to right,#00c800,#ff0,#ff8000,red)}.waypoint-marker{background:transparent;border:none}
