:root{--bg:#0d1117;--bg2:#161b22;--bg3:#21262d;--surface:#0d1117fa;--border:#ffffff14;--text:#e6edf3;--text-muted:#8b949e;--accent:#58a6ff;--accent2:#a78bfa;--green:#3fb950;--green-bg:#3fb95026;--green-glow:#3fb95066;--yellow:#d29922;--yellow-bg:#d2992226;--yellow-glow:#d2992266;--red:#f85149;--red-bg:#f8514926;--red-glow:#f8514966;--gray:#6e7681;--gray-bg:#6e76811f;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--shadow-lg:0 8px 32px #000000a6;--nav-h:60px;--legend-h:48px;--stat-h:44px}[data-theme=light]{--bg:#f8faff;--bg2:#fff;--bg3:#f1f5f9;--surface:#fff;--border:#0000000f;--text:#0f172a;--text-muted:#64748b;--accent:#3b82f6;--accent2:#8b5cf6;--shadow-lg:0 12px 40px #00000014;--green:#10b981;--green-bg:#10b9811f;--yellow:#f59e0b;--yellow-bg:#f59e0b1f;--red:#ef4444;--red-bg:#ef44441f;--gray-bg:#64748b14}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);width:100%;height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Noto Sans Thai,Inter,sans-serif;overflow:hidden}html:has(.feed-page){overflow:auto}html:has(.feed-page) body{overflow:auto}html:has(.about-content){overflow:auto}html:has(.about-content) body{overflow:auto}html:has(.leaderboard-page){overflow:auto}html:has(.leaderboard-page) body{overflow:auto}html:has(.analytics-page){overflow:auto}html:has(.analytics-page) body{overflow:auto}html:has(.dashboard-page){overflow:auto}html:has(.dashboard-page) body{overflow:auto}.splash{z-index:9999;background:linear-gradient(145deg,#0d1117 0%,#161b22 60%,#1a2030 100%);justify-content:center;align-items:center;transition:opacity .5s;display:flex;position:fixed;inset:0}.splash.out{opacity:0;pointer-events:none}.splash-icon{filter:drop-shadow(0 0 24px #58a6ff99);font-size:72px;animation:2s ease-in-out infinite floatIcon;display:block}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.splash-title{letter-spacing:-1px;background:linear-gradient(90deg,#58a6ff,#a78bfa);-webkit-text-fill-color:transparent;text-align:center;-webkit-background-clip:text;background-clip:text;margin-top:12px;font-size:2.4rem;font-weight:700}.splash-sub{color:var(--text-muted);text-align:center;margin-top:4px}.splash-loader{margin-top:48px}.loader-bar{background:var(--bg3);border-radius:4px;width:220px;height:4px;margin:0 auto;overflow:hidden}.loader-fill{background:linear-gradient(90deg,#58a6ff,#a78bfa);border-radius:4px;height:100%;animation:2s forwards loadFill}@keyframes loadFill{0%{width:0}to{width:100%}}.loader-text{color:var(--text-muted);text-align:center;margin-top:10px;font-size:.85rem}.app{flex-direction:column;display:flex;position:fixed;inset:0}.map-topbar{height:var(--nav-h);-webkit-backdrop-filter:blur(24px)saturate(1.2);z-index:520;background:linear-gradient(#fffffff5,#ffffffe0);border-bottom:1px solid #0f172a0f;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex;position:relative}.map-topbar-brand{align-items:center;gap:12px;min-width:0;display:flex}.map-topbar-logo{background:linear-gradient(145deg,#22c55e 0%,#16a34a 48%,#ef4444 100%);border-radius:14px;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:inset 0 1px #ffffff47,0 10px 22px #22c55e2e,0 6px 14px #ef444424}.map-topbar-logo-pin{color:#fff;background:#ffffff24;border-radius:999px;justify-content:center;align-items:center;width:26px;height:26px;display:flex;box-shadow:inset 0 1px #ffffff2e}.map-topbar-copy{flex-direction:column;gap:2px;min-width:0;display:flex}.map-topbar-copy strong{color:#0f172a;letter-spacing:-.02em;font-size:.98rem;line-height:1}.map-topbar-copy span{color:#64748b;white-space:nowrap;font-size:.76rem}.map-topbar-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.map-topbar-search-btn,.map-topbar-user-btn,.map-topbar-mode-btn{cursor:pointer;color:#0f172a;background:#ffffffb8;border:1px solid #94a3b833;border-radius:999px;align-items:center;gap:8px;height:42px;transition:transform .18s,box-shadow .18s,border-color .18s;display:inline-flex;box-shadow:0 8px 22px #0f172a14}.map-topbar-search-btn:hover,.map-topbar-user-btn:hover,.map-topbar-mode-btn:hover{border-color:#3b82f63d;transform:translateY(-1px);box-shadow:0 12px 26px #0f172a1f}.map-topbar-mode-btn{font:inherit;padding:0 12px;font-size:.82rem;font-weight:800}.map-topbar-search-btn{font:inherit;padding:0 14px;font-size:.85rem;font-weight:700}.map-topbar-user-btn{font:inherit;max-width:190px;padding:0 10px 0 8px;font-size:.84rem;font-weight:700;overflow:hidden}.map-topbar-user-btn span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.map-topbar-mode-btn span{white-space:nowrap}.map-topbar-user-avatar,.map-topbar-user-fallback{border-radius:50%;flex-shrink:0;width:30px;height:30px}.map-topbar-user-avatar{object-fit:cover;object-position:center;width:30px;min-width:30px;height:30px;min-height:30px;display:block}.map-topbar-user-fallback{color:#334155;background:linear-gradient(135deg,#e2e8f0,#dbeafe);justify-content:center;align-items:center;display:flex}.topnav{height:var(--nav-h);background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:500;flex-shrink:0;align-items:center;gap:10px;padding:0 16px;display:flex;position:relative}.topnav-logo{font-size:1.4rem}.topnav-brand{white-space:nowrap;background:linear-gradient(90deg,#58a6ff,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.15rem;font-weight:700}.topnav-left{align-items:center;gap:6px;display:flex}.topnav-center{flex:1}.topnav-right{gap:8px;display:flex}.topnav-feed-btn{background:linear-gradient(135deg,#3b82f6,#a78bfa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;text-decoration:none;transition:transform .15s,opacity .2s;display:flex}.topnav-feed-btn:hover{opacity:.85;transform:scale(1.08)}.topnav-feed-btn:active{transform:scale(.95)}.search-wrap{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-xl);align-items:center;padding:0 14px;transition:border-color .2s;display:flex;position:relative}.search-wrap:focus-within{border-color:var(--accent)}.search-icon{color:var(--text-muted);margin-right:8px;font-size:.9rem}.search-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;height:36px;font-family:inherit;font-size:.9rem}.search-input::placeholder{color:var(--text-muted)}.search-modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0006;flex-direction:column;justify-content:flex-start;align-items:center;padding-top:15vh;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.search-modal-content{background:#1a1a24f2;border:1px solid #ffffff1a;border-radius:20px;flex-direction:column;width:90%;max-width:500px;animation:.3s cubic-bezier(.16,1,.3,1) slideDown;display:flex;overflow:hidden;box-shadow:0 24px 64px #0009}.search-close-btn{color:#8a8a9a;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;font-size:1.2rem;transition:all .2s;display:flex}.search-close-btn:hover{color:#fff;background:#ffffff1a}.search-suggestions-container{border-top:1px solid #ffffff0d;max-height:40vh;overflow-y:auto}.search-empty-state{text-align:center;color:#8a8a9a;padding:24px;font-size:.9rem}.suggestion-item{cursor:pointer;color:var(--text);align-items:center;gap:12px;padding:12px 18px;font-size:.95rem;transition:background .15s;display:flex}.suggestion-item:hover{background:var(--bg3)}.btn-locate,.btn-icon{background:var(--bg3);border:1px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:background .2s,transform .15s;display:flex}.btn-locate:hover,.btn-icon:hover{background:var(--bg);transform:scale(1.05)}.btn-locate:active,.btn-icon:active{transform:scale(.95)}.legend-bar{height:calc(var(--legend-h) + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);background:var(--surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:490;scrollbar-width:none;flex-shrink:0;align-items:center;gap:6px;padding-left:14px;padding-right:14px;display:flex;overflow-x:auto}.legend-bar::-webkit-scrollbar{display:none}.legend-item{border-radius:var(--radius-xl);cursor:pointer;white-space:nowrap;color:var(--text-muted);-webkit-user-select:none;user-select:none;border:1px solid #0000;align-items:center;gap:6px;padding:5px 12px;font-size:.82rem;transition:all .2s;display:flex}.legend-item:hover{background:var(--bg3);color:var(--text)}.legend-item.active-filter{background:var(--bg3);color:var(--text);border-color:var(--border)}.dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.dot-all{background:var(--accent)}.dot-green{background:var(--green)}.dot-yellow{background:var(--yellow)}.dot-red{background:var(--red)}.dot-gray{background:var(--gray)}.badge{background:var(--bg3);border-radius:20px;padding:1px 7px;font-size:.75rem;font-weight:600}.badge-green{background:var(--green-bg);color:var(--green)}.badge-yellow{background:var(--yellow-bg);color:var(--yellow)}.badge-red{background:var(--red-bg);color:var(--red)}#map{z-index:1;flex:1}.leaflet-top.leaflet-left .leaflet-control{margin-top:12px;margin-left:12px}.leaflet-control-zoom{-webkit-backdrop-filter:blur(18px)saturate(1.15);overflow:hidden;box-shadow:0 18px 36px #0206173d;background:#0f172ac7!important;border:1px solid #94a3b82e!important;border-radius:18px!important}.leaflet-control-zoom a{font-weight:700;transition:background .18s,color .18s,transform .18s;color:#f8fafc!important;background:0 0!important;border-color:#ffffff14!important;width:24px!important;height:24px!important;font-size:.84rem!important;line-height:22px!important}.leaflet-control-zoom a:hover{color:#fff!important;background:#ffffff14!important}.leaflet-control-zoom a:active{transform:scale(.97)}.leaflet-control-zoom-in{border-bottom:1px solid #ffffff14!important}.leaflet-touch .leaflet-control-zoom a{width:26px!important;height:26px!important;line-height:24px!important}.leaflet-control-attribution{color:var(--text-muted)!important;background:#0d1117b3!important;font-size:10px!important}.leaflet-control-attribution a{color:var(--text-muted)!important}.marker-pin{width:40px;height:40px;transform:scale(var(--marker-scale,1)) rotate(-45deg);transform-origin:50%;border:3px solid #ffffff40;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;transition:transform .1s linear;display:flex;position:relative;box-shadow:0 4px 16px #00000080}.marker-logo{justify-content:center;align-items:center;width:100%;height:100%;display:flex;transform:rotate(45deg)}.marker-logo img{object-fit:contain;background:#fff;border-radius:50%;width:24px;height:24px;padding:2px;box-shadow:inset 0 2px 4px #0000001a}.marker-logo .alt-text{text-shadow:0 1px 3px #0009;font-size:11px;font-weight:900}.marker-pin.green{background:var(--green);box-shadow:0 4px 16px var(--green-glow)}.marker-pin.yellow{background:var(--yellow);box-shadow:0 4px 16px var(--yellow-glow)}.marker-pin.red{background:var(--red);box-shadow:0 4px 16px var(--red-glow)}.marker-pin.gray{background:var(--gray);box-shadow:0 4px 16px #0000004d}.marker-pin.pulse:before{content:"";background:inherit;opacity:0;border-radius:50%;animation:2s ease-out infinite pulse;position:absolute;inset:-6px}@keyframes pulse{0%{opacity:.6;transform:rotate(45deg)scale(.8)}to{opacity:0;transform:rotate(45deg)scale(1.8)}}.sos-marker{width:48px;height:48px;transform:scale(var(--marker-scale,1));transform-origin:50%;color:#fff;background:linear-gradient(135deg,#ef4444,#b91c1c);border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;transition:transform .1s linear;animation:1.5s ease-out infinite pulse-sos;display:flex;position:relative;box-shadow:0 4px 16px #ef444499}.sos-marker-inner{filter:drop-shadow(0 2px 4px #0000004d);justify-content:center;align-items:center;display:flex}@keyframes pulse-sos{0%{box-shadow:0 0 #ef4444cc}70%{box-shadow:0 0 0 50px #ef444400}to{box-shadow:0 0 #ef444400}}@keyframes pulse-red{0%{transform:scale(1);box-shadow:0 0 #ef4444b3}50%{transform:scale(1.05);box-shadow:0 0 0 10px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}.pulse-red{animation:2s infinite pulse-red}.station-card-marker{color:#f8fafc;-webkit-backdrop-filter:blur(18px);background:linear-gradient(#0e141ff5,#0a0f18eb);border:1px solid #ffffff24;border-radius:12px;min-width:132px;max-width:132px;padding:7px 8px 8px;position:relative;box-shadow:0 12px 28px #02061757}.station-card-marker--green{background:linear-gradient(#053f2efc,#032c1ff2);border-color:#4ade8047;box-shadow:0 14px 30px #064e3b57}.station-card-marker--yellow{background:linear-gradient(#5c3607fc,#402607f2);border-color:#fbbf244d;box-shadow:0 14px 30px #92400e52}.station-card-marker--red{background:linear-gradient(#580c0cfc,#3f0a0af2);border-color:#f871714d;box-shadow:0 14px 30px #7f1d1d57}.station-card-marker--gray{background:linear-gradient(#28303ffc,#181e2bf2);border-color:#94a3b842;box-shadow:0 14px 30px #0f172a52}.station-card-marker:after{content:"";background:inherit;border-bottom:1px solid #ffffff24;border-right:1px solid #ffffff24;border-bottom-right-radius:4px;width:12px;height:12px;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)rotate(45deg)}.station-card-marker__header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.station-card-marker__logo{border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex;overflow:hidden}.station-card-marker__logo img{width:18px;height:18px}.station-card-marker__title{color:#f8fafc;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.66rem;font-weight:800;line-height:1.2;overflow:hidden}.station-card-marker__footer{align-items:center;display:flex}.station-card-marker__fuels{gap:3px;width:100%;display:flex}.station-card-marker__fuel{letter-spacing:.02em;border:1px solid #0000;border-radius:6px;flex:1 1 0;justify-content:center;align-items:center;min-width:0;padding:3px 0;font-size:.57rem;font-weight:800;display:inline-flex}.station-card-marker__fuel--green{color:#052e16;background:#22c55e;border-color:#4ade80}.station-card-marker__fuel--yellow{color:#422006;background:#facc15;border-color:#fde047}.station-card-marker__fuel--red{color:#450a0a;background:#ef4444;border-color:#f87171}.station-card-marker__fuel--gray{color:#0f172a;background:#94a3b8;border-color:#cbd5e1}.station-mini-marker{color:#f8fafc;-webkit-backdrop-filter:blur(18px);background:linear-gradient(#0e141ff5,#0a0f18eb);border:1px solid #ffffff24;border-radius:10px;align-items:center;gap:6px;min-width:80px;max-width:94px;padding:5px 7px;display:flex;position:relative;box-shadow:0 10px 24px #02061747}.station-mini-marker--green{background:linear-gradient(#053f2efc,#032c1ff2);border-color:#4ade8047;box-shadow:0 12px 26px #064e3b4d}.station-mini-marker--yellow{background:linear-gradient(#5c3607fc,#402607f2);border-color:#fbbf244d;box-shadow:0 12px 26px #92400e47}.station-mini-marker--red{background:linear-gradient(#580c0cfc,#3f0a0af2);border-color:#f871714d;box-shadow:0 12px 26px #7f1d1d4d}.station-mini-marker--gray{background:linear-gradient(#28303ffc,#181e2bf2);border-color:#94a3b842;box-shadow:0 12px 26px #0f172a47}.station-mini-marker:after{content:"";background:inherit;border-bottom:1px solid #ffffff24;border-right:1px solid #ffffff24;border-bottom-right-radius:4px;width:10px;height:10px;position:absolute;bottom:-5px;left:50%;transform:translate(-50%)rotate(45deg)}.station-mini-marker__logo{border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex;overflow:hidden}.station-mini-marker__logo img{width:16px;height:16px}.station-mini-marker__title{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.62rem;font-weight:800;line-height:1.15;overflow:hidden}.station-logo-marker{border:1.5px solid #ffffffeb;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;display:flex;box-shadow:0 8px 18px #02061738}.station-logo-marker--green{background:radial-gradient(circle at 30% 30%,#4ade80 0%,#16a34a 100%)}.station-logo-marker--yellow{background:radial-gradient(circle at 30% 30%,#facc15 0%,#f59e0b 100%)}.station-logo-marker--red{background:radial-gradient(circle at 30% 30%,#fb7185 0%,#ef4444 100%)}.station-logo-marker--gray{background:radial-gradient(circle at 30% 30%,#94a3b8 0%,#64748b 100%)}.station-logo-marker__logo{border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;display:flex;overflow:hidden}.station-logo-marker__logo img{width:18px;height:18px}.station-dot-marker{border:1.5px solid #fffffff2;border-radius:999px;width:12px;height:12px;box-shadow:0 0 0 3px #0f172a29,0 6px 14px #02061733}.station-dot-marker--green{background:#22c55e}.station-dot-marker--yellow{background:#f59e0b}.station-dot-marker--red{background:#ef4444}.station-dot-marker--gray{background:#94a3b8}.map-loader{top:calc(var(--nav-h) + var(--legend-h) + 16px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);color:var(--text-muted);z-index:400;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-lg);align-items:center;gap:10px;padding:10px 20px;font-size:.85rem;display:none;position:absolute;left:50%;transform:translate(-50%)}.map-loader.show{display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.map-floating-controls{right:16px;bottom:calc(var(--stat-h) + 16px + env(safe-area-inset-bottom));z-index:500;flex-direction:column;gap:10px;display:flex;position:absolute}.map-btn{background:var(--surface);border:1px solid var(--border);width:44px;height:44px;color:var(--text);cursor:pointer;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;transition:all .2s;display:flex;box-shadow:0 4px 12px #0000004d}.map-btn:hover{background:var(--bg2);transform:scale(1.05)}.map-btn:active{transform:scale(.95)}.map-btn.active-add{color:#fff;background:#58a6ff;border-color:#58a6ff;box-shadow:0 4px 16px #58a6ff66}.pulse-btn{animation:2s ease-out infinite radar-pulse}@keyframes radar-pulse{0%{box-shadow:0 0 #ef4444b3}70%{box-shadow:0 0 0 15px #ef444400}to{box-shadow:0 0 #ef444400}}.statbar{display:none}.menubar-wrapper{pointer-events:none;z-index:500;justify-content:center;align-items:flex-end;padding:0 14px;display:flex;position:absolute;bottom:14px;left:0;right:0}.menubar{-webkit-backdrop-filter:blur(30px)saturate(1.25);width:100%;max-width:420px;padding:10px 12px calc(10px + env(safe-area-inset-bottom) * .25);pointer-events:auto;background:linear-gradient(#181d27e6,#111827d6);border:1px solid #ffffff1f;border-radius:30px;justify-content:space-between;align-items:center;display:flex;position:relative;box-shadow:0 24px 48px #0206175c,0 8px 18px #02061738,inset 0 1px #ffffff1f}.menubar:before{content:"";pointer-events:none;background:linear-gradient(90deg,#ffffff05,#ffffff2e,#ffffff05);border-radius:999px;height:1px;position:absolute;top:8px;left:14px;right:14px}.menu-item{color:#8f99ab;cursor:pointer;background:0 0;border:none;border-radius:18px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;min-height:54px;padding:8px 6px 6px;font-family:inherit;text-decoration:none;transition:all .22s;display:flex}.menu-item svg{stroke:currentColor;fill:none;stroke-width:2.15px;stroke-linecap:round;stroke-linejoin:round;opacity:.92;width:19px;height:19px;transition:stroke .22s,transform .22s,opacity .22s}.menu-item span{opacity:1;letter-spacing:.01em;margin-top:0;font-size:.67rem;font-weight:700;transition:color .22s,opacity .22s;display:block;transform:none}.menu-item:hover{color:#e5edf8;background:#ffffff0d}.menu-item.active{color:#f8fbff;background:linear-gradient(#3b82f638,#3b82f61f);box-shadow:inset 0 1px #ffffff14,0 8px 18px #2563eb2e}.menu-item.active svg{transform:translateY(-1px)}.menu-item.active span{color:#dbeafe}.menu-center-wrapper{flex:0 0 64px;justify-content:center;width:64px;height:52px;display:flex;position:relative}.menu-center-btn{cursor:pointer;color:#0f172a;z-index:10;background:linear-gradient(#fbfdff,#dbeafe);border:1px solid #ffffffb3;border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;padding:0;transition:all .22s;display:flex;position:absolute;bottom:2px;left:50%;transform:translate(-50%);box-shadow:0 16px 26px #0f172a47,0 4px 10px #94a3b838,inset 0 1px #ffffffeb}.menu-center-btn svg{stroke-width:2.4px;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round;width:24px;height:24px}.menu-center-btn:hover{transform:translate(-50%)translateY(-2px);box-shadow:0 18px 30px #0f172a52,0 6px 12px #94a3b83d,inset 0 1px #fffffffa}.menu-center-btn:active{transform:translate(-50%)translateY(0)scale(.97);box-shadow:0 10px 16px #0f172a38}@media (max-width:720px){.map-topbar{gap:10px;padding:10px 12px}.map-topbar-search-btn span,.map-topbar-mode-btn span,.map-topbar-user-btn span,.map-topbar-copy span{display:none}.map-topbar-search-btn,.map-topbar-mode-btn,.map-topbar-user-btn{justify-content:center;width:42px;padding:0}.map-topbar-copy strong{font-size:.92rem}}.add-mode-bar{bottom:calc(var(--stat-h) + 16px);background:var(--bg2);border:2px solid var(--accent);border-radius:var(--radius-xl);z-index:500;white-space:nowrap;align-items:center;gap:16px;padding:10px 14px 10px 20px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #58a6ff66}.add-mode-text{color:var(--text);font-size:.88rem;font-weight:600}.btn-confirm-add{color:#fff;cursor:pointer;background:linear-gradient(135deg,#58a6ff,#a78bfa);border:none;border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:700;transition:transform .15s,opacity .2s}.btn-confirm-add:hover{opacity:.9}.btn-confirm-add:active{transform:scale(.95)}.station-panel{background:var(--surface);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);z-index:800;scrollbar-width:thin;scrollbar-color:var(--border) transparent;max-height:min(88vh,88dvh);box-shadow:var(--shadow-lg);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border-radius:36px 36px 0 0;animation:.4s cubic-bezier(.2,.8,.2,1) slideUp;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.station-panel.hidden{display:none}.station-panel.closing{animation:.25s ease-in forwards slideDown}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{to{opacity:0;transform:translateY(100%)}}.panel-handle{background:var(--border);opacity:.5;border-radius:5px;width:48px;height:5px;margin:16px auto 0}.panel-header{align-items:flex-start;gap:12px;padding:16px 18px 6px;display:flex}.panel-title-group{flex:1}.panel-status-badge{letter-spacing:.5px;background:var(--gray-bg);color:var(--gray);border-radius:20px;margin-bottom:6px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-block}.panel-status-badge.green{background:var(--green-bg);color:var(--green)}.panel-status-badge.yellow{background:var(--yellow-bg);color:var(--yellow)}.panel-status-badge.red{background:var(--red-bg);color:var(--red)}.panel-title{color:var(--text);letter-spacing:-.2px;font-size:1.2rem;font-weight:800;line-height:1.4}.panel-subtitle{color:var(--text-muted);margin-top:4px;font-size:.85rem;font-weight:500}.panel-close{background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;transition:background .2s;display:flex}.panel-close:hover{background:var(--bg)}.panel-updated{color:var(--text-muted);align-items:center;gap:8px;padding:0 18px 14px;font-size:.8rem;display:flex}.sync-badge{border-radius:12px;padding:2px 8px;font-size:.72rem}.sync-badge.synced{background:var(--green-bg);color:var(--green)}.sync-badge.saving{background:var(--yellow-bg);color:var(--yellow)}.sync-badge.error{background:var(--red-bg);color:var(--red)}.report-votes{grid-template-columns:repeat(3,1fr);gap:10px;padding:0 18px 18px;display:grid}.vote-card{background:var(--bg3);border-radius:var(--radius-md);text-align:center;-webkit-user-select:none;user-select:none;border:2px solid #0000;padding:16px 10px;transition:all .2s}.vote-card.green{border-color:var(--green);background:var(--green-bg)}.vote-card.yellow{border-color:var(--yellow);background:var(--yellow-bg)}.vote-card.red{border-color:var(--red);background:var(--red-bg)}.vote-emoji{font-size:1.6rem}.vote-label{color:var(--text-muted);margin-top:4px;font-size:.78rem}.vote-count{color:var(--text);margin-top:4px;font-size:1.4rem;font-weight:700}.vote-card.green .vote-count{color:var(--green)}.vote-card.yellow .vote-count{color:var(--yellow)}.vote-card.red .vote-count{color:var(--red)}.panel-actions{gap:12px;padding:0 22px 24px;display:flex}.btn-report{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#7c3aed);border:1px solid #ffffff1a;border-radius:24px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-family:inherit;font-size:.95rem;font-weight:700;transition:all .25s cubic-bezier(.2,.8,.2,1);display:flex;box-shadow:0 12px 24px #7c3aed40}.btn-report:hover{transform:translateY(-2px);box-shadow:0 16px 32px #7c3aed59}.btn-report:active{transform:translateY(1px)scale(.98);box-shadow:0 4px 12px #7c3aed33}.btn-directions{color:#e2e8f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:24px;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .25s;display:flex}.btn-directions:hover{background:#ffffff1a;transform:translateY(-2px)}.btn-directions:active{transform:translateY(1px)scale(.98)}.history-section{padding:0 18px 28px}.history-heading{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:.85rem;font-weight:600}.history-list{flex-direction:column;gap:8px;display:flex}.empty-history{color:var(--text-muted);font-size:.85rem}.history-item{background:var(--bg3);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:10px 12px;display:flex}.h-icon{flex-shrink:0;font-size:1rem}.h-body{flex:1}.h-status{font-size:.85rem;font-weight:600}.h-queue{background:color-mix(in srgb, var(--queue-color,#94a3b8) 14%, transparent);border:1px solid color-mix(in srgb, var(--queue-color,#94a3b8) 28%, transparent);width:fit-content;color:var(--queue-color,#cbd5e1);border-radius:999px;align-items:center;margin-top:6px;padding:4px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.h-note{color:var(--text-muted);margin-top:2px;font-size:.78rem}.h-time{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.modal-backdrop{z-index:1000;padding:0 max(12px, env(safe-area-inset-right)) max(0px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));background:#000000bf;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-backdrop.hidden{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{-webkit-backdrop-filter:blur(22px)saturate(1.06);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:linear-gradient(#121822f2,#0d121ceb);border:1px solid #ffffff14;border-radius:36px 36px 0 0;width:100%;max-width:500px;max-height:min(92vh,92dvh);padding:24px 20px 32px;animation:.4s cubic-bezier(.2,.8,.2,1) slideUp;overflow:hidden auto;box-shadow:0 -20px 64px #0000009e}.modal-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.modal-title{letter-spacing:-.02em;color:#f8fafc;font-size:1rem;font-weight:700}.modal-close{color:#94a3b8;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;transition:all .2s;display:flex}.modal-close:hover{color:#fff;background:#ffffff1a;transform:scale(1.05)}.modal-station-name{color:#58a6ff;letter-spacing:.2px;margin-bottom:20px;font-size:1rem;font-weight:700}.modal-desc{color:#a0abc0;margin-bottom:20px;font-size:.9rem}.modal-options{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.opt-btn{cursor:pointer;text-align:left;background:#ffffff08;border:1px solid #ffffff0d;border-radius:20px;align-items:center;gap:14px;width:100%;padding:16px 18px;font-family:inherit;transition:all .3s cubic-bezier(.2,.8,.2,1);display:flex}.opt-btn:hover{background:#ffffff0d;border-color:#ffffff26;transform:translateY(-2px)}.opt-btn.selected{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.opt-btn.opt-green{color:#4ade80}.opt-btn.opt-yellow{color:#fbbf24}.opt-btn.opt-red{color:#f87171}.opt-btn.opt-green.selected{background:linear-gradient(135deg,#3fb95026 0%,#3fb95005 100%);border-color:#4ade804d}.opt-btn.opt-yellow.selected{background:linear-gradient(135deg,#d2992226 0%,#d2992205 100%);border-color:#fbbf244d}.opt-btn.opt-red.selected{background:linear-gradient(135deg,#f8514926 0%,#f8514905 100%);border-color:#f871714d}.opt-icon{flex-shrink:0;font-size:1.4rem}.opt-label{color:inherit;font-size:.95rem;font-weight:600}.opt-desc{color:var(--text-muted);margin-top:1px;font-size:.78rem}.modal-note{margin-bottom:14px}.note-input{color:#fff;resize:none;background:#ffffff0a;border:1px solid #94a3b824;border-radius:18px;outline:none;width:100%;min-height:56px;padding:13px 15px;font-family:inherit;font-size:.88rem;line-height:1.45;transition:all .25s}.note-input:focus{background:#ffffff0f;border-color:#60a5fa66;box-shadow:0 0 0 4px #60a5fa1a}.note-input::placeholder{color:var(--text-muted)}.queue-report-card{background:#ffffff0a;border:1px solid #94a3b824;border-radius:18px;flex-direction:column;gap:12px;padding:14px 15px;display:flex}.queue-report-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.queue-report-head-main{flex:1;min-width:0}.queue-report-head strong{color:#f8fafc;margin-bottom:0;font-size:.86rem;display:block}.queue-report-pill{background:#0f172a6b;border:1px solid #94a3b824;border-radius:999px;flex-shrink:0;padding:6px 10px;font-size:.74rem;font-weight:800}.queue-report-slider{appearance:none;cursor:pointer;border-radius:999px;outline:none;width:100%;height:8px}.queue-report-slider::-webkit-slider-thumb{-webkit-appearance:none;background:#fff;border:3px solid #0f172a;border-radius:50%;width:20px;height:20px;box-shadow:0 6px 16px #0f172a3d}.queue-report-slider::-moz-range-thumb{background:#fff;border:3px solid #0f172a;border-radius:50%;width:20px;height:20px;box-shadow:0 6px 16px #0f172a3d}.queue-report-scale{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;display:grid}.queue-report-stop{color:var(--text-muted);font:inherit;cursor:pointer;background:#ffffff08;border:1px solid #94a3b824;border-radius:12px;padding:8px 6px;font-size:.7rem;font-weight:700;transition:all .2s}.queue-report-stop.active{color:#f8fafc;background:#3b82f624;border-color:#60a5fa4d}.modal-upload-wrap{justify-content:center;margin-bottom:14px;display:flex}.upload-trigger{cursor:pointer;background:linear-gradient(135deg,#58a6ff1f,#38bdf80d),#ffffff05;border:1px solid #58a6ff2e;border-radius:999px;align-items:center;gap:8px;width:auto;max-width:100%;padding:7px 11px;transition:transform .2s,border-color .2s,background .2s;display:inline-flex}.upload-trigger:hover{border-color:#60a5fa61;transform:translateY(-1px)}.upload-trigger.has-image{background:linear-gradient(135deg,#22c55e29,#10b9810d),#ffffff08;border-color:#4ade8047}.upload-trigger-icon{color:#93c5fd;background:#0f172a47;border:1px solid #94a3b824;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.upload-trigger.has-image .upload-trigger-icon{color:#86efac}.upload-trigger-copy{align-items:center;gap:6px;min-width:0;display:flex}.upload-trigger-copy strong{color:#f8fafc;white-space:nowrap;font-size:.74rem;line-height:1.2}.upload-trigger-copy span{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:.65rem;line-height:1;overflow:hidden}.upload-preview-card{border:1px solid var(--border);background:var(--bg3);border-radius:14px;margin-top:10px;position:relative;overflow:hidden;box-shadow:0 18px 32px #0f172a2e}.upload-preview-image{object-fit:cover;width:100%;max-height:180px;display:block}.upload-preview-remove{color:#fff;cursor:pointer;background:#0f172ab8;border:none;border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;transition:transform .15s,background .2s;display:flex;position:absolute;top:10px;right:10px}.upload-preview-remove:hover{background:#1e293be6;transform:scale(1.05)}.modal-footer{gap:10px;display:flex}.btn-cancel{color:#e2e8f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:22px;flex:1;padding:13px;font-family:inherit;font-size:.88rem;font-weight:600;transition:all .25s}.btn-cancel:hover{background:#ffffff1a;transform:translateY(-2px)}.btn-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#7c3aed);border:1px solid #ffffff1a;border-radius:22px;flex:2;padding:13px;font-family:inherit;font-size:.88rem;font-weight:700;transition:all .25s cubic-bezier(.2,.8,.2,1);box-shadow:0 10px 20px #4f46e538}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 16px 32px #7c3aed59}.btn-submit:active:not(:disabled){transform:translateY(1px)scale(.98);box-shadow:0 4px 12px #7c3aed33}.btn-submit:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.toast{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);z-index:9000;white-space:nowrap;align-items:center;gap:10px;padding:12px 22px;font-size:.88rem;font-weight:500;animation:.35s cubic-bezier(.16,1,.3,1) toastIn;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast.hidden{display:none}.toast.out{animation:.25s ease-in forwards toastOut}@keyframes toastIn{0%{opacity:0;transform:translateY(-16px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toastOut{to{opacity:0;transform:translate(-50%)translateY(20px)}}@media (min-width:480px){.station-panel{max-width:480px;left:50%;right:auto;transform:translate(-50%)}.modal{border-radius:var(--radius-lg);margin-bottom:40px}}@media (max-width:360px){.topnav-brand{display:none}.fuel-select-grid{grid-template-columns:repeat(2,1fr)}.upload-trigger{gap:6px;padding:6px 9px}}@media (max-width:720px){html:has(.feed-page){overflow-x:hidden}html:has(.feed-page) body{overflow-x:hidden}html:has(.about-content){overflow-x:hidden}html:has(.about-content) body{overflow-x:hidden}html:has(.leaderboard-page){overflow-x:hidden}html:has(.leaderboard-page) body{overflow-x:hidden}html:has(.analytics-page){overflow-x:hidden}html:has(.analytics-page) body{overflow-x:hidden}html:has(.dashboard-page){overflow-x:hidden}html:has(.dashboard-page) body{overflow-x:hidden}.search-modal-overlay{padding:max(72px, env(safe-area-inset-top)) 12px 12px}.search-modal-content{width:100%;max-width:none;max-height:min(72vh,72dvh)}.station-panel{max-height:calc(100dvh - var(--nav-h) - 12px - env(safe-area-inset-bottom));border-radius:28px 28px 0 0}.panel-header,.panel-updated,.panel-actions,.history-section,.fuel-grid{padding-left:14px;padding-right:14px}.panel-header{gap:10px}.panel-title{font-size:1.02rem;line-height:1.35}.panel-subtitle{word-break:break-word;font-size:.78rem;line-height:1.35}.panel-actions{flex-direction:column;gap:10px;padding-bottom:18px}.btn-report,.btn-directions{width:100%;min-height:46px}.report-votes{gap:8px;padding:0 14px 16px}.vote-card{padding:12px 8px}.vote-emoji{font-size:1.3rem}.vote-count{font-size:1.08rem}.fuel-row{align-items:flex-start;gap:12px;padding:13px 14px}.fuel-row__left,.fuel-row__right{width:100%}.fuel-row__right{justify-content:space-between;gap:8px}.modal-backdrop{padding:0 max(8px, env(safe-area-inset-right)) max(0px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));align-items:flex-end}.modal{width:100%;max-width:none;max-height:min(90dvh,100dvh - 8px);padding:18px 14px calc(18px + env(safe-area-inset-bottom));border-radius:28px 28px 0 0}.modal-header{z-index:2;background:linear-gradient(#121822fa,#121822e6);margin:-18px 0 8px;padding:10px 0 8px;position:sticky;top:-18px}.modal-station-name{word-break:break-word;margin-bottom:14px;font-size:.94rem;line-height:1.35}.modal-desc{margin-bottom:14px;font-size:.82rem;line-height:1.45}.opt-btn{gap:12px;padding:13px 14px}.opt-label{font-size:.88rem}.opt-desc{font-size:.74rem;line-height:1.35}.queue-report-card{padding:12px}.queue-report-head{align-items:center;gap:10px}.note-input{min-height:50px;padding:12px 13px}.upload-trigger{gap:7px;padding:6px 10px}.upload-trigger-copy strong,.upload-trigger-copy span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.upload-trigger-copy{gap:5px}.upload-trigger-copy span{max-width:110px}.modal-footer{bottom:calc(-18px - env(safe-area-inset-bottom));padding-top:12px;padding-bottom:max(2px, env(safe-area-inset-bottom));background:linear-gradient(#12182233,#121822fa 28%);position:sticky}.btn-cancel,.btn-submit{min-height:46px}.toast{white-space:normal;text-align:center;max-width:calc(100vw - 24px)}}.fuel-grid{flex-direction:column;gap:10px;padding:0 22px 24px;display:flex}.fuel-row{background:#ffffff08;border:1px solid #ffffff0d;border-radius:20px;justify-content:space-between;align-items:center;padding:16px 18px;transition:transform .2s,background .3s,border-color .3s;display:flex}.fuel-row:hover{background:#ffffff0d;transform:translateY(-1px)}.fuel-row--green{background:linear-gradient(135deg,#3fb9501f 0%,#3fb95005 100%);border-color:#3fb95040}.fuel-row--yellow{background:linear-gradient(135deg,#d299221f 0%,#d2992205 100%);border-color:#d2992240}.fuel-row--red{background:linear-gradient(135deg,#f851491f 0%,#f8514905 100%);border-color:#f8514940}.fuel-row--gray{border-color:#ffffff0d}.fuel-color-dot{border:2px solid #fff6;border-radius:50%;flex-shrink:0;width:28px;height:28px;box-shadow:0 4px 12px #0006,inset 0 2px 4px #fff3}.fuel-row__left{align-items:center;gap:14px;display:flex}.fuel-icon{font-size:1.4rem}.fuel-name{color:#fff;letter-spacing:.2px;font-size:1rem;font-weight:700}.fuel-votes{color:#94a3b8;margin-top:3px;font-size:.8rem;font-weight:500}.fuel-row__right{align-items:center;gap:12px;display:flex}.fuel-badge{white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid #0000;border-radius:24px;padding:6px 12px;font-size:.82rem;font-weight:700}.fuel-badge--green{color:#4ade80;background:#3fb95026;border-color:#4ade8033}.fuel-badge--yellow{color:#fbbf24;background:#d2992226;border-color:#fbbf2433}.fuel-badge--red{color:#f87171;background:#f8514926;border-color:#f8717133}.fuel-badge--gray{color:#cbd5e1;background:#ffffff14;border-color:#ffffff1a}.fuel-report-btn{cursor:pointer;color:#fff;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:all .25s cubic-bezier(.2,.8,.2,1);display:flex}.fuel-report-btn:hover{background:#ffffff26;border-color:#ffffff40;transform:scale(1.1)}.fuel-report-btn:active{transform:scale(.92)}.fuel-select-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.fuel-select-btn{background:var(--bg3);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:6px;padding:18px 12px;font-family:inherit;transition:all .2s;display:flex}.fuel-select-btn:hover{border-color:var(--accent);background:var(--bg);transform:translateY(-2px)}.fuel-select-btn.selected{border-color:var(--accent);background:#58a6ff1a}.fs-icon{font-size:1.8rem}.fs-short{color:var(--text);font-size:1.1rem;font-weight:700}.fs-label{color:var(--text-muted);font-size:.72rem}.modal-back{background:var(--bg3);border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:background .2s;display:flex}.modal-back:hover{background:var(--bg)}.selected-fuel-chip{border:1px solid var(--accent);color:var(--accent);background:#58a6ff1f;border-radius:20px;align-items:center;gap:6px;margin-bottom:14px;padding:4px 14px;font-size:.82rem;font-weight:600;display:inline-flex}.dialog-backdrop{z-index:9500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.dialog-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;outline:none;width:100%;max-width:380px;padding:32px 28px 24px;animation:.35s cubic-bezier(.16,1,.3,1) dialogPop;position:relative;overflow:hidden;box-shadow:0 24px 64px #0009}@keyframes dialogPop{0%{opacity:0;transform:scale(.85)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.dialog-glow{filter:blur(60px);pointer-events:none;opacity:.6;border-radius:50%;width:200px;height:200px;position:absolute;top:-60px;left:50%;transform:translate(-50%)}.dialog-icon-wrap{z-index:1;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex;position:relative}.dialog-icon{font-size:1.8rem;animation:.5s cubic-bezier(.16,1,.3,1) .1s both iconBounce}@keyframes iconBounce{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.dialog-title{color:var(--text);z-index:1;margin-bottom:8px;font-size:1.1rem;font-weight:700;position:relative}.dialog-message{color:var(--text-muted);z-index:1;margin-bottom:24px;font-size:.88rem;line-height:1.5;position:relative}.dialog-actions{z-index:1;gap:10px;display:flex;position:relative}.dialog-btn{border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;padding:12px 16px;font-family:inherit;font-size:.9rem;font-weight:600;transition:opacity .2s,transform .15s}.dialog-btn:hover{opacity:.9}.dialog-btn:active{transform:scale(.96)}.dialog-btn-primary,.dialog-btn-danger{color:#fff}.dialog-btn-cancel{background:var(--bg3);color:var(--text-muted);border:1px solid var(--border)}.dialog-btn-cancel:hover{background:var(--bg);color:var(--text)}.map-floating-controls,.map-floating-left,.add-mode-bar{bottom:calc(20px + 64px + 16px + env(safe-area-inset-bottom))}.station-panel{max-height:calc(100vh - 20px - 64px - env(safe-area-inset-bottom))}.feed-page{background:var(--bg);min-height:100vh;color:var(--text);max-width:640px;margin:0 auto;font-family:Noto Sans Thai,Inter,sans-serif}.feed-header{z-index:100;background:var(--surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.feed-header-left{align-items:center;gap:12px;display:flex}.feed-back-btn{background:var(--bg3);border:1px solid var(--border);width:32px;height:32px;color:var(--text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;text-decoration:none;transition:all .2s;display:flex}.feed-back-btn:hover{background:var(--bg);transform:scale(1.05)}.feed-title{background:linear-gradient(90deg,#58a6ff,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;align-items:center;gap:6px;margin:0;font-size:1.15rem;font-weight:700;line-height:1.2;display:flex}.feed-title-icon{-webkit-text-fill-color:initial;display:inline-block}.feed-subtitle{color:var(--text-muted);margin:2px 0 0;font-size:.75rem}.feed-live-badge{color:#f85149;letter-spacing:.5px;background:#f851491f;border:1px solid #f851494d;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.7rem;font-weight:700;display:flex}.live-dot{background:#f85149;border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite livePulse}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.feed-composer-banner{background:radial-gradient(circle at 100% 0,#a78bfa2e,#0000 38%),linear-gradient(135deg,#3b82f624,#ffffff0a);border:1px solid #60a5fa33;border-radius:24px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;margin:16px 20px 14px;padding:16px 18px;display:grid;box-shadow:0 14px 32px #0f172a2e}.feed-composer-banner.feed-composer-banner-compact{justify-content:flex-end;padding:12px 14px;display:flex}.feed-composer-banner strong{color:#f8fafc;margin-bottom:4px;font-size:1rem;display:block}.feed-composer-banner p{color:#94a3b8;margin:0;font-size:.82rem;line-height:1.5}.feed-compose-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#38bdf8,#2563eb);border:none;border-radius:999px;align-items:center;gap:8px;padding:12px 18px;font-family:inherit;font-size:.88rem;font-weight:800;transition:transform .2s,box-shadow .2s,filter .2s;display:inline-flex;box-shadow:0 14px 24px #2563eb52}.feed-compose-btn:hover{filter:saturate(1.08);transform:translateY(-2px);box-shadow:0 18px 30px #2563eb66}.feed-compose-btn:active{transform:translateY(0)}.feed-stats{grid-template-columns:repeat(4,1fr);gap:8px;padding:14px 16px;display:grid}@media (max-width:500px){.feed-stats{grid-template-columns:repeat(2,1fr)}.feed-composer-banner{grid-template-columns:1fr}.feed-compose-btn{justify-content:center;width:100%}}.feed-stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:12px 8px;display:flex}.stat-number{margin-bottom:2px;font-size:1.4rem;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);font-size:.7rem}.feed-filters{scrollbar-width:none;gap:8px;padding:0 16px 14px;display:flex;overflow-x:auto}.feed-filters::-webkit-scrollbar{display:none}.feed-filter-btn{background:var(--bg2);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;cursor:pointer;border-radius:20px;flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:.8rem;transition:all .2s;display:flex}.feed-filter-btn:hover{border-color:var(--accent);color:var(--text)}.feed-filter-btn.active{border-color:var(--accent);color:var(--accent);background:#58a6ff26;font-weight:600}.feed-filter-count{background:var(--bg3);border-radius:10px;padding:2px 6px;font-size:.7rem;font-weight:700}.feed-filter-btn.active .feed-filter-count{color:var(--accent);background:#58a6ff40}.feed-list{flex-direction:column;gap:12px;padding:0 20px 100px;display:flex}.feed-empty{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:60px 20px;font-size:.9rem;display:flex}.feed-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.feed-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .2s,border-color .2s;animation:.4s cubic-bezier(.16,1,.3,1) both cardSlideIn;display:flex;overflow:hidden;box-shadow:0 4px 12px #0000001a}.feed-card:hover{border-color:#ffffff1f;transform:translateY(-2px);box-shadow:0 8px 16px #0003}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.feed-card-stripe{flex-shrink:0;width:5px}.feed-card-body{flex-direction:column;flex:1;gap:8px;padding:12px 14px;display:flex}.feed-card-top{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:2px;display:flex}.feed-card-station{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.feed-card-name{color:var(--text);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1rem;font-weight:700;line-height:1.35;display:-webkit-box;overflow:hidden}.feed-card-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:2px;display:flex}.feed-brand-tag{background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);border-radius:6px;padding:2px 8px;font-size:.75rem;font-weight:600}.feed-time{color:var(--text-muted);font-size:.75rem}.feed-status-badge{white-space:nowrap;border-radius:20px;flex-shrink:0;align-items:center;gap:6px;padding:5px 10px;font-size:.75rem;font-weight:700;display:flex;box-shadow:inset 0 1px 1px #ffffff1a}.feed-fuel-row{background:var(--bg3);border:1px solid var(--border);border-radius:20px;align-items:center;gap:6px;width:fit-content;padding:4px 12px;display:inline-flex}.feed-fuel-dot{border:1.5px solid #fff3;border-radius:50%;flex-shrink:0;width:10px;height:10px}.feed-fuel-name{color:var(--text);font-size:.8rem;font-weight:600}.feed-note{color:var(--text-muted);border-left:3px solid var(--accent);white-space:pre-wrap;word-break:break-word;background:#58a6ff0d;border-radius:8px;align-items:flex-start;gap:8px;padding:10px 14px;font-size:.85rem;line-height:1.5;display:flex}.feed-card-bottom{color:var(--text-muted);border-top:1px dashed #ffffff1a;justify-content:space-between;align-items:center;padding-top:10px;font-size:.75rem;display:flex}.feed-loc{align-items:center;gap:4px;display:flex}.feed-distance{color:var(--accent);align-items:center;gap:4px;font-weight:700;display:flex}.feed-area-picker{padding:12px 20px 0}.feed-loc-indicator{border-radius:var(--radius-sm);color:var(--accent);background:#58a6ff14;border:1px solid #58a6ff33;align-items:center;gap:8px;padding:10px 16px;font-size:.8rem;display:flex}.feed-loc-all{color:var(--text-muted);background:#6e768114;border-color:#6e768133}.feed-checkin-card{background:#ffffff09;border:1px solid #94a3b824;border-radius:16px;padding:10px}.feed-checkin-head{align-items:center;gap:8px;margin-bottom:8px;display:flex}.feed-checkin-icon{color:#93c5fd;background:#2563eb1f;border:1px solid #60a5fa1f;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.feed-checkin-copy strong{color:#f8fafc;font-size:.8rem;display:block}.feed-station-select{color:#f8fafc;width:100%;min-height:40px;font:inherit;appearance:none;background:#1e293be0;border:1px solid #94a3b82e;border-radius:12px;outline:none;margin-top:6px;margin-bottom:6px;padding:0 12px;font-size:.77rem;box-shadow:inset 0 1px #ffffff0a}.feed-station-select:focus{border-color:#60a5fa5c;box-shadow:0 0 0 3px #60a5fa1a}.feed-station-select option{color:#f8fafc;background:#0f172a}.feed-station-select:disabled{opacity:.65;cursor:not-allowed}.feed-selected-station,.feed-station-option{text-align:left;width:100%;color:inherit;cursor:pointer;background:#ffffff08;border:1px solid #94a3b824;border-radius:12px;padding:8px 10px;font-family:inherit;transition:border-color .2s,background .2s,transform .2s}.feed-selected-station{background:linear-gradient(135deg,#16a34a1f,#ffffff0a);border-color:#4ade803d;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.feed-selected-station-copy{flex:1;min-width:0}.feed-selected-station-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.feed-selected-station span:last-child{color:#86efac;font-size:.68rem;font-weight:700}.feed-selected-station:hover,.feed-selected-station.static{border-color:#60a5fa47;transform:translateY(-1px)}.feed-selected-station strong,.feed-station-option strong{color:#f8fafc;margin-bottom:2px;font-size:.76rem;display:block}.feed-selected-station span,.feed-station-option span{color:#94a3b8;word-break:break-word;font-size:.66rem;line-height:1.4}.feed-selected-station.static{margin-bottom:0}.feed-selected-station-badge{color:#86efac;background:#4ade801f;border-radius:999px;flex-shrink:0;padding:5px 9px;font-size:.64rem;font-weight:800}.feed-selected-station-edit{color:#e2e8f0;font:inherit;cursor:pointer;background:#ffffff0f;border:1px solid #94a3b824;border-radius:999px;flex-shrink:0;padding:5px 9px;font-size:.64rem;font-weight:800}.feed-image-help{color:#64748b;font-size:.76rem;line-height:1.45}.feed-quick-report-card{background:linear-gradient(#0f172aa8,#0f172a80);border:1px solid #94a3b81f;border-radius:14px;margin-top:8px;padding:10px}.feed-quick-report-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.feed-quick-report-head strong{color:#f8fafc;font-size:.78rem}.feed-quick-report-head span{color:#93c5fd;text-align:right;font-size:.66rem}.feed-fuel-summary-empty{color:#94a3b8;text-align:center;background:#ffffff05;border:1px dashed #94a3b829;border-radius:14px;justify-content:center;align-items:center;min-height:56px;padding:12px;font-size:.74rem;display:flex}.feed-fuel-summary-grid{flex-direction:column;gap:8px;display:flex}.feed-fuel-report-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.feed-fuel-report-label{align-items:center;gap:8px;min-width:0;display:flex}.feed-fuel-report-dot{border-radius:999px;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 0 2px #ffffff0a}.feed-fuel-report-label strong{color:#f8fafc;min-width:22px;font-size:.74rem}.feed-fuel-current-chip{white-space:nowrap;border-radius:999px;padding:4px 7px;font-size:.62rem;font-weight:800;line-height:1}.feed-fuel-current-chip.is-available{color:#86efac;background:#22c55e29}.feed-fuel-current-chip.is-low{color:#fcd34d;background:#f59e0b2e}.feed-fuel-current-chip.is-empty{color:#fca5a5;background:#ef444429}.feed-fuel-current-chip.is-unknown{color:#cbd5e1;background:#94a3b824}.feed-fuel-report-actions{flex-wrap:nowrap;flex-shrink:0;justify-content:flex-end;gap:4px;display:flex}.feed-fuel-report-btn{color:#cbd5e1;min-width:36px;font:inherit;cursor:pointer;background:#ffffff08;border:1px solid #94a3b829;border-radius:9px;padding:5px 7px;font-size:.66rem;font-weight:700;transition:transform .18s,border-color .18s,background .18s,color .18s}.feed-fuel-report-btn:hover{transform:translateY(-1px)}.feed-fuel-report-btn.is-available.active{color:#86efac;background:#22c55e2e;border-color:#22c55e7a}.feed-fuel-report-btn.is-low.active{color:#fde68a;background:#f59e0b2e;border-color:#f59e0b7a}.feed-fuel-report-btn.is-empty.active{color:#fca5a5;background:#ef44442e;border-color:#ef44447a}.feed-area-reset{background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:12px;margin-left:auto;padding:2px 10px;font-family:inherit;font-size:.72rem;transition:all .2s}.feed-area-reset:hover{background:var(--bg);color:var(--text)}.feed-province-row{scrollbar-width:none;align-items:center;gap:10px;margin-top:10px;display:flex;overflow-x:auto}.feed-province-row::-webkit-scrollbar{display:none}.feed-province-label{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.75rem}.feed-province-chips{gap:6px;display:flex}.feed-province-chip{background:var(--bg2);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;cursor:pointer;border-radius:16px;padding:4px 12px;font-family:inherit;font-size:.75rem;transition:all .2s}.feed-province-chip:hover{border-color:var(--accent);color:var(--text)}.feed-province-chip.active{border-color:var(--accent);color:var(--accent);background:#58a6ff1f}@media (max-width:480px){.feed-stats{grid-template-columns:repeat(2,1fr)}.feed-card-name{font-size:.88rem}.feed-fuel-report-row{flex-direction:row;align-items:center;gap:6px}.feed-quick-report-head span{text-align:left}.feed-fuel-report-label{flex:1;gap:5px;min-width:0}.feed-fuel-report-label strong{min-width:20px;font-size:.7rem}.feed-fuel-current-chip{padding:3px 6px;font-size:.58rem}.feed-fuel-report-actions{justify-content:flex-end;gap:3px}.feed-fuel-report-btn{min-width:32px;padding:4px 6px;font-size:.62rem}.feed-selected-station-actions{gap:4px}.feed-selected-station-edit,.feed-selected-station-badge{padding:4px 8px;font-size:.6rem}}.about-content{max-width:640px;margin:0 auto;padding:0 20px 80px}.about-hero{text-align:center;padding:40px 20px 32px}.about-hero-icon{filter:drop-shadow(0 0 24px #58a6ff80);font-size:4rem;animation:3s ease-in-out infinite floatIcon;display:block}.about-hero-title{background:linear-gradient(90deg,#58a6ff,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-top:12px;font-size:2rem;font-weight:800}.about-hero-tagline{color:var(--text-muted);margin-top:6px;font-size:.95rem}.about-section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:16px;padding:24px 20px}.about-section-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.about-section-icon{font-size:1.6rem}.about-section-title{color:var(--text);font-size:1.1rem;font-weight:700}.about-section-text{color:var(--text-muted);font-size:.88rem;line-height:1.7}.about-features{flex-direction:column;gap:14px;display:flex}.about-feature{align-items:flex-start;gap:14px;display:flex}.about-feature-num{color:#fff;background:linear-gradient(135deg,#58a6ff,#a78bfa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:800;display:flex}.about-feature h4{color:var(--text);margin-bottom:2px;font-size:.9rem;font-weight:700}.about-feature p{color:var(--text-muted);font-size:.82rem;line-height:1.5}.about-tech-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.about-tech-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;padding:12px 10px;transition:border-color .2s}.about-tech-card:hover{border-color:var(--accent)}.about-tech-name{color:var(--text);font-size:.82rem;font-weight:700}.about-tech-desc{color:var(--text-muted);margin-top:2px;font-size:.68rem}.about-dev-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:16px;padding:16px;display:flex}.about-dev-avatar{color:#fff;background:linear-gradient(135deg,#58a6ff,#a78bfa);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.4rem;font-weight:800;display:flex}.about-dev-name{color:var(--text);font-size:1rem;font-weight:700}.about-dev-role{color:var(--text-muted);margin-top:2px;font-size:.8rem}.about-dev-links{gap:8px;margin-top:8px;display:flex}.about-link{color:var(--accent);background:#58a6ff1a;border:1px solid #58a6ff40;border-radius:12px;padding:3px 12px;font-size:.78rem;text-decoration:none;transition:all .2s}.about-link:hover{background:#58a6ff33}.about-footer{text-align:center;border-top:1px solid var(--border);margin-top:8px;padding:32px 20px 0}.about-footer p{color:var(--text-muted);font-size:.85rem}.about-footer-sub{color:var(--gray);margin-top:4px;font-size:.72rem}@media (max-width:480px){.about-tech-grid{grid-template-columns:repeat(2,1fr)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg, var(--bg3) 25%, #ffffff0f 37%, var(--bg3) 63%);background-size:800px 100%;border-radius:6px;animation:1.6s ease-in-out infinite shimmer}.skeleton-badge{border-radius:20px;width:70px;height:22px}.skeleton-title{width:55%;height:20px;margin-bottom:6px}.skeleton-subtitle{width:80%;height:14px}.skeleton-row{border-radius:var(--radius-md);height:56px;margin-bottom:8px}.skeleton-btn{border-radius:var(--radius-md);height:44px}.skeleton-text-sm{width:40%;height:12px}
