@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}#map{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%}#map canvas{pointer-events:none}#map canvas:last-child{pointer-events:auto}.settings-toggle{position:fixed;top:16px;right:16px;z-index:900;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)}.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}.settings-panel{position:fixed;top:0;right:0;z-index:800;width:var(--panel-width);height:100dvh;display:flex;flex-direction:column;background:var(--panel-bg);border-left: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:hidden}.settings-panel.is-open{transform:translate(0);box-shadow:-8px 0 40px #0006}.panel-header{padding:72px 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-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;-webkit-appearance:none;-moz-appearance:none;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;-moz-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;top:0;right:0;bottom:0;left: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;-moz-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(44px,1fr));gap:6px;background:var(--control-bg);border:1px solid var(--control-border);border-radius:8px;padding:8px}.thumbnail-item{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#ffffff08;border:1px solid var(--control-border);border-radius:6px;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;padding:4px}.thumbnail-item:hover{background:var(--control-bg-hover);border-color:var(--color-primary);transform:translateY(-2px)}.thumbnail-item.is-selected{background:var(--color-primary-dim);border-color:var(--color-primary);box-shadow:0 0 8px var(--color-primary-dim)}.thumbnail-item img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.thumbnail-item .thumbnail-emoji{font-size:20px}.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)}.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}.reset-btn{position:fixed;bottom:24px;right:16px;z-index:700;display:flex;align-items:center;gap:7px;padding:9px 16px;background:var(--btn-bg);border:1px solid var(--btn-border);border-radius:10px;color:var(--color-primary);font-family:var(--font-main);font-size:var(--font-size-base);font-weight:500;cursor:pointer;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);transition:background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.reset-btn:hover{background:var(--btn-bg-hover);box-shadow:0 0 0 3px var(--color-primary-dim);transform:translateY(-1px)}.reset-btn:active{transform:translateY(0)}.reset-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{top:auto;bottom:0;right:0;left: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)}.panel-header{padding-top:20px}.status-bar{bottom:80px;font-size:12px}.reset-btn{bottom:80px}}.mapboxgl-ctrl-attrib-inner a,.mapboxgl-ctrl-attrib-button{color:var(--text-muted)!important}.mapboxgl-ctrl-logo{opacity:.5!important}
