@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary: #4f9eff;--color-primary-dim: rgba(79, 158, 255, .2);--color-trail: #4f9eff;--color-origin: #34d399;--color-destination: #f87171;--color-accent: #a78bfa;--panel-bg: rgba(12, 14, 22, .82);--panel-border: rgba(255, 255, 255, .08);--panel-blur: blur(20px) saturate(160%);--control-bg: rgba(255, 255, 255, .06);--control-bg-hover: rgba(255, 255, 255, .1);--control-border: rgba(255, 255, 255, .12);--control-border-focus: var(--color-primary);--text-primary: #f0f4ff;--text-secondary: rgba(240, 244, 255, .6);--text-muted: rgba(240, 244, 255, .35);--status-bg: rgba(8, 10, 18, .78);--status-border: rgba(79, 158, 255, .25);--btn-bg: rgba(79, 158, 255, .15);--btn-bg-hover: rgba(79, 158, 255, .3);--btn-border: rgba(79, 158, 255, .4);--panel-width: 320px;--panel-radius: 16px;--toggle-size: 44px;--status-radius: 999px;--font-main: "Inter", "Segoe UI", system-ui, sans-serif;--font-size-base: 13px;--font-size-sm: 11.5px;--transition-panel: .35s cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden;font-family:var(--font-main);font-size:var(--font-size-base);color:var(--text-primary);background:#0a0c14;-webkit-font-smoothing:antialiased;user-select:none;-webkit-user-select:none}#map{position:fixed;inset:0;width:100%;height:100%;touch-action:none}#map canvas{pointer-events:none}#map canvas:last-child{pointer-events:auto}.settings-panel.is-open .settings-toggle{left:100%;margin-left:16px}.top-header-center{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:900;display:flex;align-items:center;gap:16px;pointer-events:none}.top-header-center>*{pointer-events:auto}.top-controls{display:flex;align-items:center;gap:12px}.draw-mode-btn{display:flex;align-items:center;justify-content:center;gap:10px;height:42px;padding:0 24px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:14px;color:var(--text-primary);font-family:var(--font-main);font-size:14px;font-weight:600;cursor:pointer;backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);transition:all var(--transition-fast);box-shadow:0 4px 20px #0003}.draw-mode-btn:hover{background:var(--btn-bg-hover);border-color:var(--color-primary);transform:translateY(-1px)}.draw-mode-btn.is-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;box-shadow:0 0 20px #4f9eff80}.draw-mode-btn.is-active .draw-icon{filter:brightness(0) invert(1)}.icon-only-btn{width:42px!important;padding:0!important;gap:0!important}.icon-only-btn .draw-text{display:none!important}.pen-toolbar{display:flex;align-items:center;gap:16px;padding:8px 16px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);box-shadow:0 4px 20px #0003;animation:slide-right .3s cubic-bezier(.4,0,.2,1)}@keyframes slide-right{0%{transform:translate(-10px);opacity:0}to{transform:translate(0);opacity:1}}.pen-toolbar-section{display:flex;align-items:center;gap:8px}.pen-toolbar-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.pen-toolbar-divider{width:1px;height:20px;background:var(--panel-border)}.pen-thickness-btn,.pen-shape-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--control-bg);border:1px solid var(--control-border);border-radius:6px;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.pen-thickness-btn:hover,.pen-shape-btn:hover{background:var(--control-bg-hover);border-color:var(--color-primary)}.pen-thickness-btn.is-active,.pen-shape-btn.is-active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pen-shape-btn{font-size:16px}.pen-clear-btn{width:auto;height:28px;padding:0 10px;display:flex;align-items:center;justify-content:center;background:#f8717126;border:1px solid rgba(248,113,113,.3);border-radius:6px;color:#f87171;font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.pen-clear-btn:hover{background:#f871714d;border-color:#f87171;transform:translateY(-1px)}.pen-clear-btn:active{transform:translateY(0)}.settings-toggle{position:absolute;top:16px;left:100%;margin-left:16px;z-index:1001;width:var(--toggle-size);height:var(--toggle-size);display:flex;align-items:center;justify-content:center;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;color:var(--text-primary);cursor:pointer;backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast),right var(--transition-panel)}.settings-toggle:hover{background:var(--btn-bg-hover);border-color:var(--btn-border);box-shadow:0 0 0 3px var(--color-primary-dim);transform:rotate(15deg)}.settings-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}.quick-clear-btn{height:28px;padding:0 10px;display:flex;align-items:center;justify-content:center;gap:4px;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:8px;color:#fca5a5;font-family:var(--font-main);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.quick-clear-btn:hover{background:#f8717133;border-color:#f87171;color:#fef2f2;transform:translateY(-1px)}.quick-clear-btn:active{transform:translateY(0)}.settings-panel{position:fixed;top:0;left:0;z-index:800;width:var(--panel-width);height:100dvh;display:flex;flex-direction:column;background:var(--panel-bg);border-right:1px solid var(--panel-border);backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);transform:translate(-100%);transition:transform var(--transition-panel);overflow:visible}.settings-panel.is-open{transform:translate(0);box-shadow:8px 0 40px #0006}.panel-header{padding:16px 20px 14px;border-bottom:1px solid var(--panel-border);flex-shrink:0}.panel-title{font-size:15px;font-weight:600;letter-spacing:.02em;color:var(--text-primary)}.panel-title-wrapper{display:flex;align-items:center;gap:10px}.app-version{font-size:10px;font-weight:700;color:var(--color-primary);background:var(--color-primary-dim);padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--status-border)}.panel-content{flex:1;overflow-y:auto;padding:16px 20px 32px;scroll-behavior:smooth}.panel-content::-webkit-scrollbar{width:4px}.panel-content::-webkit-scrollbar-track{background:transparent}.panel-content::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:2px}.control-group{margin-bottom:18px}.control-label{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:7px;letter-spacing:.03em;text-transform:uppercase}.control-label .value-badge{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);background:var(--color-primary-dim);padding:1px 7px;border-radius:4px}.control-section-title{font-size:var(--font-size-sm);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:10px 0 6px;border-bottom:1px solid var(--panel-border);margin-bottom:14px}select{width:100%;padding:9px 32px 9px 12px;background:var(--control-bg);border:1px solid var(--control-border);border-radius:8px;color:var(--text-primary);font-family:var(--font-main);font-size:var(--font-size-base);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='%23a0aec0'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px;transition:border-color var(--transition-fast),background-color var(--transition-fast)}select:hover{background-color:var(--control-bg-hover);border-color:var(--control-border-focus)}select:focus{outline:none;border-color:var(--control-border-focus);box-shadow:0 0 0 3px var(--color-primary-dim)}select option{background-color:#151825;color:#f0f4ff}select optgroup{background-color:#0d0f1c;color:#f0f4ff66}input[type=range]{width:100%;-webkit-appearance:none;appearance:none;height:4px;background:var(--control-border);border-radius:2px;cursor:pointer;transition:background var(--transition-fast)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--color-primary);border-radius:50%;border:2px solid rgba(12,14,22,.8);box-shadow:0 0 8px #4f9eff80;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 12px #4f9effcc}input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--color-primary);border-radius:50%;border:2px solid rgba(12,14,22,.8);cursor:pointer}input[type=range]:focus{outline:none}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.toggle-label{font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.toggle-switch{position:relative;width:38px;height:22px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--control-border);border-radius:11px;cursor:pointer;transition:background var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:var(--text-secondary);border-radius:50%;transition:transform var(--transition-fast),background var(--transition-fast)}.toggle-switch input:checked+.toggle-slider{background:var(--color-primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(16px);background:#fff}.toggle-switch input:focus-visible+.toggle-slider{box-shadow:0 0 0 3px var(--color-primary-dim)}input[type=color]{-webkit-appearance:none;appearance:none;width:100%;height:36px;border:1px solid var(--control-border);border-radius:8px;background:var(--control-bg);cursor:pointer;padding:2px 4px;transition:border-color var(--transition-fast)}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:none;border-radius:6px}input[type=color]:hover{border-color:var(--control-border-focus)}.thumbnail-picker-container{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.thumbnail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:5px;background:var(--control-bg);border:1px solid var(--control-border);border-radius:6px;padding:5px}.thumbnail-group-header{font-size:9px;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-top:8px;margin-bottom:3px;padding-left:4px;border-left:2px solid var(--color-primary)}.thumbnail-grid-container .thumbnail-grid{margin-bottom:8px}.thumbnail-item{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border:1px solid var(--control-border);border-radius:4px;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;padding:1px}.thumbnail-item:hover{background:var(--control-bg-hover);border-color:var(--color-primary);transform:scale(1.08);z-index:2;box-shadow:0 4px 10px #0006}.thumbnail-item.is-selected{background:var(--color-primary-dim);border-color:var(--color-primary);border-width:1.5px;box-shadow:0 0 8px var(--color-primary-dim)}.thumbnail-item img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 1px 3px rgba(0,0,0,.3));transition:transform var(--transition-fast)}.thumbnail-item[data-key=LAUNCHER0] img,.thumbnail-item[data-key=LAUNCHER1] img,.thumbnail-item[data-key=HELICOPTER] img,.thumbnail-item[data-key=STEALTHJET] img,.thumbnail-item[data-key=TANK] img{transform:scaleY(-1)}.thumbnail-item:hover img{transform:scale(1.1)}.thumbnail-item[data-key=LAUNCHER0]:hover img,.thumbnail-item[data-key=LAUNCHER1]:hover img,.thumbnail-item[data-key=HELICOPTER]:hover img,.thumbnail-item[data-key=STEALTHJET]:hover img,.thumbnail-item[data-key=TANK]:hover img{transform:scaleY(-1) scale(1.1)}.thumbnail-item .thumbnail-emoji{font-size:22px}.size-presets{display:flex;gap:6px;margin-top:8px}.size-btn{flex:1;padding:5px 4px;background:var(--control-bg);border:1px solid var(--control-border);border-radius:6px;color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:center}.size-btn:hover{background:var(--control-bg-hover);border-color:var(--color-primary);color:var(--text-primary)}.size-btn.is-active{background:var(--color-primary-dim);border-color:var(--color-primary);color:var(--text-primary)}.apply-all-btn{margin-top:8px;width:100%;padding:6px;background:transparent;border:1px dashed var(--control-border);border-radius:6px;color:var(--text-muted);font-size:11px;cursor:pointer;transition:all var(--transition-fast)}.apply-all-btn:hover{border-style:solid;border-color:var(--color-primary);color:var(--text-primary);background:var(--control-bg-hover)}.map-attribution{position:fixed;bottom:8px;right:8px;z-index:600;padding:4px 10px;background:#080a1299;border:1px solid rgba(255,255,255,.1);border-radius:6px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-size:11px;font-weight:500;color:#f0f4ffb3;pointer-events:none;letter-spacing:.02em;box-shadow:0 2px 10px #0000004d;transition:opacity .3s ease}.status-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:700;display:flex;align-items:center;gap:12px;padding:10px 20px;background:var(--status-bg);border:1px solid var(--status-border);border-radius:var(--status-radius);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);font-size:var(--font-size-base);font-weight:400;color:var(--text-primary);pointer-events:none;box-shadow:0 4px 24px #00000059,0 0 0 1px #ffffff0a;white-space:nowrap;max-width:calc(100vw - 48px);overflow:hidden;text-overflow:ellipsis;transition:opacity .3s ease,transform .3s ease}.status-message{font-size:var(--font-size-base);color:var(--text-primary)}.status-coords{font-size:var(--font-size-sm);font-family:SF Mono,Fira Code,monospace;color:var(--text-muted);margin-left:4px;letter-spacing:.02em}.status-coords:before{content:"|";margin-right:8px;color:var(--panel-border)}.status-coords:empty:before{display:none}.bottom-right-controls{position:fixed;bottom:60px;right:16px;z-index:750;display:flex;flex-direction:column;align-items:flex-end;gap:8px;pointer-events:none}.bottom-right-controls>*{pointer-events:auto}.controls-row{display:flex;flex-direction:row;align-items:center;gap:8px}.reset-btn:active,.reset-view-btn:active{transform:translateY(0)}.zoom-btn{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:14px;color:var(--text-primary);font-size:22px;font-weight:500;cursor:pointer;backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);transition:all var(--transition-fast);box-shadow:0 4px 15px #0000004d}.zoom-btn:hover{background:var(--btn-bg-hover);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 6px 20px #4f9eff33}.zoom-btn:active{transform:translateY(0)}.zoom-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.reset-btn:focus-visible,.reset-view-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}@keyframes pulse-ring{0%{transform:scale(1);opacity:.7}to{transform:scale(2.5);opacity:0}}@media(max-width:600px){:root{--panel-width: 100vw}.settings-panel{inset:auto 0 0;width:100%;height:65dvh;border-left:none;border-top:1px solid var(--panel-border);border-radius:16px 16px 0 0;transform:translateY(100%)}.settings-panel.is-open{transform:translateY(0)}.status-bar{bottom:120px;font-size:12px}.bottom-right-controls{bottom:80px;flex-direction:column;align-items:flex-end}}.mapboxgl-ctrl-attrib-inner a,.mapboxgl-ctrl-attrib-button{color:var(--text-muted)!important}.mapboxgl-ctrl-logo{opacity:.5!important}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(4px);animation:modalFadeIn .2s ease-out}.modal-content{background:#1a1a1a;color:#fff;padding:24px;border-radius:12px;width:90%;max-width:400px;box-shadow:0 10px 25px #00000080;border:1px solid #333;text-align:center;animation:modalSlideUp .3s cubic-bezier(.34,1.56,.64,1)}.modal-title{margin-top:0;font-size:1.25rem;color:#ef4444;margin-bottom:12px;font-weight:700}.modal-text{color:#ccc;line-height:1.5;margin-bottom:24px}.modal-actions{display:flex;gap:12px;justify-content:center}.modal-btn{padding:10px 20px;border-radius:6px;border:none;font-weight:600;cursor:pointer;transition:all .2s;flex:1}.modal-btn-secondary{background:#333;color:#eee}.modal-btn-secondary:hover{background:#444}.modal-btn-danger{background:#ef4444;color:#fff}.modal-btn-danger:hover{background:#dc2626;transform:translateY(-1px)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}#toast-container{display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast-message{pointer-events:auto;user-select:none;animation:toast-in .35s cubic-bezier(.18,.89,.32,1.28) forwards;background:var(--panel-bg);border:1px solid var(--color-primary);color:var(--text-primary);box-shadow:0 10px 40px #00000080;backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur)}@keyframes toast-in{0%{opacity:0;transform:translateY(-20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}.obj-move-btn{background:#6366f133;border:1px solid rgba(99,102,241,.4);color:#818cf8;border-radius:6px;height:24px;padding:0 10px;cursor:pointer;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.obj-move-btn:hover{background:#6366f159;border-color:#818cf8;transform:translateY(-1px)}.obj-protect-btn{background:#00dcff33;border:1px solid rgba(0,220,255,.4);color:#00dcff;border-radius:6px;height:24px;padding:0 10px;cursor:pointer;font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center;transition:all var(--transition-fast)}.obj-protect-btn:hover{background:#00dcff59;border-color:#00dcff;transform:translateY(-1px)}.protect-toolbar{display:flex;align-items:center;gap:16px;padding:8px 16px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;backdrop-filter:var(--panel-blur);-webkit-backdrop-filter:var(--panel-blur);box-shadow:0 4px 20px #0003;animation:slide-right .3s cubic-bezier(.4,0,.2,1)}.protect-shape-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--control-bg);border:1px solid var(--control-border);border-radius:6px;color:var(--text-secondary);font-size:16px;cursor:pointer;transition:all var(--transition-fast)}.protect-shape-btn:hover{background:var(--control-bg-hover);border-color:#00dcff}.protect-shape-btn.is-active{background:#00dcff;border-color:#00dcff;color:#fff}.protect-clear-btn{width:auto;height:28px;padding:0 10px;display:flex;align-items:center;justify-content:center;background:#f8717126;border:1px solid rgba(248,113,113,.3);border-radius:6px;color:#f87171;font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.protect-done-btn{width:auto;height:28px;padding:0 16px;display:flex;align-items:center;justify-content:center;background:#22c55e26;border:1px solid rgba(34,197,94,.4);border-radius:6px;color:#4ade80;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.protect-done-btn:hover{background:#22c55e4d;border-color:#4ade80;color:#fff}
