*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-color, #f9fafb);color:var(--text-color, #1f2937);line-height:1.5}#app{width:100%;height:100%;display:flex;flex-direction:column}a{color:var(--primary-color, #3b82f6);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}:focus-visible{outline:2px solid var(--primary-color, #3b82f6);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-color, #d1d5db);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-hover, #9ca3af)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#4b5563}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#6b7280}.app-header.svelte-65ig37{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:56px;background:var(--header-bg, #1f2937);color:var(--header-text, #fff);box-shadow:0 2px 4px #0000001a;z-index:100;flex-shrink:0}.header-left.svelte-65ig37,.header-center.svelte-65ig37,.header-right.svelte-65ig37{display:flex;align-items:center;gap:8px}.header-center.svelte-65ig37{position:absolute;left:50%;transform:translate(-50%)}.logo.svelte-65ig37{display:flex;align-items:center}.logo-img.svelte-65ig37{height:32px;width:auto}.connection-status.svelte-65ig37{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:16px;background:#ffffff1a;font-size:12px}.status-dot.svelte-65ig37{width:8px;height:8px;border-radius:50%;background:#ef4444}.connection-status.connected.svelte-65ig37 .status-dot:where(.svelte-65ig37){background:#22c55e}.connection-status.connecting.svelte-65ig37 .status-dot:where(.svelte-65ig37){background:#f59e0b;animation:svelte-65ig37-pulse 1s infinite}@keyframes svelte-65ig37-pulse{0%,to{opacity:1}50%{opacity:.5}}.header-btn.svelte-65ig37{display:flex;align-items:center;gap:4px;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:inherit;cursor:pointer;font-size:14px;text-decoration:none;transition:background .2s}.header-btn.svelte-65ig37:hover{background:#ffffff1a}.header-btn.active.svelte-65ig37{background:#3b82f64d}.btn-icon.svelte-65ig37{font-size:18px}.btn-count.svelte-65ig37{font-size:12px;font-weight:600;padding:2px 6px;background:#fff3;border-radius:10px}.btn-label.svelte-65ig37{font-size:14px}.badge.svelte-65ig37{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;background:#ef4444;border-radius:9px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center}.header-btn.svelte-65ig37:has(.badge:where(.svelte-65ig37)){position:relative}.user-menu.svelte-65ig37{display:flex;align-items:center;gap:8px;margin-left:8px;padding-left:8px;border-left:1px solid rgba(255,255,255,.2)}.user-name.svelte-65ig37{font-size:13px;opacity:.9;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-nav.svelte-65ig37{display:none;align-items:center;gap:4px}.mobile-btn.svelte-65ig37{padding:8px 10px}.menu-toggle.svelte-65ig37{padding:8px 12px}.mobile-menu-overlay.svelte-65ig37{position:fixed;inset:56px 0 0;background:#00000080;z-index:99}.mobile-menu.svelte-65ig37{position:fixed;top:56px;right:0;width:280px;max-width:80vw;background:var(--panel-bg, #ffffff);box-shadow:-4px 0 20px #0003;z-index:100;padding:8px 0;max-height:calc(100vh - 56px);overflow-y:auto}.mobile-menu-item.svelte-65ig37{display:flex;align-items:center;gap:12px;width:100%;padding:14px 20px;border:none;background:none;color:var(--text-color, #1f2937);font-size:15px;cursor:pointer;text-align:left;text-decoration:none;transition:background .2s}.mobile-menu-item.svelte-65ig37:hover{background:var(--card-bg, #f9fafb)}.mobile-menu-item.active.svelte-65ig37{background:#3b82f61a;color:var(--primary-color, #3b82f6)}.mobile-menu-item.logout.svelte-65ig37{color:#ef4444}.menu-icon.svelte-65ig37{font-size:20px;width:24px;text-align:center}.menu-divider.svelte-65ig37{margin:8px 16px;border:none;border-top:1px solid var(--border-color, #e5e7eb)}.mobile-menu-user.svelte-65ig37{padding:12px 20px;font-size:14px;color:var(--text-secondary, #6b7280)}.user-info.svelte-65ig37{font-weight:500;color:var(--text-color, #1f2937)}[data-theme=dark] .mobile-menu.svelte-65ig37{background:#1f2937}[data-theme=dark] .mobile-menu-item.svelte-65ig37{color:#f9fafb}[data-theme=dark] .mobile-menu-item.svelte-65ig37:hover{background:#374151}@media(max-width:900px){.btn-label.svelte-65ig37{display:none}}@media(max-width:768px){.desktop-nav.svelte-65ig37{display:none}.mobile-nav.svelte-65ig37{display:flex}.header-center.svelte-65ig37{position:static;transform:none}.status-text.svelte-65ig37{display:none}.connection-status.svelte-65ig37{padding:4px 8px}}@media(max-width:480px){.app-header.svelte-65ig37{padding:0 8px}.logo-img.svelte-65ig37{height:28px}}.loading-overlay.svelte-8gee6e{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:500}.loading-overlay.fullscreen.svelte-8gee6e{position:fixed;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}[data-theme=dark] .loading-overlay.svelte-8gee6e:not(.fullscreen){background:#1f2937cc}.loading-content.svelte-8gee6e{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner.svelte-8gee6e{width:48px;height:48px;color:var(--primary-color, #3b82f6)}.spinner.svelte-8gee6e svg:where(.svelte-8gee6e){animation:svelte-8gee6e-rotate 1.5s linear infinite}.spinner.svelte-8gee6e circle:where(.svelte-8gee6e){stroke-dasharray:90,150;stroke-dashoffset:0;animation:svelte-8gee6e-dash 1.5s ease-in-out infinite}@keyframes svelte-8gee6e-rotate{to{transform:rotate(360deg)}}@keyframes svelte-8gee6e-dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.dots.svelte-8gee6e{display:flex;gap:8px}.dots.svelte-8gee6e span:where(.svelte-8gee6e){width:12px;height:12px;background:var(--primary-color, #3b82f6);border-radius:50%;animation:svelte-8gee6e-bounce 1.4s ease-in-out infinite both}.dots.svelte-8gee6e span:where(.svelte-8gee6e):nth-child(1){animation-delay:-.32s}.dots.svelte-8gee6e span:where(.svelte-8gee6e):nth-child(2){animation-delay:-.16s}@keyframes svelte-8gee6e-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.ring.svelte-8gee6e{width:48px;height:48px;border:4px solid rgba(59,130,246,.2);border-top-color:var(--primary-color, #3b82f6);border-radius:50%;animation:svelte-8gee6e-rotate 1s linear infinite}.loading-message.svelte-8gee6e{margin:0;font-size:14px;color:var(--text-secondary, #6b7280);text-align:center;max-width:200px}.fullscreen.svelte-8gee6e .loading-message:where(.svelte-8gee6e){color:#fff}.map-container.svelte-lnszi{width:100%;height:100%;position:relative}.maplibregl-popup-content{border-radius:8px;box-shadow:0 2px 10px #0003}.maplibregl-popup-close-button{font-size:18px;padding:4px 8px}[data-theme=dark] .maplibregl-popup-content{background:#1f2937;color:#f9fafb}[data-theme=dark] .maplibregl-popup-tip{border-top-color:#1f2937}.layers-panel.svelte-1kqbidh{position:absolute;top:60px;right:12px;width:280px;max-height:calc(100vh - 120px);background:var(--panel-bg, #fff);border-radius:12px;box-shadow:0 4px 20px #00000026;overflow:hidden;display:flex;flex-direction:column;z-index:50}.panel-header.svelte-1kqbidh{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.panel-header.svelte-1kqbidh h3:where(.svelte-1kqbidh){margin:0;font-size:16px;font-weight:600}.btn-close.svelte-1kqbidh{background:none;border:none;font-size:18px;color:var(--text-secondary, #6b7280);cursor:pointer;padding:4px;line-height:1}.btn-close.svelte-1kqbidh:hover{color:var(--text-primary, #1f2937)}.panel-content.svelte-1kqbidh{padding:12px 16px;overflow-y:auto;flex:1}.control-group.svelte-1kqbidh{margin-bottom:16px}.control-group.svelte-1kqbidh h4:where(.svelte-1kqbidh){margin:0 0 8px;font-size:13px;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.5px}.group-header.svelte-1kqbidh{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;margin-bottom:8px;background:none;border:none;cursor:pointer;text-align:left}.group-header.svelte-1kqbidh h4:where(.svelte-1kqbidh){margin:0}.toggle-icon.svelte-1kqbidh{font-size:10px;transition:transform .2s;color:var(--text-secondary, #6b7280)}.toggle-icon.expanded.svelte-1kqbidh{transform:rotate(180deg)}.layer-group.svelte-1kqbidh{padding-left:8px}.layer-category.svelte-1kqbidh{margin-bottom:12px}.layer-category.svelte-1kqbidh h5:where(.svelte-1kqbidh){margin:0 0 6px;font-size:12px;font-weight:500;color:var(--text-secondary, #6b7280)}.layer-toggle.svelte-1kqbidh{display:flex;align-items:center;gap:8px;padding:4px 0;cursor:pointer;font-size:13px}.layer-toggle.svelte-1kqbidh input[type=checkbox]:where(.svelte-1kqbidh){width:16px;height:16px;cursor:pointer;accent-color:var(--primary-color, #3b82f6)}.layer-toggle.svelte-1kqbidh span:where(.svelte-1kqbidh){color:var(--text-primary, #1f2937)}.layer-toggle.svelte-1kqbidh span.disabled:where(.svelte-1kqbidh){color:var(--text-secondary, #9ca3af)}.layer-toggle.svelte-1kqbidh span:where(.svelte-1kqbidh) small:where(.svelte-1kqbidh){font-size:10px;opacity:.7}.slider-control.svelte-1kqbidh{margin:8px 0 8px 24px;padding:8px 12px;background:var(--card-bg, #f9fafb);border-radius:6px}.slider-control.svelte-1kqbidh label:where(.svelte-1kqbidh){display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary, #6b7280);margin-bottom:6px}.slider-value.svelte-1kqbidh{font-weight:500;color:var(--text-primary, #1f2937)}.slider-control.svelte-1kqbidh input[type=range]:where(.svelte-1kqbidh){width:100%;height:4px;cursor:pointer;accent-color:var(--primary-color, #3b82f6)}[data-theme=dark] .layers-panel.svelte-1kqbidh{--panel-bg: #1f2937;--border-color: #374151;--text-primary: #f9fafb;--text-secondary: #9ca3af}@media(max-width:480px){.layers-panel.svelte-1kqbidh{position:fixed;inset:auto 0 0;width:100%;max-height:60vh;border-radius:16px 16px 0 0}}.notifications-panel.svelte-1kjzn7a{position:absolute;top:60px;right:12px;width:360px;max-height:calc(100vh - 120px);background:var(--panel-bg, #fff);border-radius:12px;box-shadow:0 4px 20px #00000026;overflow:hidden;display:flex;flex-direction:column;z-index:60}.panel-header.svelte-1kjzn7a{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.header-left.svelte-1kjzn7a{display:flex;align-items:center;gap:8px}.panel-header.svelte-1kjzn7a h3:where(.svelte-1kjzn7a){margin:0;font-size:16px;font-weight:600}.unread-badge.svelte-1kjzn7a{background:#ef4444;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px}.header-actions.svelte-1kjzn7a{display:flex;align-items:center;gap:8px}.btn-mark-read.svelte-1kjzn7a{background:none;border:none;color:var(--primary-color, #3b82f6);font-size:13px;cursor:pointer;padding:4px 8px;border-radius:4px}.btn-mark-read.svelte-1kjzn7a:hover{background:#3b82f61a}.btn-close.svelte-1kjzn7a{background:none;border:none;font-size:18px;color:var(--text-secondary, #6b7280);cursor:pointer;padding:4px;line-height:1}.panel-content.svelte-1kjzn7a{flex:1;overflow-y:auto}.empty-state.svelte-1kjzn7a{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-secondary, #6b7280)}.empty-icon.svelte-1kjzn7a{font-size:48px;margin-bottom:12px;opacity:.5}.empty-state.svelte-1kjzn7a p:where(.svelte-1kjzn7a){margin:0;font-size:14px}.notifications-list.svelte-1kjzn7a{padding:8px 0}.notification-item.svelte-1kjzn7a{display:flex;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;position:relative}.notification-item.svelte-1kjzn7a:hover{background:var(--hover-bg, #f9fafb)}.notification-item.unread.svelte-1kjzn7a{background:#3b82f60d}.notification-item.unread.svelte-1kjzn7a:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-color, #3b82f6)}.notification-icon.svelte-1kjzn7a{font-size:24px;flex-shrink:0;width:32px;text-align:center}.notification-content.svelte-1kjzn7a{flex:1;min-width:0}.notification-title.svelte-1kjzn7a{font-weight:600;font-size:14px;margin-bottom:2px;color:var(--text-primary, #1f2937)}.notification-body.svelte-1kjzn7a{font-size:13px;color:var(--text-secondary, #6b7280);line-height:1.4;margin-bottom:4px}.notification-time.svelte-1kjzn7a{font-size:11px;color:var(--text-tertiary, #9ca3af)}.batch-toggle.svelte-1kjzn7a{background:none;border:none;color:var(--primary-color, #3b82f6);font-size:12px;cursor:pointer;padding:4px 0}.batch-entries.svelte-1kjzn7a{margin-top:8px;padding-left:12px;border-left:2px solid var(--border-color, #e5e7eb)}.batch-entry.svelte-1kjzn7a{font-size:12px;color:var(--text-secondary, #6b7280);padding:2px 0}.btn-dismiss.svelte-1kjzn7a{background:none;border:none;color:var(--text-tertiary, #9ca3af);font-size:14px;cursor:pointer;padding:4px;opacity:0;transition:opacity .15s}.notification-item.svelte-1kjzn7a:hover .btn-dismiss:where(.svelte-1kjzn7a){opacity:1}.btn-dismiss.svelte-1kjzn7a:hover{color:var(--text-secondary, #6b7280)}[data-theme=dark] .notifications-panel.svelte-1kjzn7a{--panel-bg: #1f2937;--border-color: #374151;--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--hover-bg: #374151}@media(max-width:480px){.notifications-panel.svelte-1kjzn7a{position:fixed;inset:auto 0 0;width:100%;max-height:70vh;border-radius:16px 16px 0 0}}.athletes-panel.svelte-oyqtxm{position:absolute;top:60px;right:12px;width:320px;max-height:calc(100vh - 120px);background:var(--panel-bg, #fff);border-radius:12px;box-shadow:0 4px 20px #00000026;overflow:hidden;display:flex;flex-direction:column;z-index:50}.panel-header.svelte-oyqtxm{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.panel-header.svelte-oyqtxm h3:where(.svelte-oyqtxm){margin:0;font-size:16px;font-weight:600}.btn-close.svelte-oyqtxm{background:none;border:none;font-size:18px;color:var(--text-secondary, #6b7280);cursor:pointer;padding:4px}.panel-filters.svelte-oyqtxm{padding:12px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.search-input.svelte-oyqtxm{width:100%;padding:8px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:14px;background:var(--input-bg, #fff);color:var(--text-primary, #1f2937)}.search-input.svelte-oyqtxm:focus{outline:none;border-color:var(--primary-color, #3b82f6)}.filter-row.svelte-oyqtxm{display:flex;gap:8px;margin-top:8px}.time-select.svelte-oyqtxm,.sort-select.svelte-oyqtxm{flex:1;padding:6px 10px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:13px;background:var(--input-bg, #fff);color:var(--text-primary, #1f2937);cursor:pointer}.panel-content.svelte-oyqtxm{flex:1;overflow-y:auto}.empty-state.svelte-oyqtxm{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-secondary, #6b7280)}.empty-icon.svelte-oyqtxm{font-size:48px;margin-bottom:12px;opacity:.5}.athletes-list.svelte-oyqtxm{padding:8px 0}.athlete-item.svelte-oyqtxm{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .15s}.athlete-item.svelte-oyqtxm:hover{background:var(--hover-bg, #f9fafb)}.athlete-item.selected.svelte-oyqtxm{background:#3b82f61a}.athlete-status.svelte-oyqtxm{width:10px;height:10px;border-radius:50%;flex-shrink:0}.athlete-info.svelte-oyqtxm{flex:1;min-width:0}.athlete-name.svelte-oyqtxm{font-weight:600;font-size:14px;color:var(--text-primary, #1f2937);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.athlete-stats.svelte-oyqtxm{display:flex;gap:12px;margin-top:2px}.stat.svelte-oyqtxm{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-secondary, #6b7280)}.stat-icon.svelte-oyqtxm{font-size:11px}.athlete-meta.svelte-oyqtxm{display:flex;gap:8px;margin-top:4px;font-size:11px}.status-label.svelte-oyqtxm,.update-time.svelte-oyqtxm{color:var(--text-tertiary, #9ca3af)}.athlete-actions.svelte-oyqtxm{flex-shrink:0}.btn-track.svelte-oyqtxm{background:none;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:14px;transition:all .15s}.btn-track.svelte-oyqtxm:hover{background:var(--hover-bg, #f9fafb)}.btn-track.active.svelte-oyqtxm{background:#22c55e1a;border-color:#22c55e;color:#22c55e}[data-theme=dark] .athletes-panel.svelte-oyqtxm{--panel-bg: #1f2937;--border-color: #374151;--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--hover-bg: #374151;--input-bg: #374151}@media(max-width:480px){.athletes-panel.svelte-oyqtxm{position:fixed;inset:auto 0 0;width:100%;max-height:70vh;border-radius:16px 16px 0 0}}.events-panel.svelte-d3r2aj{position:absolute;top:60px;right:12px;width:340px;max-height:calc(100vh - 120px);background:var(--panel-bg, #fff);border-radius:12px;box-shadow:0 4px 20px #00000026;overflow:hidden;display:flex;flex-direction:column;z-index:50}.panel-header.svelte-d3r2aj{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.panel-header.svelte-d3r2aj h3:where(.svelte-d3r2aj){margin:0;font-size:16px;font-weight:600}.btn-close.svelte-d3r2aj{background:none;border:none;font-size:18px;color:var(--text-secondary, #6b7280);cursor:pointer;padding:4px}.panel-filters.svelte-d3r2aj{padding:12px 16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.filter-tabs.svelte-d3r2aj{display:flex;gap:4px;background:var(--tabs-bg, #f3f4f6);padding:4px;border-radius:8px}.filter-tab.svelte-d3r2aj{flex:1;padding:6px 12px;border:none;background:none;border-radius:6px;font-size:13px;cursor:pointer;color:var(--text-secondary, #6b7280);transition:all .15s}.filter-tab.active.svelte-d3r2aj{background:var(--panel-bg, #fff);color:var(--text-primary, #1f2937);box-shadow:0 1px 3px #0000001a}.panel-content.svelte-d3r2aj{flex:1;overflow-y:auto}.loading-state.svelte-d3r2aj,.error-state.svelte-d3r2aj,.empty-state.svelte-d3r2aj{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-secondary, #6b7280)}.spinner.svelte-d3r2aj{width:32px;height:32px;border:3px solid var(--border-color, #e5e7eb);border-top-color:var(--primary-color, #3b82f6);border-radius:50%;animation:svelte-d3r2aj-spin 1s linear infinite;margin-bottom:12px}@keyframes svelte-d3r2aj-spin{to{transform:rotate(360deg)}}.error-icon.svelte-d3r2aj,.empty-icon.svelte-d3r2aj{font-size:48px;margin-bottom:12px;opacity:.5}.btn-retry.svelte-d3r2aj{margin-top:12px;padding:8px 16px;background:var(--primary-color, #3b82f6);color:#fff;border:none;border-radius:6px;cursor:pointer}.events-list.svelte-d3r2aj{padding:8px 0}.event-item.svelte-d3r2aj{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s}.event-item.svelte-d3r2aj:hover{background:var(--hover-bg, #f9fafb)}.event-status.svelte-d3r2aj{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.event-info.svelte-d3r2aj{flex:1;min-width:0}.event-name.svelte-d3r2aj{font-weight:600;font-size:14px;color:var(--text-primary, #1f2937);margin-bottom:4px}.event-datetime.svelte-d3r2aj{display:flex;gap:8px;font-size:13px;color:var(--text-secondary, #6b7280)}.event-meta.svelte-d3r2aj{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:11px}.status-badge.svelte-d3r2aj{font-weight:500}.participant-count.svelte-d3r2aj{color:var(--text-tertiary, #9ca3af)}.btn-map.svelte-d3r2aj{background:none;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;padding:6px 10px;cursor:pointer;font-size:14px;transition:all .15s;flex-shrink:0}.btn-map.svelte-d3r2aj:hover{background:var(--hover-bg, #f9fafb)}[data-theme=dark] .events-panel.svelte-d3r2aj{--panel-bg: #1f2937;--border-color: #374151;--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--hover-bg: #374151;--tabs-bg: #374151}@media(max-width:480px){.events-panel.svelte-d3r2aj{position:fixed;inset:auto 0 0;width:100%;max-height:70vh;border-radius:16px 16px 0 0}}.athlete-info-panel.svelte-1fmdt2n{position:absolute;top:60px;right:0;width:320px;max-height:calc(100vh - 120px);background:var(--panel-bg, #fff);border-radius:12px 0 0 12px;box-shadow:-4px 0 20px #00000026;overflow:hidden;display:flex;flex-direction:column;z-index:55}.panel-header.svelte-1fmdt2n{display:flex;align-items:flex-start;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.header-info.svelte-1fmdt2n{flex:1}.panel-header.svelte-1fmdt2n h3:where(.svelte-1fmdt2n){margin:0 0 6px;font-size:18px;font-weight:600;color:var(--text-primary, #1f2937)}.status-badge.svelte-1fmdt2n{display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}.btn-close.svelte-1fmdt2n{background:none;border:none;font-size:18px;color:var(--text-secondary, #6b7280);cursor:pointer;padding:4px;margin-top:-4px}.panel-content.svelte-1fmdt2n{padding:16px;overflow-y:auto;flex:1}.metrics-grid.svelte-1fmdt2n{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.metric-card.svelte-1fmdt2n{background:var(--card-bg, #f9fafb);border-radius:10px;padding:12px;text-align:center;transition:opacity .3s}.metric-card.stale.svelte-1fmdt2n{opacity:.5}.metric-card.stale.svelte-1fmdt2n .metric-value:where(.svelte-1fmdt2n){color:var(--text-secondary, #9ca3af)}.metric-icon.svelte-1fmdt2n{font-size:20px;margin-bottom:4px}.metric-value.svelte-1fmdt2n{font-size:20px;font-weight:700;color:var(--text-primary, #1f2937)}.metric-label.svelte-1fmdt2n{font-size:11px;color:var(--text-secondary, #6b7280);margin-top:2px}.update-info.svelte-1fmdt2n{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary, #6b7280);margin-bottom:12px}.device-info.svelte-1fmdt2n{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:13px}.device-label.svelte-1fmdt2n{color:var(--text-secondary, #6b7280)}.device-id.svelte-1fmdt2n{display:flex;align-items:center;gap:6px;background:var(--card-bg, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:6px;padding:4px 8px;font-family:monospace;font-size:12px;cursor:pointer;transition:background .15s}.device-id.svelte-1fmdt2n:hover{background:var(--hover-bg, #f3f4f6)}.copy-icon.svelte-1fmdt2n{font-size:11px;opacity:.6}.actions-section.svelte-1fmdt2n{margin-bottom:16px}.btn-action.svelte-1fmdt2n{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary.svelte-1fmdt2n{background:var(--primary-color, #3b82f6);color:#fff}.btn-primary.svelte-1fmdt2n:hover{background:#2563eb}.btn-secondary.svelte-1fmdt2n{background:var(--card-bg, #f9fafb);color:var(--text-primary, #1f2937);border:1px solid var(--border-color, #e5e7eb);margin-top:8px}.btn-secondary.svelte-1fmdt2n:hover{background:var(--hover-bg, #f3f4f6)}.btn-icon.svelte-1fmdt2n{font-size:16px}.social-actions-wrapper.svelte-1fmdt2n{display:flex;justify-content:center}.coordinates-section.svelte-1fmdt2n{border-top:1px solid var(--border-color, #e5e7eb);padding-top:12px}.coordinates-section.svelte-1fmdt2n summary:where(.svelte-1fmdt2n){cursor:pointer;font-size:13px;color:var(--text-secondary, #6b7280);padding:4px 0}.coordinates-content.svelte-1fmdt2n{margin-top:12px}.location-name.svelte-1fmdt2n{font-size:15px;font-weight:600;color:var(--text-primary, #1f2937);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-color, #e5e7eb)}.coord-row.svelte-1fmdt2n{display:flex;justify-content:space-between;padding:4px 0;font-size:12px}.coord-label.svelte-1fmdt2n{color:var(--text-secondary, #6b7280)}.coord-value.svelte-1fmdt2n{font-family:monospace;color:var(--text-primary, #1f2937)}[data-theme=dark] .athlete-info-panel.svelte-1fmdt2n{--panel-bg: #1f2937;--border-color: #374151;--text-primary: #f9fafb;--text-secondary: #9ca3af;--card-bg: #374151;--hover-bg: #4b5563}@media(max-width:480px){.athlete-info-panel.svelte-1fmdt2n{position:fixed;inset:auto 0 0;width:100%;max-height:60vh;border-radius:16px 16px 0 0}}.replay-controls.svelte-143hdkm{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;background:#fffffff2;padding:12px 20px;border-radius:8px;box-shadow:0 4px 16px #00000026;z-index:100}.btn-icon.svelte-143hdkm{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--primary-color, #3b82f6);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;transition:background .2s}.btn-icon.svelte-143hdkm:hover{background:var(--primary-hover, #2563eb)}.btn-icon.btn-close.svelte-143hdkm{background:#ef4444;width:28px;height:28px;font-size:12px}.btn-icon.btn-close.svelte-143hdkm:hover{background:#dc2626}.scrubber.svelte-143hdkm{width:250px;height:6px;cursor:pointer;accent-color:var(--primary-color, #3b82f6)}.time-display.svelte-143hdkm{font-family:monospace;font-size:14px;min-width:70px;color:var(--text-primary, #1f2937)}.speed-select.svelte-143hdkm{padding:6px 10px;border:1px solid var(--border-color, #e5e7eb);border-radius:4px;font-size:12px;background:#fff;cursor:pointer}[data-theme=dark] .replay-controls.svelte-143hdkm{background:#1f2937f2}[data-theme=dark] .time-display.svelte-143hdkm{color:#f9fafb}[data-theme=dark] .speed-select.svelte-143hdkm{background:#374151;border-color:#4b5563;color:#f9fafb}@media(max-width:600px){.replay-controls.svelte-143hdkm{width:calc(100% - 32px);padding:10px 16px;gap:8px}.scrubber.svelte-143hdkm{width:100%;flex:1}.time-display.svelte-143hdkm{font-size:12px;min-width:60px}}.map-controls-panel.svelte-1tuv17{position:absolute;bottom:90px;left:12px;background:var(--panel-bg, rgba(255, 255, 255, .95));border-radius:12px;box-shadow:0 2px 12px #00000026;padding:12px;z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.control-group.svelte-1tuv17{margin-bottom:10px}.control-group.svelte-1tuv17:last-child{margin-bottom:0}.group-label.svelte-1tuv17{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #6b7280);margin-bottom:6px}.button-row.svelte-1tuv17{display:flex;gap:6px}.control-btn.svelte-1tuv17{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:var(--btn-bg, white);cursor:pointer;transition:all .15s}.control-btn.svelte-1tuv17:hover:not(:disabled){background:var(--hover-bg, #f3f4f6);border-color:var(--hover-border, #d1d5db)}.control-btn.active.svelte-1tuv17{background:var(--primary-color, #3b82f6);border-color:var(--primary-color, #3b82f6)}.control-btn.active.svelte-1tuv17 .btn-icon:where(.svelte-1tuv17){filter:grayscale(1) brightness(10)}.control-btn.svelte-1tuv17:disabled{opacity:.4;cursor:not-allowed}.btn-icon.svelte-1tuv17{font-size:16px;line-height:1}[data-theme=dark] .map-controls-panel.svelte-1tuv17{--panel-bg: rgba(31, 41, 55, .95);--border-color: #374151;--text-secondary: #9ca3af;--btn-bg: #374151;--hover-bg: #4b5563;--hover-border: #4b5563}@media(max-width:480px){.map-controls-panel.svelte-1tuv17{bottom:auto;top:70px;left:8px;padding:10px}.control-btn.svelte-1tuv17{width:32px;height:32px}.btn-icon.svelte-1tuv17{font-size:14px}}[data-theme=dark]{--bg-color: #111827;--text-color: #f9fafb;--header-bg: #1f2937;--panel-bg: #1f2937;--card-bg: #374151;--border-color: #374151;--text-secondary: #9ca3af;--primary-color: #3b82f6}[data-theme=light]{--bg-color: #f9fafb;--text-color: #1f2937;--header-bg: #1f2937;--panel-bg: #ffffff;--card-bg: #f9fafb;--border-color: #e5e7eb;--text-secondary: #6b7280;--primary-color: #3b82f6}.app-container.svelte-1n46o8q{display:flex;flex-direction:column;width:100%;height:100%;overflow:hidden}.main-content.svelte-1n46o8q{flex:1;position:relative;overflow:hidden;min-height:0}.map-controls-toggle.svelte-1n46o8q{position:absolute;bottom:40px;left:12px;width:40px;height:40px;border-radius:10px;border:1px solid var(--border-color, #e5e7eb);background:var(--panel-bg, rgba(255, 255, 255, .95));box-shadow:0 2px 8px #0000001a;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:45;transition:all .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.map-controls-toggle.svelte-1n46o8q:hover{background:var(--hover-bg, #f3f4f6)}.map-controls-toggle.active.svelte-1n46o8q{background:var(--primary-color, #3b82f6);border-color:var(--primary-color, #3b82f6)}.map-controls-toggle.active.svelte-1n46o8q .toggle-icon:where(.svelte-1n46o8q){filter:grayscale(1) brightness(10)}.toggle-icon.svelte-1n46o8q{font-size:20px}[data-theme=dark] .map-controls-toggle.svelte-1n46o8q{--panel-bg: rgba(31, 41, 55, .95);--border-color: #374151;--hover-bg: #4b5563}
