*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden;-webkit-tap-highlight-color:transparent}body{font-family:Atkinson Hyperlegible,Georgia,serif;color:#3d2a1c;background:#f2e6ce;-webkit-font-smoothing:antialiased}:root{--parchment: #faf3e0;--parchment-dark: #f2e6ce;--ink: #3d2a1c;--ink-light: #6b4c3b;--ocean: #d0e1ed;--ocean-dark: #b8cfde;--border: #5c3d2e;--accent-warm: #c0392b;--shadow: rgba(61, 42, 28, .15);--topbar-height: 52px;--legend-width: 260px;--font-display: "DM Serif Display", Georgia, serif;--font-body: "Atkinson Hyperlegible", Georgia, serif}.app{display:flex;flex-direction:column;height:100%;position:relative;background-color:var(--parchment-dark)}.main-content{display:flex;flex:1;min-height:0;position:relative}.map-area{flex:1;min-width:0;position:relative;overflow:hidden;padding:14px;background:linear-gradient(90deg,#d85d3f 0,#d85d3f 18px,#f1c858 18px,#f1c858 36px,#4f8f74 36px,#4f8f74 54px,#2f86a6 54px,#2f86a6 72px) 0 0 / 72px 100% repeat-x,linear-gradient(90deg,#2f86a6 0,#2f86a6 18px,#f1c858 18px,#f1c858 36px,#d85d3f 36px,#d85d3f 54px,#8fb861 54px,#8fb861 72px) 0 100% / 72px 100% repeat-x,linear-gradient(0deg,#d85d3f 0,#d85d3f 18px,#f1c858 18px,#f1c858 36px,#4f8f74 36px,#4f8f74 54px,#2f86a6 54px,#2f86a6 72px) 0 0 / 100% 72px repeat-y,linear-gradient(0deg,#2f86a6 0,#2f86a6 18px,#f1c858 18px,#f1c858 36px,#d85d3f 36px,#d85d3f 54px,#8fb861 54px,#8fb861 72px) 100% 0 / 100% 72px repeat-y,#6a3f25;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y,no-repeat}.map-loading{display:flex;align-items:center;justify-content:center;height:100%;min-height:400px;color:#8b7355;font-style:italic}.paper-texture{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='5' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:512px 512px;mix-blend-mode:multiply}.top-bar{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-height);padding:0 20px;background:var(--parchment);border-bottom:2px solid var(--border);position:relative;z-index:100;flex-shrink:0}.top-bar-left{display:flex;align-items:center;gap:10px}.top-bar-icon{font-size:24px;line-height:1}.top-bar-title{font-family:var(--font-display);font-size:22px;font-weight:400;color:var(--ink);letter-spacing:.01em}.top-bar-right{display:flex;align-items:center}.top-bar-count{font-size:14px;color:var(--ink-light);background:var(--parchment-dark);padding:4px 12px;border-radius:20px;border:1px solid var(--ocean-dark)}.map-wrapper{position:relative;width:100%;height:100%;overflow:hidden;touch-action:none;user-select:none;-webkit-user-select:none;border:3px solid #3f2c22;background:#bfe0eb;box-shadow:inset 0 0 0 2px #fff1c8cc,0 8px 18px #3d2a1c2e}.map-svg{display:block;width:100%;height:100%}.map-compass{pointer-events:none}.zoom-controls{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:50;pointer-events:none}.zoom-btn{pointer-events:auto;width:48px;height:48px;border-radius:50%;border:2px solid #3f2c22;background:#fff1c8;color:#3f2c22;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 3px 8px #3d2a1c33,inset 0 1px #fff9;transition:transform .12s ease,background .12s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;padding:0}.zoom-btn:hover{background:#ffe8a0;transform:scale(1.08)}.zoom-btn:active{transform:scale(.93)}.zoom-btn--reset{width:44px;height:44px}@media(pointer:coarse){.zoom-controls{bottom:28px;right:24px;gap:10px}.zoom-btn{width:54px;height:54px}.zoom-btn--reset{width:50px;height:50px}}.legend-panel{width:var(--legend-width);background:var(--parchment);border-left:2px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.legend-heading{font-family:var(--font-display);font-size:16px;font-weight:400;padding:12px 16px 10px;border-bottom:1px solid var(--ocean-dark);color:var(--ink);letter-spacing:.02em}.legend-scroll{flex:1;overflow-y:auto;padding:8px 0}.legend-scroll::-webkit-scrollbar{width:6px}.legend-scroll::-webkit-scrollbar-track{background:transparent}.legend-scroll::-webkit-scrollbar-thumb{background:var(--ocean-dark);border-radius:3px}.legend-category{border-bottom:1px solid var(--parchment-dark)}.legend-cat-header{display:flex;align-items:center;width:100%;gap:8px;padding:8px 16px;border:none;border-left:3px solid transparent;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:700;color:var(--ink);text-align:left;transition:background .12s}.legend-cat-header:hover,.legend-cat-header.is-active{background:var(--parchment-dark)}.legend-cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-cat-label{flex:1}.legend-cat-count{font-size:11px;font-weight:400;color:var(--ink-light);background:var(--parchment-dark);padding:1px 8px;border-radius:10px}.legend-items{padding:0 0 4px}.legend-item{display:flex;align-items:center;gap:8px;width:100%;padding:5px 16px 5px 27px;border:none;background:transparent;font-family:var(--font-body);font-size:12px;color:var(--ink);text-align:left}.legend-item:hover{background:#d0e1ed66}.legend-item-icon{width:18px;height:18px;object-fit:contain;border-radius:50%;flex-shrink:0}.legend-item-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-item-country{font-size:10px;color:var(--ink-light);flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes panelIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.editor-panel{width:var(--legend-width);background:var(--parchment);border-left:2px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;overflow-x:hidden;font-family:var(--font-body)}.editor-panel::-webkit-scrollbar{width:6px}.editor-panel::-webkit-scrollbar-track{background:transparent}.editor-panel::-webkit-scrollbar-thumb{background:var(--ocean-dark);border-radius:3px}.editor-heading{font-family:var(--font-display);font-size:16px;font-weight:400;padding:12px 16px 10px;border-bottom:1px solid var(--ocean-dark);color:var(--ink);letter-spacing:.02em}.editor-section{padding:10px 14px;border-bottom:1px solid var(--parchment-dark)}.editor-section-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:6px}.editor-hint{font-size:11px;color:var(--ink-light);margin-bottom:8px;line-height:1.4}.editor-icon-library{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 2px;max-height:340px}.editor-icon-library::-webkit-scrollbar{width:5px}.editor-icon-library::-webkit-scrollbar-track{background:transparent}.editor-icon-library::-webkit-scrollbar-thumb{background:var(--ocean-dark);border-radius:3px}.editor-icon-group{margin-bottom:10px}.editor-icon-group-label{display:block;font-size:11px;font-weight:600;color:var(--ink-light);text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px}.editor-icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.editor-icon-cell{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:1px solid var(--ocean-dark);border-radius:6px;background:var(--parchment-dark);cursor:grab;transition:background .1s,border-color .1s;user-select:none;-webkit-user-select:none}.editor-icon-cell:hover{background:#ffe8a0;border-color:var(--border)}.editor-icon-cell:active{cursor:grabbing;transform:scale(.92)}.editor-icon-img{width:28px;height:28px;object-fit:contain;pointer-events:none;user-select:none;-webkit-user-select:none}.editor-mode-toggle{display:flex;gap:4px;margin-bottom:4px}.editor-mode-btn{flex:1;padding:6px 8px;border:1px solid var(--ocean-dark);border-radius:5px;background:var(--parchment);font-family:var(--font-body);font-size:12px;font-weight:600;color:var(--ink-light);cursor:pointer;transition:background .1s,border-color .1s,color .1s}.editor-mode-btn:hover{background:var(--parchment-dark)}.editor-mode-btn.is-active{background:#c5d792;border-color:#8fb861;color:var(--ink)}.editor-actions{display:flex;flex-direction:column;gap:6px;padding-top:10px;padding-bottom:14px}.editor-btn{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer;transition:background .1s,transform .1s}.editor-btn:active{transform:scale(.97)}.editor-btn--save{background:#4f8f74;color:#fff;border-color:#3d7a60}.editor-btn--save:hover{background:#5da084}.editor-btn--reset{background:var(--parchment);color:var(--ink)}.editor-btn--reset:hover{background:#f0dbb0}.editor-btn--export{background:var(--parchment-dark);color:var(--ink-light);border-color:var(--ocean-dark)}.editor-btn--export:hover{background:var(--ocean)}@media(max-width:500px){.editor-panel{width:100%;height:180px;border-left:none;border-top:2px solid var(--border)}.editor-heading{display:none}.editor-icon-library{display:flex;flex-direction:row;overflow-y:hidden;overflow-x:auto;max-height:none;gap:6px;padding:4px 8px}.editor-icon-group{flex-shrink:0;margin-bottom:0}.editor-section{padding:6px 10px}}.editor-slider-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.editor-slider-label{font-size:12px;font-weight:600;color:var(--ink-light);white-space:nowrap}.editor-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--ocean-dark);border-radius:2px;outline:none;cursor:pointer}.editor-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--border);border:2px solid var(--parchment);cursor:pointer;box-shadow:0 1px 3px var(--shadow)}.editor-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--border);border:2px solid var(--parchment);cursor:pointer}.editor-scale-value{font-size:12px;font-weight:700;color:var(--ink);min-width:42px;text-align:right}.editor-btn--delete{background:#c0392b;color:#fff;border-color:#a03022;margin-top:4px}.editor-btn--delete:hover{background:#d44a3a}.editor-btn--auto{background:#5a7a9a;color:#fff;border-color:#4a6a8a}.editor-btn--auto:hover{background:#6a8aaa}.editor-upload-row{display:flex;gap:6px;margin-bottom:6px;align-items:center}.editor-upload-file{font-size:11px;width:100%;padding:4px 0;color:var(--ink-light)}.editor-upload-input{width:100%;padding:6px 8px;border:1px solid var(--ocean-dark);border-radius:4px;font-family:var(--font-body);font-size:12px;color:var(--ink);background:var(--parchment);outline:none}.editor-upload-input:focus{border-color:var(--border)}.editor-upload-select{flex:1;padding:6px 8px;border:1px solid var(--ocean-dark);border-radius:4px;font-family:var(--font-body);font-size:12px;color:var(--ink);background:var(--parchment);outline:none;cursor:pointer}.editor-upload-select:focus{border-color:var(--border)}.editor-btn--upload{background:var(--parchment);color:var(--ink);border-color:var(--border);padding:6px 14px;font-size:12px;width:auto;display:inline-block}.editor-btn--upload:hover{background:#f0dbb0}@media(max-width:900px){:root{--legend-width: 220px}.top-bar-title{font-size:18px}}@media(max-width:700px){:root{--legend-width: 180px}.top-bar{padding:0 12px}.top-bar-title{font-size:16px}.top-bar-count{font-size:12px;padding:2px 10px}.legend-panel{width:var(--legend-width)}.legend-cat-label{font-size:12px}}@media(max-width:500px){.main-content{flex-direction:column}.legend-panel{width:100%;height:160px;border-left:none;border-top:2px solid var(--border)}.legend-scroll{display:flex;flex-direction:row;overflow-y:hidden;overflow-x:auto;padding:4px 8px;gap:4px}.legend-category{border-bottom:none;flex-shrink:0;min-width:140px}.legend-heading{display:none}}
