:root{--text:#6b6375;--text-h:#08060d;--bg:#0a0a0f;--surface:#141420;--border:#2a2a3a;--accent:#00ff41;--accent-dim:#00ff4126;--accent-border:#00ff4166;--danger:#f44;--danger-dim:#ff444426;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, "Cascadia Code", Consolas, monospace;font:16px/1.5 var(--sans);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#c0c0d0;background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box;margin:0;padding:0}body{margin:0}#app{max-width:1200px;min-height:100vh;margin:0 auto;padding:24px}.topbar{z-index:100;background:var(--bg);justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:12px 0;display:flex;position:sticky;top:0}.topbar h1{color:var(--accent);font-size:1.2rem;font-weight:700;font-family:var(--mono);white-space:nowrap;align-items:center;gap:6px;display:flex}.search-bar{gap:6px;display:flex}#uid-input{border:1px solid var(--border);background:var(--surface);color:#666;width:180px;font-size:.75rem;font-family:var(--mono);text-overflow:ellipsis;white-space:nowrap;border-radius:6px;outline:none;padding:7px 10px;transition:all .2s;overflow:hidden}#uid-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);color:#fff}#uid-input::placeholder{color:#555}#fetch-btn{background:var(--accent);color:#000;cursor:pointer;border:none;border-radius:6px;padding:7px 14px;font-size:.75rem;font-weight:700;transition:opacity .2s}#fetch-btn:hover{opacity:.85}.switch-btn{border:1px solid var(--accent-border);background:var(--accent-dim);color:var(--accent);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;transition:all .2s;display:flex}.switch-btn:hover{background:#00ff4140}.switch-icon{image-rendering:pixelated}.dashboard{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:16px;padding:10px 14px}.dashboard-summary{align-items:center;gap:10px;margin-bottom:6px;display:flex}.player-name{font-family:var(--mono);color:var(--accent);font-size:.85rem;font-weight:700}.dash-inline{font-family:var(--mono);color:#888;margin-left:auto;font-size:.75rem}.dash-inline .accent{color:var(--accent);font-weight:700}.dash-toggle{color:#666;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px;font-size:.6rem;transition:transform .2s}.dash-toggle.open{transform:rotate(180deg)}.progress-bar{background:var(--border);border-radius:2px;height:3px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .5s}.dashboard-detail{max-height:0;padding-top:0;transition:max-height .25s,padding .25s;overflow:hidden}.dashboard-detail.open{max-height:80px;padding-top:8px}.dash-row{justify-content:space-between;gap:8px;display:flex}.dash-item{color:#666;text-align:center;flex:1;font-size:.7rem}.dash-val{font-family:var(--mono);color:#ccc;font-weight:700}.dash-val.accent{color:var(--accent)}.dash-val.danger{color:var(--danger)}.filter-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:wrap;gap:6px;margin-bottom:20px;padding-bottom:2px;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-btn{border:1px solid var(--border);background:var(--surface);color:#aaa;cursor:pointer;white-space:nowrap;border-radius:14px;flex-shrink:0;padding:4px 12px;font-size:.75rem;transition:all .2s}.filter-btn:hover{border-color:var(--accent-border);color:#fff}.filter-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.city-section{border:1px solid var(--border);border-radius:10px;margin-bottom:16px;overflow:hidden}.city-header{cursor:pointer;background:var(--surface);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:14px;transition:background .15s;display:flex}.city-header:hover{background:#ffffff08}.city-toggle{color:#666;flex-shrink:0;font-size:.6rem;transition:transform .2s}.city-section:not(.collapsed) .city-toggle{transform:rotate(90deg)}.city-header h2{color:#e0e0e0;flex:1;margin:0;font-size:.9rem;font-weight:600}.city-content{padding:10px 12px 14px;transition:max-height .3s,padding .3s;overflow:hidden}.city-section.collapsed .city-content{max-height:0;padding:0 12px}.city-code{font-family:var(--mono);color:#666;background:var(--surface);border-radius:4px;padding:2px 8px;font-size:.8rem}.count{color:var(--accent);font-size:.7rem;font-weight:400;font-family:var(--mono);flex-shrink:0;margin-left:auto}.invader-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;display:grid}.invader-tile{border:1px solid var(--border);background:var(--surface);border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:6px;transition:all .2s;display:flex;overflow:hidden}.invader-tile:hover{border-color:var(--accent-border);transform:translateY(-2px);box-shadow:0 4px 12px #00ff411a}.invader-tile.flashed{background:var(--accent-dim);border-color:var(--accent-border)}.invader-img{aspect-ratio:1;object-fit:cover;background:#000;border-radius:4px;width:100%}.invader-info{justify-content:space-between;width:100%;padding:2px 2px 0;display:flex}.invader-name{font-family:var(--mono);color:var(--accent);font-size:.65rem}.invader-points{font-family:var(--mono);color:#888;font-size:.65rem}.tab-bar{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:16px;padding:3px;display:flex;position:relative}.tab-btn{color:#666;cursor:pointer;z-index:1;background:0 0;border:none;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 4px;font-size:.75rem;font-weight:600;transition:color .2s;display:flex;position:relative}.tab-icon{justify-content:center;align-items:center;line-height:1;display:flex}.tab-invader,.px-icon{image-rendering:pixelated;vertical-align:middle}.px-apple{color:#ff375f}.px-gfit{color:#4285f4}.px-lock{color:#888}.px-runner{color:#f0ad4e}.how-to--other .how-to-header .px-icon,.how-to--other .how-to-header h3{color:var(--accent)}.tab-label{text-transform:uppercase;letter-spacing:.5px;font-size:.6rem}#bottom-nav{z-index:200;background:var(--bg);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);position:fixed;bottom:0;left:0;right:0}.tab-bar--bottom{background:0 0;border:none;border-radius:0;margin:0;padding:8px}.mobile-nav #app{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.ios .tab-bar--bottom{-webkit-backdrop-filter:blur(20px);background:#0a0a0fd9}.ios .tab-bar--bottom .tab-indicator{display:none}.ios .tab-bar--bottom .tab-btn.active{color:var(--accent)}.android .tab-bar--bottom{background:var(--surface);padding:0 8px;padding-bottom:max(0px, env(safe-area-inset-bottom));border-top:none;box-shadow:0 -2px 8px #0000004d}.android .tab-bar--bottom .tab-indicator{background:var(--accent);border:none;border-radius:0 0 3px 3px;height:3px;top:0;bottom:auto}.android .tab-bar--bottom .tab-btn{padding:12px 4px 8px;position:relative;overflow:hidden}.android .tab-bar--bottom .tab-btn:after{content:"";opacity:0;background:currentColor;border-radius:50%;transition:opacity .2s;position:absolute;inset:0}.android .tab-bar--bottom .tab-btn:active:after{opacity:.08}.android .tab-bar--bottom .tab-btn.active .tab-invader{color:var(--accent)}.android .tab-bar--bottom .tab-label{letter-spacing:.3px;font-size:.6rem;font-weight:500}.tab-btn.active{color:var(--accent)}.tab-btn:hover:not(.active){color:#aaa}.tab-indicator{background:var(--accent-dim);border:1px solid var(--accent-border);z-index:0;border-radius:8px;width:calc(33.3333% - 2px);transition:left .25s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;bottom:3px}.missed-upload{max-width:640px;margin:0 auto}.missed-upload h2{color:#e0e0e0;margin-bottom:12px;font-size:1.4rem}.missed-desc{color:#888;margin-bottom:28px}.how-to{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:24px;padding:20px 24px}.how-to--strava{background:#fc4c020a;border-color:#fc4c024d}.how-to--health{opacity:.7;transition:opacity .2s}.how-to--health:hover{opacity:1}.how-to-header{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.how-to-header>svg{flex-shrink:0}.how-to-header h3{color:#e0e0e0;margin:0;font-size:1rem}.how-to--strava .how-to-header h3,.how-to--strava .px-icon{color:#fc4c02}.how-to-badge{text-transform:uppercase;letter-spacing:.3px;color:#fc4c02;white-space:nowrap;background:#fc4c0226;border-radius:4px;padding:2px 6px;font-size:.55rem;font-weight:600}.how-to-badge--secondary{color:#888;background:#ffffff0f}.how-to h3{color:var(--accent);margin-bottom:0;font-size:1rem}.how-to ol{color:#bbb;margin:0;padding-left:20px;line-height:2}.how-to ol a{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.how-to--strava ol a{color:#fc4c02}.how-to ol strong{color:#e0e0e0}.how-to ol code{font-family:var(--mono);color:var(--accent);background:#00ff411a;border-radius:3px;padding:1px 6px;font-size:.85rem}.how-to-sub{color:#999;margin-bottom:14px;font-size:.85rem}.how-to-sub code{font-family:var(--mono);color:var(--accent);background:#00ff411a;border-radius:3px;padding:1px 6px;font-size:.8rem}.how-to-sources{flex-direction:column;gap:10px;display:flex}.source-item{color:#aaa;align-items:flex-start;gap:12px;padding:6px 0;font-size:.85rem;line-height:1.5;display:flex}.source-item .px-icon{flex-shrink:0;margin-top:2px}.source-item strong{color:#e0e0e0}.source-item a{color:var(--accent);text-underline-offset:2px;text-decoration:underline}.privacy-note{color:#777;justify-content:center;align-items:flex-start;gap:8px;margin:24px 0;font-size:.8rem;display:flex}.privacy-note .px-icon{flex-shrink:0;margin-top:2px}.upload-area{border:2px dashed var(--border);text-align:center;border-radius:12px;padding:32px;transition:all .2s}.upload-area.drag-over{border-color:var(--accent);background:var(--accent-dim)}.upload-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;display:flex}.radius-label{color:#888;font-size:.9rem}.radius-label select{border:1px solid var(--border);background:var(--surface);color:#e0e0e0;border-radius:6px;margin-left:4px;padding:6px 10px;font-size:.9rem}.upload-btn{background:var(--accent);color:#000;cursor:pointer;border-radius:8px;padding:10px 24px;font-weight:700;transition:opacity .2s;display:inline-block}.upload-btn:hover{opacity:.85}.upload-hint{color:#555;margin-top:12px;font-size:.85rem}.missed-summary{text-align:center;color:#bbb;margin-bottom:24px}.missed-summary strong{color:var(--accent)}.missed-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.missed-tile{background:var(--danger-dim)!important;border-color:#ff44444d!important}.missed-tile:hover{border-color:#f449!important;box-shadow:0 4px 12px #ff444426!important}.missed-distance{font-family:var(--mono);color:var(--danger);padding:8px 0 4px;font-size:1.4rem;font-weight:700}.missed-tile .invader-name{color:#ccc}.invader-status{font-family:var(--mono);border-radius:3px;padding:1px 4px;font-size:.6rem}.status-ok{color:var(--accent)}.status-damaged{color:#f0ad4e}.status-destroyed{color:var(--danger)}.missed-date{color:#666;font-size:.65rem;font-family:var(--mono)}.no-results{text-align:center;color:#888;padding:48px}.loading{text-align:center;color:var(--accent);font-family:var(--mono);padding:48px}.error{text-align:center;color:var(--danger);padding:48px}.route-planner{max-width:800px;margin:0 auto}.route-header{margin-bottom:20px}.route-header h2{color:#e0e0e0;margin-bottom:8px;font-size:1.4rem}.route-desc{color:#888;font-size:.9rem}.route-controls{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.route-undo-btn,.route-clear-btn{border:1px solid var(--border);background:var(--surface);color:#aaa;cursor:pointer;border-radius:6px;padding:6px 16px;font-size:.85rem;transition:all .2s}.route-undo-btn:hover{border-color:var(--accent-border);color:#fff}.route-clear-btn:hover{color:var(--danger);border-color:#f446}.route-search{margin-bottom:12px}.route-search-wrapper{width:100%;position:relative}#route-address{border:1px solid var(--border);background:var(--surface);color:#fff;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:.9rem;transition:border-color .2s}#route-address:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.route-suggestions{z-index:1000;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;max-height:220px;list-style:none;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.route-suggestion{color:#bbb;cursor:pointer;border-bottom:1px solid var(--border);padding:10px 14px;font-size:.85rem;line-height:1.4;transition:background .15s}.route-suggestion:last-child{border-bottom:none}.route-suggestion:hover{background:var(--accent-dim);color:#fff}#route-map{border:1px solid var(--border);z-index:0;border-radius:12px;height:450px;overflow:hidden}.route-stats{justify-content:center;gap:16px;margin-top:20px;display:flex}.route-stat{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:12px;min-width:120px;padding:16px 28px}.route-stat-number{font-size:1.8rem;font-weight:700;font-family:var(--mono);display:block}.route-stat-number.flashed{color:var(--accent)}.route-stat-number.missed{color:var(--danger)}.route-stat-number.total{color:#888}.route-stat-label{color:#888;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.route-hint{text-align:center;color:#555;margin-top:12px;font-size:.8rem}.route-generate-btn{color:#ff8c00;cursor:pointer;background:linear-gradient(135deg,#ff8c0026,#ffa50040);border:2px solid #ff8c00;border-radius:8px;align-items:center;gap:6px;padding:8px 20px;font-size:.95rem;font-weight:700;transition:all .2s;display:inline-flex}.route-generate-btn svg{width:18px;height:14px}.route-generate-btn:hover{color:orange;background:linear-gradient(135deg,#ff8c0040,#ffa50059);border-color:orange;transform:scale(1.03)}.auto-route-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:12px;padding:14px}.auto-route-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.auto-route-row:last-of-type{margin-bottom:0}.auto-route-start-btn{border:1px solid var(--border);background:var(--bg);color:#aaa;cursor:pointer;border-radius:6px;padding:6px 14px;font-size:.8rem;transition:all .2s}.auto-route-start-btn:hover{color:#ff8c00;border-color:#ff8c0066}.auto-route-start-label{color:#ff8c00;font-size:.8rem}.auto-route-panel .radius-label{color:#aaa;align-items:center;gap:8px;font-size:.85rem;display:flex}.dist-step-btn{background:var(--surface);color:#ff8c00;cursor:pointer;-webkit-tap-highlight-color:transparent;border:1px solid #ff8c0066;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;font-weight:700;transition:all .15s;display:inline-flex}.dist-step-btn:active{background:#ff8c0033;transform:scale(.95)}.dist-value{text-align:center;min-width:50px}#auto-route-distance-label{color:#ff8c00;min-width:40px;font-weight:600}.auto-route-go-btn{color:#ff8c00;cursor:pointer;background:#ff8c0026;border:1px solid #ff8c00;border-radius:6px;padding:8px 20px;font-size:.85rem;font-weight:600;transition:all .2s}.auto-route-go-btn:hover:not(:disabled){background:#ff8c0040}.auto-route-go-btn:disabled{opacity:.4;cursor:not-allowed}.auto-route-msg{color:#ff8c00;margin:8px 0 0;font-size:.8rem}.route-export{text-align:center;margin-top:12px}.route-export-btn{border:1px solid var(--border);background:var(--surface);color:#aaa;cursor:pointer;border-radius:6px;padding:8px 24px;font-size:.85rem;transition:all .2s}.route-export-btn:hover:not(:disabled){border-color:var(--accent-border);color:var(--accent)}.route-export-btn:disabled{opacity:.3;cursor:not-allowed}.empty-state{text-align:center;max-width:440px;margin:0 auto;padding:40px 20px}.empty-invader{margin-bottom:20px}.empty-invader svg{width:64px;height:48px;color:var(--accent);opacity:.7}.empty-state h2{color:#fff;margin:0 0 12px;font-size:1.4rem;font-weight:700}.empty-state>p{color:#888;margin:0 0 24px;font-size:.9rem;line-height:1.5}.empty-steps{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.empty-step{border:1px solid var(--border);background:var(--surface);text-align:left;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;display:flex}.empty-step-icon{color:var(--accent);opacity:.8;flex-shrink:0}.empty-step-text{color:#ccc;font-size:.85rem}.empty-hint{color:#555;font-size:.8rem}@media (width<=640px){input[type=text],input[type=search],input[type=email],input[type=url],input[type=number],select,textarea{font-size:16px!important}#app{padding:10px}.topbar{margin-bottom:8px;padding:8px 0}.topbar h1{font-size:1rem}#uid-input{width:120px;padding:5px 8px}#fetch-btn{padding:6px 10px;font-size:.7rem}.dashboard{margin-bottom:8px;padding:8px 10px}.player-name{font-size:.8rem}.dash-inline{font-size:.7rem}.tab-bar{margin-bottom:12px}.tab-icon{font-size:1rem}.tab-label{font-size:.6rem}.filter-bar{gap:4px;margin-bottom:16px}.filter-btn{padding:4px 10px;font-size:.7rem}.invader-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:6px}.route-header h2{font-size:1.1rem}.route-desc{font-size:.8rem}.route-controls{gap:6px}.route-undo-btn,.route-clear-btn,.route-generate-btn{padding:5px 10px;font-size:.75rem}#route-map{height:300px}.route-stats{gap:6px;margin-top:12px}.route-stat{flex:1;min-width:0;padding:10px 8px}.route-stat-number{font-size:1.2rem}.route-stat-label{font-size:.65rem}.missed-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.missed-upload h2{font-size:1.1rem}.how-to{padding:14px 16px}}
