:root{--bg:#0d1117;--bg2:#161b22;--bg3:#21262d;--surface:#161b22f0;--border:#ffffff14;--text:#e6edf3;--text-muted:#8b949e;--accent:#58a6ff;--accent2:#a78bfa;--green:#3fb950;--green-bg:#3fb95026;--green-glow:#3fb95066;--yellow:#d29922;--yellow-bg:#d2992226;--yellow-glow:#d2992266;--red:#f85149;--red-bg:#f8514926;--red-glow:#f8514966;--gray:#6e7681;--gray-bg:#6e76811f;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--shadow-lg:0 8px 32px #000000a6;--nav-h:60px;--legend-h:48px;--stat-h:44px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);width:100%;height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Noto Sans Thai,Inter,sans-serif;overflow:hidden}.splash{z-index:9999;background:linear-gradient(145deg,#0d1117 0%,#161b22 60%,#1a2030 100%);justify-content:center;align-items:center;transition:opacity .5s;display:flex;position:fixed;inset:0}.splash.out{opacity:0;pointer-events:none}.splash-icon{filter:drop-shadow(0 0 24px #58a6ff99);font-size:72px;animation:2s ease-in-out infinite floatIcon;display:block}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.splash-title{letter-spacing:-1px;background:linear-gradient(90deg,#58a6ff,#a78bfa);-webkit-text-fill-color:transparent;text-align:center;-webkit-background-clip:text;margin-top:12px;font-size:2.4rem;font-weight:700}.splash-sub{color:var(--text-muted);text-align:center;margin-top:4px}.splash-loader{margin-top:48px}.loader-bar{background:var(--bg3);border-radius:4px;width:220px;height:4px;margin:0 auto;overflow:hidden}.loader-fill{background:linear-gradient(90deg,#58a6ff,#a78bfa);border-radius:4px;height:100%;animation:2s forwards loadFill}@keyframes loadFill{0%{width:0}to{width:100%}}.loader-text{color:var(--text-muted);text-align:center;margin-top:10px;font-size:.85rem}.app{flex-direction:column;display:flex;position:fixed;inset:0}.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;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}.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-suggestions{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-md);z-index:600;box-shadow:var(--shadow-lg);display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden}.search-suggestions.open{display:block}.suggestion-item{cursor:pointer;color:var(--text);align-items:center;gap:10px;padding:11px 16px;font-size:.88rem;transition:background .15s;display:flex}.suggestion-item:hover{background:var(--bg3)}.btn-locate,.btn-icon{background:var(--bg3);border:1px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:background .2s,transform .15s;display:flex}.btn-locate:hover,.btn-icon:hover{background:var(--bg);transform:scale(1.05)}.btn-locate:active,.btn-icon:active{transform:scale(.95)}.legend-bar{height:var(--legend-h);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:0 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-control-zoom a{background:var(--bg2)!important;color:var(--text)!important;border-color:var(--border)!important}.leaflet-control-zoom a:hover{background:var(--bg3)!important}.leaflet-control-attribution{color:var(--text-muted)!important;background:#0d1117b3!important;font-size:10px!important}.leaflet-control-attribution a{color:var(--text-muted)!important}.marker-pin{border:3px solid #ffffff40;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative;transform:rotate(-45deg);box-shadow:0 4px 16px #00000080}.marker-logo{justify-content:center;align-items:center;width:100%;height:100%;display:flex;transform:rotate(45deg)}.marker-logo img{object-fit:contain;background:#fff;border-radius:50%;width:24px;height:24px;padding:2px;box-shadow:inset 0 2px 4px #0000001a}.marker-logo .alt-text{text-shadow:0 1px 3px #0009;font-size:11px;font-weight:900}.marker-pin.green{background:var(--green);box-shadow:0 4px 16px var(--green-glow)}.marker-pin.yellow{background:var(--yellow);box-shadow:0 4px 16px var(--yellow-glow)}.marker-pin.red{background:var(--red);box-shadow:0 4px 16px var(--red-glow)}.marker-pin.gray{background:var(--gray);box-shadow:0 4px 16px #0000004d}.marker-pin.pulse:before{content:"";background:inherit;opacity:0;border-radius:50%;animation:2s ease-out infinite pulse;position:absolute;inset:-6px}@keyframes pulse{0%{opacity:.6;transform:rotate(45deg)scale(.8)}to{opacity:0;transform:rotate(45deg)scale(1.8)}}.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}.statbar{height:var(--stat-h);background:var(--surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);color:var(--text-muted);z-index:490;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px;font-size:.82rem;display:flex}.stat-count{color:var(--accent);font-weight:600}.statbar-hint{font-size:.78rem}.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(--bg2);border-top:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:800;scrollbar-width:thin;scrollbar-color:var(--bg3) transparent;max-height:90vh;animation:.35s cubic-bezier(.16,1,.3,1) slideUp;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -8px 40px #000000b3}.station-panel.hidden{display:none}.station-panel.closing{animation:.25s ease-in forwards slideDown}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{to{opacity:0;transform:translateY(100%)}}.panel-handle{background:var(--bg3);border-radius:4px;width:40px;height:4px;margin:12px 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);font-size:1.15rem;font-weight:700;line-height:1.3}.panel-subtitle{color:var(--text-muted);margin-top:3px;font-size:.82rem}.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:10px;padding:0 18px 18px;display:flex}.btn-report{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:linear-gradient(135deg,#58a6ff,#a78bfa);border:none;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px;font-family:inherit;font-size:.9rem;font-weight:600;transition:opacity .2s,transform .15s;display:flex}.btn-report:hover{opacity:.9}.btn-report:active{transform:scale(.97)}.btn-directions{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);cursor:pointer;justify-content:center;align-items:center;gap:6px;padding:12px 16px;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .2s,transform .15s;display:flex}.btn-directions:hover{background:var(--bg)}.btn-directions:active{transform:scale(.97)}.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-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:#000000bf;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-backdrop.hidden{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:500px;padding:24px 20px 40px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp}.modal-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.modal-title{font-size:1.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:32px;height:32px;font-size:.9rem;transition:background .2s;display:flex}.modal-close:hover{background:var(--bg)}.modal-station-name{color:var(--accent);margin-bottom:16px;font-size:.88rem;font-weight:600}.modal-desc{color:var(--text-muted);margin-bottom:16px;font-size:.85rem}.modal-options{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.opt-btn{background:var(--bg3);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:left;align-items:center;gap:14px;width:100%;padding:14px 16px;font-family:inherit;transition:all .2s;display:flex}.opt-btn:hover{border-color:currentColor;transform:translate(4px)}.opt-btn.selected{transform:translate(4px)}.opt-btn.opt-green{color:var(--green)}.opt-btn.opt-yellow{color:var(--yellow)}.opt-btn.opt-red{color:var(--red)}.opt-btn.opt-green.selected{background:var(--green-bg);border-color:var(--green)}.opt-btn.opt-yellow.selected{background:var(--yellow-bg);border-color:var(--yellow)}.opt-btn.opt-red.selected{background:var(--red-bg);border-color:var(--red)}.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:20px}.note-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:10px 14px;font-family:inherit;font-size:.88rem;transition:border-color .2s}.note-input:focus{border-color:var(--accent)}.note-input::placeholder{color:var(--text-muted)}.modal-footer{gap:10px;display:flex}.btn-cancel{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;flex:1;padding:12px;font-family:inherit;font-size:.9rem;transition:background .2s}.btn-cancel:hover{background:var(--bg)}.btn-submit{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:linear-gradient(135deg,#58a6ff,#a78bfa);border:none;flex:2;padding:12px;font-family:inherit;font-size:.9rem;font-weight:600;transition:opacity .2s,transform .15s}.btn-submit:hover:not(:disabled){opacity:.9}.btn-submit:active:not(:disabled){transform:scale(.97)}.btn-submit:disabled{opacity:.3;cursor:not-allowed}.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:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@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)}}.fuel-grid{flex-direction:column;gap:8px;padding:0 18px 18px;display:flex}.fuel-row{background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;padding:12px 14px;transition:border-color .2s,background .2s;display:flex}.fuel-row--green{border-color:var(--green);background:var(--green-bg)}.fuel-row--yellow{border-color:var(--yellow);background:var(--yellow-bg)}.fuel-row--red{border-color:var(--red);background:var(--red-bg)}.fuel-row--gray{border-color:var(--border);background:var(--bg3)}.fuel-color-dot{border:2px solid #ffffff40;border-radius:50%;flex-shrink:0;width:24px;height:24px;box-shadow:inset 0 2px 4px #0000004d}.fuel-row__left{align-items:center;gap:12px;display:flex}.fuel-icon{font-size:1.4rem}.fuel-name{color:var(--text);font-size:.9rem;font-weight:600}.fuel-votes{color:var(--text-muted);margin-top:2px;font-size:.72rem}.fuel-row__right{align-items:center;gap:10px;display:flex}.fuel-badge{white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:.78rem;font-weight:600}.fuel-badge--green{background:var(--green-bg);color:var(--green)}.fuel-badge--yellow{background:var(--yellow-bg);color:var(--yellow)}.fuel-badge--red{background:var(--red-bg);color:var(--red)}.fuel-badge--gray{background:var(--gray-bg);color:var(--gray)}.fuel-report-btn{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.85rem;transition:background .2s,transform .15s;display:flex}.fuel-report-btn:hover{background:var(--bg2);transform:scale(1.1)}.fuel-report-btn:active{transform:scale(.92)}.fuel-select-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}.fuel-select-btn{background:var(--bg3);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:center;flex-direction:column;align-items:center;gap:6px;padding:18px 12px;font-family:inherit;transition:all .2s;display:flex}.fuel-select-btn:hover{border-color:var(--accent);background:var(--bg);transform:translateY(-2px)}.fuel-select-btn.selected{border-color:var(--accent);background:#58a6ff1a}.fs-icon{font-size:1.8rem}.fs-short{color:var(--text);font-size:1.1rem;font-weight:700}.fs-label{color:var(--text-muted);font-size:.72rem}.modal-back{background:var(--bg3);border:1px solid var(--border);cursor:pointer;width:28px;height:28px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:background .2s;display:flex}.modal-back:hover{background:var(--bg)}.selected-fuel-chip{border:1px solid var(--accent);color:var(--accent);background:#58a6ff1f;border-radius:20px;align-items:center;gap:6px;margin-bottom:14px;padding:4px 14px;font-size:.82rem;font-weight:600;display:inline-flex}
