: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,.app-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)}.sidebar-reset-row{display:flex;justify-content:flex-start;margin-bottom:10px}.sidebar-reset-button{width:34px;height:34px;border:1px solid rgba(51,65,85,.42);border-radius:999px;background:#edf2f7;color:#0f172a;cursor:pointer;font-size:1rem;line-height:1;transition:transform .12s ease,box-shadow .12s ease,background .12s ease}.sidebar-reset-button:hover{transform:translateY(-1px)}.workspace{padding:24px}.map-stage{position:relative;margin-bottom:18px}.workspace-header{margin-bottom:18px}.workspace-header-groups{display:flex;flex-wrap:wrap;gap:12px 18px;align-items:flex-end;justify-content:flex-start}.workspace-header-group{position:relative;flex:0 0 auto;align-self:flex-end}.workspace-header-group:not(:first-child){padding-left:18px}.workspace-header-group:not(:first-child):before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:1px;background:#47556929}.workspace-title-block{display:grid;gap:2px;flex:0 0 auto}.workspace-style-library{margin-top:0}.toolbar-checkbox{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid rgba(71,85,105,.16);border-radius:999px;background:#ffffffeb;color:#0f172a;font-size:.82rem;line-height:1.2;box-shadow:0 8px 18px #0f172a0d}.toolbar-checkbox input{width:16px;height:16px;margin:0;accent-color:#0f766e}.toolbar-checkbox span{white-space:nowrap}.export-controls{display:flex;align-items:flex-end;gap:8px;flex-wrap:nowrap;justify-content:flex-start;flex:0 0 auto}.projection-control{display:grid;gap:4px;min-width:168px;color:#486581;font-size:.82rem}.projection-settings-group{display:flex;flex-wrap:nowrap;gap:8px;align-items:flex-end;align-self:flex-end}.projection-control select,.export-format-control select{padding:10px 12px;border:1px solid #cbd5e1;border-radius:999px;background:#fffffff5;color:#0f172a}.export-format-control{display:grid;gap:4px;min-width:104px;color:#486581;font-size:.82rem}.export-format-availability{font-size:.72rem;color:#6b7f92;line-height:1.2}.projection-slider-control{min-width:180px}.projection-slider-control input[type=range]{width:100%;margin:0}.projection-center-controls{display:flex;flex-wrap:nowrap;gap:6px;justify-content:flex-start;align-items:flex-end;min-width:0;flex:0 0 auto}.projection-center-controls .projection-control{font-size:.76rem}.projection-center-reset{align-self:flex-end;margin-left:-2px;box-shadow:none}.projection-center-reset.is-active,.map-view-reset.is-active{background:#d8e2ec;border-color:#33415594}.map-view-actions{display:grid;gap:8px;grid-template-columns:repeat(3,auto);align-items:flex-end;justify-content:flex-start}.map-view-group{min-width:0}.map-view-actions .ghost-button:nth-child(-n+2){min-width:3.75rem}.map-view-hint-note{font-size:.72rem;color:#6b7f92}.projection-center-group{min-width:0}.pattern-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.pattern-option{display:grid;gap:8px;padding:10px;border:1px solid rgba(51,65,85,.42);border-radius:14px;background:#ffffffeb;color:#0f172a;text-align:left}.pattern-option.active{border-color:#0f766e8c;box-shadow:0 0 0 2px #0f766e1f}.pattern-option span{font-size:.82rem;font-weight:600}.pattern-option-swatch{width:100%;height:48px}.eyebrow{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:#486581}.workspace-title-block h2{font-size:clamp(1.4rem,1.2rem + .8vw,1.9rem);line-height:1.05}.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=range]{padding:0}.color-editor-field{position:relative}.color-editor-row{display:grid;grid-template-columns:58px 110px;gap:10px}.color-editor-trigger{display:flex;align-items:center;justify-content:center;width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;color:#0f172a;text-align:left}.color-editor-swatch{width:28px;height:28px;border-radius:999px;border:1px solid rgba(15,23,42,.12);box-shadow:inset 0 0 0 1px #ffffff38;flex:0 0 auto}.color-editor-input{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;color:#0f172a;text-transform:uppercase}.color-editor-popover{position:absolute;top:calc(100% + 10px);left:0;z-index:40;padding:14px;border:1px solid rgba(71,85,105,.18);border-radius:18px;background:#fffffffa;box-shadow:0 18px 36px #0f172a24}.color-editor-popover .react-colorful{width:220px;height:180px}.color-editor-popover .react-colorful__saturation{border-bottom:12px solid #fff;border-radius:12px 12px 0 0}.color-editor-popover .react-colorful__hue{height:18px;border-radius:999px;margin-top:12px}.color-editor-popover .react-colorful__pointer{width:18px;height:18px}.color-editor-popover-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.color-editor-confirm{background:#d7ecf3;border-color:#0e749057}.checkbox-field{display:flex;align-items:center;gap:10px;margin-bottom:14px;color:#0f172a}.checkbox-field input{width:16px;height:16px;margin: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:1px solid rgba(51,65,85,.42);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:1px solid rgba(51,65,85,.42);border-radius:999px;background:#edf2f7}.save-style-button{width:100%;margin-bottom:12px;padding:12px 16px;border:1px solid rgba(51,65,85,.42);border-radius:14px;background:#d7ecf3;color:#0f172a;cursor:pointer;font-weight:600}.style-editor-actions{display:grid;gap:10px}.style-editor-actions.has-cancel{grid-template-columns:minmax(0,1fr) auto;align-items:center}.sidebar-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:28px;background:#0f172a57;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.style-editor-panel-modal{width:min(560px,calc(100vw - 32px));max-height:calc(100vh - 40px);overflow:auto;box-shadow:0 28px 60px #0f172a2e}.export-button{padding:12px 16px;border:1px solid rgba(51,65,85,.5);border-radius:999px;background:#0f766e;color:#fff;font-weight:600;box-shadow:0 12px 24px #0f766e38}.export-button:disabled{background:#94a3b8;border-color:#47556966;box-shadow:none;cursor:not-allowed}.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(148,163,184,.16);background:#ffffffe6;box-shadow:0 16px 40px #0f172a0d}.globe-svg{background:radial-gradient(circle at 50% 44%,rgba(226,232,240,.62),transparent 28%),#ffffffeb}.country-hit-area{cursor:pointer;pointer-events:all}.country-path{transition:opacity .12s ease,stroke-width .12s ease,fill .12s ease,stroke .12s ease}.country-path:hover{opacity:.96}.country-path.selected{filter:brightness(.99) saturate(1.02)}.country-selection-outline{opacity:.82;animation:country-selection-dash .9s linear infinite}.map-legend{position:absolute;z-index:2;min-width:280px;max-width:380px;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[data-subtle-shadow=true]{box-shadow:0 10px 24px #0f172a17}.map-legend[data-subtle-shadow=false]{box-shadow:none}.map-legend[data-appearance=paper]{box-shadow:0 16px 36px #78716c29;-webkit-backdrop-filter:none;backdrop-filter:none}.map-legend[data-appearance=paper][data-subtle-shadow=true]{box-shadow:0 9px 22px #78716c1a}.map-legend[data-appearance=paper][data-subtle-shadow=false]{box-shadow:none}.map-legend[data-appearance=slate]{box-shadow:0 22px 48px #0f172a3d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.map-legend[data-appearance=slate][data-subtle-shadow=true]{box-shadow:0 12px 28px #0f172a29}.map-legend[data-appearance=slate][data-subtle-shadow=false]{box-shadow:none}.map-legend:active{cursor:grabbing}.map-legend-resize-handle{position:absolute;z-index:3}.map-legend-resize-handle.right{top:16px;right:-8px;bottom:16px;width:16px;cursor:ew-resize}.map-legend-resize-handle.bottom{left:16px;right:16px;bottom:-8px;height:16px;cursor:ns-resize}.map-legend-resize-handle.corner{right:-8px;bottom:-8px;width:18px;height:18px;cursor:nwse-resize}.map-legend-header{display:flex;align-items:flex-start;margin-bottom:12px}.map-legend-title-group{min-width:0;flex:1;display:flex;align-items:flex-start}.map-legend-header h3,.map-legend-eyebrow{margin:0}.map-legend-header h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-legend-eyebrow{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#486581}.map-legend-size-controls{position:absolute;top:14px;left:calc(100% + 10px);display:flex;flex-direction:column;gap:6px}.map-legend-size-controls .ghost-button{min-width:38px;padding:6px 10px;background:#edf2f780;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.map-legend-size-controls .ghost-button:hover{background:#edf2f7a8}.map-legend-list{display:grid;gap:10px}.map-legend-item{display:flex;align-items:center;gap:10px;min-width:0}.map-legend-swatch{width:52px;height:36px;flex:0 0 auto}.map-legend-copy{display:grid;flex:1 1 0;gap:2px;min-width:0}.map-legend-copy strong{color:inherit}.map-legend-title-input,.map-legend-entry-input{display:block;min-width:0;max-width:100%;padding:0;border:0;background:transparent;color:inherit;font:inherit;font-weight:700;line-height:1.1;text-align:left}.map-legend-title-input{flex:0 1 auto;font-weight:800}.map-legend-entry-input{width:100%}.map-legend-title-input::placeholder,.map-legend-entry-input::placeholder{color:currentColor;opacity:1}.map-legend-title-input:focus,.map-legend-entry-input:focus{outline:none}.map-legend-copy span{font-size:.82rem;color:#486581}.style-preset-inline-name-input{display:block;width:100%;min-width:0;padding:0;border:0;background:transparent;color:#0f172a;font:inherit;font-size:1rem;font-weight:600;line-height:1.2;text-align:left}.style-preset-inline-name-input::placeholder{color:#0f172a;opacity:1}.style-preset-inline-name-input:focus{outline:none}@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;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.style-preset-card{display:grid;gap:10px;padding:10px;border:1px solid rgba(51,65,85,.42);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-preset-action-row{display:flex;gap:8px;width:100%}.style-swatch{width:100%;height:56px}.style-preset-meta{color:#486581;font-size:.86rem}.style-preset-delete{padding:6px 10px;border:1px solid rgba(51,65,85,.42);border-radius:999px;background:#edf2f7;color:#486581;cursor:pointer}.style-preset-secondary{flex:1;padding:6px 10px;border:1px solid rgba(51,65,85,.42);border-radius:999px;background:#dbeafe;color:#1d4ed8;cursor:pointer}.style-preset-edit{padding:6px 10px;border:1px solid rgba(51,65,85,.42);border-radius:999px;background:#f8fafc;color:#334155;cursor:pointer;font-size:1rem;line-height:1}.style-preset-secondary:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.site-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 24px 28px;color:#486581}.site-footer-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.site-footer a{color:inherit;text-decoration:none}.site-footer a:hover{text-decoration:underline}.site-footer-note{margin:0;font-size:.88rem}.legal-page{padding:40px 24px 16px}.legal-page-shell{max-width:860px;margin:0 auto;display:grid;gap:18px}.legal-page-shell h1{margin:0}.legal-card{padding:20px 22px;border:1px solid rgba(71,85,105,.14);border-radius:20px;background:#ffffffeb;box-shadow:0 16px 40px #0f172a0d}.legal-card h2{margin:0 0 10px}.legal-card p{margin:0 0 10px;line-height:1.6}.legal-card p:last-child{margin-bottom:0}.legal-note{color:#486581;font-size:.92rem}.cookie-banner{position:fixed;right:20px;bottom:20px;z-index:10;width:min(460px,calc(100vw - 32px));display:grid;gap:14px;padding:18px;border:1px solid rgba(15,23,42,.12);border-radius:20px;background:#fffffff5;box-shadow:0 20px 48px #0f172a29;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.cookie-banner-copy h2{margin:0 0 8px}.cookie-banner-copy p{margin:0 0 8px;line-height:1.5;color:#486581}.cookie-banner-note{font-size:.92rem}.cookie-banner-actions{display:flex;gap:8px;flex-wrap:wrap}@media (max-width: 980px){.workspace-header-groups{gap:14px}.workspace-header-group:not(:first-child){padding-left:14px}.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid rgba(15,23,42,.08)}.map-svg{height:60vh}.site-footer{flex-direction:column;align-items:flex-start}}
