:root{--bg:#f4f5f7;--bg2:#eceef1;--surface:#ffffff;--surface2:#fbfbfd;--surface3:#f1f2f5;--border:#e7e9ee;--border2:#d9dce2;--text:#1d1d1f;--text2:#5b6470;--text3:#8a929e;--brand:#0e9f76;--brand-ink:#0a7c5c;--brand-soft:#e8f6f0;--brandgrad:linear-gradient(135deg,#16b88a,#0b8f68);--green:#1a9e6b;--amber:#d98e27;--red:#d1495b;--blue:#2f6fed;--radius:16px;--radius-sm:11px;--shadow-sm:0 1px 2px rgba(16,24,40,.05);--shadow:0 1px 3px rgba(16,24,40,.05),0 10px 28px rgba(16,24,40,.05);--shadow-lg:0 18px 48px rgba(16,24,40,.16);--mono:ui-monospace,"SF Mono","JetBrains Mono",monospace;--sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Inter",system-ui,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;letter-spacing:-.01em;font-size:14px;overflow:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#d2d6dd;border-radius:6px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#bcc2cc;background-clip:padding-box}::-webkit-scrollbar-track{background:transparent}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:0}.tnum{font-variant-numeric:tabular-nums}.muted{color:var(--text3)}.app{display:grid;grid-template-columns:68px 1fr;grid-template-rows:60px 1fr;height:100vh}.main{position:relative;overflow:hidden;background:var(--bg)}.rail{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:13px 0;gap:5px;grid-row:1/span 2;z-index:40}.rail-logo{width:42px;height:42px;border-radius:12px;background:var(--brandgrad);display:grid;place-items:center;margin-bottom:14px;box-shadow:0 6px 16px #0e9f7659;flex:none}.rail-logo svg{width:23px;height:23px;color:#fff}.rail-sp{flex:1}.rbtn{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:var(--text3);position:relative;transition:color .18s,background .18s;flex:none}.rbtn svg{width:21px;height:21px;stroke-width:1.85}.rbtn:hover{color:var(--text);background:var(--surface3)}.rbtn.active{color:var(--brand);background:var(--brand-soft)}.rbtn.active:before{content:"";position:absolute;left:-13px;top:11px;bottom:11px;width:3px;border-radius:3px;background:var(--brand)}.rbtn .tip{position:absolute;left:58px;white-space:nowrap;background:#1d1d1f;color:#fff;padding:7px 11px;border-radius:9px;font-size:12px;font-weight:500;opacity:0;pointer-events:none;transform:translate(-6px);transition:.16s;box-shadow:var(--shadow-lg);z-index:50}.rbtn:hover .tip{opacity:1;transform:translate(0)}.topbar{background:#ffffffd1;-webkit-backdrop-filter:blur(16px) saturate(1.4);backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 22px;z-index:30}.tb-title{font-weight:680;font-size:16px;letter-spacing:-.3px}.tb-title small{display:block;font-weight:500;font-size:11.5px;color:var(--text3);letter-spacing:-.1px;margin-top:1px}.tb-sp{flex:1}.seg{display:flex;background:var(--surface3);border-radius:11px;padding:3px;gap:2px}.seg button{padding:6px 13px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--text2);transition:.18s}.seg button.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.live-pill{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);padding:7px 13px;border-radius:11px;font-size:12px;font-weight:700;letter-spacing:.3px;box-shadow:var(--shadow-sm);cursor:pointer}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite;flex:none}.live-pill.paused .live-dot{background:var(--text3);animation:none}.live-pill.paused{color:var(--text3)}@keyframes pulse{0%{box-shadow:0 0 #1a9e6b73}70%{box-shadow:0 0 0 7px #1a9e6b00}to{box-shadow:0 0 #1a9e6b00}}.tb-clock{font-family:var(--mono);font-size:13px;color:var(--text2);min-width:60px;text-align:right}.icon-btn{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:var(--text2);border:1px solid var(--border);background:var(--surface);transition:.15s;box-shadow:var(--shadow-sm)}.icon-btn:hover{color:var(--text);border-color:var(--border2)}.icon-btn svg{width:18px;height:18px}.user-btn{display:flex;align-items:center;gap:9px;border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:5px 7px 5px 12px;box-shadow:var(--shadow-sm);transition:.15s;cursor:pointer}.user-btn:hover{border-color:var(--border2);background:var(--surface2)}.user-btn .nm{font-size:12.5px;font-weight:600;line-height:1.15;text-align:right}.user-btn .rl{font-size:10.5px;color:var(--text3);text-align:right}.avatar{width:31px;height:31px;border-radius:9px;background:var(--brandgrad);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700;flex:none;letter-spacing:.3px}.user-menu{position:fixed;top:56px;right:22px;width:236px;background:var(--surface);border:1px solid var(--border);border-radius:15px;box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;animation:menupop .18s ease}@keyframes menupop{0%{opacity:0;transform:scale(.96) translateY(-4px)}to{opacity:1;transform:none}}.menu-head{padding:15px 16px;border-bottom:1px solid var(--border)}.menu-head .nm{font-weight:650;font-size:13.5px}.menu-head .em{font-size:12px;color:var(--text3);margin-top:1px}.menu-item{display:flex;align-items:center;gap:11px;padding:11px 16px;font-size:13px;font-weight:550;color:var(--text2);width:100%;text-align:left;transition:.12s}.menu-item:hover{background:var(--surface2);color:var(--text)}.menu-item svg{width:17px;height:17px}.menu-item.danger{color:#b53249}.menu-item.danger:hover{background:#d1495b14}.pad{padding:24px 28px 64px;overflow-y:auto;height:100%}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);position:relative;box-shadow:var(--shadow-sm)}.card-h{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}.card-h h3{margin:0;font-size:14px;font-weight:680;letter-spacing:-.2px}.card-h .sub{font-size:11.5px;color:var(--text3);font-weight:500}.grid{display:grid;gap:18px}.chip{font-size:11px;font-weight:650;padding:3px 10px;border-radius:20px;background:var(--surface3);color:var(--text2)}.chip.green{background:#1a9e6b1f;color:#0f7a52}.chip.amber{background:#d98e2724;color:#a86a13}.chip.red{background:#d1495b1f;color:#b53249}.section-title{font-size:11.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--text3);margin:4px 2px 14px}.kpi{padding:20px}.kpi .label{font-size:12.5px;color:var(--text2);font-weight:600;display:flex;align-items:center;gap:7px}.kpi .val{font-size:32px;font-weight:740;letter-spacing:-1.2px;margin-top:9px;line-height:1;font-variant-numeric:tabular-nums}.kpi .delta{font-size:12px;font-weight:650;margin-top:9px;display:flex;align-items:center;gap:5px;color:var(--text3)}.kpi .delta.up{color:#0f7a52}.kpi .delta.down{color:#b53249}.tbl-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th{position:sticky;top:0;background:var(--surface2);text-align:left;padding:12px 15px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;cursor:pointer;border-bottom:1px solid var(--border);z-index:1}table.data th:hover{color:var(--text)}table.data td{padding:11px 15px;border-bottom:1px solid var(--border);white-space:nowrap;color:var(--text)}table.data tr:last-child td{border-bottom:none}table.data tr:hover td{background:var(--surface2)}.pill-status{font-size:11px;font-weight:650;padding:2px 9px;border-radius:20px}.toolbar{display:flex;gap:11px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.input{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:10px 14px;color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:.15s;box-shadow:var(--shadow-sm)}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0e9f761f}.input::placeholder{color:var(--text3)}.btn{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:9px 15px;font-size:13px;font-weight:600;color:var(--text);display:inline-flex;align-items:center;gap:8px;transition:.15s;box-shadow:var(--shadow-sm);cursor:pointer}.btn:hover{border-color:var(--border2);background:var(--surface2)}.btn svg{width:16px;height:16px}.btn.primary{background:var(--brand);color:#fff;border:none;box-shadow:0 4px 12px #0e9f7647}.btn.primary:hover{background:var(--brand-ink)}.pager{display:flex;gap:6px;align-items:center;justify-content:flex-end;margin-top:14px;font-size:13px;color:var(--text2)}.pager button{width:33px;height:33px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text2);box-shadow:var(--shadow-sm);cursor:pointer}.pager button:hover:not(:disabled){border-color:var(--border2);color:var(--text)}.pager button:disabled{opacity:.4;cursor:default}.bar-row{display:flex;align-items:center;gap:11px;margin:8px 0;font-size:12.5px}.bar-row .nm{width:152px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:none}.bar-track{flex:1;height:9px;background:var(--surface3);border-radius:5px;overflow:hidden}.bar-fill{height:100%;border-radius:5px;transform-origin:left;animation:growbar .7s cubic-bezier(.22,1,.36,1)}@keyframes growbar{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.bar-row .vv{width:76px;text-align:right;font-family:var(--mono);font-weight:650;flex:none;color:var(--text)}.stat{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:14px 15px}.stat .l{font-size:11px;color:var(--text3);font-weight:600}.stat .v{font-size:20px;font-weight:740;letter-spacing:-.6px;margin-top:6px;font-variant-numeric:tabular-nums}.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:20px}.merch-row{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}.merch-row:last-child{border-bottom:none}.merch-rank{width:23px;height:23px;border-radius:7px;background:var(--surface3);display:grid;place-items:center;font-size:11px;font-weight:700;color:var(--text2);flex:none}.dr-sec{margin-bottom:22px}.dr-sec h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text3);margin:0 0 11px}.sql-editor{width:100%;min-height:154px;background:var(--surface2);border:1px solid var(--border);border-radius:13px;padding:16px 18px;color:#0b3b2c;font-family:var(--mono);font-size:13.5px;line-height:1.7;outline:none;resize:vertical;-moz-tab-size:2;tab-size:2}.sql-editor:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0e9f761f}.sql-presets{display:flex;flex-wrap:wrap;gap:8px;margin:13px 0}.preset{font-size:12px;font-weight:550;padding:6px 13px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text2);transition:.15s;cursor:pointer}.preset:hover{border-color:var(--brand);color:var(--brand-ink);background:var(--brand-soft)}.sql-msg{font-size:12.5px;font-family:var(--mono);padding:10px 14px;border-radius:10px;margin-top:13px}.sql-msg.ok{background:#1a9e6b1a;color:#0f7a52}.sql-msg.err{background:#d1495b1a;color:#b53249}.heatcell{stroke:#fff;stroke-width:1.5}.skel{background:linear-gradient(90deg,var(--surface3) 25%,var(--surface2) 37%,var(--surface3) 63%);background-size:400% 100%;animation:shimmer 1.4s infinite;border-radius:8px}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes drawline{0%{stroke-dashoffset:1}to{stroke-dashoffset:0}}@keyframes slidein{0%{opacity:0;transform:translate(14px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.05ms!important}}.maplibregl-popup-content{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);font-family:var(--sans);padding:12px 14px;font-size:12px}.maplibregl-popup-tip{display:none}.maplibregl-ctrl-group{box-shadow:var(--shadow)!important;border:1px solid var(--border)!important;border-radius:11px!important;overflow:hidden}.maplibregl-ctrl-bottom-left{z-index:6}.maplibregl-ctrl-bottom-left .maplibregl-ctrl{margin:0 0 12px 12px}.pulse-marker{width:13px;height:13px;border-radius:50%;background:var(--brand);position:relative;box-shadow:0 0 0 2px #fff,0 1px 4px #00000040}.pulse-marker:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:2px solid var(--brand);animation:pmpulse 1.6s ease-out infinite}@keyframes pmpulse{0%{transform:scale(.6);opacity:.85}to{transform:scale(3.4);opacity:0}}.login-wrap{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:1000;background:radial-gradient(1100px 560px at 72% -12%,#e8f6f0,transparent),radial-gradient(900px 500px at 10% 110%,#e9edff,transparent),linear-gradient(180deg,#f7f8fa,#eceef2);transition:opacity .45s cubic-bezier(.22,1,.36,1)}.login-wrap.hide{opacity:0;pointer-events:none}.login-card{width:404px;max-width:92vw;background:var(--surface);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-lg);padding:36px 34px;animation:pop .5s cubic-bezier(.22,1,.36,1)}@keyframes pop{0%{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}.login-card h1{font-size:23px;font-weight:740;letter-spacing:-.6px;margin:18px 0 5px}.login-card .sub{color:var(--text3);font-size:13px;margin:0 0 26px}.login-logo{width:56px;height:56px;border-radius:16px;background:var(--brandgrad);display:grid;place-items:center;box-shadow:0 8px 22px #0e9f7659}.login-logo svg{width:31px;height:31px;color:#fff}.login-card label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin:0 0 7px}.login-card input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:12px 14px;font-size:14px;margin-bottom:15px;outline:none;font-family:inherit;color:var(--text)}.login-card input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0e9f761f}.login-btn{width:100%;background:var(--brand);color:#fff;border-radius:13px;padding:13px;font-size:14px;font-weight:650;box-shadow:0 6px 16px #0e9f764d;transition:.15s;margin-top:6px}.login-btn:hover{background:var(--brand-ink)}.login-err{background:#d1495b1a;color:#b53249;font-size:12.5px;padding:10px 13px;border-radius:11px;margin-bottom:14px}.login-hint{margin-top:20px;font-size:11.5px;color:var(--text3);text-align:center;line-height:1.7}.login-hint code{background:var(--surface3);padding:1px 6px;border-radius:6px;font-family:var(--mono);color:var(--text2);font-size:11px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.shake{animation:shake .35s}.placeholder{display:grid;place-items:center;height:100%;color:var(--text3);font-size:14px;text-align:center;padding:40px}.map-panel{position:absolute;background:#ffffffc7;-webkit-backdrop-filter:blur(22px) saturate(1.6);backdrop-filter:blur(22px) saturate(1.6);border:1px solid rgba(255,255,255,.7);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:5}.mc-sec{padding:14px 16px;border-bottom:1px solid var(--border)}.mc-sec:last-child{border-bottom:none}.mc-title{font-size:10.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--text3);margin-bottom:11px}.basemap-row{display:flex;gap:7px}.bm{flex:1;border:1px solid var(--border);border-radius:9px;padding:8px 0;text-align:center;font-size:11px;font-weight:650;color:var(--text2);background:var(--surface);transition:.15s;cursor:pointer}.bm:hover{border-color:var(--border2)}.bm.on{border-color:var(--brand);color:var(--brand-ink);background:var(--brand-soft)}.metric-list{display:flex;flex-direction:column;gap:2px}.metric-item{display:flex;align-items:center;gap:9px;padding:8px 9px;border-radius:9px;font-size:12.5px;font-weight:550;color:var(--text2);transition:.13s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.metric-item:hover{background:var(--surface3);color:var(--text)}.metric-item.on{background:var(--brand-soft);color:var(--brand-ink);font-weight:650}.metric-item .sw{width:11px;height:11px;border-radius:3px;flex:none}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:12.5px;font-weight:550;color:var(--text2)}.sw-toggle{width:38px;height:22px;border-radius:20px;background:#d2d6dd;position:relative;transition:.2s;flex:none;cursor:pointer}.sw-toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s;box-shadow:var(--shadow-sm)}.sw-toggle.on{background:var(--brand)}.sw-toggle.on:after{left:18px}.legend-bar{height:10px;border-radius:5px;margin:9px 0 6px}.legend-scale{display:flex;justify-content:space-between;font-size:10.5px;color:var(--text3);font-family:var(--mono)}.lt-h{padding:13px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.lt-h .t{font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;color:var(--text2)}.lt-feed{overflow-y:auto;padding:6px;flex:1}.lt-item{display:flex;gap:10px;padding:9px 10px;border-radius:10px;align-items:center;animation:slidein .35s cubic-bezier(.22,1,.36,1)}.lt-item:hover{background:var(--surface3)}.lt-dot{width:9px;height:9px;border-radius:50%;flex:none}.lt-main{flex:1;min-width:0}.lt-main .a{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lt-main .b{font-size:11px;color:var(--text3)}.lt-val{font-family:var(--mono);font-size:12.5px;font-weight:650;color:var(--brand-ink)}.ms{padding:12px 18px;border-right:1px solid var(--border);text-align:center}.ms:last-child{border-right:none}.ms .v{font-size:19px;font-weight:740;font-variant-numeric:tabular-nums;letter-spacing:-.6px}.ms .l{font-size:9.5px;color:var(--text3);font-weight:650;text-transform:uppercase;letter-spacing:.3px;margin-top:3px}.zone-drawer{position:absolute;top:0;right:0;bottom:0;width:438px;max-width:93vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:20;overflow-y:auto;transform:translate(100%);transition:transform .36s cubic-bezier(.22,1,.36,1)}.zone-drawer.open{transform:none}@keyframes slideFromRight{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:none}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.inline-code{font-family:var(--mono);font-size:12px;background:var(--surface3);padding:2px 6px;border-radius:5px;color:var(--text2)}.dr-head{padding:24px 24px 20px;border-bottom:1px solid var(--border);position:relative}.dr-name{font-size:20px;font-weight:740;letter-spacing:-.5px;margin-top:8px;line-height:1.2}.dr-hoods{font-size:12.5px;color:var(--text3);margin-top:6px;line-height:1.5}.dr-body{padding:22px 22px 40px}
