:root{--bg: #0f172a;--panel: #ffffff;--ink: #0f172a;--muted: #64748b;--line: #e2e8f0;--accent: #2563eb}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,PingFang TC,Microsoft JhengHei,Noto Sans TC,system-ui,sans-serif;color:var(--ink);background:#f1f5f9}.app{display:flex;flex-direction:column;height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;background:var(--bg);color:#fff;flex-shrink:0}.brand{display:flex;align-items:center;gap:14px}.logo{font-size:30px}.topbar h1{margin:0;font-size:20px;letter-spacing:.5px}.topbar p{margin:2px 0 0;font-size:13px;color:#cbd5e1}.body{flex:1;display:flex;min-height:0}.map-area{flex:1;position:relative;background:radial-gradient(circle at 50% 30%,#eef4fb,#dde7f3);min-width:0}.sidebar{width:340px;flex-shrink:0;background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden}.map-wrap{position:absolute;top:0;right:0;bottom:0;left:0}.op-label{fill:#111827;paint-order:stroke;stroke:#fff;stroke-width:2.4px;stroke-linejoin:round;font-weight:700;pointer-events:none;font-family:inherit}.zoom-controls{position:absolute;left:14px;bottom:14px;display:flex;flex-direction:column;gap:6px}.zoom-controls button{width:40px;height:36px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:18px;cursor:pointer;color:var(--ink);box-shadow:0 1px 3px #0000001f}.zoom-controls .reset{font-size:13px}.zoom-controls button:hover{background:#f1f5f9}.legend{position:absolute;right:14px;top:14px;background:#fffffff0;border:1px solid var(--line);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:6px;font-size:12px;box-shadow:0 2px 10px #00000014;max-width:230px}.legend-item{display:flex;align-items:center;gap:7px}.swatch{width:14px;height:14px;border-radius:3px;display:inline-block}.legend-hint{color:var(--muted);font-size:11px;line-height:1.4}.tooltip{position:fixed;z-index:50;pointer-events:none;max-width:260px;background:#0f172a;color:#fff;border-radius:10px;padding:10px 12px;box-shadow:0 6px 24px #0000004d;font-size:13px}.tt-country{font-weight:700;margin-bottom:4px}.tt-en{color:#94a3b8;font-weight:400;font-size:11px}.tt-op{display:flex;align-items:center;gap:7px;font-weight:600}.tt-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.tt-metric{color:#cbd5e1;font-size:11px;margin-top:5px;line-height:1.4}.tt-nodata{color:#94a3b8}.list{display:flex;flex-direction:column;min-height:0;height:100%}.search{margin:14px;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;outline:none}.search:focus{border-color:var(--accent)}.list ul,.detail{list-style:none;margin:0;padding:0;overflow-y:auto}.list ul{padding:0 8px 12px}.list li{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;font-size:13px}.list li:hover{background:#f1f5f9}.li-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.li-country{font-weight:600}.li-op{margin-left:auto;color:var(--muted);font-size:12px}.list li.empty{color:var(--muted);justify-content:center;cursor:default}.detail{padding:16px;height:100%}.back{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:0;margin-bottom:14px}.detail-head h2{margin:0;font-size:22px}.detail-en{color:var(--muted);font-size:12px}.op-card{display:flex;align-items:center;gap:12px;margin:16px 0 12px;padding:14px;border:2px solid;border-radius:12px;background:#f8fafc}.op-dot{width:22px;height:22px;border-radius:50%;flex-shrink:0}.op-label-sm{font-size:11px;color:var(--muted);margin-bottom:2px}.op-name{font-size:18px;font-weight:700}.op-metric{color:#334155;font-size:13px;line-height:1.6}@media (max-width: 820px){.body{flex-direction:column}.sidebar{width:100%;height:42%;border-left:none;border-top:1px solid var(--line)}}
