:root{color:#2f342b;background:#d8ded2;font-family:Hanken Grotesk,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:980px}button,input{font:inherit}button{cursor:pointer}.dashboard-shell{min-height:100vh;background:#e7ece3;color:#2f342b;display:flex;flex-direction:column}.topbar{height:72px;flex:none;display:flex;align-items:center;gap:18px;padding:14px 22px;background:#f4f7f0;border-bottom:1px solid rgba(90,110,85,.14)}.brand-lockup{display:inline-flex;align-items:center;gap:10px;font-weight:900;letter-spacing:1px;line-height:1}.brand-lockup span{font-size:22px}.topbar-divider{width:1px;height:30px;background:#5a6e552e}.event-title{display:grid;gap:3px}.event-title strong{font-size:17px;font-weight:900}.event-title span{color:#6f756a;font-size:12px;font-weight:700}.live-chip{display:inline-flex;align-items:center;gap:7px;border-radius:8px;padding:6px 11px;border:1px solid rgba(127,163,124,.4);background:#7fa37c29;color:#5e8159;font-size:11px;font-weight:900;letter-spacing:.6px;text-transform:uppercase}.live-chip span{width:8px;height:8px;border-radius:999px;background:#7fa37c;box-shadow:0 0 #7fa37c80;animation:pulse 1.8s infinite}.live-chip-loading{border-color:#e0b66e73;background:#e0b66e26;color:#9a7327}.live-chip-loading span{background:#e0b66e}.live-chip-offline{border-color:#c76b5a73;background:#c76b5a1f;color:#a65344}.live-chip-offline span{background:#c76b5a}.top-actions{margin-left:auto;display:flex;align-items:center;gap:9px}.top-actions button,.filters button,.alert-row,.runner-row{border:0}.top-actions button{display:inline-flex;align-items:center;gap:8px;height:38px;border-radius:8px;padding:0 13px;background:#e7ece3;border:1px solid rgba(90,110,85,.14);color:#5a604f;font-size:13px;font-weight:800}.top-actions svg,.search-box svg,.empty-state svg{stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.workspace{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 430px}.map-panel{min-width:0;position:relative}.map-canvas{position:relative;width:100%;height:100%;min-height:640px;overflow:hidden;background:#dce3d7}.topo-map{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.contours{stroke:#50694b33;fill:none;stroke-width:1.4}.river-line{stroke:#8faab88c;stroke-width:4;fill:none}.route-halo{stroke:#d9805f4d;stroke-width:18;fill:none;stroke-linecap:round}.route-line{stroke:#d9805f;stroke-width:5;fill:none;stroke-linecap:round}.stat-strip{position:absolute;left:18px;top:18px;display:flex;gap:10px;align-items:stretch}.stat-card{min-width:112px;border-radius:8px;background:#f4f7f0;border:1px solid rgba(90,110,85,.16);box-shadow:0 4px 14px #2f342b0f;padding:12px 14px}.stat-card strong{display:block;font-size:30px;font-weight:900;line-height:.95}.stat-card span{display:block;margin-top:5px;color:#6f756a;font-size:11px;font-weight:800}.checkpoint-marker,.runner-dot{position:absolute;transform:translate(-50%,-50%)}.checkpoint-marker{display:grid;place-items:center;gap:6px;pointer-events:none}.checkpoint-marker span{width:14px;height:14px;border-radius:3px;background:#f4f7f0;border:2px solid #8faab8;transform:rotate(45deg)}.checkpoint-marker strong{border-radius:8px;background:#f4f7f0eb;border:1px solid rgba(143,170,184,.45);color:#5d7682;font-size:10px;font-weight:900;padding:3px 7px}.runner-dot{border:0;background:transparent;padding:0;color:#2f342b;z-index:3}.runner-dot span{position:relative;display:block;width:18px;height:18px;border-radius:999px;background:var(--runner-color);border:3px solid #f4f7f0;box-shadow:0 3px 8px #2f342b2e}.runner-dot em{position:absolute;left:22px;top:50%;transform:translateY(-50%);min-width:42px;border-radius:8px;background:#f4f7f0;border:1px solid rgba(90,110,85,.14);padding:4px 7px;font-size:11px;font-style:normal;font-weight:900;white-space:nowrap;opacity:0;pointer-events:none}.runner-dot:hover em,.runner-dot-selected em{opacity:1}.runner-dot-selected{z-index:5}.runner-dot-selected span:before{content:"";position:absolute;top:-9px;right:-9px;bottom:-9px;left:-9px;border-radius:999px;background:var(--runner-color);opacity:.22;animation:ping 2s infinite}.legend{position:absolute;left:18px;bottom:18px;display:flex;gap:15px;align-items:center;border-radius:8px;background:#f4f7f0;border:1px solid rgba(90,110,85,.16);box-shadow:0 6px 18px #2f342b14;padding:12px 14px}.legend span{display:inline-flex;align-items:center;gap:7px;color:#5a604f;font-size:12px;font-weight:800}.legend i{width:10px;height:10px;border-radius:999px}.selected-card{position:absolute;right:20px;bottom:20px;width:min(390px,calc(100% - 40px));border-radius:8px;background:#f4f7f0;border:1px solid rgba(90,110,85,.16);box-shadow:0 10px 30px #2f342b21;padding:16px}.selected-header{display:flex;align-items:center;gap:12px}.selected-header>span{width:13px;height:13px;flex:none;border-radius:999px}.selected-header div{display:grid;gap:3px}.selected-header strong{font-size:17px;font-weight:900}.selected-header em{color:#d9805f;font-style:normal}.selected-header small,.selected-progress span,.selected-stats span,.runner-row small,.alert-row small,.list-meta span,.panel-footer span{color:#6f756a}.selected-progress{margin-top:14px}.selected-progress div{display:flex;justify-content:space-between;margin-bottom:7px;color:#6f756a;font-size:12px;font-weight:800}.progress{height:7px;border-radius:999px;background:#dde4d8;overflow:hidden}.progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#d9805f,#e8a488)}.selected-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:14px}.selected-stats span{border-radius:8px;background:#e7ece3;padding:10px;font-size:11px;font-weight:800}.selected-stats b{display:block;color:#2f342b;font-size:15px;font-weight:900;margin-bottom:3px}.control-panel{min-height:0;background:#f4f7f0;border-left:1px solid rgba(90,110,85,.14);display:flex;flex-direction:column}.alerts-section{flex:none;padding:17px 18px 14px;border-bottom:1px solid rgba(90,110,85,.12)}.panel-heading{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.kicker{display:block;color:#9aa193;font-size:10px;font-weight:900;letter-spacing:.7px;text-transform:uppercase;margin-bottom:3px}.panel-heading h2{margin:0;font-size:18px;line-height:1.1}.count-pill{min-width:28px;height:24px;border-radius:999px;display:grid;place-items:center;background:#c76b5a;color:#fbf2ec;font-size:12px;font-weight:900}.alerts-list{display:grid;gap:7px}.alert-row{width:100%;display:grid;grid-template-columns:10px minmax(0,1fr) auto;align-items:start;gap:11px;text-align:left;border-radius:8px;background:#e7ece3;color:#2f342b;padding:11px 12px}.alert-row>span{width:9px;height:9px;border-radius:999px;margin-top:4px}.alert-row div{min-width:0;display:grid;gap:2px}.alert-row strong{font-size:10px;font-weight:900;letter-spacing:.7px}.alert-row b{font-size:13px;font-weight:900}.alert-row small{font-size:11px;font-weight:700}.alert-row em{align-self:center;border-radius:8px;background:#f4f7f0;border:1px solid rgba(90,110,85,.16);color:#5a604f;font-size:11px;font-style:normal;font-weight:900;padding:6px 9px}.search-section{flex:none;display:grid;gap:10px;padding:13px 18px;border-bottom:1px solid rgba(90,110,85,.1)}.search-box{display:flex;align-items:center;gap:9px;height:40px;padding:0 12px;border-radius:8px;background:#e7ece3;border:1px solid rgba(90,110,85,.14);color:#9aa193}.search-box input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:#2f342b;font-size:13px;font-weight:700}.search-box input::placeholder{color:#9aa193}.filters{display:flex;flex-wrap:wrap;gap:7px}.filters button{border-radius:999px;background:#e7ece3;border:1px solid rgba(90,110,85,.12);color:#5a604f;font-size:12px;font-weight:900;padding:7px 10px}.filters button.active{background:#d9805f;border-color:#d9805f;color:#fbf2ec}.runner-section{min-height:0;display:flex;flex:1;flex-direction:column;padding:0 18px 14px}.list-meta{flex:none;display:flex;justify-content:space-between;align-items:center;padding:11px 0}.list-meta strong{font-size:13px;font-weight:900}.list-meta span{font-size:12px;font-weight:800}.runner-list{min-height:0;flex:1;overflow:auto;display:grid;align-content:start;gap:5px;padding-right:2px}.runner-row{width:100%;display:grid;grid-template-columns:10px minmax(0,1fr) auto;gap:12px;align-items:center;text-align:left;border-radius:8px;background:transparent;color:#2f342b;border:1px solid transparent;padding:12px}.runner-row:hover,.runner-row-selected{background:#e7ece3;border-color:#5a6e551f}.runner-state-dot{width:10px;height:10px;border-radius:999px}.runner-row-main{min-width:0;display:grid;gap:3px}.runner-row-main strong{overflow:hidden;color:#2f342b;font-size:14px;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.runner-row-main em{color:#9aa193;font-style:normal;font-weight:900}.runner-row-main small{overflow:hidden;font-size:11px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.battery{display:inline-flex;align-items:center;gap:7px}.battery span{width:28px;height:13px;display:block;border-radius:3px;border:1.5px solid currentColor;padding:2px}.battery i{display:block;height:100%;border-radius:1px}.battery b{min-width:32px;font-size:13px;font-weight:900}.panel-footer{flex:none;display:flex;justify-content:space-between;gap:10px;border-top:1px solid rgba(90,110,85,.12);padding-top:12px;margin-top:10px}.panel-footer span{min-width:0;overflow:hidden;font-size:11px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.empty-state{min-height:64px;display:grid;place-items:center;gap:6px;border:1px dashed rgba(90,110,85,.2);border-radius:8px;color:#6f756a;font-size:13px;font-weight:800}@keyframes pulse{0%{box-shadow:0 0 #7fa37c80}70%,to{box-shadow:0 0 0 8px #7fa37c00}}@keyframes ping{0%{transform:scale(.8);opacity:.5}80%,to{transform:scale(1.8);opacity:0}}@media (max-width: 1180px){body{min-width:0}.topbar{height:auto;flex-wrap:wrap}.top-actions{width:100%;margin-left:0}.workspace{grid-template-columns:1fr}.map-canvas{height:58vh;min-height:520px}.control-panel{border-left:0;border-top:1px solid rgba(90,110,85,.14)}.runner-list{max-height:360px}}
