:root{font-family:PingFang SC,Microsoft YaHei,Arial,system-ui,sans-serif;color:#333;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body{margin:0;min-width:100%;min-height:100%}body{background:#e8e8e8;color:#333}#app{min-height:100vh;display:flex;justify-content:center;align-items:flex-start;background:#e8e8e8}button,input{font:inherit}button{border:0;background:none;cursor:pointer}.screen{width:375px;min-height:100vh;display:flex;flex-direction:column;position:relative;background:#f5f5f5;border-left:1px solid #bbb;border-right:1px solid #bbb}.status-bar{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px 16px 6px;font-size:11px;color:#999;border-bottom:1px solid #ddd;background:#fff}.hero{padding-top:40px;padding-bottom:14px;background:#d0d0d0;border-bottom:1.5px solid #aaa}.hero--purple,.hero--violet{background:#d0d0d0}.hero--compact{padding-bottom:10px}.hero-head,.sub-header,.profile-card{width:calc(100% - 32px);margin:0 auto;display:flex;align-items:center;gap:10px}.hero-head{justify-content:space-between}.hero h2{margin:0;font-size:18px;font-weight:700;color:#222;line-height:1.3}.hero p,.sub-header p,.profile-card p{margin:4px 0 0;color:#777;font-size:12px}.icon-chip{width:34px;height:34px;border-radius:6px;background:silver;border:1px solid #aaa;color:#555;font-size:16px;display:grid;place-items:center}.search-box{display:block;width:calc(100% - 32px);margin:10px auto 0;height:36px;border-radius:4px;background:#e8e8e8;border:1px solid #bbb;color:#999;text-align:left;padding:0 12px;font-size:12px}.content{flex:1;width:100%;background:#f5f5f5;color:#333;padding:12px 16px}.content--with-tab{padding-bottom:90px}.login-screen{justify-content:center;background:#f0f0f0;border-left:1px solid #bbb;border-right:1px solid #bbb}.login-stars{display:none}.login-card{margin:0 auto;width:calc(100% - 48px);border-radius:8px;padding:28px 20px;background:#fff;border:1.5px solid #ccc;text-align:center}.login-card h1{margin:0;font-size:18px;font-weight:700;color:#222}.login-card p{margin:10px 0 22px;line-height:1.7;color:#888;font-size:12px}.login-logo,.profile-avatar{width:64px;height:64px;border-radius:8px;display:grid;place-items:center;background:#d8d8d8;border:1.5px solid #bbb;font-size:28px;margin:0 auto 16px;color:#666}.primary-btn{min-width:100px;height:44px;padding:0 20px;border-radius:4px;background:#555;color:#fff;font-weight:700;font-size:14px;border:1.5px solid #444}.primary-btn--wechat{width:100%;background:#888;border-color:#777}.login-agreement{margin-top:14px;font-size:11px;color:#aaa}.map-card,.menu-card,.route-card,.cost-card{background:#fff;border-radius:6px;border:1.5px solid #ccc}.map-card{padding:10px}.map-filter-row{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px}.filter-pill{flex:0 0 auto;padding:5px 10px;border-radius:3px;background:#eee;border:1px solid #ccc;color:#666;font-size:11px}.filter-pill.is-active{background:#555;border-color:#444;color:#fff}.park-map{position:relative;height:300px;border-radius:4px;overflow:hidden;background:repeating-linear-gradient(0deg,#ddd 0 1px,transparent 1px 30px),repeating-linear-gradient(90deg,#ddd 0 1px,transparent 1px 30px),#ebebeb}.map-road{position:absolute;background:#bbb;border-radius:2px}.road-v{width:4px}.road-h{height:4px}.poi{position:absolute;display:grid;justify-items:center;gap:3px;color:#fff;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:4px;font-size:16px;align-items:center;background:#aaa;border:1.5px solid #888}.poi:before{display:none}.poi span{padding:2px 5px;border-radius:2px;font-size:10px;background:#0000008c;color:#fff;white-space:nowrap;position:absolute;top:38px}.poi--ride{background:#bbb;border-color:#999}.poi--food{background:#c8c8c8;border-color:#aaa}.poi--shop{background:#b8b8b8;border-color:#999}.poi--service{background:#d0d0d0;border-color:#aaa}.map-tools{position:absolute;right:10px;top:12px;display:grid;gap:6px}.map-tools button{width:32px;height:32px;border-radius:4px;background:#fff;color:#555;border:1px solid #ccc;font-size:14px}.ai-fab{position:fixed;right:calc(50% - 171px);bottom:100px;width:56px;height:56px;border-radius:50%;background:#888;border:2px solid #666;color:#fff;z-index:100;display:flex;align-items:center;justify-content:center}.ai-fab span{font-size:24px;line-height:1;display:block}.ai-fab em{position:absolute;right:2px;top:2px;min-width:18px;padding:1px 4px;border-radius:999px;background:#fff;color:#555;font-size:10px;font-style:normal;font-weight:700;border:1px solid #999}.ai-tooltip{position:fixed;right:calc(50% - 107px);bottom:114px;padding:5px 10px;border-radius:3px;background:#555;color:#fff;font-size:11px;z-index:100;white-space:nowrap;border:1px solid #444}.panel-grid,.stat-grid,.summary-grid{display:grid;gap:10px}.panel-grid{grid-template-columns:repeat(2,1fr);margin-top:12px}.panel-card{padding:14px 12px;border-radius:6px;background:#fff;color:#333;text-align:left;border:1.5px solid #ccc}.panel-card strong,.plan-title,.section-title,.timeline-card strong{display:block;font-size:13px;font-weight:700;color:#222}.panel-card span,.plan-desc,.timeline-card p,.cost-card span,.menu-item span,.menu-item em,.stat-grid span,.summary-grid span{color:#888;font-size:11px}.chat-content{display:flex;flex-direction:column;gap:10px}.chat-list{flex:1;overflow:auto;display:flex;flex-direction:column;gap:10px}.date-chip{align-self:center;padding:4px 10px;border-radius:3px;background:#e0e0e0;border:1px solid #ccc;color:#888;font-size:11px}.message{display:flex;gap:8px;align-items:flex-start}.message--user{justify-content:flex-end}.avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#ccc;border:1px solid #aaa;flex:0 0 auto;font-size:14px;color:#555}.bubble{max-width:72%;padding:10px 12px;border-radius:6px;line-height:1.7;font-size:12px;background:#fff;color:#333;border:1px solid #ccc;white-space:pre-wrap}.message--user .bubble{background:#e0e0e0;border-color:#bbb;color:#333}.bubble--loading{display:flex;gap:5px;align-items:center}.bubble--loading span{width:6px;height:6px;border-radius:999px;background:#bbb;animation:pulse 1s infinite ease-in-out}.bubble--loading span:nth-child(2){animation-delay:.15s}.bubble--loading span:nth-child(3){animation-delay:.3s}@keyframes pulse{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-4px);opacity:1}}.quick-prompts{display:flex;flex-wrap:wrap;gap:6px;margin-left:38px}.quick-prompt,.chips span,.plan-tags span,.route-tag,.profile-badge{padding:5px 10px;border-radius:3px;font-size:11px}.quick-prompt{background:#f0f0f0;color:#555;border:1px solid #ccc}.plan-list{display:grid;gap:10px}.plan-card{padding:14px;border-radius:6px;background:#fff;border:1.5px solid #ccc;color:#333;text-align:left}.plan-card--economy{border-left:4px solid #888}.plan-card--comfort{border-left:4px solid #aaa}.plan-card--luxury{border-left:4px solid #666}.plan-card__head,.plan-stats,.cost-card>div,.menu-item,.sticky-footer{display:flex;align-items:center;justify-content:space-between}.plan-desc,.plan-stats span,.plan-tags span,.summary-grid span{color:#888}.plan-stats{margin-top:10px}.plan-stats div{display:grid;gap:3px}.plan-stats strong,.summary-grid strong,.stat-grid strong,.cost-card strong,.sticky-footer strong{font-size:15px;color:#222}.plan-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.plan-tags span{background:#ebebeb;border:1px solid #ccc;color:#666}.chat-input-bar{width:100%;display:grid;grid-template-columns:40px 1fr auto;gap:8px;padding:8px;border-radius:6px;background:#fff;border:1.5px solid #ccc}.voice-btn,.send-btn{height:40px;border-radius:4px}.voice-btn{background:#eee;color:#555;border:1px solid #ccc}.voice-btn.is-recording{background:#bbb;color:#fff;border-color:#aaa}.chat-input{border:1px solid #ccc;outline:none;background:#f5f5f5;border-radius:4px;padding:0 10px;font-size:12px;color:#333}.send-btn{min-width:56px;background:#666;color:#fff;font-weight:700;font-size:12px;border:1px solid #555}.back-btn{width:32px;height:32px;border-radius:50%;background:#fff3;border:1px solid rgba(255,255,255,.4);color:#444;font-size:22px;line-height:1;display:flex;align-items:center;justify-content:center}.summary-grid{grid-template-columns:repeat(3,1fr);padding:12px 16px 0;width:calc(100% - 32px);margin:0 auto}.summary-grid div{padding:10px;border-radius:4px;background:#ffffff4d;border:1px solid rgba(255,255,255,.5);display:grid;gap:4px;text-align:center}.summary-grid strong{color:#222}.detail-content{padding-bottom:80px}.route-card,.detail-section,.stat-grid,.menu-card{margin-bottom:12px}.route-card{padding:12px}.route-badge{display:inline-flex;padding:4px 8px;border-radius:3px;background:#e8e8e8;border:1px solid #bbb;color:#666;font-size:11px;font-weight:700}.route-map{margin-top:8px;position:relative;height:140px;border-radius:4px;overflow:hidden;background:repeating-linear-gradient(0deg,#ddd 0 1px,transparent 1px 30px),repeating-linear-gradient(90deg,#ddd 0 1px,transparent 1px 30px),#ebebeb}.route-map svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.route-map path{fill:none;stroke:#888;stroke-width:2;stroke-dasharray:6 4}.point{fill:#888}.point--start{fill:#555}.point--end{fill:#777}.route-tag{position:absolute;background:#0000008c;color:#fff;font-size:10px;padding:2px 6px;border-radius:2px}.detail-section{background:#fff;border-radius:6px;padding:14px;border:1.5px solid #ccc}.section-title{margin-bottom:12px;color:#222;font-weight:700;font-size:13px}.timeline{position:relative;display:grid;gap:12px}.timeline:before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:#ccc}.timeline-item{position:relative;padding-left:26px}.timeline-dot{position:absolute;left:3px;top:7px;width:12px;height:12px;border-radius:50%;background:#aaa;border:2px solid #e8e8e8}.timeline-dot.is-start{background:#777}.timeline-dot.is-end{background:#999}.timeline-card{padding:10px 12px;border-radius:4px;background:#f5f5f5;border:1px solid #ddd}.timeline-card p{margin:6px 0 0;line-height:1.7;font-size:12px;color:#666}.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.chips span{background:#e8e8e8;border:1px solid #ccc;color:#666}.cost-card{padding:4px 14px}.cost-card>div{padding:12px 0;border-bottom:1px solid #eee}.cost-card>div:last-child{border-bottom:0}.cost-card strong,.cost-card .cost-total strong{color:#222}.cost-total span,.cost-total strong{font-size:14px;font-weight:800}.sticky-footer{position:fixed;left:50%;transform:translate(-50%);width:375px;bottom:0;padding:12px 16px 16px;background:#fffffff7;border-top:1.5px solid #ccc}.sticky-footer>*{width:100%}.sticky-footer span{display:block;color:#888;font-size:11px;margin-bottom:4px}.sticky-footer strong{color:#333}.profile-card{align-items:center;padding-top:6px}.profile-avatar{margin:0;border-radius:50%;width:56px;height:56px;border:2px solid #aaa;background:#ccc}.profile-badge{display:inline-flex;margin-top:8px;background:#ddd;border:1px solid #bbb;color:#555;font-size:11px}.stat-grid{grid-template-columns:repeat(3,1fr)}.stat-grid>div{background:#fff;border-radius:6px;padding:14px 8px;text-align:center;border:1.5px solid #ccc}.stat-grid strong{display:block;color:#222;font-size:20px;font-weight:700}.stat-grid span{font-size:11px;color:#888;margin-top:2px;display:block}.menu-card{padding:2px 14px;background:#fff;border:1.5px solid #ccc;border-radius:6px}.menu-item{width:100%;padding:14px 0;border-bottom:1px solid #eee;color:#333;font-size:13px}.menu-item:last-child{border-bottom:0}.tab-bar{position:fixed;left:50%;transform:translate(-50%);width:375px;bottom:0;height:60px;display:grid;grid-template-columns:repeat(3,1fr);background:#fff;border-top:1.5px solid #ccc;z-index:200}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:#999;font-size:11px;padding:6px 0;border-radius:0;background:transparent}.tab-item--ai{margin-top:0}.tab-item.is-active{color:#444;font-weight:700}.tab-icon{font-size:20px;line-height:1}.tab-icon--ai{font-size:22px;line-height:1}@media (max-width: 430px){.screen{width:100vw;border:none}.tab-bar,.sticky-footer{width:100vw;left:0;transform:none}.ai-fab{right:16px}.ai-tooltip{right:80px}}
