@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{visibility:visible;background:#1a1a1a;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}#map{width:100%;height:100dvh}.header{z-index:31;-webkit-backdrop-filter:blur(12px);color:#fff;pointer-events:none;background:#141414cc;border:1px solid #ffffff14;border-radius:12px;align-items:center;padding:12px 16px;display:flex;position:absolute;top:12px;left:12px;right:12px}.ws-badge{letter-spacing:1px;color:#ffffff80;pointer-events:auto;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-flex}.header-type-select{appearance:none;color:#fff;cursor:pointer;pointer-events:auto;text-align:center;background:url("data:image/svg+xml,%3Csvg fill%3D%22rgba(255%2C255%2C255%2C0.5)%22 viewBox%3D%220 0 24 24%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath d%3D%22M7 10l5 5 5-5z%22%2F%3E%3C%2Fsvg%3E") right 6px center/20px no-repeat;border:none;border-bottom:1px solid #fff3;border-radius:0;outline:none;margin:0 auto;padding:4px 32px 4px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .2s,border-color .2s}.header-type-select:hover{border-bottom-color:#fff6}.header-type-select option{color:#fff;background:#1a1a1a}.ws-dot{background:#ffffff80;border-radius:50%;width:8px;height:8px;transition:background .3s}.ws-dot.connected{background:#4caf50;animation:2s ease-in-out infinite glow-pulse;box-shadow:0 0 6px #4caf5080}.ws-dot.connecting{background:#ff9800}.header-sep{background:#ffffff1f;width:1px;height:20px}.ws-badge.tappable{cursor:pointer}.ws-badge.tappable:active{opacity:.7}@keyframes glow-pulse{0%,to{box-shadow:0 0 6px #4caf5080}50%{box-shadow:0 0 12px #4caf50b3}}.side-panel{z-index:31;pointer-events:none;flex-direction:column;gap:12px;width:280px;display:flex;position:absolute;top:70px;bottom:12px;left:12px}.side-panel>*{pointer-events:auto}.panel-logout{color:#fff6;cursor:pointer;text-align:center;z-index:20;background:#141414eb;border:1px solid #ffffff12;border-radius:10px;flex-shrink:0;width:100%;padding:10px 16px;font-family:inherit;font-size:12px;transition:color .2s,background .2s;position:relative}.panel-logout:hover{color:#ffffffb3;background:#1e1e1ef2}.panel-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#141414eb;border:1px solid #ffffff12;border-radius:12px;overflow:hidden}.feed-card{flex-direction:column;flex:1;min-height:0;display:flex}.feed-list{flex:1;padding:8px;overflow-y:auto}.feed-list::-webkit-scrollbar{width:4px}.feed-list::-webkit-scrollbar-track{background:0 0}.feed-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.feed-item{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;transition:background .2s;display:flex}.feed-item:hover{background:#ffffff0d}.feed-item.new{background:#ffffff0a;animation:.4s ease-out feed-slide-in}@keyframes feed-slide-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.feed-item.active{background:#ffffff14;border-left:2px solid #ffffff80;padding-left:8px}.feed-item.active .feed-marker{background:#ff1744;border-color:#ff17444d}.feed-item.active .feed-name{color:#fff}.feed-marker{background:#00b0ff;border:2px solid #00b0ff4d;border-radius:50%;flex-shrink:0;width:10px;height:10px}.feed-info{flex:1;min-width:0}.feed-name{color:#ffffffd9;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.feed-meta{color:#ffffff4d;text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-family:JetBrains Mono,monospace;font-size:10px;overflow:hidden}.feed-context{color:#ffffff2e;word-break:break-all;margin-top:1px;font-family:JetBrains Mono,monospace;font-size:10px}.feed-dates{color:#ffffff59;white-space:pre-line;margin-top:2px;font-family:JetBrains Mono,monospace;font-size:10px}.type-overlay{z-index:100;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);opacity:1;background:#141414f2;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.type-overlay.hidden{opacity:0;pointer-events:none}.type-picker{text-align:center;width:100%;max-width:480px;padding:0 24px}.type-picker-logo{margin-bottom:24px}.type-picker-icon{width:56px;height:56px;box-shadow:none;background:#ffffff1a;border-radius:16px;justify-content:center;align-items:center;margin-bottom:20px;font-size:28px;display:inline-flex}.type-picker h2{color:#fff;margin-bottom:6px;font-size:22px;font-weight:600}.type-picker p{color:#fff6;margin-bottom:28px;font-size:13px}.toast{z-index:20;pointer-events:none;color:#fff;opacity:0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1e1e1ef2;border:1px solid #ffffff1f;border-radius:10px;align-items:center;gap:8px;padding:12px 18px;font-size:12px;font-weight:500;transition:all .35s cubic-bezier(.16,1,.3,1);display:flex;position:absolute;bottom:24px;right:20px;transform:translateY(12px);box-shadow:0 8px 32px #0006}.toast:before{content:"";background:#4caf50;border-radius:50%;flex-shrink:0;width:6px;height:6px;box-shadow:0 0 6px #4caf5066}.toast.show{opacity:1;transform:translateY(0)}.entity-count{z-index:20;pointer-events:none;color:#ffffffb3;white-space:nowrap;opacity:0;background:#1e1e1ee6;border:1px solid #ffffff1f;border-radius:12px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:11px;transition:opacity .3s;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.entity-count.visible{opacity:1}.loading-indicator{z-index:15;pointer-events:none;opacity:0;flex-direction:column;align-items:center;gap:12px;transition:opacity .3s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loading-indicator.visible{opacity:1}.loading-spinner{border:2.5px solid #ffffff1a;border-top-color:#ffffff80;border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}.loading-text{color:#fff6;letter-spacing:1px;font-family:JetBrains Mono,monospace;font-size:11px}@keyframes spin{to{transform:rotate(360deg)}}.bottom-sheet{z-index:30;will-change:transform;background:#2a2a2a;border-top-left-radius:16px;border-top-right-radius:16px;flex-direction:column;max-height:60vh;transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;bottom:0;left:304px;right:0;transform:translateY(100%);box-shadow:0 -4px 32px #0009}.bottom-sheet.open{transform:translateY(0)}.bottom-sheet-handle{background:#fff3;border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:10px auto 0}.bottom-sheet-close{color:#fff6;cursor:pointer;z-index:1;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;transition:background .2s,color .2s;display:flex;position:absolute;top:8px;right:12px}.bottom-sheet-close:hover{color:#fff;background:#ffffff1a}.bottom-sheet-header{border-bottom:1px solid #ffffff0f;flex-shrink:0;padding:12px 20px 8px}.bottom-sheet-body{-webkit-overflow-scrolling:touch;flex:1;padding:12px 20px 20px;overflow-y:auto}.bottom-sheet-body::-webkit-scrollbar{width:4px}.bottom-sheet-body::-webkit-scrollbar-track{background:0 0}.bottom-sheet-body::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}@media (prefers-reduced-motion:reduce){.bottom-sheet,.bottom-sheet-overlay{transition:none}}.bottom-sheet-overlay{z-index:29;opacity:0;pointer-events:none;background:#0000004d;transition:opacity .3s;position:fixed;inset:0}.bottom-sheet-overlay.visible{opacity:1;pointer-events:auto}.login-overlay{z-index:200;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);opacity:1;background:#141414fa;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.login-overlay.hidden{opacity:0;pointer-events:none}.login-box{text-align:center;width:100%;max-width:400px;padding:0 24px}.login-box h2{color:#fff;margin-bottom:6px;font-size:22px;font-weight:600}.login-box p{color:#fff6;margin-bottom:24px;font-size:13px}.login-field{color:#fff;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;outline:none;width:100%;margin-bottom:12px;padding:12px 16px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s;display:block}.login-field:focus{border-color:#ffffff4d}.login-field::placeholder{color:#ffffff40}.login-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #fff3;border-radius:10px;width:100%;margin-top:4px;padding:12px 20px;font-size:14px;font-weight:600;transition:background .2s}.login-btn:hover{background:#ffffff2e}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{color:#ff5252;min-height:18px;margin-top:12px;font-size:12px}.logout-btn{pointer-events:auto;color:#ffffff80;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;margin-left:auto;padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:11px;transition:background .2s,color .2s}.logout-btn:hover{color:#ff5252;background:#ff525226;border-color:#ff52524d}#type-input option{color:#fff;background:#1a1a1a}.type-form{align-items:center;gap:8px;margin-top:8px;padding:0 8px;display:flex}.type-form .login-field{margin-bottom:0}.type-form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg fill%3D%22rgba(255%2C255%2C255%2C0.4)%22 viewBox%3D%220 0 24 24%22 xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath d%3D%22M7 10l5 5 5-5z%22%2F%3E%3C%2Fsvg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:20px}.type-form-submit{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff1f;border:1px solid #fff3;border-radius:10px;padding:12px 20px;font-size:14px;font-weight:600;transition:background .2s}.type-form-submit:hover{background:#ffffff2e}.error-icon{background:linear-gradient(135deg,#ff5252 0%,#d32f2f 100%);box-shadow:0 0 40px #ff525240}.back-link{color:#fff;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;margin-top:20px;padding:10px 24px;font-size:13px;text-decoration:none;transition:background .2s;display:inline-block}.back-link:hover{background:#ffffff1a}.overlay-logout{color:#ffffff59;margin-top:20px;font-size:12px;text-decoration:none;transition:color .2s;display:inline-block}.overlay-logout:hover{color:#ff5252}.maplibregl-ctrl-top-right{top:80px!important}.compass-btn{padding:0;cursor:pointer!important;background:#fff!important;border:none!important;border-radius:50%!important;justify-content:center!important;align-items:center!important;width:44px!important;height:44px!important;display:flex!important;box-shadow:0 2px 8px #0006!important}.compass-btn:hover{background:#f0f0f0!important}.compass-btn svg{transition:transform .15s}.maplibregl-ctrl-group{box-shadow:none!important;background:0 0!important;border:none!important}.maplibregl-ctrl-geolocate{cursor:pointer!important;background:#fff!important;border:none!important;border-radius:50%!important;justify-content:center!important;align-items:center!important;width:44px!important;height:44px!important;display:flex!important;box-shadow:0 2px 8px #0006!important}.maplibregl-ctrl-geolocate:hover{background:#f0f0f0!important}.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon{width:100%;height:100%;position:relative;background-image:none!important}.maplibregl-ctrl-geolocate .maplibregl-ctrl-icon:after{content:"";background-color:#333;width:24px;height:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='5' fill='currentColor'/%3E%3Ccircle cx='12' cy='12' r='9' fill='none' stroke='currentColor' stroke-width='2.5'/%3E%3Cline x1='12' y1='0' x2='12' y2='5' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='12' y1='19' x2='12' y2='24' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='0' y1='12' x2='5' y2='12' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='19' y1='12' x2='24' y2='12' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='5' fill='currentColor'/%3E%3Ccircle cx='12' cy='12' r='9' fill='none' stroke='currentColor' stroke-width='2.5'/%3E%3Cline x1='12' y1='0' x2='12' y2='5' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='12' y1='19' x2='12' y2='24' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='0' y1='12' x2='5' y2='12' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3Cline x1='19' y1='12' x2='24' y2='12' stroke='currentColor' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E");-webkit-mask-size:contain;mask-size:contain}.maplibregl-ctrl-geolocate.maplibregl-ctrl-geolocate-active .maplibregl-ctrl-icon:after{background-color:#4285f4}.panel-toggle{display:none}@media (width<=768px){.header{padding:12px;top:8px;left:8px;right:8px}.header-type-select{margin:0;font-size:13px;position:absolute;left:50%;transform:translate(-50%)}.header-sep{display:none}.panel-toggle{color:#fff;cursor:pointer;pointer-events:auto;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;margin-left:auto;font-size:18px;transition:background .2s;display:flex}.panel-toggle:hover{background:#fff3}.side-panel{-webkit-backdrop-filter:none;backdrop-filter:none;pointer-events:auto;z-index:31;background:0 0;width:300px;padding:70px 12px 16px;transition:transform .3s cubic-bezier(.16,1,.3,1);top:0;bottom:0;left:0;transform:translate(-100%)}.side-panel.open{transform:translate(0)}.side-panel>*{pointer-events:auto}.panel-overlay{z-index:9;opacity:0;pointer-events:none;background:#0006;transition:opacity .3s;position:fixed;inset:0}.panel-overlay.visible{opacity:1;pointer-events:auto}.bottom-sheet{left:0}.toast{bottom:24px;left:16px;right:16px}}
