:root{--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--gap: 16px;--gap-lg: 24px;--ease: cubic-bezier(.4, 0, .2, 1);--duration: .2s;--duration-slow: .35s}:root,[data-theme=dark]{--bg-deep: #06080f;--bg: #0c1021;--surface: #151b30;--surface-hover: #1c2440;--surface-active: #232d52;--glass: rgba(21, 27, 48, .72);--glass-border: rgba(255, 255, 255, .06);--glass-border-hover: rgba(255, 255, 255, .12);--accent: #60a5fa;--accent-glow: rgba(96, 165, 250, .15);--accent-soft: rgba(96, 165, 250, .08);--accent-vivid: #3b82f6;--accent-gradient: linear-gradient(135deg, #3b82f6, #60a5fa);--green: #34d399;--green-soft: rgba(52, 211, 153, .1);--red: #f87171;--red-soft: rgba(248, 113, 113, .1);--amber: #fbbf24;--amber-soft: rgba(251, 191, 36, .08);--purple: #a78bfa;--purple-soft: rgba(167, 139, 250, .08);--text: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--text-bright: #f8fafc;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 24px var(--accent-glow)}[data-theme=light]{--bg-deep: #f0f4f8;--bg: #ffffff;--surface: #f8fafc;--surface-hover: #f1f5f9;--surface-active: #e2e8f0;--glass: rgba(255, 255, 255, .82);--glass-border: rgba(0, 0, 0, .06);--glass-border-hover: rgba(0, 0, 0, .12);--accent: #2563eb;--accent-glow: rgba(37, 99, 235, .1);--accent-soft: rgba(37, 99, 235, .06);--accent-vivid: #1d4ed8;--accent-gradient: linear-gradient(135deg, #1d4ed8, #3b82f6);--green: #059669;--green-soft: rgba(5, 150, 105, .08);--red: #dc2626;--red-soft: rgba(220, 38, 38, .06);--amber: #d97706;--amber-soft: rgba(217, 119, 6, .06);--purple: #7c3aed;--purple-soft: rgba(124, 58, 237, .06);--text: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--text-bright: #0f172a;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow: 0 0 24px var(--accent-glow)}[data-theme=light] body:before,[data-theme=light] body:after{opacity:.3}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Noto Sans SC,sans-serif;background:var(--bg-deep);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{content:"";position:fixed;top:-40%;left:-20%;width:80%;height:80%;background:radial-gradient(ellipse,rgba(59,130,246,.04) 0%,transparent 60%);z-index:-1;pointer-events:none}body:after{content:"";position:fixed;bottom:-30%;right:-20%;width:70%;height:70%;background:radial-gradient(ellipse,rgba(167,139,250,.03) 0%,transparent 60%);z-index:-1;pointer-events:none}.app{max-width:960px;margin:0 auto;padding:24px 20px 64px}.header{text-align:center;padding:48px 0 36px;position:relative}.header-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:var(--radius-lg);background:var(--accent-gradient);font-size:28px;margin-bottom:16px;box-shadow:var(--shadow-glow)}.header h1{font-size:28px;font-weight:700;color:var(--text-bright);letter-spacing:-.5px}.theme-toggle{position:absolute;top:48px;right:0;width:40px;height:40px;border:1px solid var(--glass-border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-secondary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration) var(--ease)}.theme-toggle:hover{background:var(--surface-hover);border-color:var(--glass-border-hover);color:var(--text)}.header p{font-size:14px;color:var(--text-muted);margin-top:6px}.nav{display:flex;gap:4px;background:var(--surface);padding:4px;border-radius:var(--radius);margin-bottom:var(--gap-lg);border:1px solid var(--glass-border)}.nav-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;background:none;color:var(--text-muted);font-size:14px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap}.nav-btn:hover{color:var(--text-secondary);background:var(--surface-hover)}.nav-btn.active{color:var(--text-bright);background:var(--accent-gradient);box-shadow:var(--shadow-glow)}.nav-btn .nav-icon{font-size:16px}.panel{display:none;animation:fadeSlideIn var(--duration-slow) var(--ease)}.panel.active{display:block}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--gap-lg);margin-bottom:var(--gap);box-shadow:var(--shadow-md)}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--gap)}.form-grid.cols-3{grid-template-columns:repeat(3,1fr)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full{grid-column:1 / -1}.form-group label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select{background:var(--bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);padding:10px 14px;font-size:14px;transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease);outline:none;width:100%}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-group select option{background:var(--surface);color:var(--text)}.check-label{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.check-label input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:1.5px solid var(--text-muted);border-radius:4px;background:var(--bg);cursor:pointer;position:relative;transition:all var(--duration) var(--ease);flex-shrink:0}.check-label input[type=checkbox]:checked{background:var(--accent-vivid);border-color:var(--accent-vivid)}.check-label input[type=checkbox]:checked:after{content:"✓";position:absolute;color:#fff;font-size:12px;font-weight:700;top:50%;left:50%;transform:translate(-50%,-50%)}.btn-row{grid-column:1 / -1;display:flex;gap:12px;padding-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 28px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--duration) var(--ease);outline:none}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm),var(--shadow-glow)}.btn-primary:hover{box-shadow:var(--shadow-md),0 0 32px var(--accent-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-ghost{background:var(--surface-hover);color:var(--text-secondary);border:1px solid var(--glass-border)}.btn-ghost:hover{background:var(--surface-active);color:var(--text);border-color:var(--glass-border-hover)}.btn-sm{padding:6px 14px;font-size:12px;border-radius:6px}.btn-icon{width:32px;height:32px;padding:0;border-radius:8px;background:var(--surface-hover);color:var(--text-muted);border:1px solid var(--glass-border);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px;transition:all var(--duration) var(--ease)}.btn-icon:hover{background:var(--red-soft);color:var(--red);border-color:#f8717133}.loading{text-align:center;padding:48px 0;color:var(--text-muted);font-size:14px}.loading:before{content:"";display:block;width:32px;height:32px;margin:0 auto 12px;border:3px solid var(--surface-active);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{text-align:center;padding:24px;color:var(--red);background:var(--red-soft);border-radius:var(--radius);font-size:14px}.empty-msg{text-align:center;padding:48px 0;color:var(--text-muted);font-size:14px}.result-info{font-size:13px;color:var(--text-muted);margin-bottom:12px;padding-left:2px}.result-info strong{color:var(--accent)}.ticket-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:18px 20px;margin-bottom:10px;transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.ticket-card:hover{border-color:var(--glass-border-hover);box-shadow:var(--shadow-md)}.ticket-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.train-code{font-size:18px;font-weight:700;color:var(--accent);letter-spacing:.5px}.train-type-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:100px;background:var(--accent-soft);color:var(--accent)}.ticket-date{font-size:12px;color:var(--text-muted);margin-left:auto}.ticket-route{display:flex;align-items:center;gap:12px;margin-bottom:14px}.station-block{text-align:center;min-width:72px}.station-time{font-size:22px;font-weight:700;color:var(--text-bright);font-variant-numeric:tabular-nums}.station-name{font-size:12px;color:var(--text-secondary);margin-top:2px}.route-arrow{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}.route-arrow:before{content:"";width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--text-muted),transparent)}.route-duration{font-size:11px;color:var(--text-muted);font-weight:500}.price-row{display:flex;flex-wrap:wrap;gap:8px}.price-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg);border-radius:100px;font-size:12px;border:1px solid var(--glass-border)}.price-tag .seat{color:var(--text-secondary)}.price-tag .amt{font-weight:600;color:var(--green)}.price-tag .num{color:var(--text-muted);font-size:11px}.price-tag .num.sold-out{color:var(--red)}.sort-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);margin-bottom:12px;flex-wrap:wrap}.sort-bar label{font-size:12px;color:var(--text-muted);font-weight:500}.sort-bar select,.sort-bar input{background:var(--bg);border:1px solid var(--glass-border);color:var(--text);border-radius:6px;padding:5px 10px;font-size:12px;outline:none}.sort-bar select:focus,.sort-bar input:focus{border-color:var(--accent)}.sort-bar .spacer{flex:1}.sort-bar .count{font-size:12px;color:var(--text-muted)}.route-card{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:12px;overflow:hidden;transition:border-color var(--duration) var(--ease)}.route-card:hover{border-color:var(--glass-border-hover)}.route-summary{display:flex;align-items:center;gap:16px;padding:18px 24px;cursor:pointer;transition:background var(--duration) var(--ease)}.route-summary:hover{background:var(--surface-hover)}.route-rank{font-size:16px;font-weight:700;color:var(--accent);min-width:32px}.route-stats{display:flex;gap:32px;flex:1}.route-stat{text-align:center}.route-stat-val{font-size:18px;font-weight:700;color:var(--text-bright);font-variant-numeric:tabular-nums}.route-stat-val.price{color:var(--green)}.route-stat-label{font-size:11px;color:var(--text-muted);margin-top:2px}.route-detail{border-top:1px solid var(--glass-border);padding:20px 24px;transition:max-height var(--duration-slow) var(--ease)}.route-detail.collapsed{display:none}.seg-timeline{position:relative;padding-left:24px}.seg-timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--glass-border)}.seg-item{position:relative;margin-bottom:16px}.seg-item:last-child{margin-bottom:0}.seg-dot{position:absolute;left:-20px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);z-index:1}.seg-item.flight .seg-dot{background:var(--purple)}.seg-mode-badge{display:inline-block;font-size:11px;font-weight:600;padding:1px 8px;border-radius:100px;margin-right:6px}.seg-mode-badge.train{background:var(--accent-soft);color:var(--accent)}.seg-mode-badge.flight{background:var(--purple-soft);color:var(--purple)}.seg-line1{font-size:14px;color:var(--text);font-weight:500;margin-bottom:3px}.seg-line2{font-size:12px;color:var(--text-muted)}.ai-box{margin-top:16px;padding:14px 16px;border-radius:var(--radius);background:linear-gradient(135deg,var(--accent-soft),var(--purple-soft));border:1px solid var(--glass-border);font-size:13px;color:var(--text-secondary);line-height:1.7}.ai-box:before{content:"🤖 AI 分析";display:block;font-weight:600;color:var(--accent);margin-bottom:6px;font-size:12px}.tips-box{margin-top:12px;padding:14px 16px;border-radius:var(--radius);background:var(--green-soft);border:1px solid rgba(52,211,153,.1);font-size:13px;color:var(--text-secondary);line-height:1.7}.tips-box:before{content:"🏞 游玩推荐";display:block;font-weight:600;color:var(--green);margin-bottom:6px;font-size:12px}.station-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.station-table thead th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:var(--bg);border-bottom:1px solid var(--glass-border)}.station-table thead th:first-child{border-radius:var(--radius-sm) 0 0 0}.station-table thead th:last-child{border-radius:0 var(--radius-sm) 0 0}.station-table tbody td{padding:10px 14px;border-bottom:1px solid var(--glass-border);color:var(--text)}.station-table tbody tr:hover td{background:var(--surface-hover)}.station-table .code-cell{color:var(--accent);font-weight:600;font-family:SF Mono,Fira Code,monospace}.stop-list{display:flex;flex-direction:column;gap:8px}.stop-row{display:flex;align-items:center;gap:10px}.stop-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:12px;font-weight:700;flex-shrink:0}.btn-add-stop{display:inline-flex;align-items:center;gap:4px;color:var(--accent);font-size:13px;font-weight:500;cursor:pointer;padding:6px 0;transition:opacity var(--duration) var(--ease)}.btn-add-stop:hover{opacity:.8}.leg-header{font-size:15px;font-weight:600;color:var(--text);padding:12px 0 8px;border-bottom:1px solid var(--glass-border);margin-bottom:10px}.leg-body{margin-bottom:20px}.ac-wrap{position:relative}.ac-dropdown{display:none;position:absolute;top:100%;left:0;right:0;z-index:100;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-sm);margin-top:4px;max-height:240px;overflow-y:auto;box-shadow:var(--shadow-lg)}.ac-dropdown.show{display:block;animation:fadeSlideIn .15s var(--ease)}.ac-item{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;cursor:pointer;transition:background var(--duration) var(--ease);font-size:13px}.ac-item:hover,.ac-item.active{background:var(--surface-hover)}.ac-name{font-weight:500;color:var(--text)}.ac-city{font-size:11px;color:var(--text-muted);margin-left:8px}.ac-code{font-size:11px;font-weight:600;color:var(--accent);font-family:SF Mono,Fira Code,monospace}@media(max-width:640px){.app{padding:16px 12px 48px}.header{padding:32px 0 24px}.header h1{font-size:22px}.card{padding:16px}.form-grid,.form-grid.cols-3{grid-template-columns:1fr}.nav-btn{padding:8px 10px;font-size:12px}.nav-btn .nav-label{display:none}.nav-btn .nav-icon{font-size:18px}.route-stats{gap:16px}.route-stat-val{font-size:15px}.route-summary{padding:14px 16px}.route-detail{padding:16px}.ticket-route{flex-wrap:nowrap}.station-time{font-size:18px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-active);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;text-align:center;padding:10px 16px;font-size:14px;font-weight:600;transform:translateY(-100%);transition:transform .3s ease}.offline-banner.show{transform:translateY(0)}.btn-retry{display:inline-block;margin-top:12px;padding:6px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;transition:background .2s}.btn-retry:hover{background:var(--accent-hover)}.skeleton-card{background:var(--surface);border-radius:12px;padding:20px;margin-bottom:12px;border:1px solid var(--border)}.skeleton-line{height:14px;background:linear-gradient(90deg,var(--surface-hover) 25%,var(--surface-active) 50%,var(--surface-hover) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:6px;margin-bottom:12px}.skeleton-line.w-40{width:40%}.skeleton-line.w-60{width:60%}.skeleton-line.w-80{width:80%}.skeleton-row{display:flex;gap:10px;margin-top:8px}.skeleton-tag{width:80px;height:28px;background:linear-gradient(90deg,var(--surface-hover) 25%,var(--surface-active) 50%,var(--surface-hover) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:6px}.skeleton-pulse{height:4px;background:linear-gradient(90deg,var(--accent) 0%,transparent 50%,var(--accent) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.2s ease-in-out infinite;border-radius:2px;margin-bottom:12px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.plan-progress{background:var(--surface);border-radius:12px;padding:24px;border:1px solid var(--border);text-align:center}.progress-msg{color:var(--text-muted);font-size:14px;margin-top:8px}.virtual-scroll-container{border-radius:12px}.virtual-scroll-container::-webkit-scrollbar{width:6px}.virtual-scroll-container::-webkit-scrollbar-thumb{background:var(--surface-active);border-radius:3px}
