@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Fraunces:opsz,wght@9..144,600;700&display=swap";:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset}.ol-viewport{touch-action:none}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}:root{--bg: radial-gradient(circle at 20% 20%, #e2e8f0, #f8fafc 40%, #e5e7eb 80%), radial-gradient(circle at 70% 20%, rgba(16, 185, 129, .18), transparent 45%), radial-gradient(circle at 85% 80%, rgba(113, 66, 142, .16), transparent 35%);--panel: rgba(255, 255, 255, .92);--panel-strong: rgba(15, 23, 42, .94);--border: rgba(15, 23, 42, .12);--shadow: 0 24px 60px rgba(15, 23, 42, .18);--accent: #10b981;--accent-strong: #71428E;--accent-soft: rgba(16, 185, 129, .2);--track: #71428E;--track-highlight: #00FF00;--checkpoint-all: #2563eb;--checkpoint-done: #16a34a;--admin-low: #22c55e;--admin-mid: #f59e0b;--admin-high: #ef4444;--admin-inactive: rgba(148, 163, 184, .5);--text: #0f172a;--muted: #475569;--success: #16a34a;--error: #dc2626;--header-h: 76px;--footer-h: 48px;--bottom-nav-h: 0px}*{box-sizing:border-box}body{margin:0;min-height:100dvh;font-family:Space Grotesk,Segoe UI,sans-serif;color:var(--text);background:var(--bg);overflow:hidden}body:before{content:"";position:fixed;inset:0;background-image:radial-gradient(rgba(15,23,42,.06) 1px,transparent 1px);background-size:20px 20px;opacity:.55;pointer-events:none;z-index:0}.app-header{position:sticky;top:0;z-index:50;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:#000;color:#f8fafc;box-shadow:0 10px 24px #00000059}body[data-track-panel-mode=fullscreen] .app-header,body[data-public-panel-mode=fullscreen] .app-header{display:none}.brand{display:flex;align-items:center;gap:12px}.brand img{width:38px;height:38px;border-radius:12px;object-fit:cover}.brand-title{font-family:Fraunces,serif;font-size:20px;font-weight:700}.brand-subtitle{font-size:12px;color:#f8fafcb8}.nav-tabs{display:flex;gap:10px;flex-wrap:wrap;background:#ffffff14;padding:6px;border-radius:999px}.nav-tab{border:none;background:transparent;color:#f8fafcb8;padding:8px 16px;border-radius:999px;font-weight:600;cursor:pointer;transition:all .2s ease}.nav-tab.is-active{background:#ffffff2e;color:#f8fafc}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:var(--bottom-nav-h);display:none;align-items:center;justify-content:space-between;gap:6px;padding:8px 10px;background:#000000f2;border-top:1px solid rgba(255,255,255,.08);z-index:80}.bottom-nav-tab{flex:1;min-width:0;padding:10px 6px;font-size:12px;border-radius:12px;background:transparent;color:#f8fafcb3;border:1px solid transparent;text-align:center}.bottom-nav-tab.is-active{background:#ffffff24;color:#fff}.header-actions{display:flex;align-items:center;gap:8px}.header-menu{position:relative}.header-menu-toggle{width:44px;height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center}.menu-icon{width:20px;height:16px;display:inline-flex;flex-direction:column;justify-content:space-between}.menu-icon span{display:block;height:2px;width:100%;background:#f8fafc;border-radius:999px;box-shadow:0 1px 2px #0f172a66}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.header-menu-panel{position:absolute;top:calc(100% + 10px);right:0;min-width:200px;padding:10px;display:none;flex-direction:column;gap:8px;background:#0f172afa;border:1px solid rgba(255,255,255,.12);border-radius:16px;box-shadow:0 20px 40px #0f172a59;z-index:90}.header-menu-panel.is-open{display:flex}.header-menu-panel .ghost{width:100%;justify-content:flex-start;background:#ffffff14;color:#f8fafc;border-color:#fff3}button{border:none;cursor:pointer;border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}button:disabled{opacity:.65;cursor:not-allowed}.primary{background:linear-gradient(120deg,var(--accent-strong),#71428E);color:#fff;box-shadow:0 10px 30px #71428e40}.ghost{background:#eef2f7;color:var(--text);border:1px solid var(--border)}.ghost:hover{transform:translateY(-1px)}.app-header .ghost{background:#ffffff1a;color:#f8fafc;border-color:#fff3}.app-main{position:relative;height:calc(100dvh - var(--header-h) - var(--footer-h) - var(--bottom-nav-h));overflow:hidden;z-index:1}.view{height:100%}.map-layout{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:18px;height:100%;padding:18px 20px 16px}.panel{background:var(--panel);border-radius:20px;border:1px solid var(--border);box-shadow:var(--shadow);padding:18px;display:flex;flex-direction:column;gap:14px;overflow:hidden}.panel-header{position:relative}.panel-close{display:none;position:absolute;top:10px;right:10px;width:42px;height:42px;border-radius:14px;border:0;background:#71428e80;color:#fff;align-items:center;justify-content:center;font-size:22px;font-weight:700;line-height:1;box-shadow:0 12px 24px #71428e4d;cursor:pointer}.panel-open{display:none}.track-panel,.public-panel{min-height:0}.public-panel.is-fullscreen{position:fixed;inset:0 0 var(--bottom-nav-h) 0;width:100%;max-width:none;height:calc(100dvh - var(--bottom-nav-h));border-radius:0;z-index:95}.public-panel.is-fullscreen .panel-close{display:inline-flex}.track-panel.is-fullscreen{position:fixed;inset:0 0 var(--bottom-nav-h) 0;width:100%;max-width:none;height:calc(100dvh - var(--bottom-nav-h));border-radius:0;z-index:95}.panel-tabs{display:flex;gap:8px;padding:6px;border-radius:999px;background:#0f172a0f}.track-panel .panel-tabs{position:relative;padding-right:46px}.track-panel .panel-close{top:6px;right:6px}.track-panel.is-fullscreen .panel-tabs{position:sticky;top:0;z-index:2;background:#fffffffa;padding:10px;border-bottom:1px solid var(--border)}.track-panel.is-fullscreen .panel-close{display:inline-flex}.track-panel.is-fullscreen .panel-pane{padding-top:6px}.panel-tab{border:none;background:transparent;color:var(--muted);padding:8px 14px;border-radius:999px;font-weight:600;cursor:pointer;transition:all .2s ease}.panel-tab.is-active{background:#fff;color:var(--text);box-shadow:0 8px 20px #0f172a1f}.panel-pane{display:none;flex:1;min-height:0;flex-direction:column;gap:14px;overflow-y:auto;padding-right:4px}.panel-pane.is-active{display:flex}.layer-tree{display:grid;gap:16px}.layer-group{background:#0f172a0a;border-radius:14px;padding:12px 14px;border:1px solid rgba(15,23,42,.08);display:grid;gap:10px}.layer-group.is-active{border-color:#0c4a6e3d;background:#0c4a6e0d}.layer-subgroup{display:grid;gap:8px;padding-top:4px}.layer-group>.layer-subgroup{margin-left:8px;padding-left:16px;border-left:1px solid rgba(15,23,42,.14)}.layer-subgroup .layer-subgroup{margin-left:6px;padding-left:12px;border-left:1px dashed rgba(15,23,42,.12)}.layer-auto-option{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);transition:color .12s ease}.layer-auto-option.is-active{color:var(--text);font-weight:600}.layer-auto-option.is-inactive{color:#0f172a6b}.layer-subtitle{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.layer-title{font-weight:600;font-size:13px;letter-spacing:.02em;text-transform:uppercase;color:var(--muted)}.layer-field{display:grid;gap:6px;font-size:13px;color:var(--muted)}.layer-field select{border-radius:10px;border:1px solid var(--border);padding:8px 10px;font-size:14px;font-family:inherit;background:#fff;color:var(--text)}.layer-group button{align-self:start}.panel-wide{grid-column:1 / -1}.panel-header h2,.panel-header h3,.panel-header h4{margin:0;font-family:Fraunces,serif}.panel-header p{margin:6px 0 0;color:var(--muted)}.panel-form{display:grid;gap:12px}.panel-form-inline{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));align-items:end}.panel-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.panel-form input{border-radius:10px;border:1px solid var(--border);padding:8px 10px;font-size:14px;font-family:inherit}.panel-form select{border-radius:10px;border:1px solid var(--border);padding:8px 10px;font-size:14px;font-family:inherit;background:#fff;color:var(--text)}.field-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.field-row-single{grid-template-columns:1fr}.button-row{display:flex;gap:10px}.section-title{display:flex;align-items:center;justify-content:space-between}.badge{background:#0f172a14;border-radius:999px;padding:4px 10px;font-size:12px}.status{font-size:13px;color:var(--muted)}.status[data-tone=success]{color:var(--success)}.status[data-tone=error]{color:var(--error)}.track-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;max-height:320px;overflow-y:auto}.track-panel #panel-tracks{overflow:hidden}.track-panel #panel-tracks .panel-section{min-height:0;display:flex;flex-direction:column}.track-panel #panel-tracks .panel-section.fill-results{flex:1}.track-panel #panel-tracks .track-list{max-height:320px}.track-panel #panel-tracks .panel-section.fill-results .track-list{flex:1;min-height:0;max-height:none}.track-list li{margin:0}.track-card-button{width:100%;border:1px solid var(--border);border-radius:14px;background:#0f172a08;padding:12px;text-align:left;cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .15s ease}.track-card-button:hover{border-color:#3b82f673;background:#3b82f612}.track-list li.is-active .track-card-button{border-color:var(--accent);background:#10b9811f}.track-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.track-card-date{color:var(--muted);font-size:12px;white-space:nowrap}.track-list .track-title{font-weight:600;font-size:14px}.track-card-kpis{margin-top:8px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.track-chip{padding:8px;border-radius:10px;background:#0f172a0f;display:flex;flex-direction:column;gap:2px}.track-chip-label{color:var(--muted);font-size:11px}.track-chip strong{font-size:13px}.track-list .track-meta{margin-top:8px;font-size:12px;color:var(--muted)}.empty-state{border:1px dashed var(--border);border-radius:14px;background:#0ea5e914;padding:18px;text-align:center;color:var(--muted)}.empty-state h3{margin:0 0 6px;font-size:16px}.empty-state p{margin:0 12px 12px;font-size:14px}.upload-hint{font-size:13px;margin:12px 0 0}.map-shell{display:flex;flex-direction:column;gap:12px;height:100%;position:relative}#view-map .map-shell{gap:0}body[data-view=tracks-list] #view-map .map-layout{grid-template-columns:1fr}body[data-view=tracks-list] #view-map .map-shell{display:none}body[data-view=tracks-list] #view-map .track-panel{max-width:none}body[data-view=tracks-list] #view-map .track-panel .panel-tabs{display:none}body[data-view=tracks-list] #view-map #panel-tracks{display:flex}.map-inline-loading{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:56;opacity:0;pointer-events:none;transition:opacity .18s ease}.map-inline-loading.is-visible{opacity:1}.map-inline-loading-card{display:inline-flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:12px;border:1px solid var(--border);background:#ffffffeb;box-shadow:0 10px 24px #0f172a2e;color:var(--text);font-size:12px;font-weight:600}.map-inline-loading-card p{margin:0}.map-inline-loading-copy{display:flex;flex-direction:column;gap:2px}.map-inline-loading-joke{color:var(--muted);font-weight:500}.map-inline-spinner{width:20px;height:20px;border-width:2px}.map-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;background:#ffffffb3;border-radius:16px;border:1px solid var(--border)}.toggle-group{display:flex;gap:10px;flex-wrap:wrap}.toggle{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer}.toggle.is-active{color:var(--text);font-weight:600}.map-canvas{flex:1;border-radius:24px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}.map-popup{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:10px 12px;box-shadow:var(--shadow);font-size:12px;max-width:220px}.popup-meta{display:block;margin-top:4px;color:var(--muted)}.popup-cta{margin-top:6px;font-weight:600;color:var(--accent-strong)}.popup-note{font-size:11px;color:#0f172aa6;margin-top:2px}.popup-hint{margin-top:8px;font-size:11px;color:var(--muted)}.popup-cta button{margin-top:6px;border-radius:10px;padding:6px 12px;font-size:12px}.popup-cta-actions{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px}.popup-cta-actions button{margin-top:0}.map-popup[aria-hidden=true]{display:none}.track-detail-top{width:100%;background:var(--panel);border:1px solid var(--border);border-bottom:0;border-radius:0;box-shadow:var(--shadow);padding:8px 10px}.track-detail-top[hidden]{display:none}.track-detail-top .detail-card{border:0;box-shadow:none;background:transparent;padding:0}.track-detail-content{position:relative;padding-right:50px;padding-bottom:2px}.track-detail-content.is-collapsed .detail-grid{display:none}.track-detail-content.is-collapsed h4{margin-bottom:0}.track-detail-collapse-toggle{position:absolute;right:0;bottom:0;width:36px;height:36px;border:0;border-radius:12px;padding:0;background:linear-gradient(140deg,var(--accent-strong),#71428E);color:#fff;box-shadow:0 10px 20px #71428e47;display:inline-flex;align-items:center;justify-content:center;font-size:17px;line-height:1}#view-map .track-detail-top:not([hidden])+.map-canvas{border-top-left-radius:0;border-top-right-radius:0}.map-fab{position:absolute;right:18px;bottom:calc(18px + var(--bottom-nav-h));display:flex;flex-direction:column;align-items:flex-end;gap:10px;z-index:55}.track-map-fab{flex-direction:row;align-items:center}.public-map-fab{display:none}.fab-button{width:56px;height:56px;border-radius:18px;background:linear-gradient(140deg,var(--accent-strong),#71428E);color:#fff;font-size:26px;font-weight:700;box-shadow:0 16px 32px #71428e59;display:inline-flex;align-items:center;justify-content:center}.fab-icon{line-height:1}.fab-button.fab-button-back{background:linear-gradient(140deg,var(--accent-strong),#71428E);box-shadow:0 16px 32px #71428e59}.fab-icon-back{font-size:24px}.detail-card{background:#0f172a08;border-radius:16px;padding:14px;border:1px solid var(--border)}.detail-card h4{margin:0 0 6px;font-size:16px}.detail-grid{display:grid;gap:8px;font-size:13px;color:var(--muted)}.legend-grid{display:grid;gap:8px}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}.swatch{width:14px;height:14px;border-radius:4px;display:inline-block}.swatch-track{background:var(--track)}.swatch-highlight{background:var(--track-highlight)}.swatch-admin-low,.swatch-admin-mid,.swatch-admin-high{background:transparent;border:2px solid}.swatch-admin-low{border-color:var(--admin-low)}.swatch-admin-mid{border-color:var(--admin-mid)}.swatch-admin-high{border-color:var(--admin-high)}.swatch-admin-preview{background:#0ea5e929;border:2px dashed #0ea5e9}.swatch-admin-inactive{background:var(--admin-inactive);border:1px solid rgba(100,116,139,.8)}.swatch-checkpoint-all{background:#2563eb4d}.swatch-checkpoint-point{background:#be80968a;border:1px solid rgba(190,128,150,.85);border-radius:999px}.swatch-checkpoint-poly{background:#be809687;border:1px solid rgba(190,128,150,.85)}.swatch-checkpoint-done{background:#16a34a4d}.dashboard-layout{padding:20px;height:100%;overflow-y:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:18px}.rankings-layout{padding:20px;height:100%;overflow-y:auto;display:grid;gap:18px}.gameplay-layout,.profile-layout{padding:20px;height:auto;min-height:100%;overflow-y:auto;display:grid;gap:18px}.gameplay-panel{max-width:920px;width:100%;margin:0 auto;overflow-y:auto}.gameplay-content{display:grid;gap:12px;max-width:74ch}.gameplay-content h3,.gameplay-content p{margin:0}.gameplay-content p{line-height:1.55}.gameplay-content-rich a{color:var(--accent-strong);text-decoration:none;font-weight:600}.view-profile,.view-gameplay{overflow-y:auto}.view-profile .panel{overflow:visible}.upload-layout{padding:20px;height:100%;overflow-y:auto;display:grid;gap:18px}.upload-result{margin-top:8px;font-size:13px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.profile-field{background:#0f172a0a;border-radius:14px;border:1px solid var(--border);padding:12px 14px;display:grid;gap:6px}.profile-label{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.profile-value{font-size:16px;font-weight:600}.profile-panel{background:#0f172a0a;border-radius:16px;border:1px solid var(--border);padding:14px;display:grid;gap:12px}.profile-actions{display:flex;flex-wrap:wrap;gap:10px}#stravaInfoButton{background:#fc5200;color:#fff;border-color:#fc5200}#stravaInfoButton:hover{background:#e54a00;border-color:#e54a00}.profile-map{height:260px;border-radius:14px;border:1px solid var(--border);background:#0f172a;overflow:hidden}.profile-zone-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:13px}.profile-zone-list{display:grid;gap:8px;font-size:13px}.profile-zone-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:8px 10px;border-radius:12px;border:1px solid var(--border);background:#0f172a0a;cursor:pointer;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}.profile-zone-item:hover{background:#2563eb17}.profile-zone-item:focus-visible{outline:2px solid rgba(37,99,235,.7);outline-offset:1px}.profile-zone-item.is-active{border-color:#0f0;box-shadow:0 0 0 1px #0f0 inset;background:#00ff001a}.ranking-table{display:grid;gap:10px}.ranking-row{display:grid;grid-template-columns:52px minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border-radius:14px;background:#0f172a0a}.ranking-row.is-highlight{border:1px solid rgba(16,185,129,.5);background:#10b9811f}.ranking-rank{font-weight:700;color:var(--accent-strong)}.ranking-main strong{display:block;font-size:14px}.ranking-meta{font-size:12px;color:var(--muted)}.ranking-score{font-size:16px;font-weight:700}.ranking-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.subpanel{border-radius:16px;border:1px solid var(--border);padding:12px;background:#0f172a08}.station-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border-radius:14px;background:#0f172a0a}.station-row.is-clickable{cursor:pointer}.station-row.is-clickable:hover{background:#2563eb1a}.summary-list{list-style:none;padding:0;margin:0;display:grid;gap:6px;font-size:13px;color:var(--muted)}.summary-list li:before{content:"•";margin-right:6px;color:var(--accent)}.station-main{display:grid;gap:4px}.station-score{text-align:right}.station-score-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.station-score-value{font-size:16px;font-weight:700}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;grid-column:1 / -1}.kpi-card{background:var(--panel);border-radius:18px;border:1px solid var(--border);padding:16px;box-shadow:var(--shadow)}.kpi-card h4{margin:0;font-size:14px;color:var(--muted)}.kpi-value{font-size:28px;font-weight:700;margin:8px 0 6px}.chart-grid,.table-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;grid-column:1 / -1}.view-dashboard .chart-grid{order:-1}.dashboard-highlight-title{display:inline-block;padding:4px 10px;border-radius:10px;background:#71428e80;color:#fff}.chart{min-height:220px}.chart svg{width:100%;height:220px}.timeseries-interactive{display:grid;gap:8px}.timeseries-point{transition:r .16s ease,stroke-width .16s ease}.timeseries-point.is-active{stroke:#ffffffeb;stroke-width:2.2}.timeseries-hit-target{fill:#fff0;cursor:pointer;pointer-events:all}.timeseries-hit-target:focus-visible{stroke:#0f172a8c;stroke-width:2}.timeseries-selection{min-height:18px;font-size:12px}.bar-chart{display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,1fr));align-items:end;gap:12px;height:180px}.bar-group{display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}.bar{width:100%;background:linear-gradient(180deg,#71428e,#71428e);border-radius:10px 10px 6px 6px;display:flex;align-items:flex-end;justify-content:center;color:#fff;font-size:11px;padding-bottom:6px}.bar-label{font-size:11px;color:var(--muted);text-align:center}.table{display:grid;gap:8px}.table-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:10px 12px;border-radius:12px;background:#0f172a0a}.table-row.is-clickable{cursor:pointer}.table-row.is-clickable:hover{border:1px solid rgba(113,66,142,.35);background:#71428e14}.table-row strong{font-size:14px}.table-row span{font-size:12px;color:var(--muted)}.community-progress-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.community-progress-card{display:grid;gap:10px;padding:12px;border-radius:14px;border:1px solid var(--border);background:#0f172a0a}.community-progress-card.is-threshold-hit{border-color:#16a34a59}.community-progress-card.is-unlock-ready{border-color:#2563eb73;background:#2563eb17}.community-progress-card-head{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:start}.community-progress-rank{font-weight:700;color:var(--accent-strong)}.community-progress-title-wrap{min-width:0;display:grid;gap:6px}.community-progress-title{margin:0;font-size:14px}.community-progress-chips{display:flex;flex-wrap:wrap;gap:6px}.community-progress-chip{font-size:11px;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:2px 8px;background:#ffffffb3}.community-progress-score{font-size:16px;font-weight:700}.community-progress-meter{height:8px;border-radius:999px;background:#0f172a1f;overflow:hidden}.community-progress-meter span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#16a34a,#3b82f6)}.community-progress-stats{display:flex;justify-content:space-between;gap:8px;font-size:12px;color:var(--muted)}.community-progress-meta{font-size:12px;color:var(--muted)}.community-progress-actions{display:flex;justify-content:flex-end}.community-progress-jump{white-space:nowrap}.muted{color:var(--muted);font-size:13px}.app-footer{height:var(--footer-h);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:#000000eb;color:#f8fafcb3;font-size:12px;z-index:40}.footer-info-button{display:none;background:#ffffff1f;color:#f8fafc;border-color:#fff3}.footer-sources a{color:#f8fafce6;text-decoration:none}.loading-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:#0f172a33;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:60}.loading-overlay.is-visible{display:flex}.loading-card{background:var(--panel);padding:18px 22px;border-radius:16px;border:1px solid var(--border);display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}.spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(15,23,42,.2);border-left-color:var(--accent);animation:spin .9s linear infinite}.info-popup{position:fixed;right:20px;bottom:calc(var(--footer-h) + var(--bottom-nav-h) + 20px);max-width:340px;background:var(--panel);border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow);padding:16px;font-size:13px;line-height:1.5;display:none;z-index:70}.info-popup.is-visible{display:block}.info-popup h3{margin:0 0 8px;font-family:Fraunces,serif}.info-popup a{color:var(--accent-strong);text-decoration:none;font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1100px){.map-layout{grid-template-columns:minmax(240px,320px) minmax(0,1fr)}}@media(max-width:900px){:root{--footer-h: 0px;--bottom-nav-h: calc(56px + env(safe-area-inset-bottom, 0px)) }.app-header{flex-wrap:wrap;height:auto;padding:12px 16px;gap:10px}.nav-tabs{display:none}.bottom-nav{display:flex;gap:4px;padding:4px 8px calc(4px + env(safe-area-inset-bottom,0px))}.bottom-nav-tab{min-height:32px;padding:6px 4px;font-size:11px;border-radius:10px}.app-main{height:calc(100dvh - var(--header-h) - var(--footer-h) - var(--bottom-nav-h))}button,input,select{min-height:44px}.map-layout{grid-template-columns:1fr;padding:0;gap:8px}body[data-view=tracks-list] #view-map .map-layout{padding:0;gap:0}body[data-view=tracks-list] #view-map .track-panel{border-radius:0;border:0;box-shadow:none;padding:14px}.map-shell{min-height:320px;margin:0}.track-detail-top{padding:8px}.track-card-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.map-canvas{border-radius:0;border:0;box-shadow:none}.map-toolbar [data-public-fit],#view-public-map .map-toolbar,.public-panel.is-collapsed{display:none}.public-panel .panel-close{display:inline-flex}.public-map-fab{display:flex}body[data-public-panel=visible] .public-map-fab,body[data-public-panel-mode=fullscreen] .public-map-fab,.track-panel.is-collapsed{display:none}.track-panel .panel-close{display:inline-flex}.app-footer{display:none}.dashboard-layout{grid-template-columns:1fr}.dashboard-layout,.rankings-layout,.gameplay-layout,.profile-layout{padding:12px;gap:12px}.view-dashboard .panel,.view-rankings .panel,.view-gameplay .panel,.view-profile .panel{background:transparent;border:0;border-radius:0;box-shadow:none;padding:0;gap:10px}.view-profile .profile-panel,.view-profile .profile-field,.view-rankings .subpanel{background:transparent;border:0;border-radius:0;padding:0;box-shadow:none}.view-profile .profile-field{border-bottom:1px solid var(--border);padding:8px 0;gap:4px}.kpi-grid{gap:10px}.kpi-card{border-radius:14px;padding:12px;box-shadow:0 10px 24px #0f172a1f}.track-list,.ranking-table,.table{gap:0}.community-progress-card-grid{grid-template-columns:1fr;gap:0}.panel-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.panel-tab{padding:10px 16px}.track-list li,.ranking-row,.station-row,.table-row,.community-progress-card{background:transparent;border:0;border-radius:0;box-shadow:none;border-bottom:1px solid var(--border)}.track-list li,.ranking-row,.station-row,.table-row,.community-progress-card{padding:10px 0}.track-list li.is-active,.ranking-row.is-highlight{border-bottom-color:#71428e80;background:#71428e14}.table-row{grid-template-columns:1fr;gap:6px}.ranking-row,.station-row{grid-template-columns:1fr;align-items:start}.community-progress-card-head{grid-template-columns:minmax(0,1fr) auto}.community-progress-rank{grid-column:1 / -1}.community-progress-actions{justify-content:flex-start}.ranking-score,.station-score{text-align:left}.ranking-description{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.4}}.intro-modal-backdrop{position:fixed;inset:0;background:#0f172ac7;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1100;opacity:0;pointer-events:none;transition:opacity .25s ease}.intro-modal-backdrop.is-visible{opacity:1;pointer-events:auto}.intro-modal{position:relative;max-width:640px;width:min(100%,640px);max-height:min(90vh,720px);background:#fff;border-radius:28px;border:1px solid var(--border);box-shadow:0 30px 80px #0f172a66;padding:32px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;overscroll-behavior:contain}.intro-modal h1{font-family:Fraunces,serif;font-size:30px;margin:0}.intro-modal h2{font-size:18px;margin:0;color:var(--muted);font-weight:500}.intro-modal p{margin:0;line-height:1.5}.intro-modal-section{display:flex;flex-direction:column;gap:6px}.intro-modal-section ul{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:4px}.intro-modal .beta-section{background:var(--panel);padding:16px;border-radius:18px;border:1px dashed var(--border)}.intro-modal a{color:var(--accent-strong);text-decoration:none;font-weight:600}.intro-modal-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:4px}.intro-modal-actions .primary{min-width:140px}.intro-modal-close{position:absolute;top:16px;right:18px;background:transparent;color:var(--text);border-radius:999px;border:1px solid var(--border);width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;font-size:20px}.intro-modal-footer{font-weight:600;text-align:center}.confirm-modal-backdrop{position:fixed;inset:0;background:#0f172ab3;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1050;opacity:0;pointer-events:none;transition:opacity .2s ease}.confirm-modal-backdrop.is-visible{opacity:1;pointer-events:auto}.confirm-modal{width:min(100%,420px);background:#fff;border-radius:20px;border:1px solid var(--border);box-shadow:0 30px 80px #0f172a59;padding:22px;display:grid;gap:12px}.confirm-modal h2{margin:0;font-family:Fraunces,serif;font-size:22px}.confirm-modal p{margin:0;color:var(--muted);white-space:pre-line;line-height:1.5}.confirm-modal-actions{display:flex;justify-content:flex-end;gap:10px}.confirm-modal-secondary{border-color:#dc262659;color:#b91c1c}.confirm-modal-secondary:disabled{border-color:#94a3b880;color:#64748be6;background:#94a3b82e;cursor:not-allowed;transform:none}@media(max-width:640px){.intro-modal-backdrop{align-items:flex-start;padding:16px}.intro-modal{padding:20px;width:min(100%,100%);max-height:calc(100dvh - 32px);border-radius:22px}.confirm-modal{width:min(100%,100%)}.track-card-kpis{grid-template-columns:1fr}}
