*{box-sizing:border-box}html,body,#root{color:#f9fafb;background:#111827;width:100%;height:100%;margin:0;font-family:Arial,sans-serif}button,input,select{font:inherit}.app{width:100%;height:100%;display:flex}.sidebar{background:linear-gradient(#1b2432 0%,#161d29 100%);border-right:1px solid #2d3748;flex-direction:column;gap:14px;width:340px;padding:20px;display:flex;overflow:auto}.sidebar-header{align-items:center;gap:12px;padding:4px 0 10px;display:flex}.sidebar-logo-img{object-fit:contain;width:42px;height:42px}.sidebar-title{margin:0;font-size:24px;line-height:1}.sidebar-subtitle{color:#94a3b8;margin:4px 0 0;font-size:13px}.sidebar-section{background:#0f172a8c;border:1px solid #2b3647;border-radius:14px;padding:14px}.sidebar-section-title{letter-spacing:.08em;text-transform:uppercase;color:#93c5fd;margin:0 0 12px;font-size:12px;font-weight:800}.sidebar-input,.sidebar-select{color:#f8fafc;appearance:none;background:#0f172a url("data:image/svg+xml;utf8,<svg fill='%233b82f6' height='20' viewBox='0 0 20 20' width='20' xmlns='http://www.w3.org/2000/svg'><path d='M5 7l5 5 5-5z'/></svg>") right 10px center/16px no-repeat;border:1px solid #334155;border-radius:10px;width:100%;height:38px;padding:0 12px}.sidebar-input:focus,.sidebar-select:focus{border-color:#60a5fa}.sidebar-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border:0;border-radius:10px;width:100%;height:38px;margin-top:10px;font-weight:700;transition:transform .12s,opacity .12s}.sidebar-button:hover{opacity:.95}.sidebar-button:active{transform:translateY(1px)}.sidebar-error{color:#f87171;margin:10px 0 0;font-size:13px}.sidebar-info-list{flex-direction:column;gap:8px;display:flex}.sidebar-info-list p{color:#e5e7eb;margin:0;font-size:13px}.sidebar-checkbox{color:#e5e7eb;align-items:center;gap:10px;margin-bottom:8px;font-size:14px;display:flex}.sidebar-checkbox:last-child{margin-bottom:0}.sidebar-checkbox input{accent-color:#3b82f6}.sidebar-color-grid{flex-wrap:wrap;gap:8px;display:flex}.sidebar-color-swatch{cursor:pointer;border:1px solid #475569;border-radius:999px;width:24px;height:24px;transition:transform .12s,box-shadow .12s,border-color .12s}.sidebar-color-swatch:hover{transform:scale(1.06)}.sidebar-color-swatch.active{border:2px solid #fff;box-shadow:0 0 0 2px #60a5fa59}.sidebar-footer{flex-direction:column;gap:12px;margin-top:auto;padding-top:6px;display:flex}.sidebar-discord-button{color:#fff;background:#5865f2;border-radius:10px;justify-content:center;align-items:center;height:40px;font-weight:700;text-decoration:none;transition:opacity .12s,transform .12s;display:inline-flex}.sidebar-discord-button:hover{opacity:.95}.sidebar-discord-button:active{transform:translateY(1px)}.sidebar-credits{border-top:1px solid #2b3647;padding-top:10px}.sidebar-credits p{color:#94a3b8;margin:0;font-size:12px;line-height:1.5}.viewer{background:#0f172a;flex:1;position:relative;overflow:hidden}.map-viewport{-webkit-user-select:none;user-select:none;width:100%;height:100%;cursor:var(--map-cursor,crosshair);background:radial-gradient(circle at 30% 30%,#ffffff14,#0000 25%),radial-gradient(circle at 70% 60%,#ffffff0d,#0000 30%),linear-gradient(#1b6ca8 0%,#14507c 45%,#0c3554 100%);position:relative;overflow:hidden}.map-viewport.dragging{cursor:grabbing}.map-stage{transform-origin:0 0;position:absolute;top:0;left:0}.map-stage-animated{transition:transform .35s}.map-image{-webkit-user-select:none;user-select:none;pointer-events:none;-webkit-user-drag:none;width:100%;height:100%;position:absolute;inset:0}.map-overlay{pointer-events:none;z-index:5;position:absolute;top:0;left:0}.map-marker{z-index:20;cursor:pointer;background:#ff4d4f;border:2px solid #fff;border-radius:999px;width:12px;height:12px;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 10px #ff4d4fe6}.context-menu{z-index:1000;background:#1f2937;border:1px solid #374151;border-radius:10px;flex-direction:column;gap:6px;min-width:180px;padding:8px;display:flex;position:fixed;box-shadow:0 8px 24px #00000059}.context-menu button{text-align:left;color:#f9fafb;cursor:pointer;background:#111827;border:1px solid #374151;border-radius:8px;width:100%;padding:8px 10px}.context-menu button:hover:not(:disabled){background:#374151}.context-menu button:disabled{opacity:.45;cursor:not-allowed}.salt-rock-wrapper{z-index:8;pointer-events:none;-webkit-user-select:none;user-select:none;transform-origin:50%;position:absolute}.salt-rock-marker{object-fit:contain;box-sizing:content-box;background:#000000b3;border-radius:999px;width:28px;height:28px;padding:6px;display:block}.zone-mig{fill:#0a64d799;stroke:#0a64d7e6;stroke-width:2px}.zone-pz{fill:#be0fdc99;stroke:#be0fdce6;stroke-width:2px}.zone-sanc{fill:#f009;stroke:#ffff00e6;stroke-width:2px}.map-label{pointer-events:none;-webkit-user-select:none;user-select:none;z-index:9;text-align:center;white-space:nowrap;text-shadow:-1px -1px #000,1px -1px #000,-1px 1px #000,1px 1px #000,0 0 4px #000000a6;font-weight:700;line-height:1.05;position:absolute}.map-label-small-line{font-size:.65em}.map-label-primal_area{color:#fff;filter:drop-shadow(0 0 5px #000);font-size:22px}.map-label-secondary_area{color:#fff;filter:drop-shadow(0 0 3px #000);font-size:16px}.map-label-water_label{color:#7dd3fc;filter:drop-shadow(0 0 2px #000);font-size:14px}.map-label-structure{color:#facc15;filter:drop-shadow(0 0 2px #000);font-size:14px}.map-label-gate{color:#ef4444;filter:drop-shadow(0 0 2px #000);font-size:14px}.map-label-landsite_big{color:#fb923c;filter:drop-shadow(0 0 3px #000);font-size:18px}.map-label-landsite_small{color:#fb923c;filter:drop-shadow(0 0 2px #000);font-size:14px}.air-current-path{fill:none;stroke:#ffffffe6;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:8 6;opacity:.95}.air-current-arrowhead{fill:none;stroke:#fffffff2;stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round}.air-current-path-bold{fill:none;stroke:#ffc80ab3;stroke-width:15px;stroke-linecap:round;stroke-linejoin:round;paint-order:stroke;filter:drop-shadow(0 0 5px #000)}.air-current-arrowhead-bold{fill:none;stroke:#ffc80ab3;stroke-width:15px;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 5px #000)}.air-current-up-spiral{fill:none;stroke:#fffc;stroke-width:3.5px;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 5px #000)}.air-current-up-dot{fill:#fffc;filter:drop-shadow(0 0 5px #000)}.air-current-hover-target{fill:#0000;pointer-events:auto}.air-current-tooltip{pointer-events:none;z-index:30;color:#fff;white-space:nowrap;background:#000000d9;border-radius:6px;padding:4px 8px;font-size:12px;font-weight:600;position:fixed;transform:translate(-50%,-100%);box-shadow:0 2px 8px #00000059}.map-marker-icon-wrapper{width:34px;height:34px;transform:translate(-50%, -100%) scale(var(--marker-scale,1));transform-origin:50%;z-index:12;cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;display:flex;position:absolute}.map-marker-icon{object-fit:contain;z-index:2;pointer-events:none;filter:drop-shadow(0 2px 6px #0000008c);width:34px;height:34px;position:relative}.map-marker-icon-wrapper-alert .map-marker-icon{filter:drop-shadow(0 0 8px #f97316e6)drop-shadow(0 2px 6px #0000008c)}.map-marker-alert-pulse{z-index:1;pointer-events:none;background:#f9731659;border-radius:999px;width:18px;height:18px;animation:1.6s ease-out infinite marker-alert-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 #f97316b3}@keyframes marker-alert-pulse{0%{opacity:.95;transform:translate(-50%,-50%)scale(.7);box-shadow:0 0 #f97316b3}70%{opacity:.15;transform:translate(-50%,-50%)scale(2.2);box-shadow:0 0 0 12px #f9731600}to{opacity:0;transform:translate(-50%,-50%)scale(2.5);box-shadow:0 0 0 18px #f9731600}}.map-marker-icon-wrapper-alert{animation:.9s ease-in-out infinite marker-alert-shake}@keyframes marker-alert-shake{0%{transform:translate(-50%, -100%) scale(var(--marker-scale,1)) rotate(0deg)}10%{transform:translate(calc(-50% - 1px), -100%) scale(var(--marker-scale,1)) rotate(-2deg)}20%{transform:translate(calc(-50% + 1px), -100%) scale(var(--marker-scale,1)) rotate(2deg)}30%{transform:translate(calc(-50% - 1px), calc(-100% - 1px)) scale(var(--marker-scale,1)) rotate(-2deg)}40%{transform:translate(calc(-50% + 1px), calc(-100% + 1px)) scale(var(--marker-scale,1)) rotate(2deg)}50%{transform:translate(calc(-50% - 1px), -100%) scale(var(--marker-scale,1)) rotate(-1deg)}60%{transform:translate(calc(-50% + 1px), -100%) scale(var(--marker-scale,1)) rotate(1deg)}70%{transform:translate(calc(-50% - 1px), calc(-100% - 1px)) scale(var(--marker-scale,1)) rotate(-1deg)}80%{transform:translate(calc(-50% + 1px), calc(-100% + 1px)) scale(var(--marker-scale,1)) rotate(1deg)}90%{transform:translate(-50%, -100%) scale(var(--marker-scale,1)) rotate(0deg)}to{transform:translate(-50%, -100%) scale(var(--marker-scale,1)) rotate(0deg)}}.map-position-trail{fill:none;stroke:#fff;stroke-width:2px;stroke-dasharray:6 6;stroke-linecap:round;stroke-linejoin:round;pointer-events:none;z-index:6}.map-position-trail-point{fill:#fff;stroke:#000c;stroke-width:1px;pointer-events:none}.draw-line{fill:none;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.draw-line-white{stroke:#fff}.draw-line-black{stroke:#000}.draw-line-yellow{stroke:#ff0}.draw-line-orange{stroke:orange}.draw-line-red{stroke:red}.draw-line-blue{stroke:#00f}.draw-line-green{stroke:#32cd32}.draw-line-violet{stroke:violet}.draw-line.drawing{stroke-dasharray:6 6}.draw-line-selected{stroke-width:4px;filter:drop-shadow(0 0 6px #fff9)}.draw-legend{color:#fff;pointer-events:none;background:#0009;border-radius:6px;padding:10px;font-size:12px;position:absolute;bottom:12px;right:12px}
