:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f4f7fb;--bg2:#fff;--bg3:#edf2f7;--surface:#ffffffd6;--surface-strong:#fffffff5;--surface-soft:#f8fafcd6;--surface-inverse:#0f172a;--overlay:#0f172a85;--border:#0f172a14;--border-strong:#0f172a24;--text:#0f172a;--text-muted:#5f6f84;--text-soft:#8a99ad;--accent:#2563eb;--accent2:#14b8a6;--accent-soft:#2563eb1f;--accent-strong:#1d4ed8;--input-bg:#ffffffeb;--input-border:#94a3b847;--input-text:#0f172a;--input-placeholder:#8a99ad;--green:#16a34a;--green-bg:#16a34a1f;--green-glow:#16a34a38;--yellow:#d97706;--yellow-bg:#d977061f;--yellow-glow:#d9770638;--red:#dc2626;--red-bg:#dc26261f;--red-glow:#dc262633;--gray:#64748b;--gray-bg:#64748b1a;--map-gray-marker:#9aa8b8;--map-gray-marker-highlight:#c6d0db;--map-gray-marker-glow:#94a3b82e;--map-gray-surface-top:#596577f0;--map-gray-surface-bottom:#434f61e6;--map-gray-border:#94a3b833;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--shadow-lg:0 20px 60px #0f172a1f;--shadow-md:0 12px 36px #0f172a17;--nav-h:60px;--legend-h:48px;--stat-h:44px}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#08111f;--bg2:#0f1a2d;--bg3:#162338;--surface:#09111fd1;--surface-strong:#0b1322f0;--surface-soft:#121d30d1;--surface-inverse:#f8fafc;--overlay:#020617b8;--border:#94a3b824;--border-strong:#94a3b83d;--text:#e5eef9;--text-muted:#95a7bd;--text-soft:#71839a;--accent:#60a5fa;--accent2:#2dd4bf;--accent-soft:#60a5fa29;--accent-strong:#93c5fd;--input-bg:#0f172acc;--input-border:#94a3b82e;--input-text:#e5eef9;--input-placeholder:#7b8ca2;--green:#22c55e;--green-bg:#22c55e26;--green-glow:#22c55e4d;--yellow:#f59e0b;--yellow-bg:#f59e0b29;--yellow-glow:#f59e0b47;--red:#ef4444;--red-bg:#ef444429;--red-glow:#ef444442;--gray:#94a3b8;--gray-bg:#94a3b824;--map-gray-marker:#6f8094;--map-gray-marker-highlight:#95a6b9;--map-gray-marker-glow:#4755695c;--map-gray-surface-top:#212936fc;--map-gray-surface-bottom:#121823f5;--map-gray-border:#64748b4d;--shadow-lg:0 22px 64px #0206176b;--shadow-md:0 12px 32px #02061747}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:radial-gradient(circle at top, color-mix(in srgb, var(--accent) 8%, transparent), transparent 28%), linear-gradient(180deg, var(--bg) 0%, color-mix(in srgb, var(--bg2) 88%, var(--bg) 12%) 100%);width:100%;height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Noto Sans Thai,Inter,sans-serif;transition:background-color .25s,color .25s,background .25s;overflow:hidden}body{accent-color:var(--accent)}button,input,textarea,select{font:inherit}input,textarea,select{color:var(--input-text)}select,select option{background:var(--bg2);color:var(--text)}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}html:has(.place-detail-page){overflow:auto}html:has(.place-detail-page) body{overflow:auto}@keyframes place-route-radar{0%{opacity:.65;transform:scale(.55)}to{opacity:0;transform:scale(1.5)}}.splash{z-index:9999;background:radial-gradient(circle at top, color-mix(in srgb, var(--accent2) 10%, transparent), transparent 34%), linear-gradient(180deg, var(--bg) 0%, color-mix(in srgb, var(--bg2) 88%, var(--bg) 12%) 100%);justify-content:center;align-items:center;transition:opacity .22s;display:flex;position:fixed;inset:0;overflow:hidden}.splash.out{opacity:0;pointer-events:none}.splash-shell{border:1px solid var(--border);background:var(--surface-strong);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);width:min(92vw,440px);box-shadow:var(--shadow-lg);text-align:center;border-radius:32px;padding:36px 30px 28px;position:relative}.splash-brandline{color:var(--text-muted);letter-spacing:.16em;text-transform:uppercase;font-size:.76rem;font-weight:700}.splash-mark{background:linear-gradient(180deg, var(--bg2) 0%, var(--bg3) 100%);border:1px solid var(--border);border-radius:26px;justify-content:center;align-items:center;width:88px;height:88px;margin:20px auto 18px;display:flex;box-shadow:inset 0 1px #ffffff3d,0 14px 30px #0f172a14}.splash-icon{filter:saturate(.95);font-size:38px;display:block}.splash-title{letter-spacing:-.07em;color:var(--text);text-align:center;margin:0;font-size:clamp(2.2rem,5.4vw,3rem);font-weight:800}.splash-sub{color:var(--text-muted);text-align:center;max-width:340px;margin:14px auto 0;font-size:.96rem;line-height:1.7}.splash-divider{background:var(--border-strong);width:72px;height:1px;margin:24px auto 18px}.splash-status-row{color:var(--text-muted);justify-content:center;align-items:center;gap:8px;font-size:.9rem;font-weight:600;display:flex}.splash-status-dot{background:var(--green);width:8px;height:8px;box-shadow:0 0 0 6px color-mix(in srgb, var(--green) 12%, transparent);border-radius:50%}.splash-loader{width:100%;margin-top:16px}.loader-bar{background:color-mix(in srgb, var(--border-strong) 70%, transparent);border-radius:999px;width:100%;height:4px;margin:0 auto;overflow:hidden}.loader-fill{background:linear-gradient(90deg, var(--accent2) 0%, var(--green) 100%);border-radius:999px;height:100%;animation:2.2s forwards loadFill}@keyframes loadFill{0%{width:0}to{width:100%}}.map-mode-switcher{top:calc(var(--nav-h) + 74px);z-index:520;background:color-mix(in srgb, var(--surface-strong) 88%, transparent);border:1px solid color-mix(in srgb, var(--border-strong) 82%, transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);scrollbar-width:none;border-radius:22px;gap:6px;padding:6px;display:flex;position:absolute;left:16px;right:16px;overflow-x:auto;box-shadow:0 14px 28px #0f172a1f}.map-mode-switcher::-webkit-scrollbar{display:none}.map-mode-switcher__item{min-width:fit-content;color:var(--text-muted);cursor:pointer;background:0 0;border:0;border-radius:16px;flex:1 0 auto;justify-content:center;align-items:center;gap:7px;padding:9px 12px;font-size:.78rem;font-weight:800;transition:background-color .18s,color .18s,box-shadow .18s,transform .18s;display:inline-flex}.map-mode-switcher__item.is-active{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 16%, #fff), color-mix(in srgb, var(--accent2) 12%, #fff));color:var(--accent-strong);box-shadow:0 8px 18px color-mix(in srgb, var(--accent) 16%, transparent)}.map-mode-switcher__icon{background:color-mix(in srgb, var(--surface-inverse) 7%, transparent);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}.map-mode-switcher__item.is-active .map-mode-switcher__icon{background:#ffffffb8}.map-mode-switcher__label{white-space:nowrap;line-height:1}@media (max-width:640px){.splash-shell{border-radius:26px;width:min(92vw,390px);padding:28px 20px 22px}.splash-mark{border-radius:24px;width:78px;height:78px;margin:18px auto 16px}.splash-sub{font-size:.9rem}.map-mode-switcher{top:calc(var(--nav-h) + 68px);border-radius:20px;gap:4px;padding:5px;left:12px;right:12px}.map-mode-switcher__item{border-radius:14px;gap:6px;padding:8px 10px;font-size:.74rem}.map-mode-switcher__icon{width:20px;height:20px}}.app{flex-direction:column;display:flex;position:fixed;inset:0}.theme-toggle{border:1px solid var(--input-border);background:var(--surface-strong);width:42px;height:42px;color:var(--text);cursor:pointer;box-shadow:var(--shadow-md);border-radius:999px;justify-content:center;align-items:center;padding:0;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s;display:inline-flex}.theme-toggle:hover{border-color:color-mix(in srgb, var(--accent) 28%, var(--input-border));transform:translateY(-1px);box-shadow:0 16px 28px #0f172a24}.theme-toggle-icon{font-size:1rem;line-height:1}.map-topbar{height:var(--nav-h);background:linear-gradient(180deg, var(--surface-strong), var(--surface));-webkit-backdrop-filter:blur(24px)saturate(1.2);border-bottom:1px solid var(--border);z-index:520;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex;position:relative;box-shadow:0 10px 30px #0f172a0f}.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:var(--text);letter-spacing:-.02em;font-size:.98rem;line-height:1}.map-topbar-copy span{color:var(--text-muted);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{border:1px solid var(--input-border);background:var(--surface-strong);cursor:pointer;height:42px;color:var(--text);box-shadow:var(--shadow-md);border-radius:999px;align-items:center;gap:8px;transition:transform .18s,box-shadow .18s,border-color .18s;display:inline-flex}.map-topbar-search-btn:hover,.map-topbar-user-btn:hover,.map-topbar-mode-btn:hover{border-color:color-mix(in srgb, var(--accent) 28%, var(--input-border));transform:translateY(-1px);box-shadow:0 14px 28px #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{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, var(--bg3)), var(--bg3));color:var(--text);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;background:var(--overlay);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);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:var(--surface-strong);border:1px solid var(--border);width:90%;max-width:500px;box-shadow:var(--shadow-lg);border-radius:20px;flex-direction:column;animation:.3s cubic-bezier(.16,1,.3,1) slideDown;display:flex;overflow:hidden}.search-close-btn{color:var(--text-muted);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{background:var(--accent-soft);color:var(--text)}.search-suggestions-container{border-top:1px solid var(--border);max-height:40vh;overflow-y:auto}.search-empty-state{text-align:center;color:var(--text-muted);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(--accent-soft)}.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);box-shadow:var(--shadow-md);overflow:hidden;border:1px solid var(--border)!important;background:var(--surface-strong)!important;border-radius:18px!important}.leaflet-control-zoom a{font-weight:700;transition:background .18s,color .18s,transform .18s;width:24px!important;height:24px!important;color:var(--text)!important;border-color:var(--border)!important;background:0 0!important;font-size:.84rem!important;line-height:22px!important}.leaflet-control-zoom a:hover{background:var(--accent-soft)!important;color:var(--text)!important}.leaflet-control-zoom a:active{transform:scale(.97)}.leaflet-control-zoom-in{border-bottom:1px solid var(--border)!important}.leaflet-touch .leaflet-control-zoom a{width:26px!important;height:26px!important;line-height:24px!important}.leaflet-control-attribution{background:var(--surface)!important;color:var(--text-muted)!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(--map-gray-marker);box-shadow:0 4px 16px var(--map-gray-marker-glow)}.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(180deg, var(--map-gray-surface-top), var(--map-gray-surface-bottom));border-color:var(--map-gray-border);box-shadow:0 14px 30px var(--map-gray-marker-glow)}.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(180deg, var(--map-gray-surface-top), var(--map-gray-surface-bottom));border-color:var(--map-gray-border);box-shadow:0 12px 26px var(--map-gray-marker-glow)}.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%, var(--map-gray-marker-highlight) 0%, var(--map-gray-marker) 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:var(--map-gray-marker)}.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:18px;left:0;right:0}.menubar{background:linear-gradient(180deg, var(--surface-strong), var(--surface));-webkit-backdrop-filter:blur(30px)saturate(1.25);border:1px solid var(--border);pointer-events:auto;border-radius:30px;justify-content:space-between;align-items:center;width:100%;max-width:420px;padding:10px 12px;display:flex;position:relative;box-shadow:0 24px 48px #02061729,0 8px 18px #02061714,inset 0 1px #ffffff2e}.menubar:before{content:"";background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--surface-inverse) 16%, transparent), transparent);pointer-events:none;border-radius:999px;height:1px;position:absolute;top:8px;left:14px;right:14px}.menu-item{color:var(--text-muted);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:var(--text);background:color-mix(in srgb, var(--accent) 7%, transparent)}.menu-item.active{color:var(--text);background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 18%, transparent), color-mix(in srgb, var(--accent) 10%, transparent));box-shadow:inset 0 1px 0 #ffffff1f, 0 8px 18px color-mix(in srgb, var(--accent) 18%, transparent)}.menu-item.active svg{transform:translateY(-1px)}.menu-item.active span{color:var(--accent)}.menu-center-wrapper{flex:0 0 64px;justify-content:center;width:64px;height:52px;display:flex;position:relative}.menu-center-btn{background:linear-gradient(180deg, var(--bg2), color-mix(in srgb, var(--accent-soft) 65%, var(--bg2)));border:1px solid color-mix(in srgb, var(--accent) 20%, var(--border));cursor:pointer;width:54px;height:54px;color:var(--text);z-index:10;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:all .22s;display:flex;position:absolute;bottom:2px;left:50%;transform:translate(-50%);box-shadow:0 16px 26px #0f172a2e,0 4px 10px #94a3b824,inset 0 1px #ffffff85}.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 #0f172a38,0 6px 12px #94a3b829,inset 0 1px #ffffff9e}.menu-center-btn:active{transform:translate(-50%)translateY(0)scale(.97);box-shadow:0 10px 16px #0f172a38}.mobile-bottom-nav{z-index:700;pointer-events:none;justify-content:center;padding:20px 14px 0;display:flex;position:static}.mobile-bottom-nav__inner{pointer-events:auto;border:1px solid var(--border);background:linear-gradient(180deg, var(--surface-strong), var(--surface));-webkit-backdrop-filter:blur(30px)saturate(1.2);border-radius:30px;justify-content:space-between;align-items:center;gap:4px;width:100%;max-width:420px;padding:10px 12px;display:flex;box-shadow:0 24px 48px #02061729,0 8px 18px #02061714,inset 0 1px #ffffff2e}.mobile-bottom-nav__item{min-height:54px;color:var(--text-muted);border-radius:18px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 6px 6px;text-decoration:none;transition:color .22s,background .22s,transform .22s,box-shadow .22s;display:flex}.mobile-bottom-nav__item svg{stroke:currentColor}.mobile-bottom-nav__item span{letter-spacing:.01em;font-size:.67rem;font-weight:700}.mobile-bottom-nav__item:hover{color:var(--text);background:color-mix(in srgb, var(--accent) 7%, transparent)}.mobile-bottom-nav__item.is-active{color:var(--text);background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 18%, transparent), color-mix(in srgb, var(--accent) 10%, transparent));box-shadow:inset 0 1px 0 #ffffff1f, 0 8px 18px color-mix(in srgb, var(--accent) 18%, transparent)}.mobile-bottom-nav__item.is-active span{color:var(--accent)}@media (max-width:820px){.menubar-wrapper{bottom:calc(14px + env(safe-area-inset-bottom));position:fixed}.mobile-bottom-nav{left:0;right:0;bottom:calc(14px + env(safe-area-inset-bottom));padding:0 14px;position:fixed}}@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-strong);-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}[data-theme=light] .station-panel{-webkit-backdrop-filter:blur(18px);background:linear-gradient(#fffffffa,#faf7fff5)}[data-theme=dark] .station-panel{background:linear-gradient(#0b1322f5,#09111ff0)}.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-title-icon{width:28px;height:28px;color:var(--accent);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, var(--surface-strong)), color-mix(in srgb, var(--accent2) 10%, var(--surface)));border:1px solid color-mix(in srgb, var(--accent) 22%, var(--border));box-shadow:inset 0 1px 0 #ffffff38, 0 8px 18px color-mix(in srgb, var(--accent) 12%, transparent);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.station-title-inline{align-items:center;gap:8px;min-width:0;display:inline-flex}.station-title-inline__icon{width:24px;height:24px;color:var(--accent);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, var(--surface-strong)), color-mix(in srgb, var(--accent2) 8%, var(--surface)));border:1px solid color-mix(in srgb, var(--accent) 20%, var(--border));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;box-shadow:inset 0 1px #fff3}.checkpoint-title-inline{align-items:center;gap:8px;min-width:0;display:inline-flex}.checkpoint-title-inline__icon{color:#2563eb;background:linear-gradient(135deg, color-mix(in srgb, #2563eb 14%, var(--surface-strong)), color-mix(in srgb, #60a5fa 10%, var(--surface)));border:1px solid color-mix(in srgb, #2563eb 24%, var(--border));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex;box-shadow:inset 0 1px #fff3}.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{background:linear-gradient(135deg, var(--accent), #7c3aed);color:#fff;cursor:pointer;box-shadow:0 12px 24px color-mix(in srgb, var(--accent) 26%, transparent);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}.btn-report:hover{box-shadow:0 16px 32px color-mix(in srgb, var(--accent) 34%, transparent);transform:translateY(-2px)}.btn-report:active{box-shadow:0 4px 12px color-mix(in srgb, var(--accent) 18%, transparent);transform:translateY(1px)scale(.98)}.btn-directions{background:var(--bg3);border:1px solid var(--border);color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;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:var(--accent-soft);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;background:var(--overlay);padding:0 max(12px, env(safe-area-inset-right)) max(0px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));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{background:linear-gradient(180deg, var(--surface-strong), var(--surface));-webkit-backdrop-filter:blur(22px)saturate(1.06);border:1px solid var(--border);width:100%;max-width:500px;max-height:min(92vh,92dvh);box-shadow:var(--shadow-lg);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border-radius:36px 36px 0 0;padding:24px 20px 32px;animation:.4s cubic-bezier(.2,.8,.2,1) slideUp;overflow:hidden auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.modal-title{letter-spacing:-.02em;color:var(--text);font-size:1rem;font-weight:700}.modal-close{background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;transition:all .2s;display:flex}.modal-close:hover{background:var(--accent-soft);color:var(--text);transform:scale(1.05)}.modal-station-name{color:var(--accent-strong);letter-spacing:.2px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:20px;font-size:1rem;font-weight:700;display:flex}.modal-desc{color:var(--text-muted);margin-bottom:20px;font-size:.9rem}.modal-options{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.opt-btn{background:var(--input-bg);border:1px solid var(--input-border);cursor:pointer;text-align:left;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{border-color:var(--border-strong);background:color-mix(in srgb, var(--input-bg) 82%, var(--accent-soft));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{background:var(--input-bg);border:1px solid var(--input-border);width:100%;color:var(--input-text);resize:none;border-radius:18px;outline:none;min-height:56px;padding:13px 15px;font-family:inherit;font-size:.88rem;line-height:1.45;transition:all .25s}.note-input:focus{border-color:color-mix(in srgb, var(--accent) 48%, var(--input-border));background:var(--input-bg);box-shadow:0 0 0 4px var(--accent-soft)}.note-input::placeholder{color:var(--input-placeholder)}.queue-report-card{background:var(--input-bg);border:1px solid var(--input-border);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:var(--text);margin-bottom:0;font-size:.86rem;display:block}.queue-report-pill{background:var(--bg3);border:1px solid var(--input-border);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{border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-muted);font:inherit;cursor:pointer;border-radius:12px;padding:8px 6px;font-size:.7rem;font-weight:700;transition:all .2s}.queue-report-stop.active{color:var(--text);border-color:color-mix(in srgb, var(--accent) 32%, var(--input-border));background:var(--accent-soft)}.modal-upload-wrap{justify-content:center;margin-bottom:14px;display:flex}.upload-trigger{border:1px solid color-mix(in srgb, var(--accent) 24%, var(--border));background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, var(--input-bg)), color-mix(in srgb, var(--accent2) 10%, var(--input-bg)));cursor:pointer;width:auto;max-width:100%;box-shadow:0 12px 24px color-mix(in srgb, var(--accent) 12%, transparent);border-radius:999px;align-items:center;gap:8px;padding:9px 14px;transition:transform .2s,border-color .2s,background .2s,box-shadow .2s;display:inline-flex}.upload-trigger:hover{border-color:color-mix(in srgb, var(--accent) 36%, var(--border));box-shadow:0 16px 28px color-mix(in srgb, var(--accent) 18%, transparent);transform:translateY(-1px)}.upload-trigger.has-image{border-color:color-mix(in srgb, var(--green) 28%, var(--border));background:linear-gradient(135deg, color-mix(in srgb, var(--green) 16%, var(--input-bg)), color-mix(in srgb, var(--accent2) 8%, var(--input-bg)))}.upload-trigger-icon{width:28px;height:28px;color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, var(--bg2));border:1px solid color-mix(in srgb, var(--accent) 16%, var(--border));border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.upload-trigger.has-image .upload-trigger-icon{color:var(--green)}.upload-trigger-copy{align-items:center;gap:6px;min-width:0;display:flex}.upload-trigger-copy strong{color:var(--text);white-space:nowrap;font-size:.78rem;font-weight:800;line-height:1.2}.upload-trigger-copy span{color:var(--text-muted);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{background:var(--bg3);border:1px solid var(--border);color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;border-radius:22px;flex:1;padding:13px;font-family:inherit;font-size:.88rem;font-weight:600;transition:all .25s}.btn-cancel:hover{background:var(--accent-soft);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-title-icon{width:24px;height:24px}.station-title-inline__icon,.checkpoint-title-inline__icon{width:22px;height:22px}.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:10px;padding:10px 12px}.fuel-row__left,.fuel-row__right{width:100%}.fuel-row__right{justify-content:space-between;gap:8px}.fuel-name{font-size:.92rem}.fuel-votes{font-size:.74rem}.fuel-badge{padding:5px 9px;font-size:.74rem}.fuel-report-btn{width:30px;height:30px}.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(180deg, var(--surface-strong), color-mix(in srgb, var(--surface-strong) 86%, transparent));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));background:linear-gradient(180deg, color-mix(in srgb, var(--surface-strong) 16%, transparent), var(--surface-strong) 28%);padding-top:12px;padding-bottom:max(2px, env(safe-area-inset-bottom));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:var(--input-bg);border:1px solid var(--input-border);border-radius:20px;justify-content:space-between;align-items:center;padding:12px 14px;transition:transform .2s,background .3s,border-color .3s;display:flex}.fuel-row:hover{background:color-mix(in srgb, var(--input-bg) 82%, var(--accent-soft));transform:translateY(-1px)}.fuel-row--green{background:linear-gradient(135deg, color-mix(in srgb, var(--green) 12%, var(--input-bg)) 0%, var(--input-bg) 100%);border-color:color-mix(in srgb, var(--green) 26%, var(--input-border))}.fuel-row--yellow{background:linear-gradient(135deg, color-mix(in srgb, var(--yellow) 12%, var(--input-bg)) 0%, var(--input-bg) 100%);border-color:color-mix(in srgb, var(--yellow) 26%, var(--input-border))}.fuel-row--red{background:linear-gradient(135deg, color-mix(in srgb, var(--red) 12%, var(--input-bg)) 0%, var(--input-bg) 100%);border-color:color-mix(in srgb, var(--red) 26%, var(--input-border))}.fuel-row--gray{border-color:var(--input-border)}.fuel-color-dot{border:2px solid #fff6;border-radius:50%;flex-shrink:0;width:24px;height:24px;box-shadow:0 4px 12px #0006,inset 0 2px 4px #fff3}.fuel-row__left{align-items:center;gap:12px;display:flex}.fuel-icon{font-size:1.4rem}.fuel-name{color:var(--text);letter-spacing:.1px;font-size:.96rem;font-weight:700;line-height:1.2}.fuel-votes{color:var(--text-muted);margin-top:2px;font-size:.78rem;font-weight:500;line-height:1.2}.fuel-row__right{align-items:center;gap:10px;display:flex}.fuel-badge{white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid #0000;border-radius:999px;padding:5px 10px;font-size:.78rem;font-weight:700;line-height:1}.fuel-badge--green{background:var(--green-bg);color:var(--green);border-color:color-mix(in srgb, var(--green) 22%, var(--input-border))}.fuel-badge--yellow{background:var(--yellow-bg);color:var(--yellow);border-color:color-mix(in srgb, var(--yellow) 22%, var(--input-border))}.fuel-badge--red{background:var(--red-bg);color:var(--red);border-color:color-mix(in srgb, var(--red) 22%, var(--input-border))}.fuel-badge--gray{background:var(--gray-bg);color:var(--gray);border-color:var(--input-border)}.fuel-report-btn{background:var(--bg3);border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;transition:all .25s cubic-bezier(.2,.8,.2,1);display:flex}.fuel-report-btn:hover{background:var(--accent-soft);border-color:color-mix(in srgb, var(--accent) 24%, var(--border));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:var(--accent-soft)}.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{background:var(--accent-soft);border:1px solid color-mix(in srgb, var(--accent) 38%, var(--border));color:var(--accent);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;background:var(--overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.dialog-box{background:var(--surface-strong);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:380px;box-shadow:var(--shadow-lg);outline:none;padding:32px 28px 24px;animation:.35s cubic-bezier(.16,1,.3,1) dialogPop;position:relative;overflow:hidden}@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)}.announcement-modal-backdrop{z-index:9800;padding:max(18px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));-webkit-backdrop-filter:blur(14px);background:#0f172a95;place-items:center;display:grid;position:fixed;inset:0}.announcement-modal-card{background:radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 14%, transparent), transparent 34%), linear-gradient(180deg, color-mix(in srgb, var(--surface-strong) 95%, white), var(--surface));border:1px solid color-mix(in srgb, var(--border-strong) 82%, transparent);border-radius:30px;width:min(720px,100%);max-height:min(88vh,88dvh);padding:26px 24px 22px;position:relative;overflow:auto;box-shadow:0 28px 70px #0206173d,0 8px 24px #02061729}.announcement-modal-close{border:1px solid var(--border);background:color-mix(in srgb, var(--surface-strong) 88%, white);width:46px;height:46px;color:var(--text);cursor:pointer;z-index:2;border-radius:16px;justify-content:center;align-items:center;margin-left:auto;display:flex;position:sticky;top:0;box-shadow:0 10px 24px #0f172a1f}.announcement-modal-hero{gap:12px;margin-top:-6px;display:grid}.announcement-modal-badge{width:fit-content;color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 18%, var(--border));background:linear-gradient(135deg,#2563eb1f,#10b9811f);border-radius:999px;align-items:center;gap:10px;padding:10px 14px;display:inline-flex}.announcement-modal-kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-size:.8rem;font-weight:800}.announcement-modal-title{letter-spacing:-.03em;color:var(--text);margin:0;font-size:clamp(1.6rem,4vw,2.35rem);font-weight:900;line-height:1}.announcement-modal-message{color:var(--text-secondary);margin:0;font-size:1rem;line-height:1.8}.announcement-modal-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-top:18px;display:grid}.announcement-modal-point{background:color-mix(in srgb, var(--bg3) 78%, white);border:1px solid var(--border);border-radius:22px;grid-template-columns:auto 1fr;align-items:flex-start;gap:12px;padding:16px;display:grid}.announcement-modal-point-icon{width:38px;height:38px;color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, white);border-radius:14px;justify-content:center;align-items:center;display:inline-flex}.announcement-modal-point-title{color:var(--text);margin-bottom:6px;font-size:.95rem;font-weight:800}.announcement-modal-point-body{color:var(--text-muted);font-size:.88rem;line-height:1.65}.announcement-modal-note{border:1px solid color-mix(in srgb, var(--accent) 14%, var(--border));color:var(--text-secondary);background:linear-gradient(135deg,#3b82f614,#10b98114);border-radius:22px;margin-top:16px;padding:16px 18px;line-height:1.75}.announcement-modal-checkbox{background:color-mix(in srgb, var(--bg3) 82%, white);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:18px;align-items:center;gap:12px;margin-top:18px;padding:14px 16px;font-weight:700;display:flex}.announcement-modal-checkbox input{width:19px;height:19px;accent-color:var(--accent);flex-shrink:0}.announcement-modal-actions{background:linear-gradient(180deg, color-mix(in srgb, var(--surface-strong) 18%, transparent), var(--surface-strong) 34%);grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:18px;padding-top:14px;display:grid;position:sticky;bottom:-22px}.announcement-modal-action{cursor:pointer;border:0;border-radius:18px;min-height:52px;padding:0 16px;font-family:inherit;font-size:.96rem;font-weight:800}.announcement-modal-action-secondary{background:var(--bg3);border:1px solid var(--border);color:var(--text)}.announcement-modal-action-primary{color:#fff;background:linear-gradient(135deg,#2563eb,#10b981);box-shadow:0 18px 36px #2563eb3d}.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;padding-bottom:calc(108px + env(safe-area-inset-bottom));margin:0 auto;font-family:Noto Sans Thai,Inter,sans-serif}.feed-header{z-index:100;background:var(--surface-strong);-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, var(--accent), color-mix(in srgb, var(--accent2) 68%, var(--accent)));-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{background:color-mix(in srgb, var(--red) 10%, transparent);border:1px solid color-mix(in srgb, var(--red) 24%, var(--border));color:var(--red);letter-spacing:.5px;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.7rem;font-weight:700;display:flex}.live-dot{background:var(--red);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{border:1px solid color-mix(in srgb, var(--accent) 18%, var(--border));background:radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--accent2) 18%, transparent), transparent 38%), linear-gradient(135deg, color-mix(in srgb, var(--accent) 14%, transparent), color-mix(in srgb, var(--bg2) 74%, transparent));box-shadow:var(--shadow-md);border-radius:24px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;margin:16px 20px 14px;padding:16px 18px;display:grid}.feed-composer-banner.feed-composer-banner-compact{justify-content:flex-end;padding:12px 14px;display:flex}.feed-composer-banner strong{color:var(--text);margin-bottom:4px;font-size:1rem;display:block}.feed-composer-banner p{color:var(--text-muted);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(--surface-strong);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:transform .2s,border-color .2s;animation:.4s cubic-bezier(.16,1,.3,1) both cardSlideIn;display:flex;overflow:hidden}.feed-card:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:0 18px 34px #0f172a1f}@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);background:color-mix(in srgb, var(--accent) 6%, var(--bg2));border-left:3px solid var(--accent);white-space:pre-wrap;word-break:break-word;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{border:1px solid var(--input-border);background:linear-gradient(180deg, var(--input-bg), color-mix(in srgb, var(--bg2) 82%, var(--input-bg)));border-radius:16px;padding:10px}.feed-checkin-head{align-items:center;gap:8px;margin-bottom:8px;display:flex}.feed-checkin-icon{width:28px;height:28px;color:var(--accent);background:var(--accent-soft);border:1px solid color-mix(in srgb, var(--accent) 16%, var(--border));border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.feed-checkin-copy strong{color:var(--text);font-size:.8rem;display:block}.feed-station-select{border:1px solid var(--input-border);background:var(--input-bg);width:100%;min-height:40px;color:var(--text);font:inherit;appearance:none;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:color-mix(in srgb, var(--accent) 40%, var(--input-border));box-shadow:0 0 0 3px var(--accent-soft)}.feed-station-select option{background:var(--bg2);color:var(--text)}.feed-station-select:disabled{opacity:.65;cursor:not-allowed}.feed-selected-station,.feed-station-option{text-align:left;border:1px solid var(--input-border);background:var(--input-bg);width:100%;color:inherit;cursor:pointer;border-radius:12px;padding:8px 10px;font-family:inherit;transition:border-color .2s,background .2s,transform .2s}.feed-selected-station{border-color:color-mix(in srgb, var(--green) 26%, var(--input-border));background:linear-gradient(135deg, color-mix(in srgb, var(--green) 12%, var(--input-bg)), var(--input-bg));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:var(--green);font-size:.68rem;font-weight:700}.feed-selected-station:hover,.feed-selected-station.static{border-color:color-mix(in srgb, var(--accent) 30%, var(--input-border));transform:translateY(-1px)}.feed-selected-station strong,.feed-station-option strong{color:var(--text);align-items:center;gap:8px;margin-bottom:2px;font-size:.76rem;display:flex}.feed-selected-station span,.feed-station-option span{color:var(--text-muted);word-break:break-word;font-size:.66rem;line-height:1.4}.feed-selected-station.static{margin-bottom:0}.feed-selected-station-badge{background:var(--green-bg);color:var(--green);border-radius:999px;flex-shrink:0;padding:5px 9px;font-size:.64rem;font-weight:800}.feed-selected-station-edit{border:1px solid var(--input-border);background:var(--bg3);color:var(--text);font:inherit;cursor:pointer;border-radius:999px;flex-shrink:0;padding:5px 9px;font-size:.64rem;font-weight:800}.feed-image-help{color:var(--text-muted);font-size:.76rem;line-height:1.45}.feed-quick-report-card{border:1px solid var(--input-border);background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 4%, var(--input-bg)), var(--input-bg));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:var(--text);font-size:.78rem}.feed-quick-report-head span{color:var(--accent);text-align:right;font-size:.66rem}.feed-fuel-summary-empty{border:1px dashed color-mix(in srgb, var(--border-strong) 80%, transparent);background:color-mix(in srgb, var(--bg3) 72%, transparent);min-height:56px;color:var(--text-muted);text-align:center;border-radius:14px;justify-content:center;align-items:center;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:var(--text);min-width:22px;font-size:.74rem;font-weight:800}.feed-fuel-current-chip{white-space:nowrap;border:1px solid #0000;border-radius:999px;padding:4px 7px;font-size:.62rem;font-weight:800;line-height:1;box-shadow:inset 0 1px #ffffff2e}.feed-fuel-current-chip.is-available{background:var(--green-bg);color:var(--green);border-color:color-mix(in srgb, var(--green) 22%, var(--input-border))}.feed-fuel-current-chip.is-low{background:var(--yellow-bg);color:var(--yellow);border-color:color-mix(in srgb, var(--yellow) 22%, var(--input-border))}.feed-fuel-current-chip.is-empty{background:var(--red-bg);color:var(--red);border-color:color-mix(in srgb, var(--red) 22%, var(--input-border))}.feed-fuel-current-chip.is-unknown{background:color-mix(in srgb, var(--surface-strong) 72%, var(--bg2));color:var(--text-muted);border-color:color-mix(in srgb, var(--border-strong) 78%, transparent)}.feed-fuel-report-actions{flex-wrap:nowrap;flex-shrink:0;justify-content:flex-end;gap:4px;display:flex}.feed-fuel-report-btn{border:1px solid var(--input-border);background:var(--bg3);min-width:36px;color:var(--text);font:inherit;cursor:pointer;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;padding:0 20px calc(120px + env(safe-area-inset-bottom));margin:0 auto}@media (min-width:821px){.feed-page{padding-bottom:36px}.about-content{padding-bottom:44px}}.about-hero{text-align:center;flex-direction:column;align-items:center;padding:40px 20px 32px;display:flex}.about-hero-icon{display:none}.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}.app-layout{flex:1;width:100%;min-height:0;display:flex;position:relative}.app-map-area{flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.app-feed-area{display:none}@media (min-width:1024px){.app-feed-area{z-index:500;border-left:1px solid var(--border);flex-shrink:0;width:380px;height:100vh;display:flex;position:relative}}@media (min-width:1440px){.app-feed-area{width:420px}}.desktop-feed-panel{background:var(--bg);flex-direction:column;width:100%;height:100vh;font-family:Noto Sans Thai,Inter,sans-serif;display:flex;overflow:hidden}.dfp-header{border-bottom:1px solid var(--border);background:var(--surface-strong);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.dfp-header-left{align-items:center;gap:10px;display:flex}.dfp-header-icon{background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent2) 68%, var(--accent)));color:#fff;box-shadow:0 4px 12px color-mix(in srgb, var(--accent) 24%, transparent);border-radius:50%;justify-content:center;align-items:center;padding:5px;display:flex}.dfp-title{background:linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent2) 68%, var(--accent)));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:.95rem;font-weight:700;line-height:1.2}.dfp-live-badge{background:color-mix(in srgb, var(--red) 10%, transparent);border:1px solid color-mix(in srgb, var(--red) 24%, var(--border));color:var(--red);letter-spacing:.5px;border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:.6rem;font-weight:700;display:flex}.dfp-live-dot{background:var(--red);border-radius:50%;width:5px;height:5px;animation:1.5s ease-in-out infinite livePulse}.dfp-list{scrollbar-width:thin;scrollbar-color:color-mix(in srgb, var(--text-muted) 20%, transparent) transparent;flex-direction:column;flex:1;gap:8px;padding:12px 12px 24px;display:flex;overflow:hidden auto}.dfp-list::-webkit-scrollbar{width:4px}.dfp-list::-webkit-scrollbar-track{background:0 0}.dfp-list::-webkit-scrollbar-thumb{background:color-mix(in srgb, var(--text-muted) 20%, transparent);border-radius:4px}.dfp-empty{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:40px 16px;font-size:.82rem;display:flex}.dfp-card{background:var(--surface-strong);border:1px solid var(--border);cursor:default;border-radius:14px;flex-direction:column;gap:6px;padding:10px 12px;transition:transform .2s,border-color .2s,box-shadow .2s;animation:.35s cubic-bezier(.16,1,.3,1) both dfpCardIn;display:flex}.dfp-card:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:0 8px 20px #0f172a1a}@keyframes dfpCardIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dfp-card-header{align-items:center;gap:8px;display:flex}.dfp-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:26px;height:26px}.dfp-avatar--placeholder{background:var(--bg3);justify-content:center;align-items:center;display:flex}.dfp-card-meta{flex:1;align-items:baseline;gap:6px;min-width:0;display:flex}.dfp-reporter-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;font-weight:600;overflow:hidden}.dfp-time{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.62rem}.dfp-station{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.dfp-station-icon{color:var(--text-muted);align-items:center;display:flex}.dfp-station-name{color:var(--text);font-size:.82rem;font-weight:700;line-height:1.3}.dfp-queue{border-radius:999px;align-items:center;gap:3px;padding:2px 6px;font-size:.58rem;font-weight:800;line-height:1;display:inline-flex}.dfp-addr{color:var(--text-muted);flex-wrap:wrap;gap:4px;font-size:.66rem;line-height:1.4;display:flex}.dfp-note{color:var(--text-muted);background:color-mix(in srgb, var(--accent) 5%, var(--bg2));border-left:2px solid var(--accent);word-break:break-word;border-radius:6px;align-items:flex-start;gap:6px;padding:5px 8px;font-size:.76rem;font-style:italic;line-height:1.4;display:flex}.dfp-note span{flex:1}.dfp-fuels{flex-wrap:wrap;gap:4px;display:flex}.dfp-fuel-badge{border-radius:5px;align-items:center;gap:5px;width:fit-content;padding:2px 6px;display:flex}.dfp-fuel-badge span{letter-spacing:.1px;font-size:.62rem;font-weight:700}.dfp-fuel-dot{width:7px;height:7px;box-shadow:0 0 0 1px color-mix(in srgb, var(--surface-inverse) 20%, transparent), inset 0 1px 2px #0003;border-radius:50%;flex-shrink:0}.dfp-sos-note{color:var(--text);background:color-mix(in srgb, var(--red) 8%, var(--bg2));border-left:2px solid var(--red);word-break:break-word;border-radius:6px;align-items:flex-start;gap:6px;padding:5px 8px;font-size:.76rem;font-weight:500;display:flex}.dfp-sos-note span{flex:1}.dfp-image-wrap{border:1px solid var(--border);border-radius:8px;overflow:hidden}.dfp-image{object-fit:cover;width:100%;max-height:160px;display:block}.image-lightbox-backdrop{z-index:10050;-webkit-backdrop-filter:blur(10px);padding:max(20px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(20px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left));background:#080b14e6;justify-content:center;align-items:center;animation:.18s ease-out fadeIn;display:flex;position:fixed;inset:0}.image-lightbox-close{top:max(16px, env(safe-area-inset-top));right:max(16px, env(safe-area-inset-right));color:#fff;cursor:pointer;background:#0f172ab8;border:1px solid #ffffff29;border-radius:16px;justify-content:center;align-items:center;width:46px;height:46px;display:inline-flex;position:fixed;box-shadow:0 16px 36px #00000047}.image-lightbox-shell{justify-content:center;align-items:center;width:min(100%,1200px);height:min(100%,100dvh - 48px);display:flex}.image-lightbox-image{object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;border-radius:18px;width:100%;height:100%;display:block;box-shadow:0 24px 60px #00000061}.dfp-card-footer{border-top:1px solid color-mix(in srgb, var(--border) 50%, transparent);justify-content:space-between;align-items:center;padding-top:6px;display:flex}.dfp-loc{color:var(--text-muted);align-items:center;gap:3px;font-size:.58rem;display:flex}.dfp-nav-link{color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent);border:1px solid color-mix(in srgb, var(--accent) 20%, var(--border));border-radius:10px;align-items:center;gap:3px;padding:2px 7px;font-size:.62rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.dfp-nav-link:hover{background:color-mix(in srgb, var(--accent) 16%, transparent);transform:translateY(-1px)}.dfp-footer{border-top:1px solid var(--border);background:var(--surface-strong);text-align:center;flex-shrink:0;padding:10px 14px}.dfp-view-all{color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent);border:1px solid color-mix(in srgb, var(--accent) 20%, var(--border));border-radius:999px;align-items:center;gap:6px;padding:6px 16px;font-size:.82rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.dfp-view-all:hover{background:color-mix(in srgb, var(--accent) 16%, transparent);transform:translateY(-1px)}.trip-planner-modal{width:min(96vw,1100px);max-height:90vh;color:var(--text);background:radial-gradient(circle at 0 0,#38bdf824,#0000 28%),radial-gradient(circle at 100% 0,#818cf829,#0000 32%),linear-gradient(#fffffffa,#f8fafcfa);border:1px solid #94a3b82e;border-radius:32px;position:relative;overflow:hidden auto;box-shadow:0 40px 90px #0f172a38}.trip-planner-modal__close{width:44px;height:44px;color:var(--text-muted);cursor:pointer;z-index:2;background:#ffffffc7;border:1px solid #94a3b833;border-radius:999px;justify-content:center;align-items:center;transition:transform .18s,background .18s,color .18s;display:flex;position:absolute;top:18px;right:18px}.trip-planner-modal__close:hover{color:var(--text);background:#fff;transform:translateY(-1px)}.trip-planner-modal__hero{padding:32px 34px 22px}.trip-planner-modal__badge,.trip-planner-kicker{letter-spacing:.03em;border-radius:999px;align-items:center;gap:7px;font-size:.75rem;font-weight:800;display:inline-flex}.trip-planner-modal__badge{color:#312e81;background:linear-gradient(135deg,#38bdf829,#818cf824);margin-bottom:14px;padding:8px 12px}.trip-planner-kicker{color:#475569;text-transform:uppercase}.trip-planner-modal__title{letter-spacing:-.045em;max-width:760px;margin:0;font-size:clamp(1.6rem,2.8vw,2.35rem);line-height:1.08}.trip-planner-modal__subtitle{color:#475569;max-width:760px;margin:12px 0 0;font-size:.99rem;line-height:1.7}.trip-planner-modal__body{grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:18px;padding:0 18px 18px;display:grid}.trip-planner-panel,.trip-planner-results{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffad;border:1px solid #94a3b829;border-radius:28px}.trip-planner-panel{padding:22px}.trip-planner-results{min-height:620px;padding:18px}.trip-planner-section-head{gap:4px;margin-bottom:18px;display:grid}.trip-planner-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.trip-planner-field{gap:8px;display:grid}.trip-planner-field--full{grid-column:1/-1}.trip-planner-field label{color:#334155;align-items:center;gap:6px;font-size:.84rem;font-weight:800;display:inline-flex}.trip-planner-duration-grid,.trip-planner-chip-grid{flex-wrap:wrap;gap:8px;display:flex}.trip-planner-duration-card{min-width:110px;color:var(--text);text-align:left;cursor:pointer;background:linear-gradient(#ffffffeb,#f8fafccc);border:1px solid #94a3b82e;border-radius:18px;flex:1 1 0;gap:3px;padding:14px 14px 13px;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid}.trip-planner-duration-card span{font-weight:800}.trip-planner-duration-card small{color:#64748b;line-height:1.45}.trip-planner-duration-card.is-active{background:linear-gradient(145deg,#6366f124,#38bdf81a);border-color:#4f46e557;box-shadow:0 14px 30px #6366f11f}.trip-planner-chip{color:#334155;cursor:pointer;background:#ffffffc2;border:1px solid #94a3b82e;border-radius:999px;padding:10px 13px;font-size:.84rem;font-weight:800;transition:transform .18s,border-color .18s,background .18s}.trip-planner-chip.is-active{color:#0f172a;background:linear-gradient(135deg,#22c55e14,#3b82f61a);border-color:#0ea5e942}.trip-planner-input,.trip-planner-select,.trip-planner-textarea{width:100%;color:var(--text);font:inherit;background:#fffc;border:1px solid #94a3b833;border-radius:16px;outline:none;padding:13px 14px;transition:border-color .18s,box-shadow .18s,background .18s}.trip-planner-input:focus,.trip-planner-select:focus,.trip-planner-textarea:focus{background:#fff;border-color:#4f46e561;box-shadow:0 0 0 4px #6366f114}.trip-planner-textarea{resize:vertical;min-height:96px}.trip-planner-actions{gap:12px;margin-top:18px;display:flex}.trip-planner-btn{height:52px;font:inherit;cursor:pointer;border:0;border-radius:18px;flex:1;justify-content:center;align-items:center;gap:8px;font-weight:800;transition:transform .18s,box-shadow .18s,opacity .18s;display:inline-flex}.trip-planner-btn:disabled{cursor:not-allowed;opacity:.6}.trip-planner-btn--ghost{color:#334155;background:#e2e8f08f;border:1px solid #94a3b829}.trip-planner-btn--primary{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 18px 34px #4f46e540}.trip-planner-error{color:#b91c1c;background:#ef444414;border:1px solid #ef444426;border-radius:16px;margin-top:14px;padding:13px 14px;font-size:.9rem}.trip-planner-empty{background:radial-gradient(circle at top,#3b82f614,#0000 38%),linear-gradient(#f8fafce6,#ffffffeb);border-radius:24px;justify-content:center;align-items:center;min-height:100%;display:flex;position:relative;overflow:hidden}.trip-planner-empty__glow{background:radial-gradient(circle,#6366f114,#0000 55%);position:absolute;inset:0}.trip-planner-empty__content{z-index:1;text-align:center;max-width:430px;padding:28px;position:relative}.trip-planner-empty__icon{color:#4338ca;background:linear-gradient(135deg,#38bdf82e,#818cf833);border-radius:18px;justify-content:center;align-items:center;width:58px;height:58px;margin:0 auto 16px;display:flex}.trip-planner-empty__content strong{margin-bottom:10px;font-size:1.06rem;display:block}.trip-planner-empty__content p{color:#64748b;margin:0;line-height:1.7}.trip-planner-plan{gap:16px;display:grid}.trip-planner-plan__hero,.trip-planner-day-card,.trip-planner-plan__footer,.trip-planner-plan__reason-list{background:#ffffffd1;border:1px solid #94a3b824;border-radius:22px}.trip-planner-plan__hero{padding:18px 18px 16px}.trip-planner-plan__hero-top{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.trip-planner-plan__count{color:#64748b;font-size:.78rem}.trip-planner-plan__hero h4{letter-spacing:-.03em;margin:0;font-size:1.22rem;line-height:1.2}.trip-planner-plan__hero p{color:#475569;margin:10px 0 0;line-height:1.7}.trip-planner-plan__reason-list{gap:10px;padding:14px 16px;display:grid}.trip-planner-plan__reason-item{color:#475569;align-items:flex-start;gap:10px;line-height:1.6;display:flex}.trip-planner-plan__reason-dot{background:linear-gradient(135deg,#0ea5e9,#6366f1);border-radius:999px;flex-shrink:0;width:8px;height:8px;margin-top:8px}.trip-planner-day-list{gap:14px;display:grid}.trip-planner-day-card{padding:16px}.trip-planner-day-card__head{margin-bottom:14px}.trip-planner-day-card__head strong{margin-top:4px;font-size:1.02rem;display:block}.trip-planner-stop-list{gap:0;display:grid}.trip-planner-stop{grid-template-columns:24px minmax(0,1fr);gap:12px;display:grid}.trip-planner-stop+.trip-planner-stop{margin-top:2px}.trip-planner-stop__rail{flex-direction:column;align-items:center;display:flex;position:relative}.trip-planner-stop__dot{background:linear-gradient(135deg,#06b6d4,#4f46e5);border-radius:999px;width:12px;height:12px;margin-top:7px;box-shadow:0 0 0 4px #6366f114}.trip-planner-stop__line{background:linear-gradient(#6366f12e,#94a3b814);width:2px;position:absolute;top:20px;bottom:-6px}.trip-planner-stop__body{padding-bottom:16px}.trip-planner-stop__topline{justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;display:flex}.trip-planner-stop__time,.trip-planner-stop__cost{color:#64748b;font-size:.78rem}.trip-planner-stop__title{color:var(--text);margin-bottom:8px;font-size:1rem;font-weight:800;text-decoration:none;display:inline-block}.trip-planner-stop__meta{gap:8px;margin-bottom:8px;display:flex}.trip-planner-stop__type{color:#334155;background:#f1f5f9eb;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:.76rem;font-weight:800;display:inline-flex}.trip-planner-stop__reason,.trip-planner-stop__tip{color:#475569;margin:0;line-height:1.7}.trip-planner-stop__tip{margin-top:6px;font-size:.84rem}.trip-planner-plan__footer{gap:14px;padding:16px;display:grid}.trip-planner-plan__note-block strong{margin-bottom:8px;display:block}.trip-planner-plan__note-block p,.trip-planner-plan__tip-list{color:#475569;margin:0;line-height:1.7}@media (max-width:900px){.trip-planner-modal{border-radius:28px 28px 0 0;width:100vw;max-height:100vh}.trip-planner-modal__hero{padding:26px 22px 18px}.trip-planner-modal__body{grid-template-columns:1fr;padding:0 12px 12px}.trip-planner-panel,.trip-planner-results{border-radius:22px}.trip-planner-results{min-height:0}}@media (max-width:640px){.trip-planner-grid{grid-template-columns:1fr}.trip-planner-duration-grid,.trip-planner-actions{flex-direction:column}.trip-planner-btn{width:100%}.trip-planner-modal__title{max-width:none}}
