:root{--bg:#f7f8fa;--panel:#fff;--panel-2:#f3f4f6;--border:#e5e7eb;--text:#111827;--muted:#6b7280;--accent:#2563eb;--hover:#eef2f7;--state-default:#e5e7eb;--state-stroke:#111827}*{box-sizing:border-box}html,body{height:100%;color:var(--text);margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}body{background:var(--bg)}.app{grid-template-rows:minmax(0,1fr);grid-template-columns:320px 1fr;height:100vh;display:grid;overflow:hidden}.sidebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;gap:20px;padding:20px;display:flex;overflow-y:auto}.sidebar-header h1{letter-spacing:-.01em;margin:0 0 4px;font-size:20px}.hint{color:var(--muted);margin:0;font-size:13px}.panel{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:12px}.panel-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px;font-size:12px}.team-list{flex-direction:column;gap:6px;margin:0 0 12px;padding:0;list-style:none;display:flex}.team-item{background:var(--panel);cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;transition:background .12s,border-color .12s;display:flex}.team-item:hover{background:var(--hover)}.team-item.selected{border-color:var(--accent);background:var(--hover)}.team-swatch{border:1px solid #0000001f;border-radius:5px;flex-shrink:0;width:18px;height:18px}.team-name{flex:1;font-size:14px}.team-count{color:var(--muted);background:var(--panel-2);border-radius:999px;padding:2px 8px;font-size:12px}.team-menu-wrap{position:relative}.team-menu-btn{color:var(--muted);cursor:pointer;letter-spacing:.04em;background:0 0;border:none;border-radius:4px;padding:2px 8px;font-size:18px;line-height:1}.team-menu-btn:hover{color:var(--text);background:var(--hover)}.team-menu{z-index:20;background:var(--panel);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:2px;min-width:180px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0000001f}.team-menu-item{text-align:left;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 10px;font-size:13px}.team-menu-item:hover{background:var(--hover)}.team-menu-item.danger{color:#b91c1c}.team-menu-item.danger:hover{background:#ef44441a}.team-menu-back{color:var(--muted);border-bottom:1px solid var(--border);border-radius:0;margin-bottom:2px;font-size:12px}.team-menu-victim{align-items:center;gap:8px;display:flex}.menu-dot{border:1px solid #0003;border-radius:999px;flex-shrink:0;width:10px;height:10px}.menu-victim-name{flex:1}.menu-count{color:var(--muted);font-variant:tabular-nums;font-size:12px}.add-team{grid-template-columns:1fr 36px auto;gap:6px;display:grid}.add-team input[type=text]{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:6px;min-width:0;padding:6px 10px;font-size:13px}.add-team input[type=text]:focus{outline:1px solid var(--accent);border-color:var(--accent)}.add-team input[type=color]{border:1px solid var(--border);background:var(--panel);cursor:pointer;border-radius:6px;width:36px;height:32px;padding:0}.add-team button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600}.add-team button:hover{filter:brightness(1.1)}.state-search{background:var(--panel);width:100%;color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px}.state-search:focus{outline:1px solid var(--accent);border-color:var(--accent)}.state-results{flex-direction:column;gap:2px;max-height:200px;margin:8px 0 0;padding:0;list-style:none;display:flex;overflow-y:auto}.state-results:empty{display:none}.state-result{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:13px;display:flex}.state-result:hover{background:var(--hover)}.state-result .dot{background:var(--state-default);border:1px solid #0003;border-radius:999px;flex-shrink:0;width:10px;height:10px}.state-result .code{color:var(--muted);font-variant:tabular-nums;margin-left:auto;font-size:11px}.tool-btn{background:var(--panel);width:100%;color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:8px;margin-bottom:6px;padding:8px 12px;font-size:13px;display:block}.tool-btn:last-child{margin-bottom:0}.tool-btn:hover{background:var(--hover)}.tool-btn.selected{border-color:var(--accent);background:var(--hover)}.tool-btn.danger:hover{color:#f87171;background:#f871711a;border-color:#f87171}.legend{color:var(--muted);font-size:12px}.legend:empty{display:none}.attribution{color:var(--muted);text-align:center;margin-top:auto;padding-top:12px;font-size:11px}.attribution a{color:var(--muted);text-underline-offset:2px;-webkit-text-decoration:underline #00000026;text-decoration:underline #00000026}.attribution a:hover{color:var(--text)}.legend-row{align-items:center;gap:8px;padding:4px 0;display:flex}.legend-swatch{border-radius:3px;width:12px;height:12px}.map-area{flex-direction:column;min-width:0;min-height:0;padding:20px;display:flex;overflow:hidden}.map-header{justify-content:space-between;align-items:center;padding:0 8px 12px;font-size:14px;display:flex}.hover-state{color:var(--muted)}.hover-state.active{color:var(--text);font-weight:600}.selected-team{color:var(--muted);align-items:center;gap:8px;display:inline-flex}.selected-team .swatch{border:1px solid #0000001f;border-radius:4px;width:14px;height:14px}.map-container{background:var(--panel);border:1px solid var(--border);border-radius:12px;flex:1;justify-content:center;align-items:center;min-height:0;padding:16px;display:flex;overflow:hidden}.map-container svg{width:100%;height:100%;max-height:100%}.map-container svg path{fill:var(--state-default);stroke:var(--state-stroke);stroke-width:1px;vector-effect:non-scaling-stroke;cursor:pointer;transition:fill .1s}.map-container svg path:hover{filter:brightness(1.1)}body.obs-mode{background:0 0}body.obs-mode .sidebar,body.obs-mode .map-header{display:none}body.obs-mode .app{grid-template-columns:1fr}body.obs-mode .map-area{padding:0}body.obs-mode .map-container{background:0 0;border:none;border-radius:0;padding:0}body.obs-mode .map-container svg path{cursor:default;fill:#fff;stroke-width:3px;stroke-linejoin:round;pointer-events:none;transition:none}body.obs-mode .map-container svg path:hover{filter:none}.obs-preview-link{text-align:center;text-decoration:none;display:block}.obs-steps{color:var(--muted);margin:12px 0 0;padding-left:18px;font-size:12px;line-height:1.5}.obs-steps li{margin-bottom:6px}.obs-steps li:last-child{margin-bottom:0}.obs-steps strong{color:var(--text);font-weight:600}#obs-status.live{color:#16a34a}.obs-operator-btn{color:var(--muted);font-size:12px}.obs-operator-btn:hover{color:var(--text)}.obs-note{margin-top:10px}.obs-note code{background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:1px 4px;font-size:11px}.copy-feedback{color:#16a34a}
