@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+TC:wght@400;500;700&display=swap";:root{--bg-color:#f0f4f8;--sidebar-bg:#ffffffbf;--sidebar-blur:blur(20px);--text-main:#1e293b;--text-muted:#64748b;--accent-color:#0ea5e9;--accent-hover:#0284c7;--card-bg:#ffffffe6;--seicomart:#ff7500;--seven-eleven:#007f3d;--lawson:#007bbb;--familymart:#00a0e9;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 6px -1px #0000000d;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000000d;--radius-md:12px;--radius-lg:16px;--radius-full:9999px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;height:100vh;font-family:Inter,Noto Sans TC,sans-serif;overflow:hidden}#root{height:100%}.mobile-app-container{background-color:var(--bg-color);color:#0f172a;flex-direction:column;width:100vw;height:100dvh;min-height:-webkit-fill-available;font-family:-apple-system,BlinkMacSystemFont,PingFang TC,Helvetica Neue,Arial,sans-serif;display:flex;position:relative;overflow:hidden}.location-selector{top:max(20px, env(safe-area-inset-top));z-index:20;flex-direction:column;gap:6px;width:90%;max-width:400px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.location-label{display:none}.select-wrapper{-webkit-backdrop-filter:blur(24px);background:#fffffff2;border:1px solid #0000000a;border-radius:16px;align-items:center;height:56px;transition:transform .2s cubic-bezier(.175,.885,.32,1.275);display:flex;position:relative;overflow:hidden;box-shadow:0 8px 30px #00000014}.select-wrapper:active{transform:scale(.96)}.select-wrapper .select-icon{color:#0ea5e9;pointer-events:none;position:absolute;left:18px}.select-wrapper .chevron-icon{color:#94a3b8;pointer-events:none;position:absolute;right:18px}.select-wrapper select{appearance:none;color:#0f172a;cursor:pointer;text-align:left;background:0 0;border:none;outline:none;width:100%;height:100%;padding:0 46px;font-size:16px;font-weight:800}.map-view{flex:1;width:100%}.places-bottom-sheet{z-index:20;background:#fff;border-radius:32px 32px 0 0;flex-direction:column;width:100%;transition:height .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:absolute;bottom:0;left:0;right:0;overflow:hidden;box-shadow:0 -16px 40px #0000001f}.places-bottom-sheet.collapsed{height:90px}.places-bottom-sheet.expanded{height:65vh}@media (width>=768px){.mobile-app-container{border-left:1px solid #e2e8f0;border-right:1px solid #e2e8f0;max-width:480px;margin:0 auto;box-shadow:0 0 50px #0000001a}}.places-header{cursor:pointer;background:0 0;border-bottom:1px solid #f8fafc;justify-content:space-between;align-items:center;padding:28px 24px 16px;display:flex;position:relative}.places-header:active{background:#00000005}.places-header h2{color:#0f172a;align-items:center;gap:8px;font-size:18px;font-weight:800;display:flex}.places-header .badge{color:#fff;letter-spacing:.5px;background:#0f172a;border-radius:12px;padding:5px 12px;font-size:13px;font-weight:800}.places-list{background:#fff;transition:padding .3s}.places-bottom-sheet.expanded .places-list{-webkit-overflow-scrolling:touch;height:calc(65vh - 80px);padding:12px 20px 60px;overflow-y:auto}.places-bottom-sheet.collapsed .places-list{height:0;padding:0;overflow:hidden}.place-item{cursor:pointer;border-bottom:1px solid #f8fafc;align-items:flex-start;gap:16px;padding:16px 0;transition:opacity .2s;display:flex}.place-item:active{opacity:.6}.place-item:last-child{border-bottom:none}.place-icon-wrapper{color:#fff;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;box-shadow:0 4px 10px #0000000f}.place-info{flex:1;padding-top:2px}.place-name{color:#0f172a;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:6px;font-size:16px;font-weight:800;line-height:1.3;display:-webkit-box;overflow:hidden}.place-meta{color:#94a3b8;-webkit-line-clamp:1;-webkit-box-orient:vertical;align-items:center;gap:4px;margin-top:4px;font-size:12px;display:-webkit-box;overflow:hidden}.place-desc{color:#475569;background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;margin-top:8px;padding:8px 10px;font-size:12px;font-weight:600;line-height:1.5;display:inline-block}.place-action-btn{color:#fff;background:linear-gradient(135deg,#0ea5e9,#2563eb);border-radius:100px;justify-content:center;align-items:center;gap:6px;width:max-content;margin-top:10px;padding:8px 14px;font-size:13px;font-weight:700;transition:transform .2s;display:flex;box-shadow:0 4px 12px #2563eb40}.place-time-badge{flex-direction:column;align-items:flex-end;margin-top:2px;display:flex}.place-time-badge .time-val{color:#10b981;font-size:15px;font-weight:800}.place-time-badge .dist-val{color:#94a3b8;margin-top:2px;font-size:12px;font-weight:600}.brand-seicomart{--marker-color:#ff7500;background:var(--marker-color)}.brand-711{--marker-color:#007f3d;background:var(--marker-color)}.brand-lawson{--marker-color:#007bbb;background:var(--marker-color)}.brand-familymart{--marker-color:#00a0e9;background:var(--marker-color)}.brand-generic{--marker-color:#64748b;background:var(--marker-color)}.hotel-marker-pill{--marker-color:#0f172a;background:var(--marker-color);color:#fff;white-space:nowrap;border:3px solid #fff;border-radius:20px;align-items:center;gap:8px;padding:10px 18px;font-size:15px;font-weight:800;animation:.5s cubic-bezier(.175,.885,.32,1.275) bounce-in;display:flex;position:relative;box-shadow:0 8px 30px #0f172a66}.hotel-marker-pill:after{content:"";border-top:8px solid #fff;border-left:8px solid #0000;border-right:8px solid #0000;position:absolute;top:100%;left:50%;transform:translate(-50%)}.store-marker-pill{background:var(--marker-color,#64748b);color:#fff;white-space:nowrap;cursor:pointer;transform-origin:bottom;border:2px solid #fff;border-radius:16px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:800;transition:transform .2s;display:flex;position:relative;box-shadow:0 4px 16px #00000040}.store-marker-pill:after{content:"";border-top:6px solid #fff;border-left:6px solid #0000;border-right:6px solid #0000;position:absolute;top:100%;left:50%;transform:translate(-50%)}.store-marker-pill:active{transform:scale(1.1)translateY(-4px)}@keyframes bounce-in{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.tab-page{flex-direction:column;flex:1;display:none;position:relative;overflow:hidden}.tab-page.active{display:flex!important}html,body{overscroll-behavior-y:none}.tab-page.scroll-page{background-color:#f8fafc;display:none;overflow-y:auto}.tab-page.scroll-page.active{display:block!important}.bottom-tab-bar{-webkit-backdrop-filter:blur(24px);height:84px;padding-top:12px;padding-bottom:env(safe-area-inset-bottom,16px);z-index:50;background:#fffffffa;border-top:1px solid #e2e8f0;flex-shrink:0;justify-content:space-around;align-items:flex-start;display:flex;box-shadow:0 -4px 20px #00000008}.nav-tab{color:#94a3b8;cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;font-size:12px;font-weight:800;transition:all .2s cubic-bezier(.175,.885,.32,1.275);display:flex}.nav-tab.active{color:#0ea5e9}.nav-tab .nav-icon{margin-bottom:2px;transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.nav-tab.active .nav-icon{transform:scale(1.15)translateY(-2px)}.locate-me-btn{z-index:10;cursor:pointer;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .2s,background .2s;display:flex;position:absolute;bottom:130px;right:16px;box-shadow:0 4px 24px #00000026}.locate-me-btn:active{background:#f0f9ff;transform:scale(.9)}.spin-anim{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.user-gps-dot{background-color:#3b82f6;border:3px solid #fff;border-radius:50%;width:18px;height:18px;animation:2s infinite gps-pulse;box-shadow:0 0 10px #3b82f680}@keyframes gps-pulse{0%{box-shadow:0 0 #3b82f666}70%{box-shadow:0 0 0 15px #3b82f600}to{box-shadow:0 0 #3b82f600}}.weather-view-container{flex-direction:column;flex:1;display:flex;position:relative}.weather-chart-scroll-area{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;scrollbar-width:none;width:100%;padding:0 10px;overflow-x:auto}.weather-chart-scroll-area::-webkit-scrollbar{display:none}.weather-chart-inner{background:#fff;border:1px solid #f1f5f9;border-radius:20px;width:1800px;min-height:320px;margin-bottom:20px;box-shadow:0 6px 30px #0000000d}.itinerary-view{padding:calc(max(env(safe-area-inset-top), 20px) + 20px) 20px 40px}.itinerary-header{margin-bottom:30px}.itinerary-tag{color:#fff;background:#0f172a;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:800;box-shadow:0 4px 10px #0f172a33}.itinerary-header h1{color:#0f172a;margin-top:16px;font-size:20px;font-weight:900;line-height:1.5}.itinerary-timeline{flex-direction:column;padding-left:21px;display:flex;position:relative}.itinerary-timeline:before{content:"";background:#e2e8f0;width:2px;position:absolute;top:10px;bottom:0;left:20px;transform:translate(-50%)}.timeline-day{z-index:2;margin-bottom:36px;position:relative}.timeline-dot{background:#0f172a;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;display:flex;position:absolute;top:0;left:-21px;transform:translate(-50%);box-shadow:0 4px 12px #0f172a40}.timeline-dot .day-num{color:#fff;font-size:14px;font-weight:900}.timeline-content{background:#fff;border:1px solid #f1f5f9;border-radius:20px;margin-left:20px;padding:20px;box-shadow:0 6px 24px #0000000f}.route-title{color:#0ea5e9;margin-bottom:12px;font-size:16px;font-weight:800;line-height:1.5}.route-desc{color:#475569;margin-bottom:16px;font-size:14px;font-weight:600;line-height:1.6}.day-hotel{color:#1e293b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:12px;padding:14px 16px;font-size:14px;font-weight:800;display:flex}.jump-to-map-btn{color:#0f172a;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:800;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000000d}.jump-to-map-btn:active{background:#f1f5f9;transform:scale(.98)}.rotate-icon{transform:rotate(-90deg)}.timeline-end{color:#10b981;background:#ecfdf5;border:1px dashed #a7f3d0;border-radius:16px;align-items:center;gap:12px;margin-left:20px;padding:16px 20px;font-weight:800;display:flex;position:relative}.timeline-end:before{content:"";background:#10b981;border:3px solid #fff;border-radius:50%;width:14px;height:14px;position:absolute;top:50%;left:-21px;transform:translate(-50%,-50%)}.end-icon-wrapper{background:#10b981;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex}
