:root{--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface-2: #22263a;--color-border: #2e3350;--color-text: #e2e6f3;--color-text-muted: #8890b0;--color-accent: #3ddc84;--color-accent-dark: #29a863;--color-danger: #e05252;--color-danger-dark: #b83c3c;--color-waypoint: #f5a623;--color-route: #3ddc84;--color-gpx-1: #5b9cf6;--color-gpx-2: #c77dff;--color-gpx-3: #ff9f43;--sidebar-width: 300px;--radius: 10px;--radius-sm: 6px;--shadow: 0 4px 20px rgba(0, 0, 0, .4);--transition: .18s ease;--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;overflow:hidden;font-family:var(--font);background:var(--color-bg);color:var(--color-text)}#sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100%;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;z-index:100;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}#sidebar::-webkit-scrollbar{width:4px}#sidebar::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}#mapContainer{position:fixed;top:0;left:var(--sidebar-width);right:0;bottom:0}#map{width:100%;height:100%}.sidebar-header{padding:24px 20px 16px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;gap:6px;background:linear-gradient(160deg,var(--color-surface-2) 0%,var(--color-surface) 100%)}.sidebar-header .logo{width:44px;height:44px;background:var(--color-accent);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px #3ddc8459}.sidebar-header .logo svg{width:26px;height:26px;stroke:#0f1117}.sidebar-header h1{font-size:1.25rem;font-weight:700;letter-spacing:.5px;color:var(--color-text)}.sidebar-header .subtitle{font-size:.72rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1.2px}.sidebar-section{padding:16px 16px 8px;border-bottom:1px solid var(--color-border)}#routeInfoSection{padding:10px 12px}.sidebar-section:last-child{border-bottom:none}.section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:var(--color-text-muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}.badge{background:var(--color-accent);color:var(--color-bg);border-radius:20px;padding:1px 7px;font-size:.65rem;font-weight:800;min-width:20px;text-align:center}.sidebar-section:has(.profile-selector){padding-bottom:10px}.profile-selector{display:flex;gap:6px;justify-content:space-between;margin-bottom:6px}.profile-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:9px 0;background:var(--color-surface-2);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);font-family:var(--font);position:relative}.profile-btn:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%) translateY(-4px);background:var(--color-surface);color:var(--color-text);font-size:.7rem;font-weight:600;white-space:normal;width:max-content;max-width:160px;text-align:center;padding:5px 10px;border-radius:6px;border:1px solid var(--color-border);box-shadow:0 6px 18px #00000080;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:200}.profile-btn:before{content:"";position:absolute;top:calc(100% + 3px);left:50%;transform:translate(-50%) translateY(-4px);border:5px solid transparent;border-bottom-color:var(--color-border);opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:201}.profile-btn:hover:after,.profile-btn:hover:before{opacity:1;transform:translate(-50%) translateY(0)}.profile-selector .profile-btn:first-child:after{left:0;transform:translate(0) translateY(-4px)}.profile-selector .profile-btn:first-child:before{left:50%}.profile-selector .profile-btn:first-child:hover:after{transform:translate(0) translateY(0)}.profile-selector .profile-btn:first-child:hover:before{transform:translate(-50%) translateY(0)}.profile-selector .profile-btn:last-child:after{left:auto;right:0;transform:translate(0) translateY(-4px)}.profile-selector .profile-btn:last-child:before{left:50%}.profile-selector .profile-btn:last-child:hover:after{transform:translate(0) translateY(0)}.profile-selector .profile-btn:last-child:hover:before{transform:translate(-50%) translateY(0)}.profile-btn svg{width:20px;height:20px;stroke:currentColor;display:block}.profile-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:#3ddc8412}.profile-btn.active{border-color:var(--color-accent);background:#3ddc841f;color:var(--color-accent);box-shadow:0 0 10px #3ddc8433}.profile-active-name{font-size:.72rem;font-weight:700;color:var(--color-accent);text-align:center;letter-spacing:.4px;margin:0;min-height:1em}.tools-grid{display:flex;flex-direction:row;gap:6px;margin-bottom:4px;overflow:visible}.tool-btn{position:relative;flex:1;display:flex;align-items:center;justify-content:center;padding:10px 0;background:var(--color-surface-2);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);font-family:var(--font)}.tool-btn svg{width:17px;height:17px;flex-shrink:0;stroke:currentColor}.tool-btn:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%) translateY(-4px);background:var(--color-surface);color:var(--color-text);font-size:.7rem;font-weight:600;white-space:nowrap;padding:5px 10px;border-radius:6px;border:1px solid var(--color-border);box-shadow:0 6px 18px #00000080;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:200}.tool-btn:before{content:"";position:absolute;top:calc(100% + 3px);left:50%;transform:translate(-50%) translateY(-4px);border:5px solid transparent;border-bottom-color:var(--color-border);opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:201}.tool-btn:not(:disabled):hover:after,.tool-btn:not(:disabled):hover:before{opacity:1;transform:translate(-50%) translateY(0)}.tools-grid .tool-btn:first-child:after{left:0;transform:translate(0) translateY(-4px)}.tools-grid .tool-btn:first-child:before{left:50%}.tools-grid .tool-btn:first-child:not(:disabled):hover:after{transform:translate(0) translateY(0)}.tools-grid .tool-btn:first-child:not(:disabled):hover:before{transform:translate(-50%) translateY(0)}.tools-grid .tool-btn:last-child:after{left:auto;right:0;transform:translate(0) translateY(-4px)}.tools-grid .tool-btn:last-child:before{left:50%}.tools-grid .tool-btn:last-child:not(:disabled):hover:after{transform:translate(0) translateY(0)}.tools-grid .tool-btn:last-child:not(:disabled):hover:before{transform:translate(-50%) translateY(0)}.tool-btn:hover{border-color:var(--color-accent);color:var(--color-text);background:#3ddc840d}.tool-btn.active{border-color:var(--color-accent);background:#3ddc841f;color:var(--color-accent)}.tool-btn.danger:hover{border-color:var(--color-danger);color:var(--color-danger);background:#e0525214}.tool-btn:disabled{opacity:.35;cursor:not-allowed}.route-mode-row{display:flex;align-items:center;gap:8px;margin-top:6px;padding:6px 8px;background:var(--color-surface-2);border:1.5px solid var(--color-border);border-radius:var(--radius-sm)}.route-mode-label{flex:1;font:600 .74rem var(--font);color:var(--color-accent);white-space:nowrap;transition:color var(--transition)}.route-mode-label-alt{font:600 .74rem var(--font);color:var(--color-text-muted);white-space:nowrap;transition:color var(--transition)}.route-mode-row:has(input:checked) .route-mode-label{color:var(--color-text-muted)}.route-mode-row:has(input:checked) .route-mode-label-alt{color:#f0a500}.route-mode-row:has(input:checked){border-color:#f0a500}.toggle-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;inset:0;border-radius:20px;background:var(--color-accent);transition:background var(--transition)}.toggle-slider:before{content:"";position:absolute;width:14px;height:14px;left:3px;top:3px;border-radius:50%;background:#fff;transition:transform var(--transition);box-shadow:0 1px 3px #0006}.toggle-switch input:checked+.toggle-slider{background:#f0a500}.toggle-switch input:checked+.toggle-slider:before{transform:translate(16px)}.file-upload-label{display:flex;flex-direction:row;align-items:center;gap:10px;padding:9px 12px;border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);font-size:.75rem;margin-bottom:8px}.file-upload-label svg{width:16px;height:16px;flex-shrink:0;stroke:currentColor}.file-upload-label small{font-size:.68rem}.file-upload-label:hover,.file-upload-label.drag-over{border-color:var(--color-accent);background:#3ddc8412;color:var(--color-accent)}.route-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:8px;max-height:320px;overflow-y:auto;overflow-x:hidden;transition:max-height .3s ease,opacity .3s ease,margin .3s ease}.route-list.collapsed{max-height:0!important;overflow:hidden;margin-bottom:0;opacity:0}.route-collapse-btn{margin-left:auto;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px 4px;border-radius:4px;display:flex;align-items:center;transition:color var(--transition),transform .25s ease}.route-collapse-btn:hover{color:var(--color-accent)}.route-collapse-btn svg{width:14px;height:14px;stroke:currentColor;transition:transform .25s ease}.route-collapse-btn.collapsed svg{transform:rotate(-90deg)}.route-item{display:flex;align-items:center;gap:4px;padding:4px;background:var(--color-surface-2);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition)}.route-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.route-item-name{flex:1;font-size:.78rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-item-meta{font-size:.68rem;color:var(--color-text-muted);white-space:nowrap}.route-item-remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px;border-radius:4px;transition:color var(--transition);display:flex;align-items:center}.route-item-remove:hover{color:var(--color-danger)}.route-item-remove svg{width:14px;height:14px;stroke:currentColor}.route-item-toggle{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px;border-radius:4px;transition:color var(--transition);display:flex;align-items:center}.route-item-toggle svg{width:15px;height:15px;stroke:currentColor}.route-item-toggle:hover{color:var(--color-accent)}.route-item-toggle.hidden-route{color:var(--color-border)}.export-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 14px;background:linear-gradient(135deg,var(--color-accent-dark),var(--color-accent));border:none;border-radius:var(--radius-sm);color:var(--color-bg);font-weight:700;font-size:.82rem;font-family:var(--font);cursor:pointer;transition:all var(--transition);margin-bottom:8px;box-shadow:0 2px 12px #3ddc844d}.export-btn svg{width:16px;height:16px;stroke:currentColor}.export-btn:hover:not(:disabled){box-shadow:0 4px 20px #3ddc8473;transform:translateY(-1px)}.export-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}.route-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.stat-chip{display:flex;align-items:center;gap:6px;padding:7px 9px;background:var(--color-surface-2);border-radius:var(--radius-sm);border:1px solid var(--color-border);min-width:0;position:relative}.stat-chip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(4px);background:var(--color-surface);color:var(--color-text);font-size:.7rem;font-weight:600;white-space:nowrap;padding:5px 10px;border-radius:6px;border:1px solid var(--color-border);box-shadow:0 6px 18px #00000080;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:200}.stat-chip:before{content:"";position:absolute;bottom:calc(100% + 1px);left:50%;transform:translate(-50%) translateY(4px);border:5px solid transparent;border-top-color:var(--color-border);opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:201}.stat-chip:hover:after,.stat-chip:hover:before{opacity:1;transform:translate(-50%) translateY(0)}.stat-icon{width:13px;height:13px;stroke:var(--color-text-muted);flex-shrink:0}.stat-value{font-size:.82rem;font-weight:700;color:var(--color-accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.stat-refresh-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:3px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:5px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);flex-shrink:0}.stat-refresh-btn svg{width:13px;height:13px;stroke:currentColor;display:block}.stat-refresh-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:#3ddc8414}.stat-refresh-btn:disabled{opacity:.3;cursor:not-allowed}.stat-refresh-btn.spinning svg{animation:spin .7s linear infinite}.fit-all-btn{position:absolute;top:10px;left:10px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#1a1d27eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1.5px solid var(--color-border);border-radius:8px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);z-index:10;padding:0}.fit-all-btn svg{width:18px;height:18px;flex-shrink:0;display:block}.fit-all-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:#1a1d27fa}.fit-all-btn:disabled{opacity:.35;cursor:not-allowed}.basemap-switcher{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:4px;z-index:10}.basemap-btn{display:flex;align-items:center;gap:7px;padding:6px 10px 6px 8px;background:#1a1d27eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1.5px solid var(--color-border);border-radius:8px;color:var(--color-text-muted);cursor:pointer;font-size:.7rem;font-weight:600;font-family:var(--font);letter-spacing:.3px;transition:all var(--transition);white-space:nowrap;min-width:108px}.basemap-btn svg{width:15px;height:15px;stroke:currentColor;flex-shrink:0}.basemap-btn:hover{border-color:var(--color-accent);color:var(--color-text);background:#1a1d27fa}.basemap-btn.active{border-color:var(--color-accent);color:var(--color-accent)}.loading-overlay{position:absolute;bottom:30px;right:16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:24px;padding:8px 16px;display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--color-text-muted);box-shadow:var(--shadow);z-index:50}.loading-spinner{width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-hint{position:absolute;top:16px;left:50%;transform:translate(-50%);background:var(--color-surface);border:1px solid var(--color-border);border-radius:24px;padding:8px 16px;display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--color-text-muted);box-shadow:var(--shadow);z-index:50;pointer-events:none;transition:opacity .4s ease}.map-hint.hidden{opacity:0}.toast-container{position:absolute;bottom:30px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:200;pointer-events:none}.toast{background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-accent);border-radius:var(--radius-sm);padding:9px 16px;font-size:.78rem;color:var(--color-text);box-shadow:var(--shadow);animation:toastIn .25s ease forwards;max-width:320px;text-align:center}.toast.error{border-left-color:var(--color-danger)}.toast.warning{border-left-color:var(--color-waypoint)}@keyframes toastIn{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-8px) scale(.95)}}.toast.removing{animation:toastOut .2s ease forwards}.maplibregl-marker{transition:none!important}.waypoint-marker{width:22px;height:22px;background:var(--color-waypoint);border:2.5px solid #fff;border-radius:50%;box-shadow:0 2px 8px #00000080;cursor:grab;transition:transform .15s ease,box-shadow .15s ease;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;color:#fff;will-change:transform;box-sizing:border-box}.waypoint-marker:hover{transform:scale(1.28);box-shadow:0 3px 12px #0009}.waypoint-marker.start{background:var(--color-accent)}.waypoint-marker.end{background:var(--color-danger)}.waypoint-marker.manual{width:11px;height:11px;border-width:2px;font-size:.45rem}.maplibregl-popup-content{background:var(--color-surface)!important;border:1px solid var(--color-border)!important;border-radius:var(--radius-sm)!important;color:var(--color-text)!important;font-family:var(--font)!important;font-size:.78rem!important;padding:8px 12px!important;box-shadow:var(--shadow)!important;min-width:140px}.maplibregl-popup-tip{display:none!important}.popup-coords{font-size:.68rem;color:var(--color-text-muted);margin-top:4px}.popup-remove-btn{display:block;width:100%;margin-top:8px;padding:4px 0;background:#e052521a;border:1px solid rgba(224,82,82,.3);border-radius:4px;color:var(--color-danger);font-size:.72rem;cursor:pointer;font-family:var(--font);transition:background var(--transition)}.popup-remove-btn:hover{background:#e0525238}.maplibregl-ctrl-group{background:var(--color-surface)!important;border:1px solid var(--color-border)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--shadow)!important}.maplibregl-ctrl-group button{background:transparent!important;color:var(--color-text-muted)!important}.maplibregl-ctrl-group button:hover{background:var(--color-surface-2)!important}.maplibregl-ctrl-attrib{background:#0f1117bf!important;color:var(--color-text-muted)!important;font-size:.65rem!important;border-radius:4px 0 0!important}.maplibregl-ctrl-attrib a{color:var(--color-accent)!important}.route-style-compact{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}.style-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}.style-swatches .color-swatch{width:auto;height:22px;border-radius:5px;transform:none!important}.style-swatches .color-swatch:hover{filter:brightness(1.2);transform:none!important}.style-swatches .color-swatch.selected{outline:2.5px solid #fff;outline-offset:-2.5px;box-shadow:0 0 0 3px #ffffff40}.style-sliders-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.style-slider-col{display:flex;flex-direction:column;gap:4px}.style-mini-label{display:flex;justify-content:space-between;font-size:.68rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.8px}.style-value{font-size:.7rem;font-weight:700;color:var(--color-accent);text-transform:none;letter-spacing:0}.style-slider{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:3px;background:var(--color-border);outline:none;cursor:pointer;transition:background .15s ease}.style-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-accent);cursor:pointer;border:2px solid var(--color-bg);box-shadow:0 0 6px #3ddc8466;transition:transform .12s ease}.style-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.style-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--color-accent);cursor:pointer;border:2px solid var(--color-bg)}.modal-backdrop{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:500;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 8px 40px #0009;width:320px;max-width:calc(100vw - 32px);animation:slideUp .18s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-title{font-size:.95rem;font-weight:700;padding:18px 20px 14px;border-bottom:1px solid var(--color-border);color:var(--color-text)}.modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.modal-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--color-text-muted);margin-bottom:-6px}.modal-input{width:100%;padding:8px 11px;background:var(--color-surface-2);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font);font-size:.85rem;transition:border-color var(--transition);outline:none}.modal-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #3ddc841f}.color-swatches{display:flex;flex-wrap:wrap;gap:8px}.color-swatch{width:26px;height:26px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform .12s ease,border-color .12s ease;flex-shrink:0}.color-swatch:hover{transform:scale(1.18)}.color-swatch.selected{border-color:#fff;box-shadow:0 0 0 2px #fff6;transform:scale(1.15)}.line-width-selector{display:flex;gap:8px}.line-width-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 6px 6px;background:var(--color-surface-2);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;font-family:var(--font);font-size:.7rem;transition:all var(--transition)}.line-width-btn svg{width:44px;height:18px}.line-width-btn:hover{border-color:var(--color-accent);color:var(--color-text)}.line-width-btn.selected{border-color:var(--color-accent);background:#3ddc841f;color:var(--color-accent)}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px 16px;border-top:1px solid var(--color-border)}.modal-footer-split{justify-content:space-between;align-items:center}.modal-footer-right{display:flex;gap:8px}.modal-btn{padding:7px 18px;border-radius:var(--radius-sm);font-family:var(--font);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition);border:1.5px solid transparent}.modal-btn-cancel{background:var(--color-surface-2);border-color:var(--color-border);color:var(--color-text-muted)}.modal-btn-cancel:hover{border-color:var(--color-text-muted);color:var(--color-text)}.modal-btn-save{background:linear-gradient(135deg,var(--color-accent-dark),var(--color-accent));color:var(--color-bg);border-color:transparent;box-shadow:0 2px 10px #3ddc844d}.modal-btn-save:hover{box-shadow:0 4px 16px #3ddc8473;transform:translateY(-1px)}.modal-btn-danger{background:linear-gradient(135deg,#b91c1c,var(--color-danger));color:#fff;border-color:transparent;box-shadow:0 2px 10px #e052524d}.modal-btn-danger:hover{box-shadow:0 4px 16px #e0525280;transform:translateY(-1px)}.modal-confirm{text-align:center;max-width:300px}.modal-confirm-icon{display:flex;justify-content:center;padding:24px 20px 4px}.modal-confirm-icon svg{width:42px;height:42px;stroke:var(--color-danger);filter:drop-shadow(0 0 10px rgba(224,82,82,.4))}.modal-confirm-title{border-bottom:none;padding-top:8px;padding-bottom:4px}.modal-confirm-msg{padding:4px 24px 18px;font-size:.84rem;color:var(--color-text-muted);line-height:1.5;margin:0}.route-item{cursor:pointer}.route-item:hover{border-color:var(--color-accent);background:#3ddc840a}.pin-marker{cursor:pointer;filter:drop-shadow(0 2px 5px rgba(0,0,0,.55));transition:transform .15s ease,filter .15s ease;display:flex;flex-direction:column;align-items:center}.pin-marker:hover{transform:scale(1.18) translateY(-2px);filter:drop-shadow(0 4px 8px rgba(0,0,0,.65))}.pin-marker-icon{width:30px;height:30px;fill:#f5a623;display:block;flex-shrink:0}.pin-marker-label{background:#0f1117e0;color:#e2e6f3;font-family:var(--font);font-size:10.5px;font-weight:600;line-height:1.2;padding:2px 6px;border-radius:4px;white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis;margin-top:2px;box-shadow:0 1px 4px #00000080;pointer-events:none;-webkit-user-select:none;user-select:none;border:1px solid rgba(245,166,35,.35)}@media(max-width:700px){:root{--sidebar-width: 100%}#sidebar{height:auto;max-height:45vh;bottom:0;top:auto;width:100%;flex-direction:row;flex-wrap:wrap;overflow-x:auto;border-right:none;border-top:1px solid var(--color-border)}#mapContainer{left:0;bottom:45vh}.sidebar-header{display:none}.sidebar-section{min-width:180px;flex:1;border-bottom:none;border-right:1px solid var(--color-border)}}
