body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;margin:0;padding:20px;box-sizing:border-box;height:100vh;overflow:hidden;display:flex;flex-direction:column}#mapIntegrityPanel{display:none!important}body.embed-mode>h2,body.embed-mode #pageDescription,body.embed-mode .controls-row,body.embed-mode .map-controls{display:none!important}body.embed-mode{margin:0;padding:0}.map-wrap{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;align-items:stretch;flex:1;min-height:0;overflow:hidden;overscroll-behavior:contain}.leftcol{min-height:0;min-width:0}#svgHost{position:sticky;top:12px}.sidebar{min-height:0;width:100%;overflow-y:auto;overflow-x:hidden;max-height:100%;padding-right:6px;display:flex;flex-direction:column}.controls-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:8px 0 14px}.controls-row label{display:flex;gap:8px;align-items:center}select{padding:8px 10px;border:1px solid #ddd;border-radius:10px;background:#fff;min-width:240px}#worldMapWrap{width:100%;max-width:1200px;margin:0;border:1px solid #eee;border-radius:16px;overflow:hidden;background:#fff;position:relative}#worldMapWrap svg{width:100%!important;height:auto!important;display:block;will-change:transform;transform-origin:0 0;touch-action:none}.map-controls{position:absolute;top:10px;left:10px;display:flex;gap:8px;z-index:5;background:rgba(255,255,255,.92);border:1px solid #e5e7eb;border-radius:12px;padding:8px;box-shadow:0 6px 18px rgba(0,0,0,.08)}.map-controls button{border:1px solid #d1d5db;background:#fff;border-radius:10px;padding:8px 10px;font-weight:700;cursor:pointer;line-height:1;min-width:42px}.map-controls button:hover{background:#f9fafb}.map-controls button:active{transform:translateY(1px)}.legend{border:1px solid #ddd;border-radius:12px;padding:12px;background:#fff}.legend h3{margin:0 0 10px;font-size:16px}.legend .item{display:grid;grid-template-columns:18px 1fr auto;gap:10px;align-items:center;padding:6px 0;border-bottom:1px solid #f0f0f0;cursor:pointer}.legend .item:last-child{border-bottom:0}.swatch{width:18px;height:18px;border-radius:4px;border:1px solid rgba(0,0,0,.15)}.legend label{cursor:pointer;user-select:none}.legend small{color:#666}.legend button{display:none!important}.legend input[type="checkbox"]{display:none!important}.legend.org-legend,#orgLegend{order:1}#continentLegend{order:2}.legend.country-legend,#countryLegend{order:3}.country-legend-list{max-height:55vh;overflow:auto;margin:0;padding:0;list-style:none}.country-legend-list li{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:center;padding:6px 0;border-bottom:1px solid #f0f0f0}.country-legend-list li:last-child{border-bottom:0}#viewerWrap{margin-top:12px;max-width:100%}#caseViewer{width:100%!important}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;z-index:99999;padding:16px}.modal-backdrop.open{display:flex}.modal{width:min(560px,100%);background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 18px 50px rgba(0,0,0,.25);overflow:hidden;max-height:calc(100vh - 32px);display:flex;flex-direction:column}.modal header{padding:14px 16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;gap:10px}.modal header h4{margin:0;font-size:16px}.modal .modal-body{padding:14px 16px 18px;font-size:14px;line-height:1.4;overflow:auto}.modal .close-btn{border:1px solid #d1d5db;background:#fff;border-radius:10px;padding:6px 10px;font-weight:700;cursor:pointer}.modal .close-btn:hover{background:#f9fafb}#caseModalBody{padding:0;overflow:hidden}#caseViewer{display:block;width:100%;height:min(78vh,820px);border:0}.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid #e5e7eb;border-radius:999px;background:#fafafa;font-size:12px;cursor:pointer;user-select:none;white-space:nowrap}.chip:hover{background:#f3f4f6}svg .bg,svg .ocean,svg .water{fill:#d6ecff!important}svg .country{fill:#ececec;stroke:#000;stroke-width:.35;vector-effect:non-scaling-stroke}svg .country:hover{fill:inherit!important;stroke-width:1.2}svg .country:focus{outline:0}@media(max-width:980px){.map-wrap{grid-template-columns:1fr}.sidebar{margin-top:12px}.case-panel{margin-top:12px}}