*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f8fafc;--color-surface:#fff;--color-border:#e2e8f0;--color-text:#1e293b;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-primary:#3b82f6;--color-danger:#ef4444;--color-success:#10b981;--color-warning:#f59e0b;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--sidebar-width:320px;--detail-panel-width:400px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease}html,body,#root{width:100%;height:100%;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px}.app{width:100%;height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);z-index:10;flex-direction:column;height:100%;display:flex;overflow-y:auto}.map-area{flex:1;position:relative;overflow:hidden}.map-container{width:100%;height:100%}.detail-panel{width:var(--detail-panel-width);background:var(--color-surface);z-index:100;height:100%;transition:transform var(--transition-slow) cubic-bezier(.16, 1, .3, 1);flex-direction:column;display:flex;position:absolute;top:0;right:0;overflow:hidden;transform:translate(100%);box-shadow:-4px 0 20px #0000001a}.detail-panel.open{transform:translate(0)}.search-panel{border-bottom:1px solid var(--color-border);flex-shrink:0;padding:16px}.search-panel h1{color:var(--color-text);margin-bottom:16px;font-size:18px;font-weight:700}.search-inputs{position:relative}.search-input-wrapper{margin-bottom:8px;position:relative}.search-input-wrapper input{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;transition:border-color var(--transition-fast);background:var(--color-bg);outline:none;padding:10px 36px 10px 12px;font-size:14px}.search-input-wrapper input:focus{border-color:var(--color-primary);background:var(--color-surface)}.search-input-wrapper input::placeholder{color:var(--color-text-muted)}.swap-btn{border:1px solid var(--color-border);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;z-index:2;transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.swap-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#eff6ff}.plan-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;width:100%;transition:background var(--transition-fast);border:none;margin-top:12px;padding:10px;font-size:14px;font-weight:600}.plan-btn:hover:not(:disabled){background:#2563eb}.plan-btn:disabled{opacity:.5;cursor:not-allowed}.autocomplete-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;max-height:200px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.autocomplete-item{cursor:pointer;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);padding:10px 12px}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:var(--color-bg)}.autocomplete-item .item-name{color:var(--color-text);font-size:14px;font-weight:500}.autocomplete-item .item-address{color:var(--color-text-muted);margin-top:2px;font-size:12px}.route-comparison-panel{flex:1;padding:16px;overflow-y:auto}.route-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);margin-bottom:10px;padding:14px 16px;position:relative;overflow:hidden}.route-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.route-card.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f626}.route-card-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.route-card-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.route-card-icon.driving{color:#3b82f6;background:#dbeafe}.route-card-icon.walking{color:#10b981;background:#d1fae5}.route-card-icon.cycling{color:#f59e0b;background:#fef3c7}.route-card-name{flex:1;font-size:16px;font-weight:600}.route-card-stats{flex-wrap:wrap;gap:16px;display:flex}.route-stat{color:var(--color-text-secondary);align-items:center;gap:4px;font-size:13px;display:flex}.route-stat-value{color:var(--color-text);font-weight:600}.detail-panel-header{border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;padding:16px;display:flex}.detail-panel-header h2{flex:1;font-size:16px;font-weight:700}.close-btn{cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;display:flex}.close-btn:hover{background:var(--color-bg);color:var(--color-text)}.detail-panel-body{flex:1;padding:16px;overflow-y:auto}.detail-summary{background:var(--color-bg);border-radius:var(--radius-md);gap:20px;margin-bottom:16px;padding:12px 16px;display:flex}.detail-summary-item{flex-direction:column;flex:1;align-items:center;display:flex}.detail-summary-value{color:var(--color-text);font-size:20px;font-weight:700}.detail-summary-label{color:var(--color-text-muted);margin-top:2px;font-size:12px}.step-list{list-style:none}.step-item{border-bottom:1px solid var(--color-border);padding:12px 0 12px 28px;position:relative}.step-item:last-child{border-bottom:none}.step-item:before{content:"";background:var(--color-border);width:2px;position:absolute;top:0;bottom:0;left:8px}.step-item:first-child:before{top:12px}.step-item:last-child:before{bottom:12px}.step-dot{border:2px solid var(--color-primary);background:var(--color-surface);border-radius:50%;width:12px;height:12px;position:absolute;top:16px;left:3px}.step-instruction{color:var(--color-text);font-size:14px;line-height:1.5}.step-meta{color:var(--color-text-muted);gap:12px;margin-top:6px;font-size:12px;display:flex}.loading-overlay{z-index:50;background:#ffffffb3;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.loading-dots{gap:8px;margin-bottom:12px;display:flex}.loading-dot{background:var(--color-primary);border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite pulse}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}.loading-text{color:var(--color-text-secondary);font-size:14px}@keyframes pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.error-banner{border-radius:var(--radius-md);background:#fef2f2;border:1px solid #fecaca;align-items:center;gap:10px;margin:12px 16px;padding:12px 16px;display:flex}.error-icon{color:var(--color-danger);flex-shrink:0;font-size:18px}.error-text{color:var(--color-danger);flex:1;font-size:14px}.retry-btn{background:var(--color-danger);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);border:none;padding:4px 12px;font-size:13px}.retry-btn:hover{background:#dc2626}@media (width<=768px){.app{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--color-border);width:100%;min-width:100%;height:auto;max-height:50vh}.search-panel{padding:12px}.search-panel h1{margin-bottom:12px;font-size:16px}.map-area{flex:1;min-height:50vh}.detail-panel{border-radius:16px 16px 0 0;width:100%;height:70vh;top:auto;bottom:0;transform:translateY(100%)}.detail-panel.open{transform:translateY(0)}.route-comparison-panel{gap:10px;padding:12px;display:flex;overflow-x:auto}.route-card{flex-shrink:0;min-width:200px;margin-bottom:0}}
