html,body{height:100%;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial}.map-playground[data-astro-cid-gvmsxayn],#map{height:100%;width:100%;position:relative}#paintCanvas{position:absolute;left:0;top:0;width:100%;height:100%;z-index:500;pointer-events:none}.mapPanel{position:absolute;z-index:940;background:#f9fbfdeb;border:1px solid rgba(60,64,67,.2);border-radius:16px;box-shadow:0 10px 28px #00000029;backdrop-filter:blur(6px);overflow:hidden}.mapPanelHeader{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-bottom:1px solid rgba(60,64,67,.15)}.mapPanelTitle{font-size:12px;font-weight:800;letter-spacing:.2px;color:#1f1f1f}.mapPanelBody{padding:10px;display:flex;flex-direction:column;gap:10px}.mapPanel.collapsed .mapPanelBody{display:none}.listPanel{left:18px;top:98px;width:min(420px,calc(100vw - 20px));max-height:min(62vh,460px);background:linear-gradient(180deg,#090e16db,#0c121ed1);border:1px solid rgba(45,212,255,.28);box-shadow:0 18px 36px #00000073;border-radius:16px;backdrop-filter:blur(8px);color:#e5edf7}.listPanel .mapPanelHeader{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.14);background:#ffffff08}.listPanel .mapPanelTitle{font-size:13px;font-weight:800;color:#f2f7ff}.listPanel .listPanelCloseBtn{width:28px;height:28px;min-width:28px;padding:0;border-radius:10px;font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#4b1118f2,#2d0a10eb);border:1px solid rgba(252,165,165,.58);color:#fee2e2}.listPanel .listPanelCloseBtn:hover:not(:disabled){border-color:#fecacae6;color:#fff1f2}.listPanel .mapPanelBody{padding:10px 12px 12px;gap:10px}.selectedToolsPanel{right:14px;top:60px;width:108px;background:linear-gradient(180deg,#090e16db,#0c121ed1);border:1px solid rgba(45,212,255,.28);box-shadow:0 18px 36px #00000073;color:#e5edf7}.selectedToolsPanel .mapPanelHeader{border-bottom:1px solid rgba(255,255,255,.14);background:#ffffff08;cursor:grab;user-select:none;touch-action:none}.selectedToolsPanel.dragging .mapPanelHeader{cursor:grabbing}.selectedToolsPanel .mapPanelTitle{color:#f2f7ff;font-size:13px;letter-spacing:.3px;display:inline-flex;align-items:center;gap:6px}.selectedToolsPanel .mini{background:#111827eb;color:#d9e4f3;border-color:#94a3b873;font-weight:700}.selectedToolsPanel .iconOnlyBtn{width:30px;height:30px;min-width:30px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.listPanel .iconOnlyBtn{width:30px;height:30px;min-width:30px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:#111827eb;border:1px solid rgba(148,163,184,.45);color:#d9e4f3}.listPanel .hint{color:#d7e1ef;opacity:.94}.listPanel .pill{background:#94a3b833;color:#ecf2fb;border:1px solid rgba(148,163,184,.3);padding:3px 9px;font-weight:600}.verticalTools .row{flex-direction:column;align-items:center;gap:7px}.selectedToolsName{font-size:12px;font-weight:800;color:#f4f7ff;text-align:center;line-height:1.2;word-break:break-word;background:#38bdf824;border:1px solid rgba(125,211,252,.4);border-radius:10px;padding:6px 8px}.iconToolBtn{width:46px;height:46px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:linear-gradient(180deg,#1f2937,#111827);border:1px solid rgba(148,163,184,.42);color:#f8fafc;box-shadow:inset 0 1px #ffffff14,0 2px 6px #00000059}.iconToolBtn:hover:not(:disabled){border-color:#7dd3fccc;transform:translateY(-1px)}.iconToolBtn:active:not(:disabled){transform:translateY(0)}.selectedToolsPanel .iconToolBtn:disabled{opacity:.42;filter:grayscale(.25)}.iconToolBtn svg{pointer-events:none;display:block}.selectedToolsPanel #clearAllBtn{background:linear-gradient(180deg,#4b1118,#2a0a0f);border-color:#fca5a58c;color:#fecaca}.selectedToolsPanel #rotResetBtn{background:linear-gradient(180deg,#1d2550,#0f1638);border-color:#a5b4fc94;color:#dbe4ff}.selectedToolsPanel #duplicateBtn{background:linear-gradient(180deg,#2f174a,#1e1032);border-color:#d8b4fe99;color:#f2ddff}.selectedToolsPanel #restoreShapeBtn{background:linear-gradient(180deg,#10392f,#0a241d);border-color:#86efac99;color:#d1fae5}.selectedToolsPanel #toCircleBtn{background:linear-gradient(180deg,#0f3554,#0a2138);border-color:#7dd3fcbf;color:#bae6fd}.selectedToolsPanel #toSquareBtn{background:linear-gradient(180deg,#4b2305,#2e1503);border-color:#fdba74bf;color:#ffedd5}.selectedToolsPanel input[type=color]{width:56px;height:36px;border-radius:8px;border:1px solid rgba(148,163,184,.5);background:#0c1421d9;padding:2px}.selectedToolsPanel input[type=number]{width:52px;text-align:center;padding:4px 6px}.selectedToolsPanel #rowGlobalColor,.selectedToolsPanel #rowRotateTools,.selectedToolsPanel #rowTransformTools{border-top:1px solid rgba(148,163,184,.24);padding-top:10px}.selectedToolsPanel .pill{margin-right:0;background:#94a3b82e;color:#f8fafc;font-weight:700}.rotateDial{width:90px;height:90px;border-radius:999px;border:2px solid rgba(0,229,255,.6);position:relative;cursor:grab;touch-action:none;background:radial-gradient(circle at 40% 35%,#00e5ff24,#00000059)}.rotateDial:active{cursor:grabbing}.rotateDial.isDisabled{opacity:.45;cursor:not-allowed}.rotateDialInner{position:absolute;inset:10px;border-radius:999px;border:1px dashed rgba(255,255,255,.3)}.rotatePointer{position:absolute;left:50%;top:50%;width:2px;height:34px;transform-origin:50% 100%;transform:translate(-50%,-100%) rotate(0);background:#00e5ff;border-radius:999px}.rotatePointer:after{content:"";position:absolute;top:-7px;left:50%;width:12px;height:12px;transform:translate(-50%);border-radius:999px;background:#00e5ff;box-shadow:0 0 0 2px #00000073}.rotateValue{font-size:12px;font-weight:700;color:#fffffff2}.leaflet-interactive:focus{outline:none!important}.leaflet-tooltip.polyTooltipWrap{background:linear-gradient(180deg,#0c1627f5,#101c2ef0);color:#edf4ff;border:1px solid rgba(125,211,252,.5);border-radius:10px;box-shadow:0 8px 20px #00000052;padding:6px 8px;line-height:1.2}.leaflet-tooltip.polyTooltipWrap:before{border-top-color:#101c2ef0!important}.polyTooltipTitle{font-size:12px;font-weight:800;color:#f8fbff;margin-bottom:3px;white-space:nowrap}.polyTooltipArea{font-size:11px;font-weight:600;color:#c9d9ef;white-space:nowrap}.renameModal{position:absolute;inset:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:16px;background:#050a1275;backdrop-filter:blur(3px)}.renameModalCard{width:min(430px,calc(100vw - 24px));border-radius:16px;padding:16px;background:linear-gradient(180deg,#090e16f5,#0c121ef0);border:1px solid rgba(45,212,255,.28);box-shadow:0 18px 36px #00000073}.renameModalTitle{font-size:16px;font-weight:800;color:#f2f7ff;margin-bottom:12px}.renameModalInput{width:100%;box-sizing:border-box;height:42px;border-radius:10px;border:1px solid rgba(148,163,184,.48);background:#111827eb;color:#f8fafc;font-size:16px;font-weight:600;padding:0 12px;outline:none}.renameModalInput:focus{border-color:#7dd3fcf2;box-shadow:0 0 0 2px #0ea5e947}.renameModalActions{margin-top:14px;display:flex;justify-content:flex-end;gap:8px}#shareModalText{margin-bottom:10px;color:#c9d9ef;opacity:.98}.panel{position:absolute;top:12px;left:18px;transform:none;z-index:9999;background:linear-gradient(180deg,#0c1627b3,#101c2ea8);color:#e5edf7;padding:6px 4px;border-radius:16px;box-shadow:0 12px 24px #00000038;border:1px solid rgba(125,211,252,.22);width:min(312px,calc(100vw - 20px));max-width:312px;display:flex;flex-direction:column;gap:0;backdrop-filter:blur(8px);overflow:visible}.panel.collapsed .panelBody{display:none}.panelHeader{display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:7px;flex-wrap:nowrap;width:100%}.panelBody{position:static;width:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:8px;overflow:visible;margin-top:8px;padding:8px 8px 4px;border-top:1px solid rgba(148,163,184,.28);background:transparent;border-radius:0;box-shadow:none}.title{font-weight:900;font-size:13px;letter-spacing:.2px;color:#e6eef8;line-height:1;text-transform:lowercase}.topTitleRow{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:0 8px;box-sizing:border-box}.brandTitle{display:inline-flex;align-items:center;gap:6px;min-width:auto;cursor:grab;user-select:none;touch-action:none}.panel.dragging .brandTitle{cursor:grabbing}.brandDot{width:7px;height:7px;border-radius:999px;background:#22d3ee;box-shadow:0 0 12px #22d3eecc;flex:0 0 auto}.topSearchRow{display:flex;align-items:center;gap:6px;margin:0;width:100%;min-width:0;max-width:none;align-self:center;flex-wrap:nowrap;justify-content:center;padding:0 8px;box-sizing:border-box}.topModeButtons{display:flex;align-items:center;justify-content:center;gap:6px;flex:1 1 auto;width:100%;padding:0 8px;box-sizing:border-box}.topModeSep{color:#93a4b8;font-weight:700;opacity:.9;user-select:none}.topShareRow{display:flex;align-items:center;justify-content:center;width:100%;padding:0 8px;box-sizing:border-box}.topBarDivider{height:1px;background:linear-gradient(90deg,#94a3b800,#94a3b85c,#94a3b800);margin:1px 0;width:100%}.panel button{background:linear-gradient(180deg,#1e293be6,#0f172ae0);border-color:#94a3b894;color:#f1f5f9;box-shadow:0 1px 2px #0000001f}.panel button:hover:not(:disabled){border-color:#7dd3fceb;color:#fff}.panel button:disabled{opacity:1;background:linear-gradient(180deg,#475569e0,#334155db);border-color:#94a3b880;color:#dbe5f2;cursor:not-allowed}.topBarAction{border-radius:9px;padding:6px 9px;background:#111827eb;color:#d9e4f3;border-color:#94a3b873}.hint{font-size:12px;opacity:.85;line-height:1.35}.modeHintRow{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.modeHintRow #modeHint{flex:1 1 auto;min-width:0}.modePanelCloseBtn{width:28px;height:28px;min-width:28px;padding:0;border-radius:10px;font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#4b1118f2,#2d0a10eb);border-color:#fca5a594;color:#fee2e2}.modePanelCloseBtn:hover:not(:disabled){border-color:#fecacae6;color:#fff1f2}.modeHidden{display:none!important}.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}button{padding:8px 10px;border-radius:999px;border:1px solid rgba(60,64,67,.25);background:#fff;color:#202124;cursor:pointer;font-size:12px;box-shadow:0 1px 2px #00000014}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:#111827eb;border-color:#94a3b873;color:#d9e4f3}button.active{background:#082f49eb;border-color:#22d3ee;color:#ecfeff}.panel #modeBrush.primary{background:linear-gradient(180deg,#0c3a2ef5,#0a271ff0);border-color:#86efac8c;color:#dcfce7}.panel #modeBrush.primary.active{background:linear-gradient(180deg,#15803df2,#166534f2);border-color:#86efaceb;color:#f0fdf4}.panel #modeManual.primary{background:linear-gradient(180deg,#271c5cf5,#1e1743f0);border-color:#c4b5fd94;color:#ede9fe}.panel #modeManual.primary.active{background:linear-gradient(180deg,#5b21b6f2,#4c1d95f2);border-color:#c4b5fde6;color:#f5f3ff}.panel #rowPointTools .mini{background:linear-gradient(180deg,#334155f2,#1e293bf0);border-color:#94a3b899;color:#f1f5f9}.panel #rowPointTools .toolCta{background:linear-gradient(135deg,#0ea5e9f2,#22d3eeeb);border-color:#7dd3fcf2;color:#082f49}.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:#eef1f4;margin-right:6px;font-size:12px}.panel .pill{background:#0f172ab8;color:#e6edf8;border:1px solid rgba(148,163,184,.38);font-weight:600}.divider{height:1px;background:#3c404333}.panelSection{border:1px solid rgba(60,64,67,.18);border-radius:14px;background:#ffffffa6;overflow:hidden}.panel #rowBrushTools,.panel #rowPointTools{border:1px solid rgba(148,163,184,.24);border-radius:12px;padding:8px}.panel #rowBrushTools{background:linear-gradient(180deg,#0b2c23d1,#081d18c7)}.panel #rowPointTools{background:linear-gradient(180deg,#1d183ad1,#14112ac7)}.panelSection>summary{cursor:pointer;list-style:none;padding:10px 12px;font-weight:700;font-size:13px;color:#1f1f1f;border-bottom:1px solid rgba(60,64,67,.12)}.panelSection>summary::-webkit-details-marker{display:none}.panelSectionBody{padding:10px;display:flex;flex-direction:column;gap:10px}.list{background:#ffffff08;border:1px solid rgba(148,163,184,.24);border-radius:14px;overflow-x:hidden;overflow-y:auto;padding:8px;min-height:80px;max-height:min(50vh,360px);display:flex;flex-direction:column;gap:8px}.item{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:10px;padding:10px;border-radius:12px;border:1px solid rgba(148,163,184,.34);background:linear-gradient(180deg,#1f2937eb,#111827e6);min-height:44px;cursor:pointer}.item.selected{border-color:#22d3ee;box-shadow:0 0 0 1px #22d3ee6b,0 12px 20px #0208175c;background:linear-gradient(180deg,#082f49f2,#0f172aeb)}.left{display:flex;gap:10px;align-items:flex-start;min-width:0;flex:1}.swatch{width:14px;height:14px;border-radius:999px;border:1px solid rgba(255,255,255,.35);flex:0 0 auto}.meta{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.name{font-weight:700;font-size:13px;color:#f8fafc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.1}.listItemGrow{flex:1 1 auto;min-width:0}.listDeleteBtn{width:24px;height:24px;min-width:24px;padding:0;border-radius:8px;border:1px solid rgba(252,165,165,.55);background:linear-gradient(180deg,#4b1118f2,#2d0a10eb);color:#fee2e2;font-size:16px;line-height:1;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.listDeleteBtn:hover:not(:disabled){border-color:#fecacae6;color:#fff1f2}.nameInlineInput{width:100%;min-width:120px;max-width:260px;font-weight:700;font-size:12px;padding:4px 6px;border-radius:8px;border:1px solid #1a73e8;background:#fff;color:#202124}.sub{font-size:12px;opacity:.92;color:#cbd5e1;display:flex;gap:8px;flex-wrap:wrap;line-height:1.35}.mini{padding:6px 8px;border-radius:999px;border:1px solid rgba(60,64,67,.25);background:#fff;font-size:11px;cursor:pointer}.rightActions{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;align-items:center}.iconBtn{width:38px;height:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;border:1px solid rgba(148,163,184,.45);background:linear-gradient(180deg,#1f2937,#111827);color:#f8fafc;box-shadow:inset 0 1px #ffffff14,0 2px 6px #00000052}.iconBtn:hover:not(:disabled){border-color:#7dd3fcc7}.iconBtn svg{display:block;pointer-events:none}.listPanel .rowColorPicker{width:76px;height:38px;border-radius:10px;border:1px solid rgba(148,163,184,.45);background:#0f172a99}.shareCta{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#00c4ff,#00e5ff);color:#0b1a21;border-color:#00e5ffe6;font-weight:700}.shareCta:hover{filter:brightness(1.05)}.shareCta:disabled{color:#0b1a21;background:linear-gradient(135deg,#7aaebb,#7abcc8);border-color:#7abcc8b3}.shareCtaIcon{display:inline-flex;align-items:center;justify-content:center}.toolCta{min-height:42px;padding:10px 14px;font-size:14px;font-weight:700;border-radius:12px;background:linear-gradient(135deg,#1fb6d8,#00e5ff);color:#05222a;border-color:#00e5ffbf}.toolCta:disabled{background:linear-gradient(135deg,#6f8e97,#8ea9b1);color:#0f2025;border-color:#8ea9b1b3}.panel .toolCta:disabled{background:linear-gradient(135deg,#475569d9,#64748bcc);color:#e2e8f0;border-color:#94a3b880;opacity:1}.rowColorPicker{width:32px;height:32px;padding:0;border:1px solid rgba(60,64,67,.3);border-radius:8px;background:transparent;cursor:pointer}input[type=color]{width:44px;height:30px;padding:0;border:none;background:transparent;cursor:pointer}input[type=range]{width:170px}input[type=number]{width:90px;padding:6px 8px;border-radius:10px;border:1px solid rgba(60,64,67,.3);background:#fff;color:#202124}input[type=text]{min-width:160px;padding:6px 8px;border-radius:10px;border:1px solid rgba(60,64,67,.3);background:#fff;color:#202124}.countrySearchRow{align-items:center;gap:10px}.countrySearchInput{flex:1 1 auto;min-width:0!important;max-width:none;height:28px;padding:4px 8px!important;font-size:12px;font-weight:700;border-radius:8px!important;border:1px solid rgba(226,232,240,.92)!important;background:#f1f5f9f2!important;color:#0f172a!important;line-height:1}.countrySearchInput::placeholder{color:#64748b}.topSearchRow .topBarAction{height:28px;padding:0 7px;font-size:10px;font-weight:700;border-radius:8px}.topBarClearBtn{width:28px;min-width:28px;padding:0;font-size:16px;line-height:1}.topBarShareBtn{min-width:112px}.topCollapseBtn{width:22px;height:22px;min-width:22px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;padding:1px 6px;border-radius:6px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;display:inline-block}@media(max-width:900px){.panel{width:calc(100vw - 12px);left:6px;top:6px;padding:8px}.panelHeader{gap:6px;flex-wrap:nowrap}.title{font-size:13px}.brandTitle{min-width:auto}.panelBody{width:100%}.countrySearchInput{height:30px;font-size:12px;padding:5px 9px!important}.topSearchRow .topBarAction{height:30px;padding:0 7px;font-size:10px}.listPanel{left:6px;top:78px;width:min(340px,calc(100vw - 12px));border-radius:16px}.list{max-height:min(46vh,300px)}}
