:root{font-family:Segoe UI,Helvetica Neue,Arial,sans-serif;color:#0f172a;background:radial-gradient(circle at top,rgba(153,196,208,.45),transparent 34%),linear-gradient(135deg,#f8fafc,#e6eef5)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}#root{min-height:100vh}.app-shell{display:grid;grid-template-columns:320px minmax(0,1fr);min-height:100vh}.sidebar{display:flex;flex-direction:column;gap:16px;padding:24px;border-right:1px solid rgba(15,23,42,.08);background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.workspace{padding:24px}.map-stage{position:relative}.workspace-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.workspace-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.map-controls{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.projection-control{display:grid;gap:4px;min-width:168px;color:#486581;font-size:.82rem}.projection-control select{padding:10px 12px;border:1px solid #cbd5e1;border-radius:999px;background:#fffffff5;color:#0f172a}.projection-slider-control{min-width:180px}.projection-slider-control input[type=range]{width:100%;margin:0}.eyebrow{margin:0 0 6px;text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:#486581}.panel{padding:16px;border:1px solid rgba(71,85,105,.16);border-radius:18px;background:#ffffffeb;box-shadow:0 16px 40px #0f172a0d}.panel h1,.panel h2,.workspace h2{margin:0}.muted{color:#486581;line-height:1.5}.field{display:grid;gap:8px;margin-bottom:14px}.field input,.field select{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:12px;background:#fff}.field input[type=color]{height:44px;padding:4px}.field input[type=range]{padding:0}.style-help{margin:0 0 14px;font-size:.92rem}.country-list-shell{position:relative}.country-list{display:grid;gap:8px;max-height:192px;overflow-y:auto;padding-right:4px}.country-list-ellipsis{position:absolute;left:0;right:10px;display:flex;align-items:center;justify-content:center;gap:6px;height:28px;background:linear-gradient(to bottom,#fffffff5,#ffffffb8);pointer-events:none}.country-list-ellipsis.top{top:0}.country-list-ellipsis.bottom{bottom:0;background:linear-gradient(to top,#fffffff5,#ffffffb8)}.country-list-ellipsis span{width:5px;height:5px;border-radius:999px;background:#486581b8}.country-list-meta{display:flex;align-items:center;justify-content:space-between;margin:-2px 0 12px;color:#486581;font-size:.88rem}.selected-country-summary{display:grid;gap:10px;margin-bottom:14px;padding:12px;border-radius:14px;background:#f3f8fb;border:1px solid rgba(72,101,129,.14)}.selected-country-summary-label{font-size:.88rem;font-weight:600;color:#1f2937}.selected-country-chips{display:flex;flex-wrap:wrap;gap:8px}.selected-country-actions{display:grid;gap:10px}.selected-country-style-field{gap:6px;margin:0}.selected-country-style-field span{font-size:.82rem;color:#486581}.selected-country-chip{padding:6px 10px;border:0;border-radius:999px;background:#d7ecf3;color:#0f172a;cursor:pointer}.country-button,.ghost-button,.export-button,.selected-country-chip{border:0;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.country-button{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;background:#edf2f7;color:#0f172a}.country-button.selected{background:#c9e7f0}.country-code{color:#486581;font-size:.82rem}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.ghost-button{padding:8px 12px;border-radius:999px;background:#edf2f7}.save-style-button{width:100%;margin-bottom:12px;padding:12px 16px;border:0;border-radius:14px;background:#d7ecf3;color:#0f172a;cursor:pointer;font-weight:600}.export-button{padding:12px 16px;border-radius:999px;background:#0f766e;color:#fff;font-weight:600;box-shadow:0 12px 24px #0f766e38}.country-button:hover,.ghost-button:hover,.export-button:hover,.selected-country-chip:hover,.save-style-button:hover{transform:translateY(-1px)}.map-svg{width:100%;height:calc(100vh - 120px);min-height:420px;border-radius:24px;border:1px solid rgba(71,85,105,.12);background:#ffffffb8;box-shadow:0 20px 60px #0f172a14}.country-hit-area{cursor:pointer;pointer-events:all}.country-path{transition:opacity .12s ease,stroke-width .12s ease}.country-path:hover{opacity:.88}.country-path.selected{filter:brightness(.98)}.country-selection-outline{opacity:.95;animation:country-selection-dash .9s linear infinite}.map-legend{position:absolute;z-index:2;min-width:220px;max-width:320px;padding:14px;border:1px solid rgba(71,85,105,.2);border-radius:18px;background:#fffffff0;box-shadow:0 18px 40px #0f172a24;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:grab;touch-action:none}.map-legend:active{cursor:grabbing}.map-legend-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.map-legend-header h3,.map-legend-eyebrow{margin:0}.map-legend-eyebrow{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#486581}.map-legend-size-controls{display:flex;gap:6px}.map-legend-size-controls .ghost-button{padding:6px 10px}.map-legend-list{display:grid;gap:10px}.map-legend-item{display:flex;align-items:center;gap:10px}.map-legend-swatch{width:52px;height:36px;flex:0 0 auto}.map-legend-copy{display:grid;gap:2px}.map-legend-copy span{font-size:.82rem;color:#486581}@keyframes country-selection-dash{0%{stroke-dashoffset:0}to{stroke-dashoffset:-24}}.style-library-empty{padding:14px;border:1px dashed rgba(72,101,129,.28);border-radius:14px;color:#486581;background:#f8fafce6}.style-preset-grid{display:grid;gap:10px}.style-preset-card{display:grid;gap:8px;padding:10px;border:1px solid rgba(71,85,105,.16);border-radius:16px;background:#ffffffeb}.style-preset-card.active{border-color:#0f766e8c;box-shadow:0 0 0 2px #0f766e1f}.style-preset-button{display:grid;gap:8px;padding:0;border:0;background:transparent;color:inherit;text-align:left;cursor:pointer}.style-preset-actions{display:flex;gap:8px;justify-content:space-between}.style-swatch{width:100%;height:56px}.style-preset-name{font-weight:600;color:#0f172a}.style-preset-meta{color:#486581;font-size:.86rem}.style-preset-delete{padding:6px 10px;border:0;border-radius:999px;background:#edf2f7;color:#486581;cursor:pointer}.style-preset-secondary{flex:1;padding:6px 10px;border:0;border-radius:999px;background:#dbeafe;color:#1d4ed8;cursor:pointer}.style-preset-secondary:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}@media (max-width: 980px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid rgba(15,23,42,.08)}.map-svg{height:60vh}.workspace-actions{justify-content:flex-start}}
