*{margin:0;padding:0;box-sizing:border-box}:root{--bg-color: #f5f5f5;--bg-secondary: #ffffff;--text-color: #333;--text-secondary: #666;--text-tertiary: #767676;--border-color: #e0e0e0;--shadow: rgba(0,0,0,.1);--sidebar-bg: #ffffff;--card-bg: #fafafa;--input-bg: #ffffff;--button-bg: #ffffff;--button-hover: #f5f5f5;--header-gradient: linear-gradient(135deg, #2e7d32 0%, #1976d2 100%);--header-icon-color: white;--warning-bg: #fff3e0;--warning-text: #e65100;--primary: #2e7d32;--danger: #d32f2f;--surface-alt: #fafafa;--primary-green: #4caf50;--dark-green: #2e7d32;--light-green: #66bb6a;--blue-primary: #1976d2;--blue-light: #2196f3;--tracking-color: var(--blue-light);--tracking-color-rgb: 33, 150, 243;--white: #ffffff;--shadow-green: rgba(76, 175, 80, .3);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--info-section-bg: #f8f9fa;--info-section-border: #e0e0e0;--side-left-color: #2196f3;--side-right-color: var(--warning-color);--elevation-warning-bg: #fff3e0;--link-color: var(--primary-green);--warning-color: var(--warning-color);--danger-color: #f44336}@media(prefers-color-scheme:dark){:root{--bg-color: #1a1a1a;--bg-secondary: #2a2a2a;--text-color: #e0e0e0;--text-secondary: #a0a0a0;--text-tertiary: #808080;--border-color: #404040;--shadow: rgba(0,0,0,.3);--sidebar-bg: #2a2a2a;--card-bg: #333333;--input-bg: #3a3a3a;--button-bg: #3a3a3a;--button-hover: #454545;--header-gradient: linear-gradient(135deg, #1b5e20 0%, #0d47a1 100%);--header-icon-color: white;--warning-bg: #3a2a1a;--warning-text: #ffb74d;--primary: #4caf50;--danger: #ef5350;--surface-alt: #333333;--primary-green: #66bb6a;--light-green: #81c784;--blue-primary: #42a5f5;--blue-light: #64b5f6;--info-section-bg: #2d2d2d;--info-section-border: #404040;--side-left-color: #42a5f5;--side-right-color: #ffa726;--elevation-warning-bg: #3a2a1a;--link-color: var(--light-green);--warning-color: #ffa726;--danger-color: #ef5350}}body.light-mode{--bg-color: #f5f5f5;--bg-secondary: #ffffff;--text-color: #333;--text-secondary: #666;--text-tertiary: #767676;--border-color: #e0e0e0;--shadow: rgba(0,0,0,.1);--sidebar-bg: #ffffff;--card-bg: #fafafa;--input-bg: #ffffff;--button-bg: #ffffff;--button-hover: #f5f5f5;--header-gradient: linear-gradient(135deg, #2e7d32 0%, #1976d2 100%);--header-icon-color: white;--warning-bg: #fff3e0;--warning-text: #e65100;--primary: #2e7d32;--danger: #d32f2f;--surface-alt: #fafafa;--primary-green: #4caf50;--dark-green: #2e7d32;--light-green: #66bb6a;--blue-primary: #1976d2;--blue-light: #2196f3;--info-section-bg: #f8f9fa;--info-section-border: #e0e0e0;--side-left-color: #2196f3;--side-right-color: var(--warning-color);--elevation-warning-bg: #fff3e0;--link-color: var(--primary-green);--warning-color: var(--warning-color);--danger-color: #f44336}body.dark-mode{--bg-color: #1a1a1a;--bg-secondary: #2a2a2a;--text-color: #e0e0e0;--text-secondary: #a0a0a0;--text-tertiary: #808080;--border-color: #404040;--shadow: rgba(0,0,0,.3);--sidebar-bg: #2a2a2a;--card-bg: #333333;--input-bg: #3a3a3a;--button-bg: #3a3a3a;--button-hover: #454545;--header-gradient: linear-gradient(135deg, #1b5e20 0%, #0d47a1 100%);--header-icon-color: white;--warning-bg: #3a2a1a;--warning-text: #ffb74d;--primary: #4caf50;--danger: #ef5350;--surface-alt: #333333;--primary-green: #66bb6a;--light-green: #81c784;--blue-primary: #42a5f5;--blue-light: #64b5f6;--info-section-bg: #2d2d2d;--info-section-border: #404040;--side-left-color: #42a5f5;--side-right-color: #ffa726;--elevation-warning-bg: #3a2a1a;--link-color: var(--light-green);--warning-color: #ffa726;--danger-color: #ef5350}.leaflet-marker-icon{transition:transform .1s ease-out}.leaflet-marker-icon svg{shape-rendering:geometricPrecision}.leaflet-pane .leaflet-marker-pane{z-index:600}.chart-hover-marker{filter:drop-shadow(0 0 8px rgba(255,107,53,.8)) drop-shadow(0 0 16px rgba(255,107,53,.5))}.bi{color:currentColor;vertical-align:middle;display:inline-block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-weight:500;font-size:14px;cursor:pointer;transition:all .2s ease;border:none;text-decoration:none;font-family:inherit;line-height:1.5}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--primary-green);color:#fff;border:none}.btn-primary:hover:not(:disabled){background:var(--dark-green);transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #4caf504d}.btn-secondary{background:transparent;color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){border-color:var(--primary-green);color:var(--primary-green);background:#4caf500d}.btn-secondary:active:not(:disabled){background:#4caf501a}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#b71c1c;transform:translateY(-1px);box-shadow:0 2px 8px #d32f2f4d}.btn-danger:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #d32f2f4d}.btn-icon{width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border-color)}.btn-icon:hover:not(:disabled){border-color:var(--primary-green);color:var(--primary-green);background:#4caf500d}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px;gap:4px}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:15px;gap:8px}.btn-icon.btn-sm{width:28px;height:28px}.btn-icon.btn-lg{width:44px;height:44px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-color);color:var(--text-color);transition:background .3s ease,color .3s ease;padding-top:90px}body:has(.main-content:not(.initial-view)){padding-top:0}.container{max-width:1300px;margin:0 auto;padding:20px}.container:has(.main-content:not(.initial-view)){padding:0;margin:0;max-width:none}.map-view-container{position:fixed;inset:45px 0 0;overflow-x:visible;overflow-y:hidden;z-index:1}body.header-hidden .map-view-container{top:0}#map{width:100%;height:100%;z-index:1}.sidebar-overlay{position:absolute!important;inset:0 auto 38px 0!important;width:350px!important;max-height:none!important;height:auto!important;background:var(--bg-color);box-shadow:2px 0 12px #00000026;z-index:10010;transition:transform .15s ease!important;overflow:hidden!important;display:block!important;padding:6px 6px 0;box-sizing:border-box}.sidebar-overlay.collapsed{transform:translate(-350px)!important}.sidebar-content{height:100%;display:flex;flex-direction:column;overflow:hidden}.sidebar-toggle-tab{position:fixed;left:350px;top:50%;transform:translateY(-50%);width:24px;height:60px;background:var(--bg-color);border:1px solid var(--border-color);border-left:none;border-radius:0 6px 6px 0;box-shadow:2px 0 8px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:left .15s ease,transform .15s ease;z-index:10010;opacity:.9;color:#333}.sidebar-toggle-tab:hover{background:var(--hover-bg, #f0f0f0);opacity:1;box-shadow:2px 0 12px #0003}body.dark-mode .sidebar-toggle-tab{color:#a0a0a0!important}body.dark-mode .sidebar-toggle-tab:hover{background:#404040;color:#f0f0f0}@media(prefers-color-scheme:dark){.sidebar-toggle-tab{color:#a0a0a0}.sidebar-toggle-tab:hover{background:#404040;color:#f0f0f0}}.sidebar-toggle-tab svg{transition:transform .15s ease}body.sidebar-collapsed .sidebar-toggle-tab{left:0!important;transform:translateY(-50%)!important}body:not(.sidebar-collapsed) .sidebar-toggle-tab .arrow-left{display:block}body:not(.sidebar-collapsed) .sidebar-toggle-tab .arrow-right{display:none}body.sidebar-collapsed .sidebar-toggle-tab .arrow-left{display:none}body.sidebar-collapsed .sidebar-toggle-tab .arrow-right{display:block}@media(max-width:768px){.sidebar-overlay{width:100%;bottom:38px!important}.sidebar-overlay.collapsed{transform:translate(-100%)}.sidebar-toggle-tab{display:none!important}}#sidebarOld{display:none!important}.sidebar-toggle{display:none}@media(min-width:769px){.sidebar-toggle,.sidebar-toggle.active{display:none!important}}@media(max-width:768px){.sidebar-toggle.active{display:flex!important;position:absolute;top:50%!important;left:10px!important;transform:translateY(-50%)!important;width:36px;height:36px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-md);align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:none}.sidebar-toggle.active:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-50%) scale(1.05)!important}.sidebar-toggle.active:active{transform:translateY(-50%) scale(.95)!important}.sidebar-toggle svg,.sidebar-toggle .bi{width:20px;height:20px;stroke:#fff;color:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}body.dark-mode .sidebar-toggle.active{background:#ffffff1a;border-color:#fff3}body.dark-mode .sidebar-toggle.active:hover{background:#fff3}body.dark-mode .sidebar-toggle svg,body.dark-mode .sidebar-toggle .bi{stroke:#fff;color:#fff}}.map-view-container{display:none}.map-view-container.active{display:block}header{background:var(--header-gradient);color:#fff;padding:15px 20px;text-align:center;box-shadow:0 2px 10px var(--shadow);position:fixed;top:0;left:0;right:0;overflow:visible;transition:padding .3s ease;z-index:10005;isolation:isolate}header.compact{padding:8px 20px}header.compact h1{font-size:16px;margin-bottom:0}header.compact .tagline{display:none}header.hidden{display:none!important}header.hidden~.main-content .map-view-container,body.header-hidden .map-view-container{top:0!important}body.header-hidden .sidebar-toggle.active{position:fixed!important;top:10px!important;left:10px!important;transform:none!important;z-index:10020!important;background:var(--bg-color)!important;border:1px solid var(--border-color)!important;box-shadow:0 2px 8px #00000026!important}@media(max-width:768px){body.header-hidden .sidebar-toggle.active{background:#fffffff2!important}body.dark-mode.header-hidden .sidebar-toggle.active{background:#1e1e1ef2!important}}.project-name-display{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:400;opacity:.85;max-width:250px;min-width:0}.project-name-display i{font-size:16px;flex-shrink:0}.project-name-display-content{display:flex;flex-direction:column;gap:2px;overflow:hidden;max-width:100%}.project-name-display-filename{display:flex;align-items:center;gap:6px;overflow:hidden}#projectNameText{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px;position:relative}#projectNameText[data-full-name]:hover:after{content:attr(data-full-name);position:absolute;bottom:100%;left:0;background:#000000e6;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:1000;margin-bottom:4px;pointer-events:none;box-shadow:0 2px 8px #0000004d}#projectNameText[data-full-name]:hover:before{content:"";position:absolute;bottom:100%;left:10px;border:5px solid transparent;border-top-color:#000000e6;margin-bottom:-6px;z-index:1000;pointer-events:none}.project-name-display-subtitle{font-size:11px;opacity:.7;font-weight:300;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:22px}#projectNameSubtitleText{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;position:relative}#projectNameSubtitleText[data-full-name]:hover:after{content:attr(data-full-name);position:absolute;top:100%;left:0;background:#000000e6;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:1000;margin-top:4px;box-shadow:0 2px 8px #0000004d;pointer-events:none}#projectNameSubtitleText[data-full-name]:hover:before{content:"";position:absolute;top:100%;left:10px;border:5px solid transparent;border-bottom-color:#000000e6;margin-top:-10px;z-index:1001;pointer-events:none}header.compact .project-name-display{font-size:12px;max-width:200px}header.compact .project-name-display i{font-size:14px}header.compact .project-name-display-subtitle{font-size:10px;padding-left:20px}header.compact #headerBackground{opacity:.5}#headerBackground{position:absolute;inset:0;width:100%;height:100%;opacity:1;pointer-events:none;transition:opacity .3s ease;overflow:hidden}header h1,header p{position:relative;z-index:1}header h1{padding-left:55px}h1{font-size:28px;margin-bottom:6px;transition:font-size .3s ease,margin-bottom .3s ease}.tagline{font-size:14px;opacity:.9;transition:opacity .3s ease}.beta-badge{display:inline-flex;align-items:center;justify-content:center;background:#dc3545;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;padding:3px 8px;border-radius:12px;margin-left:8px;vertical-align:middle;text-transform:uppercase;box-shadow:0 2px 4px #dc35454d;transition:all .3s ease}header.compact .beta-badge{font-size:9px;padding:2px 6px;margin-left:6px}body.dark-mode .beta-badge{background:#f44336;box-shadow:0 2px 4px #f4433666}.header-actions{position:absolute;top:15px;right:20px;z-index:10001;display:flex;align-items:center;gap:10px}.header-save-gpx-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--blue-primary);border:1px solid var(--blue-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:500;color:#fff}.header-save-gpx-btn:hover{background:var(--blue-light);border-color:var(--blue-light);transform:translateY(-2px);box-shadow:0 4px 12px #1976d266}.header-save-gpx-btn i{font-size:14px}@media(max-width:768px){.header-save-gpx-btn{display:none!important}}header.compact .header-actions{top:8px}header.compact .header-save-gpx-btn{padding:6px 12px;font-size:12px}.landing-language-selector{position:relative;display:flex;align-items:center;gap:.5rem}.landing-language-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;color:#fff;backdrop-filter:blur(10px)}.landing-language-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 4px 12px #0003}#landingLanguageFlag{font-size:20px;line-height:1;pointer-events:none}#landingLanguageText{font-size:12px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;pointer-events:none}.landing-language-btn .bi-chevron-down{pointer-events:none}header.compact .landing-language-btn{padding:.35rem .8rem}.language-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fffffff2;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-lg);box-shadow:0 4px 16px #0003;backdrop-filter:blur(10px);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;z-index:10002;min-width:180px;overflow:hidden}.language-dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}.language-dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;background:transparent;border:none;cursor:pointer;transition:background .2s ease;font-size:14px;text-align:left;color:#333}.language-dropdown-item:hover{background:#4caf501a}.language-dropdown-item:not(:last-child){border-bottom:1px solid rgba(0,0,0,.05)}.language-item-flag{font-size:20px;line-height:1;flex-shrink:0}.language-item-name{flex:1;font-weight:500}.language-item-check{color:var(--primary-green);font-size:16px;opacity:0;transition:opacity .2s ease;flex-shrink:0}.language-dropdown-item.active .language-item-check{opacity:1}.language-dropdown-footer{top:auto;bottom:calc(100% + 8px);background:var(--bg-color);border:1px solid var(--border-color)}.language-dropdown-footer .language-dropdown-item{color:var(--text-color)}.language-dropdown-footer .language-dropdown-item:hover{background:#4caf501a}.main-content{margin-top:20px;transition:all .3s ease;max-width:100vw;overflow-x:hidden;margin-left:370px;margin-right:20px;width:calc(100vw - 390px)}.main-content.sidebar-collapsed{margin-left:20px;margin-right:20px;width:calc(100vw - 40px)}.main-content.initial-view{display:flex;justify-content:center;align-items:center;min-height:60vh;margin-left:0;margin-right:0;width:auto}@media(max-width:768px){.main-content.initial-view{min-height:auto;padding-top:10px}.project-name-display{display:none!important}}@media(max-width:600px){.clock-time-inputs-row{flex-direction:column!important;gap:8px!important}}.upload-section-wrapper{max-width:1286px;width:100%;background:var(--sidebar-bg);border-radius:12px;padding:24px 32px;box-shadow:0 4px 24px var(--shadow);border:1px solid var(--border-color);transition:box-shadow .3s ease;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.upload-section-wrapper:hover{box-shadow:0 8px 32px var(--shadow)}.option-card:nth-child(3){animation:fadeInUp .6s ease-out .1s both}.option-card:nth-child(5){animation:fadeInUp .6s ease-out .2s both}.option-card:nth-child(7){animation:fadeInUp .6s ease-out .3s both}.feature-list{animation:fadeInUp .6s ease-out .4s both}.sidebar{background:var(--sidebar-bg);border-radius:var(--radius-lg);padding:20px 20px 0;box-shadow:0 2px 10px var(--shadow);max-height:calc(100vh - 165px);height:calc(100vh - 165px);overflow-y:auto;overflow-x:hidden;display:none;transition:all .3s ease;position:fixed;top:90px;left:20px;width:310px;z-index:100;box-sizing:border-box}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:var(--card-bg);border-radius:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.sidebar.active{display:block}.sidebar.collapsed{transform:translate(-100%);opacity:0;width:0;padding:0;min-width:0;box-shadow:none}.sidebar-toggle{position:absolute;top:5px;left:5px;width:40px;height:40px;background:var(--sidebar-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);display:none;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .3s ease;box-shadow:0 2px 10px var(--shadow)}.sidebar-toggle:hover{background:var(--button-hover);border-color:var(--dark-green);transform:scale(1.05);box-shadow:0 4px 16px #2e7d324d}.sidebar-toggle:active{transform:scale(.95)}.sidebar-toggle.active{display:flex}.sidebar-toggle svg{width:24px;height:24px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.sidebar-toggle:hover svg{stroke:var(--dark-green)}body.dark-mode .sidebar-toggle:hover svg{stroke:#1a1a1a}body.dark-mode .sidebar-toggle:hover .bi{color:#1a1a1a}body.dark-mode .sidebar-toggle svg{stroke:var(--primary-green)}body.dark-mode .sidebar-toggle .bi{color:var(--primary-green)}@media(prefers-color-scheme:dark){body:not(.light-mode) .sidebar-toggle svg{stroke:var(--primary-green)}body:not(.light-mode) .sidebar-toggle .bi{color:var(--primary-green)}body:not(.light-mode) .sidebar-toggle:hover svg{stroke:#1a1a1a}body:not(.light-mode) .sidebar-toggle:hover .bi{color:#1a1a1a}}.hamburger-icon,.arrow-icon{transition:all .3s ease;position:absolute}body.sidebar-collapsed .hamburger-icon,body.sidebar-collapsed .arrow-left{opacity:0;transform:scale(.8)}body.sidebar-collapsed .arrow-right{opacity:1;transform:scale(1)}body:not(.sidebar-collapsed) .hamburger-icon{opacity:0;transform:scale(.8)}body:not(.sidebar-collapsed) .arrow-left{opacity:1;transform:scale(1)}body:not(.sidebar-collapsed) .arrow-right{opacity:0;transform:scale(.8)}.hamburger-icon{opacity:1;transform:scale(1)}.arrow-icon{opacity:0;transform:scale(.8)}.map-section{display:flex;flex-direction:column;gap:5px;display:none;position:relative}.map-section.active{display:flex}.map-container{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:10px;box-shadow:0 2px 10px var(--shadow);height:600px;position:relative;z-index:1}#map{width:100%;height:100%;border-radius:4px;z-index:1}.leaflet-container{z-index:1!important}.leaflet-container:has(.leaflet-popup){z-index:10003!important}.leaflet-map-pane:has(.leaflet-popup){z-index:1001!important}.elevation-container{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-radius:0;padding:0;box-shadow:0 -2px 12px #00000026;display:none;z-index:90;transition:left .15s ease,transform .15s ease}body:not(.sidebar-collapsed) .elevation-container:not(.collapsed){left:350px}body.sidebar-collapsed .elevation-container:not(.collapsed){left:0}.elevation-container.collapsed{position:fixed;bottom:65px;right:55px;left:auto;width:220px;background:transparent;box-shadow:none}.elevation-toggle-icon{position:absolute;top:-24px;right:20px;width:60px;height:24px;background:var(--bg-color);border:1px solid var(--border-color);border-bottom:none;border-radius:var(--radius-md) 6px 0 0;box-shadow:0 -2px 8px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;z-index:91;opacity:.9}.elevation-toggle-icon svg{transition:transform .15s ease}.elevation-toggle-icon:hover{opacity:1;box-shadow:0 -2px 12px #0003;transform:translateY(-2px)}.elevation-container.collapsed .elevation-toggle-icon{right:80px}body.dark-mode .elevation-toggle-icon:hover{background:var(--light-green);color:#1a1a1a}body.dark-mode .elevation-toggle-icon:hover svg{stroke:#1a1a1a}.elevation-toggle-icon:active{transform:translateY(0)}.elevation-container.collapsed .elevation-toggle-icon .arrow-down{display:none}.elevation-container.collapsed .elevation-toggle-icon .arrow-up{display:block}.elevation-container:not(.collapsed) .elevation-toggle-icon .arrow-down{display:block}.elevation-container:not(.collapsed) .elevation-toggle-icon .arrow-up{display:none}.elevation-container.collapsed .elevation-toggle-icon{display:none}.elevation-map-sync-btn{position:absolute;top:-24px;right:90px;width:50px;height:24px;background:var(--bg-color);border:1px solid var(--border-color);border-bottom:none;border-radius:var(--radius-md) 6px 0 0;box-shadow:0 -2px 8px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;z-index:91;opacity:.9;color:var(--text-secondary);padding:0}.elevation-map-sync-btn:hover{opacity:1;box-shadow:0 -2px 12px #0003;transform:translateY(-2px)}.elevation-map-sync-btn:active{transform:translateY(0)}.elevation-map-sync-btn.active{background:var(--warning-color);color:#fff;border-color:#f57c00}.elevation-map-sync-btn.active:hover{background:#f57c00}.elevation-container.collapsed .elevation-map-sync-btn{display:none}body.dark-mode .elevation-map-sync-btn:hover{background:var(--light-green);color:#1a1a1a}body.dark-mode .elevation-map-sync-btn.active{background:var(--warning-color);color:#fff}body.dark-mode .elevation-map-sync-btn.active:hover{background:#f57c00}.elevation-mini-view{display:block;padding:10px;align-items:stretch;transition:all .15s ease;box-sizing:border-box}.elevation-mini-view.hidden{display:none}.elevation-mini-stats{flex:1;display:none;gap:8px;align-items:center;flex-wrap:wrap}.elevation-mini-stat{background:var(--card-bg);padding:4px 10px;border-radius:4px;border-left:3px solid var(--primary-green);display:flex;align-items:center;gap:6px;white-space:nowrap}.elevation-mini-stat.distance{border-left-color:#2196f3}.elevation-mini-stat.gain{border-left-color:var(--primary-green)}.elevation-mini-stat.descent{border-left-color:#03a9f4}.elevation-mini-stat.max{border-left-color:var(--primary-green)}.elevation-mini-stat.min{border-left-color:#2196f3}.elevation-mini-stat-label{font-size:9px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.elevation-mini-stat-value{font-size:13px;font-weight:700;color:var(--text-color)}.elevation-mini-chart-container{width:200px;height:70px;flex:none;min-height:70px;position:relative;background:var(--card-bg);border-radius:var(--radius-md);padding:6px;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;overflow:hidden;box-sizing:border-box}.elevation-mini-chart-container:hover{border-color:var(--light-green);box-shadow:0 2px 8px #66bb6a33;transform:translateY(-1px)}.elevation-mini-chart-container canvas{display:block;pointer-events:none;max-width:100%;max-height:100%}.elevation-content{padding:10px 20px;transition:max-height .25s ease,padding .25s ease,opacity .2s ease;opacity:1}.elevation-content.collapsed{max-height:0;overflow:hidden;padding:0;opacity:0}.elevation-content.expanded{max-height:560px;overflow:visible}.elevation-route-tabs{display:flex;gap:4px;margin-bottom:8px;padding:4px;background:var(--card-bg);border-radius:var(--radius-md);overflow-x:auto;scrollbar-width:thin}.elevation-route-tab{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:background .2s ease,color .2s ease}.elevation-route-tab:hover{background:#0000000d;color:var(--text-color)}body.dark-mode .elevation-route-tab:hover{background:#ffffff1a}.elevation-route-tab.active{background:var(--primary-color);color:#fff}.elevation-route-tab .route-color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.elevation-route-tab.combined-tab{margin-left:auto;border-left:1px solid var(--border-color);padding-left:16px}.elevation-route-tab.combined-tab .route-color-dot{background:linear-gradient(135deg,#1976d2,#4caf50,#ff9800)}.elevation-full-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px;margin-top:0}.elevation-stat-card{background:var(--card-bg);padding:12px;border-radius:var(--radius-md);border-left:4px solid var(--primary-green)}.elevation-stat-card.distance{border-left-color:#2196f3}.elevation-stat-card.gain{border-left-color:var(--primary-green)}.elevation-stat-card.descent{border-left-color:#03a9f4}.elevation-stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}.elevation-stat-value{font-size:22px;font-weight:700;color:var(--text-color);line-height:1}.elevation-stat-unit{font-size:14px;font-weight:500;color:var(--text-secondary);margin-left:4px}.elevation-chart-wrapper{position:relative;height:210px;background:var(--card-bg);border-radius:var(--radius-md);padding:10px;border:2px solid var(--border-color);margin-bottom:0}.elevation-chart-wrapper canvas{cursor:crosshair;position:relative;z-index:1;touch-action:none}.elevation-crosshair{position:absolute;top:0;bottom:0;width:2px;background:#2196f399;pointer-events:none;display:none;z-index:100}.elevation-crosshair-label{position:absolute;top:-25px;left:50%;transform:translate(-50%);background:#2196f3;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;white-space:nowrap;font-weight:600;z-index:100}.elevation-poi-marker{position:absolute;width:9px;height:12px;transform:translate(-50%,-100%);transform-origin:50% 100%;cursor:pointer;z-index:10;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));transition:transform .15s ease;pointer-events:auto}.elevation-poi-marker svg{position:absolute;top:0;left:0;width:100%;height:100%}.elevation-poi-marker .marker-icon{position:absolute;top:2px;left:0;width:9px;height:6px;display:flex;align-items:center;justify-content:center;font-size:4px;color:#fff;line-height:1;pointer-events:none;z-index:2}.elevation-poi-marker .marker-icon i{display:block;line-height:1}.elevation-poi-marker:hover{transform:translate(-50%,-100%) scale(1.2);z-index:11;filter:drop-shadow(0 3px 6px rgba(0,0,0,.7))}.elevation-poi-marker.highlighted{transform:translate(-50%,-100%) scale(1.3);z-index:1000;filter:drop-shadow(0 0 8px rgba(255,152,0,.8)) drop-shadow(0 3px 6px rgba(0,0,0,.7))}.elevation-poi-marker.highlighted svg path{stroke:var(--warning-color);stroke-width:1.5}.elevation-poi-tooltip{position:absolute;background:var(--sidebar-bg);border:2px solid var(--border-color);border-radius:var(--radius-md);padding:8px 12px;font-size:12px;white-space:nowrap;pointer-events:none;display:none;z-index:100;box-shadow:0 4px 12px #0003}.elevation-poi-tooltip.visible{display:block}.elevation-legend{display:flex;gap:15px;flex-wrap:wrap;justify-content:center;padding:10px;background:var(--card-bg);border-radius:var(--radius-md);font-size:12px;margin-bottom:15px}.elevation-loading{display:none;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:15px;color:var(--text-secondary);font-size:14px}.elevation-loading.active{display:flex}.elevation-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-green);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.elevation-legend-item{display:flex;align-items:center;gap:6px}.elevation-legend-color{width:20px;height:12px;border-radius:2px;border:1px solid rgba(0,0,0,.1)}.elevation-legend-item span{color:var(--text-secondary);font-weight:500}.elevation-stat-card{padding:10px 15px;border-radius:var(--radius-md);border-left:3px solid var(--primary-green);flex:1;min-width:140px}.elevation-stat-card.descent{border-left-color:#2196f3}.elevation-stat-card.max{border-left-color:var(--primary-green)}.elevation-stat-card.min{border-left-color:#2196f3}.elevation-stat-card.avg-grade{border-left-color:#607d8b}.elevation-stat-card.steepest{border-left-color:var(--blue-primary)}.elevation-stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.elevation-stat-value{font-size:20px;font-weight:600;color:var(--text-color)}.elevation-stat-subtext{font-size:10px;color:var(--text-tertiary);margin-top:2px}.elevation-crosshair{position:absolute;pointer-events:none;z-index:10}.elevation-crosshair-vertical{width:1px;background:#ff980099;height:100%}.elevation-crosshair-tooltip{position:absolute;background:#000000d9;color:#fff;padding:8px 12px;border-radius:var(--radius-md);font-size:12px;white-space:nowrap;pointer-events:none;transform:translate(-50%,-100%);margin-top:-10px;box-shadow:0 2px 8px #0000004d}body.dark-mode .elevation-crosshair-tooltip{background:#fffffff2;color:#1a1a1a}.elevation-grade-label{position:absolute;background:#f44336e6;color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;pointer-events:none;z-index:5}.elevation-grade-label.moderate{background:#ff9800e6}.elevation-legend{display:flex;gap:15px;margin-top:10px;font-size:11px;color:var(--text-secondary);flex-wrap:wrap}.elevation-legend-item{display:flex;align-items:center;gap:5px}.elevation-legend-color{width:20px;height:12px;border-radius:2px}.section{margin-bottom:15px;flex-shrink:0}.section-title{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text-color);display:flex;align-items:center;gap:10px}.icon-mono{width:20px;height:20px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.icon-mono svg{width:100%;height:100%;stroke:var(--text-secondary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.section-title .icon-mono svg{stroke:var(--text-color);stroke-width:2.2}.landing-intro{text-align:center;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.landing-intro h2{font-size:24px;font-weight:700;color:var(--text-color);margin-bottom:10px;line-height:1.3}.landing-intro p{font-size:14px;color:var(--text-secondary);line-height:1.5;max-width:540px;margin:0 auto}.options-horizontal-container{display:flex;gap:20px;margin-bottom:20px}.option-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:20px;transition:all .3s ease;position:relative;overflow:hidden;flex:1}.options-horizontal-container .option-card{margin-bottom:0}.option-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--dark-green) 0%,var(--blue-primary) 100%);opacity:0;transition:opacity .3s ease}.option-card:hover{border-color:var(--dark-green);transform:translateY(-4px);box-shadow:0 12px 32px #2e7d3226}.option-card:hover:before{opacity:1}body.dark-mode .option-card:hover{box-shadow:0 12px 32px #66bb6a33}.option-card-title{font-size:20px;font-weight:600;color:var(--text-color);margin-bottom:8px;display:flex;align-items:center;gap:10px}.option-card-title .emoji{font-size:28px}.option-card-title .icon-mono{width:24px;height:24px;flex-shrink:0}.option-card-title .icon-mono svg{width:100%;height:100%;stroke:var(--text-secondary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.option-card:hover .icon-mono svg{stroke:var(--dark-green)}body.dark-mode .option-card:hover .icon-mono svg{stroke:var(--light-green)}.option-card-description{font-size:14px;color:var(--text-secondary);margin-bottom:20px;line-height:1.5}.option-divider{text-align:center;margin:20px 0;position:relative;font-size:13px;color:var(--text-tertiary);font-weight:500;letter-spacing:1px}.option-divider:before,.option-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 40px);height:1px;background:linear-gradient(to right,transparent,var(--border-color),transparent)}.option-divider:before{left:0}.option-divider:after{right:0}.option-divider-prominent{text-align:center;margin:32px 0 24px;position:relative;font-size:16px;color:var(--primary-green);font-weight:700;letter-spacing:2px}.option-divider-prominent:before,.option-divider-prominent:after{content:"";position:absolute;top:50%;width:calc(50% - 50px);height:2px;background:linear-gradient(to right,transparent,var(--primary-green),transparent)}.option-divider-prominent:before{left:0}.option-divider-prominent:after{right:0}.community-stats-showcase{background:linear-gradient(135deg,#2e7d3214,#1976d214);border:2px solid var(--primary-green);border-radius:16px;padding:2rem;margin:2.5rem 0 1.5rem;text-align:center;position:relative;overflow:hidden}.stats-background-svg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.community-stats-showcase>*:not(.stats-background-svg){position:relative;z-index:1}body.dark-mode .community-stats-showcase{background:linear-gradient(135deg,#2e7d3226,#1976d226)}body.dark-mode .stats-background-svg .contour{stroke:#66bb6a47}body.dark-mode .stats-background-svg .contour-thick{stroke:#66bb6a61}body.dark-mode .stats-background-svg .road{stroke:#66bb6a52}body.dark-mode .stats-background-svg .pin{fill:#66bb6a73}@media(prefers-color-scheme:dark){body:not(.light-mode) .community-stats-showcase{background:linear-gradient(135deg,#2e7d3226,#1976d226)}body:not(.light-mode) .stats-background-svg .contour{stroke:#66bb6a47}body:not(.light-mode) .stats-background-svg .contour-thick{stroke:#66bb6a61}body:not(.light-mode) .stats-background-svg .road{stroke:#66bb6a52}body:not(.light-mode) .stats-background-svg .pin{fill:#66bb6a73}}.stats-showcase-header{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:1.5rem;font-size:1.1rem;font-weight:600;color:var(--primary-green)}.stats-showcase-header i{font-size:1.3rem}.stats-since{font-size:.75rem;font-weight:400;color:var(--text-secondary);opacity:.8}.stats-showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:900px;margin:0 auto}.stats-showcase-item{padding:1rem}.stats-showcase-value{font-size:2.8rem;font-weight:700;color:var(--primary-green);line-height:1.1;margin-bottom:.5rem}.stats-showcase-label{font-size:1rem;font-weight:600;color:var(--text-color);margin-bottom:.25rem}.stats-showcase-sublabel{font-size:.85rem;color:var(--text-secondary)}.stats-loading{display:inline-block;animation:pulse 1.5s ease-in-out infinite}.stats-loading i{font-size:1.5rem;color:var(--text-secondary)}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}@media(max-width:768px){.community-stats-showcase{padding:1.5rem 1rem;margin:2rem 0 1rem}.stats-showcase-grid{grid-template-columns:1fr;gap:1.25rem}.stats-showcase-item{padding:.75rem;border-bottom:1px solid var(--border-color)}.stats-showcase-item:last-child{border-bottom:none}.stats-showcase-value{font-size:2.2rem}}.landing-alternative-options{background:var(--card-bg);border:4px solid var(--primary-green);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px var(--shadow);margin:32px 0;transition:box-shadow .3s ease}.landing-alternative-options:hover{box-shadow:0 4px 12px var(--shadow)}.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-top:32px;margin-bottom:48px;padding-top:32px;border-top:1px dashed var(--border-color)}.feature-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-secondary)}.feature-item .icon{flex-shrink:0;display:flex;align-items:center}.feature-item .icon svg{stroke:var(--text-secondary);transition:stroke .2s ease}.latest-blog-section{margin-top:32px;padding:20px;background:linear-gradient(135deg,#2e7d3214,#1976d214);border:2px solid var(--primary-green);border-radius:16px;text-align:center;position:relative;overflow:hidden}body.dark-mode .latest-blog-section{background:linear-gradient(135deg,#2e7d3226,#1976d226)}@media(prefers-color-scheme:dark){body:not(.light-mode) .latest-blog-section{background:linear-gradient(135deg,#2e7d3226,#1976d226)}}.blog-background-svg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.latest-blog-section>*:not(.blog-background-svg){position:relative;z-index:1}body.dark-mode .blog-background-svg .blog-contour{stroke:#66bb6a47}body.dark-mode .blog-background-svg .blog-contour-thick{stroke:#66bb6a61}body.dark-mode .blog-background-svg .blog-road{stroke:#66bb6a52}body.dark-mode .blog-background-svg .blog-pin{fill:#66bb6a66}@media(prefers-color-scheme:dark){body:not(.light-mode) .blog-background-svg .blog-contour{stroke:#66bb6a47}body:not(.light-mode) .blog-background-svg .blog-contour-thick{stroke:#66bb6a61}body:not(.light-mode) .blog-background-svg .blog-road{stroke:#66bb6a52}body:not(.light-mode) .blog-background-svg .blog-pin{fill:#66bb6a66}}.latest-blog-title{font-size:1.1rem;font-weight:600;color:var(--primary-green);margin:0 0 1.5rem;display:flex;align-items:center;justify-content:center;gap:10px}.latest-blog-posts{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px}@media(max-width:600px){.latest-blog-posts{grid-template-columns:1fr}}.latest-blog-post{display:flex;flex-direction:row;align-items:stretch;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);text-decoration:none;text-align:left;transition:all .2s ease;overflow:hidden}.latest-blog-post:hover{border-color:var(--link-color);transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow)}.latest-blog-post-thumb{width:72px;height:100%;min-height:64px;object-fit:cover;flex-shrink:0}.latest-blog-post-thumb-placeholder{width:72px;min-height:64px;background:var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.latest-blog-post-thumb-placeholder i{font-size:20px;color:var(--text-secondary);opacity:.4}.latest-blog-post-content{display:flex;flex-direction:column;justify-content:center;padding:10px 12px;min-width:0}.latest-blog-post-title{font-size:13px;font-weight:600;color:var(--text-color);margin-bottom:4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.latest-blog-post:hover .latest-blog-post-title{color:var(--link-color)}.latest-blog-post-meta{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;justify-content:flex-start;gap:4px}.latest-blog-post-meta i{font-size:10px}.latest-blog-view-all{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--link-color);text-decoration:none;font-weight:500;transition:color .2s ease}.latest-blog-view-all:hover{color:var(--link-hover)}.latest-blog-view-all i{font-size:11px;transition:transform .2s ease}.latest-blog-view-all:hover i{transform:translate(2px)}@media(max-width:768px){.latest-blog-section{margin-top:24px;padding:16px}.latest-blog-title{font-size:13px}.latest-blog-post-thumb,.latest-blog-post-thumb-placeholder{width:60px;min-height:56px}.latest-blog-post-content{padding:8px 10px}.latest-blog-post-title{font-size:12px}.latest-blog-post-meta{font-size:10px}}.landing-help-link{display:inline-flex;align-items:center;gap:12px;padding:14px 28px;background:#4caf5014;border:2px solid rgba(76,175,80,.3);border-radius:12px;color:var(--link-color);text-decoration:none;font-size:15px;font-weight:500;transition:all .3s ease}.landing-help-link:hover{background:#4caf5026;border-color:var(--link-color);transform:translateY(-2px);box-shadow:0 4px 12px #4caf5033}.landing-help-link svg{flex-shrink:0;stroke:currentColor}body.dark-mode .landing-help-link{background:#66bb6a1a;border-color:#66bb6a4d;color:var(--light-green)}body.dark-mode .landing-help-link:hover{background:#66bb6a2e;border-color:var(--light-green);box-shadow:0 4px 12px #66bb6a40}.upload-hint{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:8px 14px;background:#2e7d3214;border-radius:var(--radius-md);font-size:13px;color:var(--dark-green);font-weight:500}body.dark-mode .upload-hint{background:#66bb6a1f;color:var(--light-green)}body.dark-mode .option-card{background:var(--card-bg);border-color:var(--border-color)}body.dark-mode .option-card:hover{border-color:var(--light-green)}body.dark-mode .option-card:before{background:linear-gradient(90deg,var(--light-green) 0%,var(--blue-light) 100%)}body.dark-mode .btn-primary{background:linear-gradient(135deg,#388e3c 0%,var(--primary-green) 100%)}body.dark-mode .btn-primary:hover{background:linear-gradient(135deg,var(--dark-green) 0%,#388e3c 100%);box-shadow:0 4px 12px #66bb6a59}body.dark-mode .btn-secondary{background:linear-gradient(135deg,var(--blue-primary) 0%,#42a5f5 100%)}body.dark-mode .btn-secondary:hover{background:linear-gradient(135deg,#1565c0 0%,var(--blue-primary) 100%);box-shadow:0 4px 12px #42a5f559}body.dark-mode .upload-icon{color:var(--light-green)}@media(prefers-color-scheme:dark){.option-card{background:var(--card-bg);border-color:var(--border-color)}.option-card:hover{border-color:var(--light-green)}.option-card:before{background:linear-gradient(90deg,var(--light-green) 0%,var(--blue-light) 100%)}.btn-primary{background:linear-gradient(135deg,#388e3c 0%,var(--primary-green) 100%)}.btn-primary:hover{background:linear-gradient(135deg,var(--dark-green) 0%,#388e3c 100%);box-shadow:0 4px 12px #66bb6a59}.btn-secondary{background:linear-gradient(135deg,var(--blue-primary) 0%,#42a5f5 100%)}.btn-secondary:hover{background:linear-gradient(135deg,#1565c0 0%,var(--blue-primary) 100%);box-shadow:0 4px 12px #42a5f559}.upload-icon{color:var(--light-green)}.upload-hint{background:#66bb6a1f;color:var(--light-green)}input[type=text]:focus{border-color:var(--light-green);box-shadow:0 0 0 3px #66bb6a26}}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none}.collapse-icon{font-size:12px;transition:transform .3s}.collapse-icon.collapsed{transform:rotate(-90deg)}.file-upload{border:3px dashed var(--border-color);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--card-bg);position:relative;overflow:hidden}.file-upload:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(46,125,50,.03) 100%);opacity:0;transition:opacity .3s ease}.file-upload:hover:before{opacity:1}.file-upload:hover{border-color:var(--dark-green);background:linear-gradient(to bottom,#2e7d320d,#2e7d321a);transform:translateY(-2px);box-shadow:0 8px 24px #2e7d321f}body.dark-mode .file-upload:hover{background:linear-gradient(to bottom,#66bb6a14,#66bb6a26);box-shadow:0 8px 24px #66bb6a26}.file-upload.dragover{border-color:var(--dark-green);background:#e8f5e9;transform:scale(1.02);box-shadow:0 8px 32px #2e7d3233}body.dark-mode .file-upload.dragover{background:#2a4a2a}.upload-icon{font-size:32px;color:var(--dark-green);margin-bottom:8px;display:inline-block;transition:transform .3s ease}.file-upload:hover .upload-icon{transform:translateY(-4px)}input[type=file]{position:absolute;top:0;left:0;opacity:0;width:100%;height:100%;cursor:pointer;z-index:1}.file-upload-simple{text-align:center;padding:20px}.upload-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:500}.upload-btn i{font-size:1.2rem}.intro-section{max-width:1100px;margin:0 auto 2rem;background:linear-gradient(135deg,var(--card-bg) 0%,var(--bg-secondary) 100%);border:2px solid var(--primary-green);border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 4px 12px var(--shadow);display:flex;align-items:flex-start;gap:1rem}.intro-icon{flex-shrink:0;width:50px;height:50px;background:var(--primary-green);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 8px #4caf504d}.intro-icon i{font-size:24px;color:#fff}.intro-content{flex:1}.intro-content p{margin:0;font-size:.95rem;line-height:1.5;color:var(--text-color);text-align:left}.landing-quick-links{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin:0 auto 24px;padding:0 16px;max-width:1100px}.quick-link-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;font-size:13px;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;text-decoration:none;transition:all .2s ease}.quick-link-chip:hover{color:var(--primary-green);border-color:var(--primary-green);background:var(--card-bg)}.quick-link-chip i{font-size:14px}.workflow-steps-container{display:flex;align-items:stretch;justify-content:center;gap:1rem;margin-bottom:4rem}.workflow-card-side{flex:0 0 340px;max-width:340px;min-width:340px}.workflow-card-center{flex:0 0 391px;max-width:391px;min-width:391px}.workflow-card{background:var(--card-bg);border:1px solid var(--border-color);border-left:4px solid var(--primary-green);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px var(--shadow);transition:transform .3s ease,box-shadow .3s ease}.workflow-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px var(--shadow)}.workflow-card-center{border:4px solid var(--primary-green)}.workflow-card-side:last-of-type{border-left:1px solid var(--border-color);border-right:4px solid var(--primary-green)}.card-icon{width:60px;height:60px;background:var(--primary-green);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;transition:transform .3s ease}.card-icon:hover{transform:scale(1.1)}.card-icon i{font-size:28px;color:#fff}.card-title{font-size:1.3rem;font-weight:600;margin-bottom:.6rem;color:var(--text-color);text-align:center}.card-description{font-size:1rem;margin-bottom:1rem;opacity:.85;text-align:center;line-height:1.5}.card-list{list-style:none;padding:0;margin-bottom:0}.card-list li{font-size:.9rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.card-list li:last-child{margin-bottom:0}.card-list li i{color:var(--primary-green);font-size:1rem;flex-shrink:0}.workflow-card-side .card-title,.workflow-card-side .card-description,.workflow-card-side .card-list li{color:#666}body.dark-mode .workflow-card-side .card-title,body.dark-mode .workflow-card-side .card-description,body.dark-mode .workflow-card-side .card-list li{color:#767676}@media(prefers-color-scheme:dark){.workflow-card-side .card-title,.workflow-card-side .card-description,.workflow-card-side .card-list li{color:#767676}}.card-illustration{width:180px;height:130px;margin:1rem auto 0;display:flex;align-items:center;justify-content:center}.card-illustration svg{width:100%;height:100%}.workflow-card-center .card-illustration{transform:scale(1.15);margin:24px auto}.workflow-card-center .card-illustration svg{filter:drop-shadow(0 4px 12px rgba(76,175,80,.3))}.workflow-card-clickable{cursor:pointer;transition:background-color .2s ease,transform .2s ease;border-radius:var(--radius-lg);padding:.5rem;margin:-.5rem}.workflow-card-clickable:hover{background-color:#4caf500d}body.dark-mode .workflow-card-clickable:hover{background-color:#4caf5014}.workflow-card-clickable:active{transform:scale(.98)}.workflow-card-clickable .upload-btn{position:relative;z-index:1;cursor:pointer}.workflow-card-clickable .upload-btn:hover{transform:scale(1.05)}.workflow-arrow{color:var(--primary-green);font-size:3rem;align-self:flex-end;margin-bottom:65px;flex-shrink:0;animation:pulseArrow 2s ease-in-out infinite}.workflow-arrow-mobile{display:none}@keyframes pulseArrow{0%,to{transform:translate(0);opacity:1}50%{transform:translate(8px);opacity:.7}}@media(max-width:1250px){.intro-section{padding:1rem 1.25rem;margin-bottom:1.75rem}.intro-content p{font-size:.9rem}.upload-section-wrapper{padding:24px 20px}.workflow-steps-container{gap:.75rem}.workflow-card-side{flex:0 0 280px;max-width:280px;min-width:280px}.workflow-card-center{flex:0 0 322px;max-width:322px;min-width:322px}.workflow-arrow{font-size:2.5rem;margin-bottom:55px}.workflow-card{padding:1.25rem}.card-illustration{width:150px;height:110px}.card-icon{width:50px;height:50px}.card-icon i{font-size:24px}.card-title{font-size:1.15rem}.card-description{font-size:.9rem}.card-list li{font-size:.85rem}}@media(max-width:1100px){.workflow-card-side{flex:0 0 250px;max-width:250px;min-width:250px}.workflow-card-center{flex:0 0 288px;max-width:288px;min-width:288px}.workflow-arrow{font-size:2.25rem}.workflow-card{padding:1rem}.card-illustration{width:130px;height:95px}.card-icon{width:45px;height:45px}.card-icon i{font-size:22px}.card-title{font-size:1.05rem}.card-description{font-size:.85rem}.card-list li{font-size:.8rem}}@media(max-width:950px){.workflow-card-side{flex:0 0 220px;max-width:220px;min-width:220px}.workflow-card-center{flex:0 0 253px;max-width:253px;min-width:253px}.workflow-arrow{font-size:2rem}.workflow-card{padding:.875rem}.card-illustration{width:110px;height:80px}.card-icon{width:40px;height:40px}.card-icon i{font-size:20px}.card-title{font-size:.95rem}.card-description{font-size:.8rem}.card-list li{font-size:.75rem}}@media(max-width:768px){.intro-section{flex-direction:column;align-items:center;text-align:center;padding:1rem;margin-bottom:1.5rem;gap:.75rem}.intro-icon{width:45px;height:45px}.intro-icon i{font-size:22px}.intro-content p{font-size:.9rem;line-height:1.5;text-align:center}.landing-quick-links{margin-bottom:16px;gap:6px}.quick-link-chip{padding:5px 10px;font-size:12px}.quick-link-chip i{font-size:12px}.workflow-steps-container{flex-direction:column;align-items:center;margin-bottom:2rem;gap:.75rem}.workflow-card-side,.workflow-card-center{max-width:100%;width:100%}.workflow-card{padding:1rem}.workflow-arrow{display:none}.workflow-arrow-mobile{display:block!important;color:var(--primary-green);font-size:1.5rem;margin:.25rem auto;text-align:center;animation:pulseArrowMobile 2s ease-in-out infinite}@keyframes pulseArrowMobile{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(8px);opacity:.7}}.card-illustration{display:none}.card-icon{width:50px;height:42px;margin-bottom:.8rem}.card-icon i{font-size:24px}.card-title{font-size:1.2rem;margin-bottom:.5rem}.card-description{font-size:.95rem;margin-bottom:.8rem}.card-list li{font-size:.85rem;margin-bottom:.4rem}}.btn{padding:10px 20px;border:none;border-radius:var(--radius-lg);cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease}.btn:active:before{width:300px;height:300px}.btn-primary{background:linear-gradient(135deg,var(--dark-green) 0%,#388e3c 100%);color:#fff;box-shadow:0 2px 8px #2e7d3240}.btn-primary:hover{background:linear-gradient(135deg,#1b5e20 0%,var(--dark-green) 100%);transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3259}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,var(--blue-primary) 0%,var(--blue-light) 100%);color:#fff;box-shadow:0 2px 8px #1976d240}.btn-secondary:hover{background:linear-gradient(135deg,#1565c0 0%,var(--blue-primary) 100%);transform:translateY(-2px);box-shadow:0 4px 12px #1976d259}.btn-secondary:active{transform:translateY(0)}.btn-danger{background:#d32f2f;color:#fff}.btn-danger:hover{background:#c62828}.btn-outline{background:var(--button-bg);color:var(--dark-green);border:1px solid var(--dark-green)}.btn-outline:hover{background:var(--dark-green);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.search-controls{display:flex;flex-direction:column;gap:6px}.input-group{display:flex;flex-direction:column;gap:1px}label{font-size:13px;font-weight:500;color:var(--text-secondary)}input[type=number],input[type=text],select{padding:8px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;background:var(--input-bg);color:var(--text-color);transition:all .2s ease}input[type=text]:focus{outline:none;border-color:var(--dark-green);box-shadow:0 0 0 3px #2e7d321a}body.dark-mode input[type=text]:focus{border-color:var(--light-green);box-shadow:0 0 0 3px #66bb6a26}input[type=number]:focus,select:focus{outline:none;border-color:var(--dark-green);box-shadow:0 0 0 3px #2e7d321a}.slider-container{display:flex;flex-direction:column;gap:0px}.slider-controls{display:flex;align-items:center;gap:10px}.slider-arrow{flex-shrink:0;width:32px;height:32px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);border-radius:var(--radius-md);font-size:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-tap-highlight-color:transparent}.slider-arrow:hover{background:var(--hover-bg);border-color:var(--dark-green)}.slider-arrow:active{transform:scale(.95);background:var(--border-color)}.slider-arrow:disabled{opacity:.4;cursor:not-allowed}.slider-arrow:disabled:hover{background:var(--card-bg);border-color:var(--border-color)}input[type=range]{flex:1;height:6px;border-radius:3px;background:var(--border-color);outline:none;-webkit-appearance:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer}input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer;border:none}.slider-value{text-align:center;font-size:13px;color:var(--text-secondary);font-weight:500}#searchRadius{flex:1;height:6px;border-radius:3px;outline:none;cursor:pointer;background:linear-gradient(to right,#c8e6c9 0%,#81c784 50%,var(--primary-green) 100%)}#searchRadius::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer;box-shadow:0 2px 4px #0003}#searchRadius::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer;border:none;box-shadow:0 2px 4px #0003}#poiCountLimitSlider{flex:1;height:6px;border-radius:3px;outline:none;transition:opacity .2s}#poiCountLimitSlider:disabled{opacity:.3;cursor:not-allowed;background:var(--border-color)}#poiCountLimitSlider:enabled{cursor:pointer;background:linear-gradient(to right,#c8e6c9 0%,#81c784 50%,var(--primary-green) 100%)}#poiCountLimitSlider:enabled::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer;box-shadow:0 2px 4px #0003}#poiCountLimitSlider:enabled::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer;border:none;box-shadow:0 2px 4px #0003}#poiCountLimitSlider:disabled::-webkit-slider-thumb,#poiCountLimitSlider:disabled::-moz-range-thumb{background:#ccc;cursor:not-allowed}#categoryCountSlider{flex:1;height:6px;border-radius:3px;outline:none;transition:opacity .2s}#categoryCountSlider:disabled{opacity:.3;cursor:not-allowed;background:var(--border-color)}#categoryCountSlider:enabled{cursor:pointer;background:linear-gradient(to right,#c8e6c9 0%,#81c784 50%,var(--primary-green) 100%)}#categoryCountSlider:enabled::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer;box-shadow:0 2px 4px #0003}#categoryCountSlider:enabled::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--dark-green);cursor:pointer;border:none;box-shadow:0 2px 4px #0003}#categoryCountSlider:disabled::-webkit-slider-thumb,#categoryCountSlider:disabled::-moz-range-thumb{background:#ccc;cursor:not-allowed}body.dark-mode #searchRadius{background:linear-gradient(to right,#454545,var(--dark-green))}body.dark-mode #poiCountLimitSlider:enabled{background:linear-gradient(to right,#454545,var(--dark-green))}body.dark-mode #categoryCountSlider:enabled{background:linear-gradient(to right,#454545,var(--dark-green))}input[type=checkbox]{width:18px;height:18px;min-width:18px;min-height:18px;cursor:pointer;accent-color:var(--primary-green);vertical-align:middle;flex-shrink:0}body.dark-mode input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:18px;height:18px;min-width:18px;min-height:18px;border:2px solid #666666;border-radius:3px;background-color:#2a2a2a;cursor:pointer;position:relative;vertical-align:middle;transition:all .2s ease;flex-shrink:0}body.dark-mode input[type=checkbox]:hover{border-color:#888;background-color:#333}body.dark-mode input[type=checkbox]:checked{background-color:#3a3a3a;border-color:var(--primary-green)}body.dark-mode input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid var(--primary-green);border-width:0 2px 2px 0;transform:rotate(45deg)}body.dark-mode input[type=checkbox]:focus{outline:2px solid var(--primary-green);outline-offset:2px}body.dark-mode input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}@media(prefers-color-scheme:dark){body:not(.light-mode) input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:18px;height:18px;min-width:18px;min-height:18px;border:2px solid #666666;border-radius:3px;background-color:#2a2a2a;cursor:pointer;position:relative;vertical-align:middle;transition:all .2s ease;flex-shrink:0}body:not(.light-mode) input[type=checkbox]:hover{border-color:#888;background-color:#333}body:not(.light-mode) input[type=checkbox]:checked{background-color:#3a3a3a;border-color:var(--primary-green)}body:not(.light-mode) input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid var(--primary-green);border-width:0 2px 2px 0;transform:rotate(45deg)}body:not(.light-mode) input[type=checkbox]:focus{outline:2px solid var(--primary-green);outline-offset:2px}body:not(.light-mode) input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}}.elevation-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:15px 0}.elevation-stat-card{background:var(--card-bg);border-radius:var(--radius-lg);padding:12px;display:flex;gap:10px;align-items:center;border-left:3px solid var(--primary-green);transition:transform .2s,box-shadow .2s}.elevation-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.elevation-stat-card.climb{border-left-color:var(--climb-color, #4caf50)}.elevation-stat-card.descent{border-left-color:var(--descent-color, #42a5f5)}.elevation-stat-card.warning{border-left-color:var(--blue-primary)}.stat-icon{font-size:24px}.stat-content{flex:1}.stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-value{font-size:18px;font-weight:700;color:var(--text-color)}.stat-detail{font-size:11px;color:var(--text-tertiary);margin-top:2px}.segment-analysis{margin-top:20px}.segment-category{margin-bottom:20px}.segment-category h4{font-size:14px;margin-bottom:10px;color:var(--text-color)}.segment-list{display:flex;flex-direction:column;gap:8px}.segment-item{background:var(--card-bg);border-radius:var(--radius-md);padding:10px;border-left:3px solid var(--primary-green)}.segment-item.steep-climb{border-left-color:var(--dark-green)}.segment-item.climb{border-left-color:var(--primary-green)}.segment-item.steep-descent{border-left-color:var(--blue-primary)}.segment-item.descent{border-left-color:#42a5f5}.segment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.segment-name{font-weight:600;font-size:13px}.segment-length{font-size:12px;color:var(--text-secondary)}.segment-details{display:flex;gap:12px;font-size:11px;color:var(--text-tertiary)}.poi-categories-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.poi-categories-header>label{margin:0;flex-shrink:0}.category-search-container{display:flex;align-items:center;gap:4px}.category-search-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .2s}.category-search-toggle:hover{background:#2e7d321a;color:var(--primary-color)}.category-search-toggle.active{color:var(--primary-color)}.category-search-input-wrapper{display:flex;align-items:center;width:0;overflow:hidden;opacity:0;transition:width .25s ease,opacity .2s ease}.category-search-input-wrapper.expanded{width:160px;opacity:1}.category-search-input{flex:1;min-width:0;height:28px;padding:4px 28px 4px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:12px;background:var(--card-bg);color:var(--text-color);outline:none;transition:border-color .2s}.category-search-input:focus{border-color:var(--primary-color)}.category-search-input::placeholder{color:var(--text-tertiary)}.category-search-clear{position:absolute;right:4px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;border-radius:2px;opacity:0;transition:opacity .2s,color .2s}.category-search-input-wrapper.expanded .category-search-clear.visible{opacity:1}.category-search-clear:hover{color:var(--text-color)}.category-search-input-wrapper{position:relative}.poi-group.category-search-hidden,.poi-category-item.category-search-hidden{display:none!important}.poi-category-item.category-search-match .category-name{font-weight:600}.category-search-no-results{padding:16px;text-align:center;color:var(--text-secondary);font-size:13px;display:none}.category-search-no-results.visible{display:block}.poi-search-container{display:flex;align-items:center;position:relative}.poi-search-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .2s}.poi-search-toggle:hover{background:#2e7d321a;color:var(--primary-color)}.poi-search-toggle.active{color:var(--primary-color)}.poi-search-input-wrapper{position:absolute;right:100%;display:flex;align-items:center;width:0;overflow:hidden;opacity:0;transition:width .25s ease,opacity .2s ease;margin-right:4px}.poi-search-input-wrapper.expanded{width:140px;opacity:1}.poi-search-input{flex:1;min-width:0;height:26px;padding:4px 24px 4px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:12px;background:var(--card-bg);color:var(--text-color);outline:none;transition:border-color .2s}.poi-search-input:focus{border-color:var(--primary-color)}.poi-search-input::placeholder{color:var(--text-tertiary)}.poi-search-clear{position:absolute;right:4px;display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;border-radius:2px;opacity:0;transition:opacity .2s,color .2s}.poi-search-input-wrapper.expanded .poi-search-clear.visible{opacity:1}.poi-search-clear:hover{color:var(--text-color)}.poi-list-item.poi-search-hidden{display:none!important}.poi-list-no-results{padding:16px;text-align:center;color:var(--text-secondary);font-size:13px;display:none}.poi-list-no-results.visible{display:block}.poi-category-groups{display:flex;flex-direction:column;gap:8px;margin-top:1px}.poi-group{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--card-bg)}.poi-group:last-child{margin-bottom:20px}.poi-group-header{display:flex;justify-content:space-between;align-items:center;padding:4px 12px;background:var(--card-bg);cursor:pointer;user-select:none;transition:background .2s}.poi-group-header:hover{background:#2e7d321a}body.dark-mode .poi-group-header:hover{background:#4caf5026}.poi-group-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-color)}.poi-group-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.poi-group-icon svg,.poi-category-label svg{width:16px;height:16px}.poi-group-icon svg path:not([fill]),.poi-category-label svg path:not([fill]){fill:none;stroke:var(--text-color);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.poi-group-icon svg:not(:has(path[fill])),.poi-category-label svg:not(:has(path[fill])){stroke:var(--text-color);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.poi-group-count{font-size:11px;color:var(--text-secondary);font-weight:400;margin-right:4px}.poi-group-controls{display:flex;align-items:center;gap:8px}.poi-group-toggle-all{font-size:11px;color:var(--dark-green);padding:4px 8px;border-radius:3px;background:var(--button-bg);border:1px solid var(--dark-green);cursor:pointer;transition:all .2s}.poi-group-toggle-all:hover{background:var(--dark-green);color:#fff}body.dark-mode .poi-group-toggle-all{color:var(--light-green);border-color:var(--light-green)}body.dark-mode .poi-group-toggle-all:hover{background:var(--light-green);color:#1a1a1a}.poi-group-toggle-all.all-selected{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.poi-group-toggle-all.all-selected:hover{background:var(--dark-green)}body.dark-mode .poi-group-toggle-all.all-selected{background:var(--light-green);color:#1a1a1a;border-color:var(--light-green)}body.dark-mode .poi-group-toggle-all.all-selected:hover{background:var(--primary-green)}.poi-group-icon.has-selection{color:var(--primary-green)}body.dark-mode .poi-group-icon.has-selection{color:var(--light-green)}.poi-group-arrow{font-size:12px;transition:transform .3s;transform:rotate(180deg);display:inline-block}.poi-group-arrow.collapsed{transform:rotate(0)}.poi-group-content{padding:8px 12px;display:grid;grid-template-columns:1fr;gap:6px;max-height:10000px;overflow:visible;transition:all .3s ease}.poi-group-content.collapsed{max-height:0;padding:0 12px;overflow:hidden}.sidebar-sections-container{position:relative;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}#searchSection{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}#searchSection .collapsible-content{flex:1;min-height:0}.poi-section-overlay{z-index:10;background:var(--sidebar-bg);transition:top .3s ease,bottom .3s ease,transform .3s ease,opacity .3s ease;box-shadow:0 2px 8px #00000026;border-radius:var(--radius-md);border:1px solid var(--border-color);display:flex;flex-direction:column}body.dark-mode .poi-section-overlay{box-shadow:0 2px 12px #0006}.poi-section-overlay .collapsible-content.collapsed{max-height:0;overflow:hidden;padding:0}.poi-section-overlay:not(.minimized) .collapsible-content{max-height:calc(100vh - 300px);overflow-y:auto;overflow-x:hidden;transition:max-height .3s ease}.poi-section-overlay.minimized{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}.poi-section-overlay.minimized .collapsible-content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:visible}.poi-section-overlay.minimized .poi-list{flex:1;min-height:0;max-height:none;overflow-y:auto}.poi-section-overlay:not(.minimized){position:absolute;inset:0;display:flex;flex-direction:column;margin-bottom:0}.poi-section-overlay:not(.minimized) .collapsible-content{max-height:none;flex:1;min-height:0;overflow:visible;display:flex;flex-direction:column;background:var(--sidebar-bg)}.poi-section-overlay.hidden{display:none!important}.sidebar-sections-container:before{content:"";position:absolute;inset:0;background:#0000;pointer-events:none;transition:background .3s ease;z-index:5}.sidebar-sections-container.poi-expanded:before{background:#0000000d}body.dark-mode .sidebar-sections-container.poi-expanded:before{background:#00000026}.sidebar-sections-container.poi-expanded #searchSection{pointer-events:none}.poi-category-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 8px;border-radius:4px;transition:background .2s;min-height:28px}.poi-category-item:hover{background:#2e7d321a}body.dark-mode .poi-category-item:hover{background:#4caf5026}.poi-category-item input[type=checkbox]{margin-right:8px}.poi-category-label{cursor:pointer;user-select:none;flex:1;line-height:1.3;display:flex;align-items:center;gap:6px}.poi-category-name{display:flex;align-items:center;gap:4px}.poi-category-count{font-size:11px;color:var(--success-color, #4caf50);font-weight:500;margin-left:2px}.poi-category-count[data-count="0"]{color:var(--text-secondary, #767676)}.poi-category-cache-btn{flex-shrink:0;opacity:.6;color:#2196f3;background:none;border:none;cursor:pointer;padding:2px 4px;font-size:12px;transition:opacity .2s,color .2s;margin-left:auto}.poi-category-cache-btn:hover{opacity:1;color:var(--blue-primary)}body.dark-mode .poi-category-cache-btn{color:#64b5f6}body.dark-mode .poi-category-cache-btn:hover{color:#90caf9}.poi-category-settings-btn{flex-shrink:0;opacity:.6;color:#666;transition:opacity .2s,color .2s;margin-left:0}.poi-category-cache-btn.u-hidden+.poi-category-settings-btn{margin-left:auto}.poi-category-settings-btn:hover{opacity:1;color:var(--blue-primary)!important}.poi-category-settings-btn.has-custom-distance,.poi-category-settings-btn.has-custom-settings{opacity:1;color:var(--dark-green)!important}body.dark-mode .poi-category-settings-btn{color:#999}body.dark-mode .poi-category-settings-btn.has-custom-distance,body.dark-mode .poi-category-settings-btn.has-custom-settings{color:var(--primary-green)!important}.poi-category-group--custom{border:2px solid var(--primary-green);border-radius:8px;margin-bottom:12px}body.dark-mode .poi-category-group--custom{border-color:var(--light-green)}.poi-category-add-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--primary);cursor:pointer;padding:4px 8px;margin-left:auto;margin-right:8px;border-radius:4px;transition:all .2s}.poi-category-add-btn:hover{background:#2e7d321a;color:var(--dark-green)}body.dark-mode .poi-category-add-btn{color:var(--primary-green)}body.dark-mode .poi-category-add-btn:hover{background:#4caf5026}.poi-category-delete-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;margin-left:4px;opacity:0;transition:opacity .2s,color .2s}.poi-category-cache-btn.u-hidden+.poi-category-delete-btn{margin-left:auto}.poi-category-item:hover .poi-category-delete-btn{opacity:.7}.poi-category-delete-btn:hover{opacity:1!important;color:var(--danger)!important}.poi-category-item--add-prompt{padding:8px 16px}.poi-category-add-prompt-btn{display:flex;align-items:center;gap:8px;background:none;border:1px dashed var(--border-color);border-radius:6px;padding:10px 14px;width:100%;cursor:pointer;color:var(--text-secondary);font-size:13px;transition:all .2s}.poi-category-add-prompt-btn:hover{border-color:var(--primary);color:var(--primary);background:#2e7d320d}body.dark-mode .poi-category-add-prompt-btn:hover{background:#4caf501a}.custom-tag-intro{background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;padding:12px 14px;margin-bottom:16px;font-size:13px;line-height:1.5}.custom-tag-intro p{margin:0;color:var(--text-secondary)}.custom-tag-intro p+p{margin-top:8px}.custom-tag-intro a{color:var(--primary);text-decoration:none}.custom-tag-intro a:hover{text-decoration:underline}.custom-tag-intro-examples{font-size:12px}.custom-tag-intro code{background:#2e7d321a;color:var(--dark-green);padding:2px 6px;border-radius:3px;font-family:monospace;font-size:11px}body.dark-mode .custom-tag-intro code{background:#4caf5026;color:var(--primary-green)}.custom-tag-search-results{max-height:200px;overflow-y:auto;border:1px solid var(--border-color);border-radius:6px;margin-top:8px;background:var(--bg-secondary)}.custom-tag-no-results{padding:16px;text-align:center;color:var(--text-secondary);font-size:13px}.tag-search-result{padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background .15s}.tag-search-result:last-child{border-bottom:none}.tag-search-result:hover{background:var(--button-hover)}.tag-search-result-main{display:flex;align-items:center;gap:8px}.tag-search-result-main strong{font-family:monospace;font-size:13px;color:var(--text-color)}.tag-count{color:var(--text-tertiary);font-size:11px}.tag-description{font-size:12px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.selected-tag-info{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--card-bg);border-radius:6px;border:1px solid var(--border-color)}.selected-tag-badge{display:inline-block;background:var(--primary);color:#fff;padding:4px 10px;border-radius:4px;font-family:monospace;font-size:13px;width:fit-content}.selected-tag-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.selected-tag-key-input{display:flex;align-items:center;gap:4px;margin-bottom:8px}.selected-tag-key-label{font-family:monospace;font-size:14px;font-weight:600;color:var(--primary);white-space:nowrap}.selected-tag-value-input{flex:1;padding:6px 10px;border:1px solid var(--border-color);border-radius:4px;font-family:monospace;font-size:13px;background:var(--input-bg);color:var(--text-color)}.selected-tag-value-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #2e7d321a}.selected-tag-examples{margin-top:4px}.selected-tag-examples small{font-size:11px;color:var(--text-tertiary)}.tag-search-result--key-only{border-left:3px solid var(--warning-color)}.tag-key-hint{font-size:11px;color:var(--text-tertiary);font-style:italic;margin-left:8px}.custom-tag-icon-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px}@media(max-width:600px){.custom-tag-icon-grid{grid-template-columns:repeat(6,1fr)}}.icon-option{display:flex;align-items:center;justify-content:center;padding:10px;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;background:var(--bg-secondary);color:var(--text-secondary);font-size:16px;transition:all .15s}.icon-option:hover{border-color:var(--primary);background:#2e7d320d;color:var(--primary)}.icon-option.selected{border-color:var(--primary);background:#2e7d321a;color:var(--dark-green)}body.dark-mode .icon-option:hover{background:#4caf501a}body.dark-mode .icon-option.selected{background:#4caf5026;color:var(--primary-green)}.category-poi-count-badge{display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--text-secondary);background:#2e7d321a;border:1px solid rgba(46,125,50,.3);border-radius:10px;padding:2px 7px;margin-left:auto;margin-right:4px;min-width:24px;text-align:center;transition:all .2s}body.dark-mode .category-poi-count-badge{background:#4caf5026;border-color:#4caf5066}.category-poi-count-badge:not([data-count="0"]){color:var(--dark-green);background:#2e7d3226;border-color:#2e7d3266}body.dark-mode .category-poi-count-badge:not([data-count="0"]){color:var(--light-green);background:#4caf5033;border-color:#4caf5080}.category-poi-count-badge[data-count="0"]{opacity:.3}.poi-sort-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.poi-sort-btn:hover{background:var(--button-hover);color:var(--text-color)}.poi-sort-btn.active{color:var(--primary-green);background:#4caf501a}body.dark-mode .poi-sort-btn.active{color:var(--light-green);background:#4caf5026}.viewport-filter-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.viewport-filter-btn:hover{background:var(--button-hover);color:var(--text-color)}.viewport-filter-btn.active{color:var(--primary-green);background:#4caf501a}.viewport-filter-btn.active i:before{content:""}body.dark-mode .viewport-filter-btn.active{color:var(--light-green);background:#4caf5026}.favorites-filter-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.favorites-filter-btn:hover{background:var(--button-hover);color:#ffc107}.favorites-filter-btn.active{color:#ffc107;background:#ffc10726}.favorites-filter-btn.active i:before{content:""}body.dark-mode .favorites-filter-btn.active{color:#ffd54f;background:#ffc10733}.category-favorites-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:2px 6px;margin-left:4px;border-radius:4px;transition:all .2s ease}.category-favorites-btn:hover,.category-favorites-btn.active{color:#ffc107}.category-favorites-btn.disabled,.category-favorites-btn:disabled{color:var(--text-secondary);opacity:.3;cursor:not-allowed}.category-favorites-btn.disabled:hover,.category-favorites-btn:disabled:hover{color:var(--text-secondary)}.category-delete-nonfav-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:2px 6px;margin-left:2px;border-radius:4px;transition:all .2s ease}.category-delete-nonfav-btn:hover{color:#f44336}.icon-trash-star{position:relative;display:inline-flex;align-items:center;justify-content:center}.icon-trash-star .bi-trash{font-size:14px}.icon-trash-star .icon-star-overlay{position:absolute;font-size:7px;top:-2px;right:-4px;color:#ffc107;text-shadow:0 0 2px rgba(0,0,0,.3)}.category-delete-nonfav-btn:hover .icon-star-overlay{color:#ffeb3b}.batch-elevation-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;position:relative}.batch-elevation-btn:hover{background:var(--button-hover);color:var(--text-color)}.batch-elevation-btn:disabled{opacity:.3;cursor:not-allowed}.batch-elevation-btn:disabled:hover{background:none;color:var(--text-secondary)}.elevation-count-badge{position:absolute;top:-2px;right:-2px;background:#ff6b6b;color:#fff;font-size:10px;font-weight:600;padding:2px 4px;border-radius:var(--radius-lg);min-width:16px;text-align:center;line-height:1}body.dark-mode .elevation-count-badge{background:#ff5252}.poi-quick-actions{display:flex;gap:6px;margin-top:8px;margin-bottom:30px;padding-top:8px;padding-bottom:10px;border-top:1px solid var(--border-color)}.quick-action-btn{flex:1;padding:5px 10px;border:1px solid var(--border-color);background:var(--button-bg);border-radius:4px;cursor:pointer;font-size:11px;transition:all .2s;text-align:center;color:var(--text-color)}.quick-action-btn:hover{background:#2e7d321a;border-color:var(--dark-green)}body.dark-mode .quick-action-btn:hover{background:#4caf5026;border-color:var(--light-green)}.quick-action-btn-reset{background:var(--blue-primary);color:#fff;border-color:var(--blue-primary)}.quick-action-btn-reset:hover{background:#1565c0;border-color:#1565c0}.search-button-row{display:flex;gap:6px;margin-top:1px;flex-wrap:nowrap}.search-button-row .quick-action-btn{flex:0 1 33.33%;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-button-row .btn-primary{flex:0 1 33.33%;min-width:0}.btn-text-full{display:inline}.btn-text-short{display:none}body.dark-mode .quick-action-btn-reset{background:var(--blue-primary);border-color:var(--blue-primary)}body.dark-mode .quick-action-btn-reset:hover{background:#1565c0;border-color:#1565c0}.preset-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:8px}.preset-btn{padding:5px 10px;border:1px solid var(--border-color);background:var(--button-bg);border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s;text-align:left;white-space:nowrap;color:var(--text-color)}.preset-btn:hover{background:#e8f5e9;border-color:var(--dark-green);color:var(--dark-green)}body.dark-mode .preset-btn:hover{background:#1e3a1e!important;border-color:var(--primary-green);color:var(--light-green)}.preset-btn:active{background:#c8e6c9;transform:scale(.98)}.preset-compact-group{display:flex;gap:8px}.preset-btn-compact{flex:1;display:inline-block}body.dark-mode .preset-btn:active{background:#2a4a2a}.active-preset-display{display:flex;align-items:center;padding:5px 10px;background:#fff8e1;border:1px solid #ffc107;border-radius:4px;font-size:12px;font-weight:500;grid-column:1 / -1;margin-top:0;color:#f57f17;transition:all .2s}body.dark-mode .active-preset-display{background:#3a3300;border-color:#ffc107;color:#ffd54f}.clear-preset-btn{margin-left:auto;padding:2px 6px;background:transparent;border:none;cursor:pointer;color:#f57f17;transition:color .2s;font-size:16px;line-height:1}body.dark-mode .clear-preset-btn{color:#ffd54f}.clear-preset-btn:hover{color:#f44336}.preset-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.preset-item{padding:14px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.preset-item:hover{background:#1976d20d;border-color:var(--blue-primary);transform:translate(4px)}body.dark-mode .preset-item:hover{background:#1976d21a}.preset-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:15px}.preset-item-details{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.preset-item-details span{display:flex;align-items:center;gap:4px}.preset-item-footer{font-size:11px;color:var(--text-tertiary);font-style:italic}.preset-delete-btn{padding:4px 8px;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;color:var(--text-secondary);transition:all .2s;font-size:14px}.preset-delete-btn:hover{background:#f44336;border-color:#f44336;color:#fff}.modal-field{margin-bottom:15px}.modal-field label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-color)}.modal-section{margin-bottom:20px}.modal-section-title{font-size:14px;font-weight:600;color:var(--text-color);margin-bottom:12px;display:flex;align-items:center}.modal-section-divider{height:1px;background:var(--border-color);margin:20px 0;opacity:.5}.distance-unit-input-group{display:flex;gap:8px;align-items:center}.distance-unit-input-group .distance-input{flex:1;min-width:0}.distance-unit-input-group .unit-select{flex-shrink:0;width:auto;min-width:90px;max-width:120px}@media(max-width:480px){.distance-unit-input-group{flex-direction:column;align-items:stretch}.distance-unit-input-group .unit-select{width:100%;max-width:none}}.preset-list-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:10px}.stat-card{background:var(--card-bg);padding:12px;border-radius:var(--radius-md);text-align:center}.stat-value{font-size:24px;font-weight:600;color:var(--dark-green);display:block}body.dark-mode .stat-value{color:var(--light-green)}.stat-label{font-size:12px;color:var(--text-secondary);margin-top:4px}.poi-list{max-height:400px;overflow-y:auto}.poi-section-overlay:not(.minimized) .poi-list{flex:1;min-height:0;max-height:none;overflow-y:auto;background:var(--sidebar-bg)}.poi-list-item{padding:8px 12px;cursor:pointer;border-radius:var(--radius-sm);transition:background .2s;position:relative}.poi-list-item.has-route-indicator{padding-left:16px}.poi-route-indicator{position:absolute;left:0;top:4px;bottom:4px;width:4px;border-radius:2px}.poi-list-item:hover{background:var(--card-bg)}body.dark-mode .poi-list-item:hover{background:var(--button-hover)}.poi-category-section{margin-bottom:15px}.poi-category-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card-bg);border-radius:4px;margin-bottom:5px;cursor:pointer;user-select:none;transition:background .2s}.poi-category-header:hover{background:var(--border-color)}.poi-category-header-icon{flex-shrink:0;font-size:14px}.poi-category-header-text{flex-grow:1;text-align:left;font-weight:600;font-size:13px}.category-count-badge{font-size:11px;color:var(--text-secondary);background:var(--bg-color);padding:2px 6px;border-radius:10px;flex-shrink:0}.category-count-badge.has-selection{background:var(--primary-green);color:#fff}.poi-category-toggle-icon{font-size:14px;transition:transform .3s ease;transform:rotate(0);display:inline-block;flex-shrink:0}.poi-category-header.collapsed .poi-category-toggle-icon{transform:rotate(-90deg)}.poi-category-title{display:flex;align-items:center;gap:6px;font-weight:600;font-size:13px;color:var(--text-color)}.poi-category-icon{font-size:14px;display:inline-block;opacity:.9}.poi-category-controls{display:flex;align-items:center;gap:8px}.poi-category-arrow{font-size:12px;transition:transform .3s;transform:rotate(180deg);display:inline-block}.poi-category-arrow.collapsed{transform:rotate(0)}.poi-category-items{max-height:10000px;overflow:visible;transition:max-height .3s ease,opacity .3s ease;opacity:1}.poi-category-items.collapsed{max-height:0;overflow:hidden;opacity:0}.poi-item{padding:12px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s;display:flex;justify-content:space-between;align-items:flex-start}.poi-item:hover{background:#2e7d321a}body.dark-mode .poi-item:hover{background:#4caf5026}.poi-info{flex:1}.poi-name{font-weight:600;color:var(--text-color);margin-bottom:4px}.poi-category{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.poi-distance{font-size:12px;color:var(--dark-green);font-weight:500}body.dark-mode .poi-distance{color:var(--light-green)}.poi-actions{display:flex;gap:5px}.poi-action-btn{background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:4px;font-size:12px;transition:background .2s;color:#f44336}.poi-action-btn:hover{background:var(--button-hover)}.poi-item-checkbox{margin:0}.poi-selection-footer{position:sticky;bottom:0;left:0;right:0;background:var(--card-bg);border-top:2px solid var(--primary-green);padding:8px 12px;display:none;flex-direction:column;gap:6px;z-index:100;box-shadow:0 -2px 10px #0000001a}body.dark-mode .poi-selection-footer{box-shadow:0 -2px 10px #0000004d}.poi-selection-footer.active{display:flex}.poi-selection-footer-content{display:flex;align-items:center;justify-content:space-between;gap:8px}.poi-selection-footer-info{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.poi-selection-footer-info i{color:var(--primary-green);font-size:13px;flex-shrink:0}.poi-selection-footer-info span{overflow:hidden;text-overflow:ellipsis}.poi-selection-summary{font-size:13px;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:6px}.poi-selection-summary i{color:var(--primary-green);font-size:16px}.poi-selection-footer-actions{display:flex;gap:6px;flex-shrink:0}.poi-selection-action-btn{padding:4px 10px;border-radius:4px;font-size:11px;font-weight:500;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:all .2s;white-space:nowrap}.poi-selection-action-btn i{font-size:12px}.poi-selection-action-btn:disabled{opacity:.4;cursor:not-allowed}.poi-selection-action-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.poi-selection-action-btn.delete{background:#fff;color:#f44336;border:1px solid #f44336}.poi-selection-action-btn.delete:not(:disabled):hover{background:#f44336;color:#fff}body.dark-mode .poi-selection-action-btn.delete{background:#2a2a2a}body.dark-mode .poi-selection-action-btn.delete:not(:disabled):hover{background:#f44336;color:#fff}.poi-selection-action-btn.keep{background:var(--primary-green);color:#fff}.poi-selection-action-btn.keep:not(:disabled):hover{background:var(--dark-green)}@media(max-width:768px){.poi-selection-footer{padding:8px 10px}.poi-selection-footer-content{gap:6px}.poi-selection-footer-info{font-size:10px;flex:1;min-width:0}.poi-selection-footer-info i{font-size:12px}.poi-selection-summary{justify-content:center}.poi-selection-footer-actions{gap:4px}.poi-selection-action-btn{padding:6px 8px;font-size:10px;gap:3px}.poi-selection-action-btn i{font-size:11px}}.message{position:fixed;top:70px;right:20px;padding:15px 20px;border-radius:4px;box-shadow:0 2px 10px #0003;z-index:10010;display:none;animation:slideIn .3s;display:flex;align-items:center;gap:10px;pointer-events:none}.message.success,.message.error,.message.warning,.message.info{pointer-events:auto}.message-icon{flex-shrink:0;width:18px;height:18px}.message-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.message-text{flex:1}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.message.success{background:var(--primary-green);color:#fff}.message.error{background:#f44336;color:#fff}.message.warning{background:var(--warning-color);color:#fff}.message.info{background:#2196f3;color:#fff}.loading{display:none;text-align:center;padding:20px}.loading-spinner{border:3px solid #f3f3f3;border-top:3px solid var(--dark-green);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 10px}.filter-controls{display:flex;gap:10px;margin-bottom:10px;flex-shrink:0}.delete-non-favorites-container{padding:8px 12px;margin-bottom:8px;background:#f4433614;border:1px solid rgba(244,67,54,.2);border-radius:var(--radius-md)}.delete-non-favorites-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;background:transparent;border:1px solid #f44336;border-radius:4px;color:#f44336;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.delete-non-favorites-btn:hover{background:#f44336;color:#fff}body.dark-mode .delete-non-favorites-container{background:#f443361f;border-color:#f443364d}body.dark-mode .delete-non-favorites-btn{color:#ef5350;border-color:#ef5350}body.dark-mode .delete-non-favorites-btn:hover{background:#ef5350;color:#fff}.filter-btn{padding:6px 12px;border:1px solid var(--border-color);background:var(--button-bg);border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s;color:var(--text-color)}.filter-btn:hover{background:var(--button-hover)}.filter-btn.active{background:var(--dark-green);color:#fff;border-color:var(--dark-green)}.route-manager-container{margin-bottom:0}.route-manager-section{background:var(--card-bg);border-radius:var(--radius-lg);padding:12px;border:1px solid var(--border-color);transition:padding .2s ease}.route-manager-section.collapsed{padding:6px 10px}.route-manager-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;margin-bottom:10px}.route-manager-section.collapsed .route-manager-header{margin-bottom:0}.route-manager-section.collapsed .route-manager-title,.route-manager-section.collapsed .route-manager-title i:first-child{font-size:12px}.route-manager-header-actions{display:flex;align-items:center;gap:8px}.route-manager-section.collapsed .route-manager-header-actions{gap:6px}.route-manager-summary{font-size:12px;color:var(--text-secondary);display:none}.route-manager-section.collapsed .route-manager-summary{display:inline;font-size:11px;flex:1;text-align:left;margin-left:8px}.route-manager-chevron{font-size:12px;color:var(--text-secondary);transition:transform .2s ease}.route-manager-chevron.rotated{transform:rotate(180deg)}.route-manager-section.collapsed .route-list,.route-manager-section.collapsed .route-combined-stats{display:none}.route-count-badge{background:var(--primary-green);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;margin-left:4px}.route-manager-title{font-size:13px;font-weight:600;color:var(--text-color);display:flex;align-items:center;gap:6px}.route-manager-title i:first-child{font-size:14px;color:var(--primary-green)}.route-add-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--primary-green);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:14px;transition:background .2s ease,transform .1s ease}.route-add-btn:hover{background:var(--dark-green);transform:scale(1.05)}.route-manager-section.collapsed .route-add-btn{width:22px;height:22px;font-size:12px}.route-manager-section.collapsed .route-count-badge{font-size:9px;padding:1px 5px}.gpx-export-route-options{display:flex;flex-direction:column;gap:8px;margin-top:8px}.gpx-export-route-option{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--input-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:background .2s ease}.gpx-export-route-option:hover{background:var(--card-bg)}.gpx-export-route-option input[type=checkbox]{margin:0}.gpx-export-route-option .route-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.gpx-export-route-option .route-name{flex:1;font-size:13px}.gpx-export-route-option .route-distance{font-size:12px;color:var(--text-secondary)}.gpx-export-mode-options,.sticker-route-options{display:flex;flex-direction:column;gap:8px;margin-top:8px}.sticker-route-option{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--input-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:background .2s ease}.sticker-route-option:hover{background:var(--card-bg)}.sticker-route-option input[type=radio]{margin:0}.sticker-route-option .route-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sticker-route-option .route-name{flex:1;font-size:13px}.sticker-route-option .route-stats{font-size:12px;color:var(--text-secondary)}.u-radio-label{display:flex;align-items:center;cursor:pointer}.u-text-muted{color:var(--text-secondary)}.u-text-sm{font-size:12px}.route-list{display:flex;flex-direction:column;gap:8px}.route-card{background:var(--input-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:10px 12px;cursor:pointer;transition:all .2s ease}.route-card:hover{background:var(--hover-bg)}.route-card.active{background:#4caf501a;border-color:var(--primary-green)}body.dark-mode .route-card.active{background:#4caf5026}.route-card-main{display:flex;align-items:center;gap:8px}.route-color-indicator{width:12px;height:12px;border-radius:3px;flex-shrink:0}.route-drag-handle{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);cursor:grab;padding:0 2px;margin-left:-4px;opacity:.5;transition:opacity .2s ease,color .2s ease}.route-drag-handle:hover{opacity:1;color:var(--text-secondary)}.route-drag-handle:active{cursor:grabbing}.route-card.sortable-ghost{opacity:.4;background:var(--primary-color);border:1px dashed var(--primary-color)}.route-card.sortable-chosen{box-shadow:0 4px 12px #00000026;cursor:grabbing}.route-card.sortable-drag{opacity:1;background:var(--bg-color);box-shadow:0 8px 24px #0003}.route-name{flex:1;font-size:13px;font-weight:500;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:text}.route-name:hover{text-decoration:underline;text-decoration-style:dotted}.route-name-input{flex:1;font-size:13px;font-weight:500;color:var(--text-color);background:var(--input-bg);border:1px solid var(--primary);border-radius:var(--radius-sm);padding:2px 6px;min-width:0;outline:none}.route-name-input:focus{box-shadow:0 0 0 2px #2e7d3233}.route-card-actions{display:flex;gap:4px;flex-shrink:0}.route-poi-visibility-btn,.route-visibility-btn,.route-settings-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:12px;transition:background .2s ease,color .2s ease}.route-poi-visibility-btn:hover,.route-visibility-btn:hover,.route-settings-btn:hover{background:#0000001a;color:var(--text-color)}body.dark-mode .route-poi-visibility-btn:hover,body.dark-mode .route-visibility-btn:hover,body.dark-mode .route-settings-btn:hover{background:#ffffff1a}.route-poi-visibility-btn{color:var(--text-muted)}.route-poi-visibility-btn.showing-pois{color:var(--text-color)}.route-visibility-btn.hidden-route{color:var(--text-muted)}.route-card-stats{display:flex;gap:12px;margin-top:6px;padding-left:20px;font-size:12px;color:var(--text-secondary)}.route-elevation{display:flex;align-items:center;gap:2px}.route-elevation i{font-size:10px}.route-search-checkbox{display:flex;align-items:center;justify-content:center;margin-left:auto;cursor:pointer;position:relative;width:18px;height:18px}.route-search-checkbox input{position:absolute;opacity:0;cursor:pointer;width:0;height:0}.route-search-checkmark{position:absolute;width:16px;height:16px;background:var(--bg-color);border:2px solid var(--border-color);border-radius:3px;transition:all .15s ease}.route-search-checkbox:hover .route-search-checkmark{border-color:var(--primary-green)}.route-search-checkbox input:checked~.route-search-checkmark{background:var(--primary-green);border-color:var(--primary-green)}.route-search-checkmark:after{content:"";position:absolute;display:none;left:4px;top:1px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.route-search-checkbox input:checked~.route-search-checkmark:after{display:block}body.dark-mode .route-search-checkmark{background:var(--card-bg)}body.dark-mode .route-search-checkbox input:checked~.route-search-checkmark{background:var(--primary-green)}.route-combined-stats{display:flex;gap:8px;margin-top:10px;padding-top:8px;border-top:1px solid var(--border-color);font-size:12px;color:var(--text-secondary)}.combined-label{font-weight:500}.combined-distance{color:var(--text-color);font-weight:600}.combined-elevation{display:flex;align-items:center;gap:2px;color:var(--text-secondary)}.combined-elevation i{font-size:10px}.route-search-indicator{margin:8px 0;padding:0 2px;cursor:help}.route-search-indicator-line{display:flex;height:4px;border-radius:2px;overflow:hidden;background:var(--border-color)}.route-search-indicator-segment{flex:1;min-width:20px;transition:opacity .2s ease}.route-search-indicator:hover .route-search-indicator-segment{opacity:.8}.route-color-picker{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.route-color-option{width:32px;height:32px;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:transform .1s ease,border-color .2s ease}.route-color-option:hover{transform:scale(1.1)}.route-color-option.selected{border-color:var(--text-color);box-shadow:0 0 0 2px var(--card-bg),0 0 0 4px var(--text-secondary)}.route-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.route-stat-item{display:flex;flex-direction:column;gap:2px}.route-stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.route-stat-value{font-size:14px;font-weight:600;color:var(--text-color)}.route-compare-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;margin-left:6px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:12px;transition:background .2s ease,color .2s ease;vertical-align:middle}.route-compare-btn:hover{background:#0000001a;color:var(--primary-color)}body.dark-mode .route-compare-btn:hover{background:#ffffff1a}.route-comparison-section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--text-color);margin:0 0 16px}.route-comparison-section-title i{color:var(--primary-color)}.route-comparison-chart-section{margin-bottom:24px}.route-comparison-chart-container{height:300px;background:var(--card-bg);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border-color)}.route-comparison-chart-legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius-md)}.route-comparison-legend-item{display:flex;align-items:center;gap:8px}.route-comparison-legend-color{width:16px;height:4px;border-radius:2px}.route-comparison-legend-name{font-size:13px;color:var(--text-color)}.route-comparison-table-section{margin-bottom:16px}.route-comparison-table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color)}.route-comparison-table{width:100%;border-collapse:collapse;font-size:13px}.route-comparison-table th,.route-comparison-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.route-comparison-table th{background:var(--bg-secondary);font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.route-comparison-table td{background:var(--card-bg);color:var(--text-color)}.route-comparison-table tr:last-child td{border-bottom:none}.route-comparison-table tr:hover td{background:var(--bg-secondary)}.route-comparison-color{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:8px;vertical-align:middle}.sidebar-tab-bar{display:flex;gap:4px;padding:8px;background:var(--card-bg);border-radius:var(--radius-lg);margin-bottom:16px}.sidebar-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);position:relative;transition:all .2s ease}.sidebar-tab:hover:not(.active){background:#0000000d;color:var(--text-color)}body.dark-mode .sidebar-tab:hover:not(.active){background:#ffffff0d}.sidebar-tab.active{background:var(--primary-green);color:#fff;box-shadow:0 2px 8px #4caf504d}body.dark-mode .sidebar-tab.active{background:var(--primary-green);box-shadow:0 2px 8px #4caf5066}.sidebar-tab:disabled,.sidebar-tab.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;color:var(--text-muted)}.sidebar-tab:disabled:hover,.sidebar-tab.disabled:hover{background:var(--button-bg);transform:none}body.dark-mode .sidebar-tab:disabled,body.dark-mode .sidebar-tab.disabled{opacity:.4}.sidebar-tab[data-tab=list][data-count]:not([data-count="0"]):after{content:attr(data-count);position:absolute;top:4px;right:8px;background:#ff5722;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:1.2}.sidebar-tab.active[data-tab=list]:after{display:none}.sidebar-tab i{font-size:16px}.sidebar-tab .tab-badge{position:absolute;top:-6px;right:-6px;background:#f44336;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.poi-section-static-header{padding:12px 16px;border-bottom:1px solid var(--border-color);margin-bottom:0;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.poi-header-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-color)}.poi-header-actions{display:flex;align-items:center;gap:6px}@media(max-width:768px){.sidebar-tab{font-size:13px;padding:10px 8px}.sidebar-tab span:not(.tab-badge){font-size:12px}}.undo-notification{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:12px 20px;border-radius:4px;box-shadow:0 2px 10px #0000004d;display:none;z-index:11000;animation:slideUp .3s}@keyframes slideUp{0%{transform:translate(-50%) translateY(100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.update-notification{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;padding:0;z-index:100000;transform:translateY(-100%);transition:transform .3s ease;box-shadow:0 2px 8px #0003}.update-notification.visible{transform:translateY(0)}.update-notification-content{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 16px;font-size:14px;font-weight:500}.update-notification-content i{font-size:18px}.update-notification-btn{background:#fff3;border:none;color:#fff;padding:6px 14px;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:background .2s}.update-notification-btn:hover{background:#ffffff4d}.update-notification-btn.update-now{background:#fff;color:#1976d2}.update-notification-btn.update-now:hover{background:#f5f5f5}.update-notification-btn.update-dismiss{padding:6px 8px;margin-left:4px}@media(max-width:480px){.update-notification-content{font-size:13px;gap:8px;padding:8px 12px}.update-notification-content>span{flex:1}}@keyframes darkness-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}#darknessWarningIcon{animation:darkness-pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 3px rgba(255,152,0,.5))}#darknessWarningIcon:hover{animation-play-state:paused}.undo-btn{background:var(--primary-green);color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;margin-left:10px;font-size:12px}.undo-btn:hover{background:#45a049}.ps-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:50000;align-items:center;justify-content:center;padding:20px;overflow-y:auto}.ps-modal:not(.u-hidden){display:flex}.ps-modal__container{background:var(--bg-color);border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000004d;max-height:calc(100vh - 40px);display:flex;flex-direction:column;position:relative;width:100%;animation:modalSlideIn .2s ease-out}.ps-modal__container.ps-modal--sm{max-width:350px}.ps-modal__container.ps-modal--md{max-width:500px}.ps-modal__container.ps-modal--lg{max-width:650px}.ps-modal__container.ps-modal--xl{max-width:850px}.ps-modal__container.ps-modal--fullscreen{width:calc(100vw - 32px);height:calc(100vh - 32px);max-width:none;max-height:none}.ps-modal__container.ps-modal--fullscreen .ps-modal__body{flex:1;height:auto;overflow-y:auto}.ps-modal__container:not(.ps-modal--sm):not(.ps-modal--md):not(.ps-modal--lg):not(.ps-modal--xl):not(.ps-modal--fullscreen){max-width:500px}.ps-modal__header{display:flex;align-items:center;gap:10px;padding:20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.ps-modal__title{flex:1;font-size:18px;font-weight:600;color:var(--text-color);margin:0}.ps-modal__close{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-secondary);transition:color .2s;flex-shrink:0}.ps-modal__close:hover{color:var(--text-color)}.ps-modal__close svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;stroke-linecap:round}.ps-modal__close i{font-size:18px}.ps-modal__body{padding:20px;overflow-y:auto;flex:1 1 auto;min-height:0}.ps-modal__footer{display:flex;gap:10px;justify-content:flex-end;padding:15px 20px;border-top:1px solid var(--border-color);flex-shrink:0}.ps-modal__field{margin-bottom:15px}.ps-modal__field label{display:block;margin-bottom:5px;font-weight:500;color:var(--text-secondary);font-size:14px}.ps-modal__field input[type=text],.ps-modal__field input[type=number],.ps-modal__field input[type=email],.ps-modal__field input[type=date],.ps-modal__field input[type=time],.ps-modal__field textarea,.ps-modal__field select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;background:var(--input-bg);color:var(--text-color);box-sizing:border-box}.ps-modal__field input:focus,.ps-modal__field textarea:focus,.ps-modal__field select:focus{outline:none;border-color:var(--dark-green)}.modal-address-section{margin-top:10px;padding:8px 10px;background:var(--card-bg);border-radius:4px;border:1px solid var(--border-color)}.modal-address-row{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-secondary);line-height:1.4}.modal-address-row i{color:var(--text-tertiary);flex-shrink:0;margin-top:2px}.modal-address-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.modal-address-text{word-break:break-word}.modal-address-details{font-size:11px;color:var(--text-tertiary);display:none}.modal-address-copy-btn{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px 4px;border-radius:3px;flex-shrink:0;transition:color .15s,background-color .15s}.modal-address-copy-btn:hover{color:var(--primary-green);background:var(--button-hover)}.modal-address-copy-btn i{font-size:12px;margin:0;color:inherit}.input-with-toggle{display:flex;gap:12px;align-items:stretch}.input-with-toggle input{flex:1;min-width:0}.unit-toggle-buttons{display:flex;gap:0}.unit-toggle-btn{padding:10px 16px;background:var(--button-bg);border:1px solid var(--border-color);color:var(--text-color);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.unit-toggle-btn:first-child{border-radius:var(--radius-md) 0 0 6px}.unit-toggle-btn:last-child{border-radius:0 6px 6px 0;border-left:none}.unit-toggle-btn:hover{background:var(--button-hover)}.unit-toggle-btn.active{background:var(--dark-green);border-color:var(--dark-green);color:#fff}.preview-info-box{background:var(--input-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:12px;display:flex;gap:10px;align-items:flex-start}.preview-info-box__icon{font-size:20px;line-height:1;flex-shrink:0;color:var(--text-secondary)}.preview-info-box__text{color:var(--text-secondary);font-size:13px;line-height:1.5;flex:1}.preview-info-box.has-data{background:#2e7d320d;border-color:#2e7d3233}.preview-info-box.has-data .preview-info-box__icon{color:var(--dark-green)}.preview-info-box.has-data .preview-info-box__text{color:var(--text-color);font-weight:500}@media(max-width:480px){.input-with-toggle{flex-direction:column;gap:10px}.unit-toggle-buttons{width:100%}.unit-toggle-btn{flex:1}.unit-toggle-btn:first-child{border-radius:var(--radius-md) 0 0 6px}.unit-toggle-btn:last-child{border-radius:0 6px 6px 0;border-left:none}}.type-selector{display:flex;gap:10px;flex-wrap:wrap}.type-option{flex:1;min-width:100px;padding:10px;border:2px solid var(--border-color);border-radius:4px;text-align:center;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;background:var(--button-bg);color:var(--text-color);display:flex;flex-direction:column;align-items:center;gap:4px}.type-option:hover{border-color:var(--text-tertiary);transform:translateY(-1px)}.type-option:active{transform:translateY(0)}.type-option.info{background:#e3f2fd;border-color:#2196f3;color:var(--blue-primary)}.type-option.info.selected{border-width:3px;background:#bbdefb;box-shadow:0 0 0 3px #2196f333}.type-option.alert{background:#fff3e0;border-color:var(--warning-color);color:#f57c00}.type-option.alert.selected{border-width:3px;background:#ffe0b2;box-shadow:0 0 0 3px #ff980033}.type-option.danger{background:#ffebee;border-color:#f44336;color:#c62828}.type-option.danger.selected{border-width:3px;background:#ffcdd2;box-shadow:0 0 0 3px #f4433633}.type-option.event-sticker{background:#f3e5f5;border-color:#9c27b0;color:#6a1b9a}.type-option.event-sticker.selected{border-width:3px;background:#e1bee7;box-shadow:0 0 0 3px #9c27b033}body.dark-mode .type-option{background:var(--card-bg)}body.dark-mode .type-option.info{background:#1a3a4a;border-color:#64b5f6;color:#64b5f6}body.dark-mode .type-option.info.selected{background:#1e4a60;box-shadow:0 0 0 3px #64b5f64d}body.dark-mode .type-option.alert{background:#3a2a1a;border-color:#ffb74d;color:#ffb74d}body.dark-mode .type-option.alert.selected{background:#4a3a2a;box-shadow:0 0 0 3px #ffb74d4d}body.dark-mode .type-option.danger{background:#3a1a1a;border-color:#ef5350;color:#ef5350}body.dark-mode .type-option.danger.selected{background:#4a2a2a;box-shadow:0 0 0 3px #ef53504d}body.dark-mode .type-option.event-sticker{background:#2a1a3a;border-color:#ba68c8;color:#ba68c8}body.dark-mode .type-option.event-sticker.selected{background:#3a2a4a;box-shadow:0 0 0 3px #ba68c84d}@media(prefers-color-scheme:dark){.type-option{background:var(--card-bg)}.type-option.info{background:#1a3a4a;border-color:#64b5f6;color:#64b5f6}.type-option.info.selected{background:#1e4a60;box-shadow:0 0 0 3px #64b5f64d}.type-option.alert{background:#3a2a1a;border-color:#ffb74d;color:#ffb74d}.type-option.alert.selected{background:#4a3a2a;box-shadow:0 0 0 3px #ffb74d4d}.type-option.danger{background:#3a1a1a;border-color:#ef5350;color:#ef5350}.type-option.danger.selected{background:#4a2a2a;box-shadow:0 0 0 3px #ef53504d}.type-option.event-sticker{background:#2a1a3a;border-color:#ba68c8;color:#ba68c8}.type-option.event-sticker.selected{background:#3a2a4a;box-shadow:0 0 0 3px #ba68c84d}}@media(max-width:480px){.type-selector{flex-direction:column}.type-option{flex:none;width:100%}}#poiSearchModal .ps-modal__container,#queryPoiProgressModal .ps-modal__container{padding:32px 24px}.progress-spinner{width:100px;height:100px;margin:0 auto 20px;display:flex;flex-direction:column;align-items:center;justify-content:center}.progress-spinner svg{animation:spin 2s linear infinite}.progress-spinner--sm{width:60px;height:60px;margin:0 auto 12px}.progress-spinner--lg{width:140px;height:140px;margin:0 auto 24px}.progress-text{margin-top:12px;color:var(--text-secondary);font-size:14px;text-align:center}.progress-spinner--sm .progress-text{font-size:12px;margin-top:8px}.simple-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:20px auto}.spinner-text{color:var(--text-secondary);font-size:14px;text-align:center}.spinner-border-sm{width:1.5rem;height:1.5rem}.spinner-border-lg{width:3rem;height:3rem}.spinner-checkmark{font-size:48px;color:var(--success-color);animation:checkmark-pop .3s ease-out}@keyframes checkmark-pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}#bicycleWheelSpinner,#queryBicycleWheelSpinner,#apiTestBicycleWheelSpinner,#roadObstaclesBicycleSpinner{width:100%;height:100%;animation:spin 2.5s linear infinite;display:block}.progress-spinner.complete #bicycleWheelSpinner,.progress-spinner.complete #queryBicycleWheelSpinner,.progress-spinner.complete #apiTestBicycleWheelSpinner{display:none}.progress-spinner.complete{border:none;font-size:48px;color:#4caf50;font-weight:700;animation:none}.progress-title{font-size:18px;font-weight:600;margin-bottom:12px;line-height:1.3;color:var(--text-color);text-align:center}.progress-status{font-size:14px;color:var(--text-secondary);margin-bottom:16px;min-height:20px;line-height:1.4;text-align:center}.progress-bar-container{width:100%;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--dark-green),var(--primary-green));transition:width .3s ease;border-radius:4px}.progress-details{font-size:13px;color:var(--text-tertiary);text-align:center}.progress-server{font-size:11px;color:var(--text-tertiary);text-align:center;margin-top:8px;opacity:.7;min-height:16px}.progress-server .server-success{color:var(--primary-green)}.progress-server .server-retry{color:var(--warning-color)}.progress-server .server-fail{color:#f44336}.progress-log{font-size:10px;color:var(--text-secondary);text-align:center;margin-top:10px;padding:6px 12px;background:var(--card-bg);border-radius:4px;font-family:monospace;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body.dark-mode .progress-spinner{border-color:#ffffff1a}@media(prefers-color-scheme:dark){.progress-spinner{border-color:#ffffff1a}}.api-test-results{display:flex;flex-direction:column;gap:10px}.api-test-result{padding:12px;background:var(--card-bg);border-radius:6px;border-left:3px solid}.api-test-result__header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.api-test-result__header i{font-size:16px}.api-test-result__service{flex:1;font-size:14px}.api-test-result__time{font-size:12px;color:var(--text-secondary)}.api-test-result__message{font-size:13px;color:var(--text-secondary);margin-left:24px}.ps-btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.ps-btn:disabled{opacity:.5;cursor:not-allowed}.ps-btn--primary{background:var(--dark-green);color:#fff;border:none}.ps-btn--primary:hover:not(:disabled){background:#1b5e20}.ps-btn--primary:active:not(:disabled){background:#0d3d12}.ps-btn--secondary{background:var(--button-bg);color:var(--text-color);border:1px solid var(--border-color)}.ps-btn--secondary:hover:not(:disabled){background:var(--button-hover)}.ps-btn--danger{background:#f44336;color:#fff;border:none}.ps-btn--danger:hover:not(:disabled){background:#c62828}.ps-btn--danger:active:not(:disabled){background:#8b0000}.ps-btn--compact{padding:6px 12px;font-size:12px}.ps-btn--full{width:100%;justify-content:center}.ps-btn--icon{width:32px;height:32px;padding:0;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:14px}.ps-modal--informative .ps-modal__header i,.ps-modal--informative .ps-modal__title i{color:var(--blue-primary)}.ps-modal--informative .ps-btn--primary{background:var(--blue-primary)}.ps-modal--informative .ps-btn--primary:hover:not(:disabled){background:#1565c0}.ps-modal--informative .ps-btn--primary:active:not(:disabled){background:#0d47a1}.ps-modal--informative .ps-modal__field input:focus,.ps-modal--informative .ps-modal__field textarea:focus,.ps-modal--informative .ps-modal__field select:focus{border-color:var(--blue-primary)}.ps-modal--informative a{color:var(--blue-primary)}.ps-modal--informative a:hover{color:#1565c0}.ps-modal--action .ps-modal__header i,.ps-modal--action .ps-modal__title i{color:var(--dark-green)}.poi-stats-warning{background:#fff3e0;border-left:3px solid var(--warning-color);padding:8px 12px;border-radius:4px;margin-bottom:10px;color:#e65100;font-size:13px;font-weight:500;line-height:1.4}body.dark-mode .poi-stats-warning{background:#3a2a1a;color:#ffb74d}.poi-stats-section{margin-bottom:14px}.poi-stats-section:last-child{margin-bottom:0}.poi-stats-section-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.poi-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:8px}.poi-stats-card{background:var(--card-bg);padding:8px 10px;border-radius:4px;border-left:2px solid var(--dark-green)}.poi-stats-card-label{font-size:11px;color:var(--text-secondary);margin-bottom:3px;line-height:1.3}.poi-stats-card-value{font-size:16px;font-weight:600;color:var(--text-color);line-height:1.2}.poi-stats-empty{text-align:center;padding:20px;color:var(--text-secondary);font-style:italic}.route-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:10px;background:var(--card-bg);border-radius:6px;border:1px solid var(--border-color)}.route-tab{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;background:var(--modal-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.route-tab:hover{background:var(--hover-bg);color:var(--text-color)}.route-tab.active{background:var(--dark-green);color:#fff;border-color:var(--dark-green)}.route-tab-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}body.dark-mode .route-tab{background:var(--card-bg)}body.dark-mode .route-tab:hover{background:var(--hover-bg)}body.dark-mode .route-tab.active{background:var(--dark-green)}.elevation-check-status{text-align:center;padding:40px 20px}.elevation-check-progress{display:flex;align-items:center;justify-content:center;gap:12px;font-size:14px;color:var(--text-secondary)}.elevation-check-progress .spinning{animation:spin 1s linear infinite}.elevation-check-summary h4{font-size:13px;font-weight:600;color:var(--text-color);margin-bottom:10px;display:flex;align-items:center;gap:8px}.elevation-check-summary h4 i{color:var(--dark-green)}.elevation-check-comparison,.elevation-check-variations{background:var(--bg-secondary);border-radius:8px;padding:12px}.elevation-check-variations h4,.elevation-check-variations h4 i{color:var(--warning-color)}.elevation-check-table-wrapper{max-height:250px;overflow-y:auto}.elevation-check-table{width:100%;border-collapse:collapse;font-size:13px}.elevation-check-table th,.elevation-check-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border-color)}.elevation-check-table th{font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;background:var(--card-bg);position:sticky;top:0}.elevation-check-table td{color:var(--text-color)}.elevation-check-table .diff-warning{color:var(--warning-color);font-weight:600}.elevation-check-table .diff-severe{color:var(--error-color);font-weight:600}.elev-check-map-btn,.elev-check-copy-btn{background:transparent;border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.elev-check-map-btn:hover{background:var(--info-color, #2196F3);color:#fff;border-color:var(--info-color, #2196F3)}.elev-check-copy-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.elev-check-map-btn i,.elev-check-copy-btn i{font-size:12px}.elev-check-verify-btn{background:transparent;border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;margin-left:4px}.elev-check-verify-btn:hover{background:var(--info-color, #2196F3);color:#fff;border-color:var(--info-color, #2196F3)}.elev-check-verify-btn:disabled{opacity:.6;cursor:not-allowed}.elev-check-verify-btn i{font-size:12px}.variation-count{font-size:14px;font-weight:400;color:var(--warning-color);margin-left:8px}.elevation-comparison-table{margin-top:10px}.elevation-comparison-table td:first-child{font-weight:600;color:var(--text-secondary)}.elevation-comparison-table td:not(:first-child){text-align:right;font-family:monospace;font-size:14px}.elevation-comparison-table th:not(:first-child){text-align:right}.elev-diff-cell{font-weight:600}.elev-diff-positive{color:var(--warning-color)}.elev-diff-negative{color:var(--info-color, #2196F3)}.elev-diff-neutral{color:var(--text-secondary)}.elevation-check-error{text-align:center;padding:40px 20px;color:var(--error-color)}.elevation-check-error i{font-size:32px;display:block;margin-bottom:12px}.quality-excellent{color:var(--success-color)!important}.quality-good{color:var(--dark-green)!important}.quality-fair{color:var(--warning-color)!important}.quality-poor{color:var(--error-color)!important}.elevation-check-description{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:15px;padding:10px 12px;background:var(--bg-secondary);border-radius:6px;border-left:3px solid var(--dark-green)}.elevation-check-chart{background:var(--bg-secondary);border-radius:8px;padding:12px}.elevation-check-chart-container{height:150px;position:relative}.elevation-check-chart-container canvas{width:100%!important;height:100%!important}@media(max-width:768px){.ps-modal{padding:10px}.ps-modal__container{max-height:calc(100vh - 20px)}.ps-modal__container.ps-modal--sm,.ps-modal__container.ps-modal--md,.ps-modal__container.ps-modal--lg,.ps-modal__container.ps-modal--xl{max-width:100%}.ps-modal__header,.ps-modal__body{padding:15px}.ps-modal__footer{padding:12px 15px;flex-wrap:wrap}.ps-btn{flex:1;justify-content:center;min-width:0}}@media(max-width:768px){.poi-stats-grid{grid-template-columns:repeat(2,1fr);gap:6px}.poi-stats-section-title{font-size:11px}}.services-section{margin-top:24px;padding-top:20px;border-top:2px solid var(--border-color)}.services-section h4{font-size:16px;font-weight:600;color:var(--text-color);margin-bottom:12px;padding-left:12px;border-left:4px solid var(--dark-green)}.services-section.optional h4{border-left-color:var(--blue-primary)}.services-category{margin-bottom:16px}.services-category-title{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.service-card{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;background:var(--card-bg);border-radius:var(--radius-md);margin-bottom:6px;border:1px solid var(--border-color)}.service-icon{flex-shrink:0;width:16px;height:16px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;margin-top:2px}.service-info{flex:1;min-width:0}.service-name{font-size:13px;font-weight:600;color:var(--text-color);margin-bottom:2px}.service-name a{color:var(--link-color);text-decoration:none;transition:color .2s ease}.service-name a:hover{color:var(--link-hover);text-decoration:underline}.service-description{font-size:11px;color:var(--text-secondary);line-height:1.4}.services-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:10px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:12px;transition:all .2s ease}.services-toggle:hover{background:var(--button-hover)}.services-toggle-icon{width:14px;height:14px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s ease}.services-toggle-icon.expanded{transform:rotate(90deg)}.services-toggle-text{font-size:14px;font-weight:600;color:var(--text-color)}.services-attribution{margin-top:16px;padding:10px 12px;background:var(--card-bg);border-left:4px solid var(--blue-primary);border-radius:4px;font-size:11px;color:var(--text-secondary);line-height:1.5}.services-attribution a{color:var(--blue-primary);text-decoration:none}.services-attribution a:hover{text-decoration:underline}.collapsible-content{max-height:none;overflow:visible;transition:max-height .3s ease}.collapsible-content.collapsed{max-height:0;overflow:hidden}.distance-marker-icon{background:transparent!important;border:none!important}.distance-marker-popup .leaflet-popup-content-wrapper{border-radius:8px;box-shadow:0 4px 12px #00000026}.distance-marker-popup .leaflet-popup-content{margin:0}.distance-marker-editor input{background:var(--card-bg);color:var(--text-color)}.distance-marker-editor input:focus{outline:none;border-color:var(--primary-green)}body.dark-mode .distance-marker-popup .leaflet-popup-content-wrapper{background:var(--card-bg);color:var(--text-color)}body.dark-mode .distance-marker-popup .leaflet-popup-tip{background:var(--card-bg)}@media(prefers-color-scheme:dark){body:not(.light-mode) .distance-marker-popup .leaflet-popup-content-wrapper{background:var(--card-bg);color:var(--text-color)}body:not(.light-mode) .distance-marker-popup .leaflet-popup-tip{background:var(--card-bg)}}.peak-marker,.valley-marker{background:transparent!important;border:none!important}.peak-marker-content{display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#ff6b35,#f7931a);color:#fff;padding:4px 8px;border-radius:8px;font-size:11px;font-weight:600;box-shadow:0 2px 8px #0000004d;position:relative}.peak-marker-content:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid #f7931a}.peak-marker-rank{font-size:10px;opacity:.9}.peak-marker-elevation{font-size:12px;font-weight:700}.valley-marker-content{display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff;padding:4px 8px;border-radius:8px;font-size:11px;font-weight:600;box-shadow:0 2px 8px #0000004d;position:relative}.valley-marker-content:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid #2196F3}.valley-marker-rank{font-size:10px;opacity:.9}.valley-marker-elevation{font-size:12px;font-weight:700}.footer-elevation-clickable{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background-color .2s ease}.footer-elevation-clickable:hover{background-color:#4caf5026}.footer-elevation-clickable.active{background-color:#4caf5040}#footerElevationGain.active{background-color:#ff6b3540}#footerElevationGain:hover{background-color:#ff6b3526}#footerElevationLoss.active{background-color:#2196f340}#footerElevationLoss:hover{background-color:#2196f326}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-muted{color:var(--text-tertiary);font-size:12px}.text-center-muted{text-align:center;color:var(--text-tertiary);padding:20px}body.dark-mode .leaflet-popup-content-wrapper{background-color:#2a2a2a;color:#e0e0e0}body.dark-mode .leaflet-popup-tip{background-color:#2a2a2a}body.dark-mode .leaflet-popup-content{color:#e0e0e0}body.dark-mode .leaflet-popup-content a{color:var(--light-green)}body.dark-mode .leaflet-popup-close-button{color:#e0e0e0!important}body.dark-mode .leaflet-popup-close-button:hover{color:#fff!important}.leaflet-control-zoom,.leaflet-control-layers{background:#f8f9fa!important;border:1px solid rgba(0,0,0,.2)!important;box-shadow:0 2px 6px #0000001a!important}.leaflet-control-zoom a,.leaflet-control-layers-toggle{background-color:#fff!important;color:#333!important;border-bottom:1px solid rgba(0,0,0,.1)!important}.leaflet-control-zoom a:hover,.leaflet-control-layers-toggle:hover{background-color:#f0f0f0!important}.leaflet-control-zoom{z-index:1000}.leaflet-control-scale{position:absolute!important;top:14px;right:145px}.leaflet-control-zoom-level{position:absolute!important;top:12px;right:55px}.leaflet-top.leaflet-right .leaflet-control-zoom{position:absolute!important;top:10px;right:10px}.leaflet-control-layers{position:absolute!important;top:75px;right:10px}.leaflet-control-layers-expanded{min-width:130px}.leaflet-control-map-features{position:absolute!important;top:115px;right:10px}.leaflet-control-scale{background:var(--card-bg, #fff);border:1px solid var(--border-color, rgba(0, 0, 0, .2));border-radius:4px;padding:2px 6px;font-size:11px;box-shadow:0 2px 6px #0000001a}.leaflet-control-scale-line{border:none!important;background:transparent!important;font-size:11px;padding:0;margin:0;line-height:1.2}.leaflet-control-zoom-level{background:var(--card-bg, #fff);border:1px solid var(--border-color, rgba(0, 0, 0, .2));border-radius:4px;padding:4px 8px;font-size:11px;font-weight:500;box-shadow:0 2px 6px #0000001a;white-space:nowrap}.leaflet-control-layers{z-index:999;margin-top:10px}.leaflet-control-layers-toggle{width:30px!important;height:30px!important;background-size:16px 16px!important;background-position:center!important;background-image:none!important;position:relative}.leaflet-control-layers-toggle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"%3E%3Cg fill="none" stroke="%23333" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"%3E%3Crect x="2" y="2" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="6.5" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="11" width="12" height="3" rx="0.5"/%3E%3C/g%3E%3C/svg%3E');background-size:contain;background-repeat:no-repeat;background-position:center}body.dark-mode .leaflet-control-layers-toggle:before{background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"%3E%3Cg fill="none" stroke="%23e0e0e0" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"%3E%3Crect x="2" y="2" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="6.5" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="11" width="12" height="3" rx="0.5"/%3E%3C/g%3E%3C/svg%3E')}#skipAnimationBtn:hover{background:#1565c0!important}#skipAnimationBtn:active{background:#0d47a1!important}body.dark-mode .leaflet-control-zoom,body.dark-mode .leaflet-control-layers,body.dark-mode .leaflet-bar,body.dark-mode .leaflet-control-attribution,body.dark-mode .leaflet-control-scale{background:#2a2a2a!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}body.dark-mode .leaflet-control-zoom a,body.dark-mode .leaflet-bar a,body.dark-mode .leaflet-control-layers-toggle{background-color:#333!important;background-image:none!important;color:#e0e0e0!important;border-bottom:1px solid rgba(255,255,255,.1)!important}body.dark-mode .leaflet-control-zoom-in,body.dark-mode .leaflet-control-zoom-out{color:#e0e0e0!important;text-shadow:none!important}body.dark-mode .leaflet-control-zoom-in:before,body.dark-mode .leaflet-control-zoom-out:before{filter:invert(1)!important}body.dark-mode .leaflet-control-zoom a:hover,body.dark-mode .leaflet-bar a:hover,body.dark-mode .leaflet-control-layers-toggle:hover{background-color:#404040!important;background-image:none!important}body.dark-mode .leaflet-control-zoom a:active,body.dark-mode .leaflet-bar a:active,body.dark-mode .leaflet-control-layers-toggle:active{background-color:#4a4a4a!important;background-image:none!important}body.dark-mode .leaflet-control-zoom a:focus,body.dark-mode .leaflet-bar a:focus,body.dark-mode .leaflet-control-layers-toggle:focus{outline:2px solid rgba(255,255,255,.3)!important;outline-offset:-2px!important}body.dark-mode .leaflet-disabled,body.dark-mode .leaflet-control-zoom-in.leaflet-disabled,body.dark-mode .leaflet-control-zoom-out.leaflet-disabled{background-color:#2a2a2a!important;color:#666!important;cursor:default!important;opacity:.4!important}body.dark-mode .leaflet-control-layers-expanded{background:#2a2a2a!important;color:#e0e0e0!important;border:1px solid rgba(255,255,255,.2)!important}body.dark-mode .leaflet-control-layers-base label,body.dark-mode .leaflet-control-layers-overlays label{color:#e0e0e0!important}body.dark-mode .leaflet-control-layers-selector{filter:brightness(1.2)!important}body.dark-mode .leaflet-control-layers-separator{border-top:1px solid rgba(255,255,255,.1)!important}body.dark-mode .leaflet-control-attribution,body.dark-mode .leaflet-control-attribution a{background:#2a2a2a!important;color:#999!important}body.dark-mode .leaflet-control-attribution a:hover{color:#e0e0e0!important}body.dark-mode .leaflet-control-scale{background:#2a2a2a;border-color:#fff3}body.dark-mode .leaflet-control-scale-line{background:transparent!important;border:none!important;color:#e0e0e0!important}body.dark-mode .leaflet-control-zoom-level{background:#2a2a2a;color:#e0e0e0;border-color:#fff3}.leaflet-control-map-features{background:#fff;border:2px solid rgba(0,0,0,.2);border-radius:4px;box-shadow:0 1px 5px #0000001a;margin-top:10px}.map-feature-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-bottom:1px solid rgba(0,0,0,.1);cursor:pointer;transition:background .2s ease;padding:0}.map-feature-btn:last-child{border-bottom:none}.map-feature-btn:hover{background:#f4f4f4}.map-feature-btn:active{background:#e8e8e8}.map-feature-btn.hidden{display:none}.map-feature-btn .bi{font-size:16px;color:#333}.map-feature-btn.inactive .bi{opacity:.4}body.dark-mode .leaflet-control-map-features{background:#2a2a2a!important;border:2px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}body.dark-mode .map-feature-btn{background:#333!important;border-bottom:1px solid rgba(255,255,255,.1)!important}body.dark-mode .map-feature-btn:hover{background:#404040!important}body.dark-mode .map-feature-btn:active{background:#4a4a4a!important}body.dark-mode .map-feature-btn .bi{color:#e0e0e0!important}body.dark-mode .map-feature-btn.inactive .bi{opacity:.4!important}.map-feature-btn.query-active{background:#ff98004d!important;border-left:4px solid var(--warning-color)!important}.map-feature-btn#liveTrackingBtn.active{background:rgba(var(--tracking-color-rgb),.25)!important;border-left:4px solid var(--tracking-color)!important}.map-feature-btn#liveTrackingBtn.active .bi{color:var(--tracking-color)!important;opacity:1}.map-feature-btn:disabled{opacity:.4;cursor:not-allowed}.query-poi-marker .poi-marker-circle{background-color:var(--warning-color)!important;opacity:.85}.query-poi-marker:hover .poi-marker-circle{background-color:#f57c00!important}.query-results-section{background:linear-gradient(135deg,#fff8f0,#fff);border:2px solid var(--warning-color);border-radius:var(--radius-lg);margin-bottom:16px;padding:16px;flex:1;display:flex;flex-direction:column;overflow-y:auto;min-height:0}.marker-cluster-small{background-color:#6ecc3999}.marker-cluster-small div{background-color:#6ecc39cc}.marker-cluster-medium{background-color:#ffc40099}.marker-cluster-medium div{background-color:#ffc400cc}.marker-cluster-large{background-color:#fd9c7399}.marker-cluster-large div{background-color:#fd9c73cc}.marker-cluster{background-clip:padding-box;border-radius:20px}.marker-cluster div{width:30px;height:30px;margin-left:5px;margin-top:5px;text-align:center;border-radius:15px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center}.marker-cluster span{line-height:30px;font-size:13px}body.dark-mode .marker-cluster-small{background-color:#4caf5099}body.dark-mode .marker-cluster-small div{background-color:#4caf50cc}body.dark-mode .marker-cluster-medium{background-color:#ff980099}body.dark-mode .marker-cluster-medium div{background-color:#ff9800cc}body.dark-mode .marker-cluster-large{background-color:#f4433699}body.dark-mode .marker-cluster-large div{background-color:#f44336cc}body.dark-mode .query-results-section{background:linear-gradient(135deg,#2a2420,#1e1e1e);border-color:var(--warning-color)}@media(prefers-color-scheme:dark){body:not(.light-mode) .query-results-section{background:linear-gradient(135deg,#2a2420,#1e1e1e);border-color:var(--warning-color)}}.sidebar-content:has(.query-results-section) .sidebar-sections-container{display:none}.query-results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.query-results-header h3{margin:0;font-size:1.1rem;color:var(--warning-color)}.query-location-info{font-size:.85rem;opacity:.8;margin-bottom:12px;font-family:monospace}.query-actions{display:flex;gap:8px;margin-bottom:12px}#queryResultsList{flex:1;overflow-y:auto;min-height:0}.query-action-btn{flex:1;padding:8px 12px;border:1px solid var(--primary-green);background:transparent;color:var(--primary-green);border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.query-action-btn:hover{background:var(--primary-green);color:#fff;transform:translateY(-1px)}.query-action-btn i{font-size:1rem}body.dark-mode .query-action-btn{border-color:var(--light-green);color:var(--light-green)}body.dark-mode .query-action-btn:hover{background:var(--light-green);color:#1a1a1a}@media(prefers-color-scheme:dark){body:not(.light-mode) .query-action-btn{border-color:var(--light-green);color:var(--light-green)}body:not(.light-mode) .query-action-btn:hover{background:var(--light-green);color:#1a1a1a}}.query-category-group{margin-bottom:12px}.query-category-group h4{font-size:.95rem;margin:8px 0 6px;color:var(--text-color)}.query-poi-item{display:flex;justify-content:space-between;align-items:center;padding:8px;background:var(--surface);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:4px;transition:all .2s;cursor:pointer}.query-poi-item:hover{background:var(--surface-alt);border-color:var(--warning-color);box-shadow:0 2px 8px #ff980033}.query-poi-item label{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer}.query-poi-name{font-weight:500}.query-poi-details{display:flex;align-items:center;gap:8px;font-size:.85rem;opacity:.8}.add-query-poi-btn{padding:4px 8px;border:1px solid var(--link-color);background:transparent;color:var(--link-color);border-radius:4px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:4px;transition:all .2s}.add-query-poi-btn:hover{background:var(--link-color);color:#fff}.query-result-popup-container .leaflet-popup-content-wrapper{border:2px solid var(--warning-color);border-radius:var(--radius-lg)}.query-result-popup{min-width:180px;padding:4px 0}.query-result-popup-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.query-result-popup-icon{font-size:1.2rem}.query-result-popup-header strong{font-size:1rem;color:var(--text-color)}.query-result-popup-category{font-size:.85rem;color:#888;margin-bottom:4px}.query-result-popup-distance{font-size:.85rem;color:var(--warning-color);margin-bottom:10px}.query-result-add-btn{width:100%;padding:8px 12px;border:2px solid var(--primary-green);background:var(--primary-green);color:#fff;border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.query-result-add-btn:hover:not(:disabled){background:#43a047;border-color:#43a047;transform:translateY(-1px)}.query-result-add-btn:disabled,.query-result-add-btn.added{background:#e0e0e0;border-color:#e0e0e0;color:#888;cursor:not-allowed}body.dark-mode .query-result-add-btn:disabled,body.dark-mode .query-result-add-btn.added{background:#444;border-color:#444;color:#888}.query-result-popup-links{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color);font-size:.8rem;color:#666}.query-result-popup-links a{color:var(--link-color);text-decoration:none}.query-result-popup-links a:hover{text-decoration:underline}@media(prefers-color-scheme:dark){body:not(.light-mode) .query-result-add-btn:disabled,body:not(.light-mode) .query-result-add-btn.added{background:#444;border-color:#444;color:#888}}@media(prefers-color-scheme:dark){.elevation-crosshair-tooltip{background:#fffffff2;color:#1a1a1a}.file-upload:hover{background:linear-gradient(to bottom,#66bb6a14,#66bb6a26);transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow)}.poi-group-toggle-all{background:var(--button-bg)}.poi-group-toggle-all:hover{background:var(--button-hover)}.poi-group-header:hover{background:#4caf5026}.quick-action-btn:hover{background:#4caf5026;border-color:var(--light-green)}.quick-action-btn-reset{background:var(--blue-primary);border-color:var(--blue-primary)}.quick-action-btn-reset:hover{background:#1565c0;border-color:#1565c0}.preset-btn:hover{background:#1e3a1e;border-color:var(--primary-green);color:var(--light-green);transform:translateY(-1px)}.preset-btn:active{background:#2a4a2a;transform:translateY(0)}.stat-value{color:var(--light-green)}.poi-distance{color:#90caf9}.progress-spinner{border-color:#ffffff1a;border-top-color:var(--light-green)}.leaflet-popup-content-wrapper{background-color:#2a2a2a;color:var(--text-color)}body.dark-mode .leaflet-popup-content-wrapper,.leaflet-popup-tip,body.dark-mode .leaflet-popup-tip{background-color:#2a2a2a}.leaflet-popup-content{color:var(--text-color)}.leaflet-popup-content a{color:var(--light-green)}.leaflet-popup-close-button{color:#e0e0e0!important}.leaflet-popup-close-button:hover{color:#fff!important}.leaflet-control-zoom,.leaflet-control-layers,.leaflet-bar,.leaflet-control-attribution,.leaflet-control-scale{background:#2a2a2a!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}.leaflet-control-zoom a,.leaflet-bar a,.leaflet-control-layers-toggle{background-color:#333!important;background-image:none!important;color:#e0e0e0!important;border-bottom:1px solid rgba(255,255,255,.1)!important}.leaflet-control-zoom-in,.leaflet-control-zoom-out{color:#e0e0e0!important;text-shadow:none!important}.leaflet-control-zoom-in:before,.leaflet-control-zoom-out:before{filter:invert(1)!important}.leaflet-control-zoom a:hover,.leaflet-bar a:hover,.leaflet-control-layers-toggle:hover{background-color:#404040!important;background-image:none!important}.leaflet-control-zoom a:active,.leaflet-bar a:active,.leaflet-control-layers-toggle:active{background-color:#4a4a4a!important;background-image:none!important}.leaflet-control-zoom a:focus,.leaflet-bar a:focus,.leaflet-control-layers-toggle:focus{outline:2px solid rgba(255,255,255,.3)!important;outline-offset:-2px!important}.leaflet-disabled,.leaflet-control-zoom-in.leaflet-disabled,.leaflet-control-zoom-out.leaflet-disabled{background-color:#2a2a2a!important;color:#666!important;cursor:default!important;opacity:.4!important}.leaflet-control-layers-expanded{background:#2a2a2a!important;color:#e0e0e0!important;border:1px solid rgba(255,255,255,.2)!important}.leaflet-control-layers-base label,.leaflet-control-layers-overlays label{color:#e0e0e0!important}.leaflet-control-layers-selector{filter:brightness(1.2)!important}.leaflet-control-layers-separator{border-top:1px solid rgba(255,255,255,.1)!important}.leaflet-control-attribution,.leaflet-control-attribution a{background:#2a2a2a!important;color:#999!important}.leaflet-control-attribution a:hover{color:#e0e0e0!important}.leaflet-control-scale-line{background:#2a2a2acc!important;border:2px solid rgba(255,255,255,.3)!important;color:#e0e0e0!important}.leaflet-control-scale{bottom:75px!important}.leaflet-control-map-features{background:#2a2a2a!important;border:2px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}.map-feature-btn{background:#333!important;border-bottom:1px solid rgba(255,255,255,.1)!important}.map-feature-btn:hover{background:#404040!important}.map-feature-btn:active{background:#4a4a4a!important}.map-feature-btn .bi{color:#e0e0e0!important}.map-feature-btn.inactive .bi{opacity:.4!important}.leaflet-control-layers-toggle:before{background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"%3E%3Cg fill="none" stroke="%23e0e0e0" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"%3E%3Crect x="2" y="2" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="6.5" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="11" width="12" height="3" rx="0.5"/%3E%3C/g%3E%3C/svg%3E')}}@media(max-width:768px){body{padding-top:70px}.container{padding:8px}header{padding:12px 15px}.header-actions{top:12px}.landing-language-btn{padding:.4rem .8rem}#landingLanguageText{display:none}.language-dropdown{min-width:160px;right:-10px}.language-dropdown-item{padding:.6rem .8rem;font-size:13px}.language-item-flag{font-size:18px}h1{font-size:22px;margin-bottom:6px}.tagline{font-size:13px}.upload-section-wrapper{padding:20px 16px;border-radius:10px}.options-horizontal-container{flex-direction:column;gap:16px}.option-card{padding:16px;margin-bottom:16px}.option-card-title{font-size:18px}.option-card-title .emoji{font-size:24px}.option-divider{margin:16px 0}.feature-list{grid-template-columns:1fr;gap:8px;margin-top:12px;padding-top:12px}.landing-help-link{padding:12px 20px;font-size:14px;gap:10px}.landing-help-link svg:last-child{display:none}.main-content{margin-top:15px;margin-left:20px;margin-right:20px;width:calc(100vw - 40px)}.main-content.sidebar-collapsed{margin-left:20px;margin-right:20px;width:calc(100vw - 40px)}.sidebar{padding:15px;max-height:none;height:auto;order:2;width:100%;position:relative;top:auto;left:auto}.sidebar.collapsed{display:none}.map-section{order:1}.map-container{height:350px;padding:8px}.section{margin-bottom:20px}.section-title{font-size:16px;margin-bottom:10px}.file-upload{padding:16px}.upload-icon{font-size:32px;margin-bottom:6px}.poi-categories{max-height:200px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:10px}.stat-value{font-size:20px}.stat-label{font-size:11px}.poi-list{max-height:300px}.poi-section-overlay:not(.minimized) .poi-list{max-height:none}.poi-item{padding:10px;flex-direction:column;gap:8px}.poi-actions{align-self:flex-end}.btn{padding:8px 16px;font-size:13px;width:100%;justify-content:center}.search-controls{gap:8px}.filter-controls{flex-wrap:wrap;gap:8px}.filter-btn{flex:1;min-width:calc(33.333% - 6px)}.message{top:10px;right:10px;left:10px;padding:12px 15px;font-size:13px}.undo-notification{bottom:10px;left:10px;right:10px;transform:none;font-size:13px}@keyframes slideUp{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.elevation-content.expanded{max-height:350px}.preset-buttons{grid-template-columns:repeat(2,1fr);gap:5px}.preset-btn{padding:6px 8px;font-size:11px}.slider-arrow{width:36px;height:36px;font-size:18px;touch-action:manipulation}.slider-controls{gap:8px}.elevation-toggle-icon{width:50px;height:22px;top:-22px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.elevation-container.collapsed{width:160px;bottom:55px;right:50px}.elevation-mini-view{padding:6px}.elevation-mini-chart-container{width:148px;height:60px;padding:4px}.elevation-container.collapsed .elevation-toggle-icon{right:55px}.elevation-map-sync-btn{width:45px;height:22px;top:-22px;right:80px}.search-button-row .btn-text-full{display:none}.search-button-row .btn-text-short{display:inline}.search-button-row .quick-action-btn{flex:0 1 33.33%;font-size:10px}.search-button-row .btn-primary{flex:0 1 33.33%;font-size:12px}}@media(max-width:480px){h1{font-size:20px}.tagline{font-size:13px}.map-container{height:300px}.stats-grid{grid-template-columns:1fr}.upload-section-wrapper{padding:20px 16px}.landing-intro{margin-bottom:16px;padding-bottom:16px}.landing-intro h2{font-size:18px;margin-bottom:8px}.landing-intro p{font-size:12px}.option-card{padding:16px}.option-card-title{font-size:16px}.file-upload{padding:20px 16px}.upload-icon{font-size:36px;margin-bottom:10px}.show-more-options-btn{padding:10px 16px;margin:20px 0;font-size:13px}.option-divider{margin:20px 0}.feature-list{margin-top:24px;margin-bottom:32px;padding-top:24px}}.footer-bar{position:fixed;bottom:0;left:0;right:0;height:38px;background:#2a2a2a;color:#fff;display:none;align-items:center;justify-content:space-between;padding:0 13px;box-shadow:0 -2px 10px var(--shadow);z-index:10002;transition:all .3s ease}.footer-bar.active{display:flex}.footer-info-container{position:relative;margin-right:13px}.footer-info-btn{display:flex;align-items:center;gap:5px;padding:7px 10px;background:var(--blue-primary);border:2px solid var(--blue-primary);border-radius:5px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.footer-info-btn:hover{background:var(--blue-primary);border-color:#000;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #1976d266}.footer-info-btn i{font-size:14px}.footer-info-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;min-width:180px;display:none;z-index:1000}.footer-info-menu.active{display:block}.footer-info-option{padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;color:var(--text-color);transition:background .2s ease;font-size:14px}.footer-info-option:first-child{border-radius:var(--radius-md) 6px 0 0}.footer-info-option:last-child{border-radius:0 0 6px 6px}.footer-info-option:hover,body.dark-mode .footer-info-option:hover{background:#4caf5026}.footer-info-option-icon{font-size:16px;color:var(--text-secondary)}.footer-info-version{padding:8px 16px;display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:12px;border-top:1px solid var(--border-color);background:#00000005;cursor:default}body.dark-mode .footer-info-version{background:#ffffff05}.footer-info-version .footer-info-option-icon{font-size:14px;opacity:.7}body.dark-mode .footer-info-btn{background:#64b5f6;color:#1a1a1a;border-color:#64b5f6}body.dark-mode .footer-info-btn:hover{background:#64b5f6;color:#1a1a1a;border-color:#fff}.footer-stats{display:flex;align-items:center;gap:21px;flex-wrap:wrap;flex:1}.footer-route-selector{display:flex;align-items:center}.footer-route-selector select{background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);color:#fff;font-size:11px;font-weight:500;padding:4px 24px 4px 8px;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 12 12'%3E%3Cpath fill='white' d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;min-width:100px;max-width:150px}.footer-route-selector select:hover{background-color:#fff3}.footer-route-selector select:focus{outline:none;border-color:var(--primary-color)}.footer-route-selector select option{background:var(--bg-color);color:var(--text-color)}.footer-stats-group{display:flex;align-items:center;gap:2px;background:#ffffff0d;padding:2px;border-radius:5px}.footer-stat-item{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;white-space:nowrap;padding:5px 9px;background:#ffffff1a;border-radius:3px;transition:all .2s ease}.footer-stat-item.clickable{cursor:pointer;padding:7px 12px;border:1px solid var(--dark-green);background:#ffffff26;transition:all .2s ease}.footer-stat-item.clickable:hover{background:#2e7d3233;border-color:var(--primary-green);transform:translateY(-1px)}.footer-stat-icon{font-size:15px;display:flex;align-items:center;justify-content:center}.footer-stat-value{font-weight:600}.footer-warning{color:gold;font-size:16px;margin-left:4px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes poi-marker-pulse{0%{transform:scale(1);filter:drop-shadow(0 3px 8px rgba(0,0,0,.4)) drop-shadow(0 0 0 rgba(255,152,0,.7))}50%{transform:scale(1.3);filter:drop-shadow(0 3px 8px rgba(0,0,0,.4)) drop-shadow(0 0 15px rgba(255,152,0,1))}to{transform:scale(1);filter:drop-shadow(0 3px 8px rgba(0,0,0,.4)) drop-shadow(0 0 0 rgba(255,152,0,.7))}}.poi-marker-highlighted{z-index:1000!important}.poi-marker-highlighted>div>svg{animation:poi-marker-pulse 1.5s ease-in-out infinite;transform-origin:center center}.temp-location-marker{background:transparent;border:none}.pulsing-marker{font-size:30px;text-align:center;line-height:1;animation:pulsing-glow 1.5s ease-in-out infinite;transform-origin:center center}@keyframes pulsing-glow{0%,to{transform:scale(1);filter:drop-shadow(0 0 8px var(--warning-color))}50%{transform:scale(1.2);filter:drop-shadow(0 0 16px var(--warning-color))}}.poi-marker-highlighted>div>svg path{fill:var(--warning-color)!important}.poi-marker-deleting{animation:poi-marker-delete .5s ease-out forwards;pointer-events:none}.poi-marker-deleting>div>svg path{animation:poi-marker-delete-color .2s ease-out forwards}@keyframes poi-marker-delete{0%{opacity:1;transform:scale(1)}40%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(1.8)}}@keyframes poi-marker-delete-color{0%{fill:inherit}to{fill:#f44336!important}}.poi-item.active{background:#4caf5033!important;border-left:4px solid var(--primary-green);padding-left:8px}body.dark-mode .poi-item.active{background:#4caf5040!important}.footer-actions{display:flex;align-items:center;gap:9px}.footer-download-container,.footer-tools-container{position:relative}.footer-tools-btn{display:flex;align-items:center;gap:5px;padding:7px 10px;background:#ffffff26;border:1px solid var(--dark-green);border-radius:3px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.footer-tools-btn:hover{background:#2e7d3233;border-color:var(--primary-green);transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.footer-tools-btn svg{width:15px;height:15px;fill:#fff;margin-right:5px}.footer-undo-redo-container{display:flex;gap:0;align-items:center}.footer-undo-redo-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#ffffff26;border:1px solid var(--dark-green);border-radius:0;color:#fff;font-size:15px;cursor:pointer;transition:all .2s ease}#undoBtn{border-radius:4px 0 0 4px;border-right:1px solid rgba(46,125,50,.5)}#redoBtn{border-radius:0 4px 4px 0;border-left:none}.footer-undo-redo-btn:hover:not(:disabled){background:#2e7d3233;border-color:var(--primary-green);transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d;z-index:1}#undoBtn:hover:not(:disabled){border-right-color:#4caf5099}.footer-undo-redo-btn:disabled{opacity:.3;cursor:not-allowed;background:#ffffff0d;border-color:#2e7d324d}#undoBtn:disabled{border-right-color:#2e7d324d}.footer-undo-redo-btn i{font-size:15px}.footer-tools-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 16px var(--shadow);min-width:240px;max-height:calc(100vh - 120px);overflow-y:auto;display:none;z-index:1000}.footer-tools-menu::-webkit-scrollbar{width:6px}.footer-tools-menu::-webkit-scrollbar-track{background:transparent}.footer-tools-menu::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:3px}.footer-tools-menu::-webkit-scrollbar-thumb:hover{background:var(--text-color)}.footer-tools-menu.can-scroll:after{content:"";position:sticky;bottom:0;left:0;right:0;height:40px;background:linear-gradient(to top,var(--sidebar-bg) 0%,transparent 100%);pointer-events:none;display:block;margin-top:-40px}.footer-tools-menu.active{display:block}.footer-tools-option{padding:12px 16px;cursor:pointer;color:var(--text-color);font-size:14px;transition:background .2s ease;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:10px}.footer-tools-option:last-child{border-bottom:none}.footer-tools-option:hover{background:#2e7d321a}body.dark-mode .footer-tools-option:hover{background:#4caf5026}.footer-tools-option-icon{width:16px;height:16px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;margin-right:12px;opacity:.7;flex-shrink:0;transition:opacity .2s ease;vertical-align:middle;display:inline-block}.footer-tools-option:hover .footer-tools-option-icon{opacity:1}.footer-tools-option-title{font-weight:600;font-size:13px;display:block;margin-bottom:2px}.footer-tools-option-description{font-size:11px;color:var(--text-tertiary);display:block}.footer-tools-option.submenu-parent{display:flex;align-items:center;justify-content:space-between}.footer-tools-submenu{display:none;background:var(--surface-alt);border-radius:4px;margin:4px 0;overflow:hidden;max-height:0;opacity:0;transition:max-height .2s ease,opacity .2s ease,margin .2s ease}.footer-tools-submenu.expanded{display:block;max-height:300px;opacity:1;margin:8px 0}.footer-tools-option.submenu-item{padding:10px 16px 10px 32px;font-size:13px;border-bottom:none}.footer-tools-option.submenu-item:hover{background:#2e7d3226}body.dark-mode .footer-tools-option.submenu-item:hover{background:#4caf5033}#languageSubmenu .language-item-flag{font-size:16px;display:inline-block}#languageSubmenu .language-item-name{flex:1}#languageSubmenu .language-item-check{color:var(--primary-green);font-size:14px;display:none}.submenu-arrow{width:14px;height:14px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s ease;opacity:.5}.submenu-arrow.rotated{transform:rotate(90deg)}.footer-tools-option.submenu-parent .footer-tools-option-icon{fill:var(--text-color);stroke:none}.footer-tools-divider{height:1px;background:var(--border-color);margin:8px 0}.footer-overflow-container{display:none;position:relative}.footer-overflow-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--text-color);font-size:16px;transition:all .2s ease}.footer-overflow-btn:hover{background:#2e7d321a;border-color:var(--primary-green)}body.dark-mode .footer-overflow-btn:hover{background:#4caf5033}.footer-overflow-menu{position:absolute;bottom:calc(100% + 8px);left:0;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:220px;max-height:calc(100vh - 100px);overflow-y:auto;display:none;z-index:1000;box-shadow:0 -4px 16px #00000026}body.dark-mode .footer-overflow-menu{box-shadow:0 -4px 16px #0006}.footer-overflow-menu.active{display:block}.footer-overflow-section{padding:8px 0;border-bottom:1px solid var(--border-color)}.footer-overflow-section:last-child{border-bottom:none}.footer-overflow-section-title{padding:6px 16px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.footer-overflow-option{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;color:var(--text-color);font-size:13px;transition:background .2s ease}.footer-overflow-option:hover{background:#2e7d321a}body.dark-mode .footer-overflow-option:hover{background:#4caf5033}.footer-overflow-option i{font-size:14px;color:var(--text-secondary);width:18px;text-align:center}.footer-overflow-stat{display:flex;align-items:center;gap:10px;padding:8px 16px;color:var(--text-color);font-size:13px}.footer-overflow-stat.clickable{cursor:pointer;transition:background .2s ease}.footer-overflow-stat.clickable:hover{background:#2e7d321a}body.dark-mode .footer-overflow-stat.clickable:hover{background:#4caf5033}.footer-overflow-stat i{font-size:14px;color:var(--text-secondary);width:18px;text-align:center}.footer-overflow-actions{display:flex;gap:8px;padding:8px 16px}.footer-overflow-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;padding:8px 12px;background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--text-color);font-size:12px;font-weight:500;transition:all .2s ease}.footer-overflow-action-btn:hover:not(:disabled){background:#2e7d321a;border-color:var(--primary-green)}body.dark-mode .footer-overflow-action-btn:hover:not(:disabled){background:#4caf5033}.footer-overflow-action-btn:disabled{opacity:.5;cursor:not-allowed}.footer-overflow-action-btn i{font-size:14px}.saved-projects-section{margin-bottom:20px;padding:12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.saved-projects-section h4{margin:0 0 16px;font-size:16px;color:var(--text-color);font-weight:600}#recentProjectCards{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.saved-project-card{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px;margin-bottom:0;cursor:pointer;transition:all .2s ease;height:auto;min-height:45px}.saved-project-card:hover{background:#2e7d321a;border-color:var(--primary-green);transform:translate(2px)}body.dark-mode .saved-project-card:hover{background:#4caf5026}.project-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:4px}.project-card-buttons{display:flex;gap:0;flex-shrink:0}.project-card-name{font-weight:600;font-size:12px;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-load-btn{padding:4px 12px;background:var(--primary-green);color:#fff;border:none;border-radius:4px 0 0 4px;border-right:1px solid rgba(255,255,255,.2);font-size:12px;font-weight:600;cursor:pointer;transition:background .2s ease;min-width:60px}.project-card-load-btn:hover{background:#45a049}.project-card-delete-btn{padding:4px 8px;background:#d32f2f;color:#fff;border:none;border-radius:0 4px 4px 0;font-size:14px;cursor:pointer;transition:background .2s ease;display:flex;align-items:center;justify-content:center}.project-card-delete-btn:hover{background:#c62828}.project-card-details{font-size:10px;color:var(--text-secondary);line-height:1.5}.project-card-date{font-size:9px;opacity:.7}.view-all-projects-btn{background:none;border:none;color:var(--primary-green);font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;padding:8px 0;margin-top:8px;display:inline-block;transition:color .2s ease}.view-all-projects-btn:hover{color:var(--light-green)}@media(max-width:768px){#recentProjectCards{grid-template-columns:1fr}}.project-list{max-height:400px;overflow-y:auto}.project-item{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;margin-bottom:12px;transition:all .2s ease}.project-item:hover{background:#2e7d321a;border-color:var(--primary-green)}body.dark-mode .project-item:hover{background:#4caf5026}.project-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.project-item-header h4{margin:0;font-size:16px;font-weight:600;color:var(--text-color)}.project-item-details{font-size:13px;color:var(--text-secondary);margin-bottom:8px;line-height:1.6}.project-item-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.project-badge{padding:4px 8px;background:#4caf5026;border:1px solid rgba(76,175,80,.3);border-radius:4px;font-size:11px;font-weight:600;color:var(--text-color)}.project-item-actions{display:flex;gap:8px}.project-item-actions button{padding:8px 16px;border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.project-load-btn{background:var(--primary-green);color:#fff}.project-load-btn:hover{background:#45a049}.project-delete-btn{background:#f44336;color:#fff}.project-delete-btn:hover{background:#da190b}.project-warning-box{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:var(--radius-md);padding:12px;margin-bottom:16px;font-size:13px;color:var(--text-color)}.project-warning-box strong{display:block;margin-bottom:4px;color:#ffc107}.gpx-export-summary{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;margin-top:16px;font-size:14px;color:var(--text-color);display:flex;align-items:center;gap:8px}.gpx-export-summary i{color:var(--primary-color);font-size:18px}.gpx-export-summary #gpxExportCount{font-weight:600;color:var(--primary-color)}.project-summary-box{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px;margin-bottom:16px;font-size:13px;color:var(--text-secondary)}.project-summary-box strong{display:block;margin-bottom:8px;color:var(--text-color);font-size:14px}.project-summary-item{margin-bottom:4px;line-height:1.6}.project-empty-state{text-align:center;padding:32px;color:var(--text-secondary)}.project-empty-state i{font-size:48px;margin-bottom:16px;opacity:.5}.footer-download-btn{display:flex;align-items:center;gap:5px;padding:7px 10px;background:var(--blue-primary);border:2px solid var(--blue-primary);border-radius:3px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.footer-download-btn:hover{background:var(--blue-primary);border-color:#000;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #1976d266}.footer-download-btn svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.footer-download-btn:hover svg{stroke:#fff}.footer-download-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 16px var(--shadow);min-width:240px;display:none;z-index:1000}.footer-download-menu.active{display:block}.footer-download-option{padding:12px 16px;cursor:pointer;color:var(--text-color);font-size:14px;transition:background .2s ease;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:10px}.footer-download-option:last-child{border-bottom:none}.footer-download-option:hover{background:#2e7d321a}.footer-download-option-icon{width:16px;height:16px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:.7;flex-shrink:0;transition:opacity .2s ease}.footer-download-option:hover .footer-download-option-icon{opacity:1}.footer-download-option-title{font-weight:600;font-size:13px;display:block;margin-bottom:2px}.footer-download-option-description{font-size:11px;color:var(--text-tertiary);display:block}.footer-download-option-primary{background:linear-gradient(135deg,#2e7d321f,#4caf5014);border-left:4px solid var(--primary-green);padding-left:12px}.footer-download-option-primary .footer-download-option-title{color:var(--primary-green);font-size:14px;font-weight:700}.footer-download-option-primary .footer-download-option-icon{color:var(--primary-green);opacity:1;font-size:18px}.footer-download-option-primary:hover{background:linear-gradient(135deg,#2e7d322e,#4caf501f);border-left-color:var(--dark-green)}body.dark-mode .footer-download-option-primary{background:linear-gradient(135deg,#4caf5026,#66bb6a1a)}.footer-download-option.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.footer-download-option.disabled:hover{background:transparent}.footer-download-option-primary.disabled{background:#2e7d320d;border-left-color:#2e7d324d}body.dark-mode .footer-download-option-primary:hover{background:linear-gradient(135deg,#4caf5038,#66bb6a26)}@media(prefers-color-scheme:dark){.footer-download-option-primary{background:linear-gradient(135deg,#4caf5026,#66bb6a1a)}.footer-download-option-primary:hover{background:linear-gradient(135deg,#4caf5038,#66bb6a26)}}body.dark-mode .footer-download-option:hover{background:#4caf5026}body.dark-mode .footer-download-btn{background:#64b5f6;color:#1a1a1a;border-color:#64b5f6}body.dark-mode .footer-download-btn svg{stroke:#1a1a1a}body.dark-mode .footer-download-btn:hover{background:#64b5f6;color:#1a1a1a;border-color:#fff}body.dark-mode .footer-download-btn:hover svg{stroke:#1a1a1a}.footer-collapse-toggle{display:none!important;width:32px;height:32px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:4px;color:#fff;cursor:pointer;align-items:center;justify-content:center;transition:all .2s ease;font-size:14px}.footer-collapse-toggle:hover{background:#ffffff4d}.footer-collapse-arrow{transition:transform .3s ease;display:inline-block;transform:rotate(0)}.footer-bar.collapsed{height:30px;justify-content:flex-end}.footer-bar.collapsed .footer-stats{display:none}.footer-bar.collapsed .footer-download-container{display:flex}.footer-bar.collapsed .footer-actions{gap:8px}.footer-bar.collapsed .footer-collapse-arrow{transform:rotate(180deg)}.search-location-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:2px solid var(--border-color)}.search-location-tab{flex:1;padding:10px 12px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.search-location-tab:hover{color:var(--text-color);background:var(--card-bg)}.search-location-tab.active{color:var(--link-color);border-bottom-color:var(--link-color);font-weight:600}.search-location-tab-content{display:none}.search-location-tab-content.active{display:block}@media(max-width:768px){.search-location-tabs-wrapper{position:relative}.search-location-tabs-wrapper:before,.search-location-tabs-wrapper:after{content:"";position:absolute;top:0;bottom:2px;width:60px;pointer-events:none;z-index:2;transition:opacity .3s ease}.search-location-tabs-wrapper:before{left:0;background:linear-gradient(to right,var(--primary-green) 0%,transparent 100%);opacity:0}.search-location-tabs-wrapper:after{right:0;background:linear-gradient(to left,var(--primary-green) 0%,transparent 100%)}.search-location-tabs-wrapper.at-start:before{opacity:0}.search-location-tabs-wrapper.at-end:after{opacity:0}.search-location-tabs-wrapper.can-scroll-left:before{opacity:1}.search-location-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:4px;padding-bottom:2px;padding-right:40px}.search-location-tabs::-webkit-scrollbar{display:none}.search-location-tab{flex:0 0 auto;min-width:90px;padding:10px 8px;font-size:12px}.scroll-hint-arrow{display:flex;align-items:center;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);width:24px;height:24px;color:#fff;font-size:18px;font-weight:700;z-index:3;pointer-events:none;opacity:1;transition:opacity .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.3)}.scroll-hint-left{left:2px}.scroll-hint-right{right:2px;animation:scrollHintPulse 1.5s ease-in-out 2}.search-location-tabs-wrapper.at-start .scroll-hint-left,.search-location-tabs-wrapper.at-end .scroll-hint-right{opacity:0}@keyframes scrollHintPulse{0%,to{transform:translateY(-50%) translate(0);opacity:1}50%{transform:translateY(-50%) translate(3px);opacity:1}}}@media(min-width:769px){.scroll-hint-arrow{display:none!important}}.search-location-input-group{margin-bottom:16px}.search-location-label{display:block;font-size:13px;font-weight:500;color:var(--text-color);margin-bottom:6px}.search-location-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--card-bg);color:var(--text-color);font-size:14px;transition:all .2s ease}.search-location-input:focus{outline:none;border-color:var(--link-color);box-shadow:0 0 0 3px #4caf501a}.search-location-input::placeholder{color:var(--text-secondary);opacity:.7}.search-location-helper{font-size:11px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.landing-input-button-row{display:flex;gap:10px}@media(max-width:768px){.landing-input-button-row{flex-direction:column;gap:8px}.landing-input-button-row .ps-btn{width:100%;white-space:normal;justify-content:center}}.search-location-results{margin-top:16px;padding:12px;background:var(--card-bg);border-radius:var(--radius-md);border-left:3px solid var(--link-color)}.search-location-result-item{display:flex;align-items:center;gap:10px;padding:10px;border-bottom:1px solid var(--border-color);transition:background .2s ease}.search-location-result-item:last-child{border-bottom:none}.search-location-result-item:hover{background:var(--sidebar-bg)}.search-result-content{flex:1;min-width:0}.search-location-result-name{font-weight:600;color:var(--text-color);margin-bottom:4px}.search-location-result-metadata{font-size:13px;opacity:.8;margin-top:2px;margin-bottom:4px;color:var(--text-secondary)}.search-location-result-details{font-size:12px;color:var(--text-secondary)}.search-location-type-badge{font-size:11px;margin-top:6px;padding:3px 8px;background:var(--surface-alt);border-radius:12px;display:inline-block}.search-result-content{flex:1}.search-clear-markers-btn{margin-top:10px;padding:8px 12px;background:var(--button-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-color);font-size:13px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;width:100%;justify-content:center}.search-clear-markers-btn:hover{background:var(--button-hover);border-color:var(--link-color)}.search-clear-markers-btn i{font-size:14px}.search-location-error{padding:12px;background:#ffebee;border-left:3px solid #d32f2f;border-radius:var(--radius-md);color:#c62828;font-size:13px;margin-top:16px}body.dark-mode .search-location-error{background:#3a1a1a;color:#ef5350}.search-location-success{padding:12px;background:#e8f5e9;border-left:3px solid var(--primary-green);border-radius:var(--radius-md);color:var(--dark-green);font-size:13px;margin-top:16px}body.dark-mode .search-location-success{background:#1a3a1a;color:#81c784}.search-location-result-item.highlighted{background:var(--link-color);color:#fff}.search-location-result-item.highlighted .search-location-result-name,.search-location-result-item.highlighted .search-location-result-details{color:#fff}.search-result-actions{display:flex;gap:6px;align-items:center;margin-left:auto;padding-left:10px}.search-action-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid var(--border-color);background:var(--surface);border-radius:var(--radius-md);cursor:pointer;font-size:12px;white-space:nowrap;transition:all .2s}.search-action-btn:hover{background:var(--surface-alt);transform:translateY(-1px);box-shadow:0 2px 4px var(--shadow)}.search-action-btn i{font-size:14px}.search-action-create{color:var(--link-color);border-color:var(--link-color)}.search-action-create:hover{background:#4caf501a;border-color:var(--link-color)}.search-action-show{color:var(--warning-color);border-color:var(--warning-color)}.search-action-show:hover{background:#ff98001a;border-color:var(--warning-color)}.copy-coords-btn{padding:6px 10px;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;color:var(--text-secondary)}.copy-coords-btn:hover{background:var(--surface-alt);color:var(--text-color)}.search-location-result-item.highlighted .copy-coords-btn{border-color:#ffffff80;color:#fff}.search-location-result-item.highlighted .copy-coords-btn:hover{background:#fff3;border-color:#fff}@media(max-width:768px){.search-result-actions{flex-direction:column;gap:4px;width:100%;margin-left:0;margin-top:8px}.search-action-btn{width:100%;justify-content:center}.search-location-result-item{flex-direction:column;align-items:stretch}}.search-radius-section{margin-top:15px;padding:12px;background:var(--card-bg);border-radius:var(--radius-md);border:1px solid var(--border-color)}.radius-toggle-btn{width:100%;padding:10px 12px;background:transparent;border:none;color:var(--text-color);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:all .2s ease}.radius-toggle-btn:hover{color:var(--link-color)}.radius-toggle-btn i:last-child{transition:transform .2s ease}.radius-toggle-btn.expanded i:last-child{transform:rotate(180deg)}#modalRadiusControls{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color)}#modalRadiusSlider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;-webkit-appearance:none}#modalRadiusSlider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer}#modalRadiusSlider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer;border:none}.search-location-input-wrapper{position:relative}.route-filter-section{margin-top:15px;padding:12px;background:var(--card-bg);border-radius:var(--radius-md);border:1px solid var(--border-color)}#routeFilterControls{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color)}#routeFilterSlider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;-webkit-appearance:none}#routeFilterSlider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer}#routeFilterSlider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer;border:none}#routeFilterSlider:disabled{opacity:.5;cursor:not-allowed}.search-preview-marker{background:transparent}.search-preview-marker-inner{width:24px;height:24px;background:#2196f3;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.search-preview-marker-inner i{transform:rotate(45deg);color:#fff;font-size:14px}.search-preview-marker-inner:hover{background:var(--blue-primary);transform:rotate(-45deg) scale(1.1);box-shadow:0 4px 12px #2196f380}@media(max-width:768px){.footer-bar{padding:0 9px;height:auto;min-height:38px}.footer-overflow-container{display:block;margin-right:7px}.footer-info-container,.footer-undo-redo-container,.footer-stats-group{display:none!important}.footer-info-btn{padding:5px 7px;font-size:11px}.footer-info-btn span{display:none}.footer-theme-btn{padding:5px 7px;font-size:11px}.footer-theme-btn span{display:none}.footer-theme-container{margin-right:7px}.footer-stats{gap:9px;flex-wrap:nowrap}.footer-stat-item{font-size:10px;padding:5px 9px}#footerPOI{display:flex!important}.footer-tools-btn span{display:none}.footer-tools-btn{padding:7px!important;gap:0!important}.footer-download-btn span{display:none}.footer-download-btn svg:last-child{display:none}.footer-download-btn{padding:7px!important;gap:0!important}.footer-collapse-toggle{display:flex}.footer-bar.collapsed{min-height:34px}.poi-popup-wrapper{min-width:unset;max-width:calc(100vw - 24px)!important;max-height:400px;width:calc(100vw - 24px)!important;box-sizing:border-box;overflow:hidden}.poi-popup-content{max-height:300px}.leaflet-popup-content-wrapper{max-height:350px;max-width:calc(100vw - 20px)!important;width:auto!important;overflow:hidden}.leaflet-popup-content{margin:6px 8px!important;width:auto!important;max-width:100%!important;overflow:hidden}.poi-popup-content-scrollable{max-width:100%;overflow-x:hidden;box-sizing:border-box}.poi-info-grid-2col{grid-template-columns:1fr;gap:3px;margin-bottom:6px;max-width:100%;box-sizing:border-box}.poi-info-item{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:2px 0}.poi-info-item i{margin-right:3px;font-size:11px}.poi-info-label{font-size:10px}.poi-name-edit{gap:4px}.poi-popup-input{font-size:16px}.poi-popup-save-btn,.poi-popup-cancel-btn{min-width:36px;padding:8px}.poi-popup-save-btn svg,.poi-popup-cancel-btn svg{width:18px;height:18px}.poi-popup-actions-footer{gap:2px;padding-top:6px;max-width:100%;box-sizing:border-box;flex-wrap:wrap}.poi-popup-btn-navigate,.poi-popup-btn-street,.poi-popup-btn-osm,.poi-popup-btn-delete,.poi-popup-btn-coords{padding:6px 8px!important;font-size:0!important;gap:0!important;min-width:unset!important;flex:0 0 auto!important}.poi-popup-btn-navigate span,.poi-popup-btn-street span,.poi-popup-btn-osm span,.poi-popup-btn-delete span,.poi-popup-btn-coords span{display:none!important}.poi-popup-btn-navigate svg,.poi-popup-btn-street svg,.poi-popup-btn-osm svg,.poi-popup-btn-delete svg,.poi-popup-btn-coords svg,.poi-popup-btn-navigate i,.poi-popup-btn-street i,.poi-popup-btn-osm i,.poi-popup-btn-delete i,.poi-popup-btn-coords i{width:14px!important;height:14px!important;font-size:14px!important}.poi-popup-header{margin-bottom:6px}.poi-popup-title{font-size:14px}.poi-popup-badge{padding:1px 6px;font-size:10px;margin-left:4px}.poi-nearby-header{padding:6px 8px;font-size:12px}.poi-nearby-content{max-width:100%;overflow:hidden}.poi-category-row{font-size:11px}}.poi-popup-wrapper{display:flex;flex-direction:column;min-width:380px;max-width:450px;max-height:600px}.poi-popup-content-scrollable{flex:1;overflow-y:visible;overflow-x:hidden;padding-bottom:8px}.leaflet-popup-content-wrapper{max-height:600px}@media(max-width:768px){.leaflet-popup-content-wrapper{max-height:400px}}.leaflet-popup-content{margin:8px 10px!important}.leaflet-popup-content p{margin:3px 0!important}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background-color:var(--sidebar-bg)}body.dark-mode .leaflet-popup-content-wrapper,body.dark-mode .leaflet-popup-tip{background-color:#2a2a2a}.leaflet-popup{margin-bottom:60px;z-index:2000!important}.poi-popup-header{margin-bottom:8px}.poi-name-display{display:flex;align-items:center;gap:8px}.poi-name-edit{display:none;align-items:center;gap:6px;flex-wrap:nowrap!important}.poi-name-edit[style*="display: block"],.poi-name-edit[style*="display: flex"]{display:flex!important}.poi-editing-name .leaflet-popup-close-button{display:none!important}.poi-popup-title{margin:0;flex:1;display:flex;align-items:center;gap:6px;font-size:16px;font-weight:600}.poi-popup-badge{display:inline-block;color:#fff;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:700;margin-left:8px;display:inline-flex;align-items:center;gap:4px}.poi-popup-badge svg{width:14px;height:14px;fill:currentColor}.poi-popup-badge-info{background:#2196f3}.poi-popup-badge-alert{background:var(--blue-primary)}.poi-popup-badge-danger{background:#d32f2f}.poi-popup-badge-event{background:#9c27b0}body.dark-mode .poi-popup-badge-info{background:#42a5f5}body.dark-mode .poi-popup-badge-alert{background:#2196f3}body.dark-mode .poi-popup-badge-danger{background:#ef5350}body.dark-mode .poi-popup-badge-event{background:#ba68c8}.poi-type-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.poi-type-clickable:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.poi-type-selector{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;box-shadow:0 4px 20px #00000026;padding:4px;display:flex;flex-direction:column;gap:2px;min-width:120px}.poi-type-option{display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;border-radius:6px;background:transparent;cursor:pointer;font-size:13px;color:var(--text-color, #333);transition:background-color .15s}.poi-type-option:hover{background:var(--surface-hover, #f5f5f5)}.poi-type-option.selected{font-weight:600}.poi-type-option svg{width:16px;height:16px;flex-shrink:0}.poi-type-option--info svg{color:#2196f3}.poi-type-option--alert svg{color:#ff9800}.poi-type-option--danger svg{color:#f44336}.poi-type-option--event svg{color:#9c27b0}.poi-type-option--info.selected{background:#e3f2fd}.poi-type-option--alert.selected{background:#fff3e0}.poi-type-option--danger.selected{background:#ffebee}.poi-type-option--event.selected{background:#f3e5f5}body.dark-mode .poi-type-selector{background:var(--card-bg, #1e1e1e);border-color:var(--border-color, #333)}body.dark-mode .poi-type-option:hover{background:var(--surface-hover, #2a2a2a)}body.dark-mode .poi-type-option--info.selected{background:#1a3a4a}body.dark-mode .poi-type-option--alert.selected{background:#3a2a1a}body.dark-mode .poi-type-option--danger.selected{background:#3a1a1a}body.dark-mode .poi-type-option--event.selected{background:#2a1a3a}.poi-tags-section{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;margin:4px 0;border-top:1px solid var(--border-color, #e0e0e0);border-bottom:1px solid var(--border-color, #e0e0e0)}.poi-tag-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--tag-bg, #f5f5f5);border-radius:var(--radius-md);color:var(--tag-color, #555);font-size:14px;cursor:default;transition:background-color .2s,transform .1s}.poi-tag-icon:hover{background:var(--tag-hover-bg, #e8e8e8);transform:scale(1.1)}.poi-tag-link{cursor:pointer;color:var(--link-color, #1976d2)}.poi-tag-link:hover{background:var(--link-hover-bg, #e3f2fd)}body.dark-mode .poi-tags-section{border-color:var(--border-color-dark, #444)}body.dark-mode .poi-tag-icon{background:var(--tag-bg-dark, #333);color:var(--tag-color-dark, #ccc)}body.dark-mode .poi-tag-icon:hover{background:var(--tag-hover-bg-dark, #444)}body.dark-mode .poi-tag-link{color:var(--link-color-dark, #64b5f6)}body.dark-mode .poi-tag-link:hover{background:var(--link-hover-bg-dark, #1a3a4a)}.poi-popup-nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:48px;background:var(--primary-color, #4caf50);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;opacity:.9;transition:opacity .2s,background-color .2s;z-index:1000;box-shadow:0 2px 8px #0000004d}.poi-popup-nav-btn:hover{opacity:1;background:var(--primary-dark, #388e3c)}.poi-popup-nav-btn:active{transform:translateY(-50%) scale(.95)}.poi-popup-nav-prev{left:-40px;border-radius:4px 0 0 4px}.poi-popup-nav-next{right:-40px;border-radius:0 4px 4px 0}body.dark-mode .poi-popup-nav-btn{background:var(--primary-color-dark, #66bb6a)}body.dark-mode .poi-popup-nav-btn:hover{background:var(--primary-dark, #4caf50)}@media(max-width:480px){.poi-popup-nav-btn{width:28px;height:40px;font-size:16px}.poi-popup-nav-prev{left:-32px}.poi-popup-nav-next{right:-32px}}.poi-popup-edit-btn{background:none;border:none;cursor:pointer;padding:4px;color:var(--blue-primary);display:flex;align-items:center;justify-content:center;transition:color .2s}.poi-popup-edit-btn:hover{color:#1565c0}.poi-popup-edit-btn svg{width:16px;height:16px;fill:currentColor}body.dark-mode .poi-popup-edit-btn{color:#fff}body.dark-mode .poi-popup-edit-btn:hover{color:#e0e0e0}.poi-popup-edit-container{display:none;margin-bottom:8px}.poi-popup-edit-container.active{display:block}.poi-popup-input{padding:6px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff;color:#333;box-sizing:border-box;min-width:0;flex:1 1 auto!important;max-width:none!important}body.dark-mode .poi-popup-input{background:#1a1a1a;border-color:#444;color:#e0e0e0}.poi-popup-edit-buttons{display:flex;gap:4px}.poi-popup-save-btn,.poi-popup-cancel-btn{padding:6px 8px;border:none;border-radius:4px;cursor:pointer;font-size:11px;flex:0 0 auto;min-width:32px;display:flex;align-items:center;justify-content:center;gap:4px;font-weight:500;transition:background .2s}.poi-popup-save-btn svg,.poi-popup-cancel-btn svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}.poi-popup-save-btn{background:var(--primary-green);color:#fff}.poi-popup-save-btn:hover{background:#45a049}.poi-popup-cancel-btn{background:#999;color:#fff}.poi-popup-cancel-btn:hover{background:#888}body.dark-mode .poi-popup-save-btn{background:var(--light-green)}body.dark-mode .poi-popup-save-btn:hover{background:#81c784}body.dark-mode .poi-popup-cancel-btn{background:#666}body.dark-mode .poi-popup-cancel-btn:hover{background:#777}.poi-popup-info{margin:4px 0;font-size:13px}.poi-popup-info strong{font-weight:600}.opening-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;margin-left:8px}.opening-status-badge.open{background:#e8f5e9;color:var(--dark-green)}.opening-status-badge.closed{background:#ffebee;color:#c62828}body.dark-mode .opening-status-badge.open{background:#1b3d1f;color:#81c784}body.dark-mode .opening-status-badge.closed{background:#3d1b1b;color:#e57373}.opening-status-badge i{font-size:10px}.gap-warning-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;margin-top:6px}.gap-warning-badge.last-chance{background:#fff3e0;color:#e65100}.gap-warning-badge.significant-gap{background:#ffebee;color:#c62828}body.dark-mode .gap-warning-badge.last-chance{background:#3d2a1a;color:#ffb74d}body.dark-mode .gap-warning-badge.significant-gap{background:#3d1b1b;color:#e57373}.gap-warning-badge i{font-size:10px}.gap-info{display:flex;align-items:center;gap:6px;padding:4px 8px;margin:4px 0;font-size:12px;border-radius:4px;background:var(--info-section-bg)}.gap-info.warning{background:#fff3e0;color:#e65100}.gap-info.first-on-route,.gap-info.last-on-route{background:#e3f2fd;color:#1565c0}body.dark-mode .gap-info.warning{background:#3d2a1a;color:#ffb74d}body.dark-mode .gap-info.first-on-route,body.dark-mode .gap-info.last-on-route{background:#1a3a4a;color:#64b5f6}.gap-info i{font-size:11px}.poi-info-section{background:var(--info-section-bg);border:1px solid var(--info-section-border);border-radius:var(--radius-md);padding:8px 10px;margin:8px 0}.poi-info-section:first-of-type{margin-top:4px}.poi-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px}.poi-info-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.poi-info-item{display:flex;align-items:center;font-size:13px;line-height:1.5}.poi-info-item i{margin-right:6px;font-size:14px;color:var(--link-color);flex-shrink:0}.poi-info-item strong{font-weight:600;margin-right:4px}.poi-info-label{color:var(--text-secondary);font-size:12px;margin-right:4px}.poi-info-value{font-weight:500;color:var(--text-color)}.poi-side-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;color:#fff;margin-left:4px}.poi-side-badge.left{background:var(--side-left-color)}.poi-side-badge.right{background:var(--side-right-color)}.poi-elevation-warning{background:var(--elevation-warning-bg);border-left:3px solid var(--warning-color)}.poi-elevation-diff{display:flex;align-items:center;gap:6px;margin-top:4px}.poi-elevation-diff-value{font-weight:600}.poi-elevation-diff-value.normal{color:var(--link-color)}.poi-elevation-diff-value.warning{color:var(--warning-color)}.poi-elevation-diff i.bi-exclamation-triangle{color:var(--danger-color);font-size:16px}.nearby-poi-close{color:var(--primary-green);font-weight:500}.nearby-poi-far{color:var(--warning-color);font-weight:500}body.dark-mode .nearby-poi-close{color:var(--light-green)}body.dark-mode .nearby-poi-far{color:#ffb74d}.nearby-poi-link{cursor:pointer;text-decoration:underline;text-decoration-style:dotted}.nearby-poi-link:hover{text-decoration-style:solid;opacity:.8}.poi-nearby-section{margin:12px 0}.poi-nearby-header{display:flex;align-items:center;gap:6px;padding:8px;background:var(--card-bg);border-radius:4px;cursor:pointer;margin-bottom:8px;transition:background .2s}.poi-nearby-header:hover{background:var(--button-hover)}.poi-nearby-header i{transition:transform .2s}.poi-nearby-header i.rotated{transform:rotate(90deg)}.poi-nearby-count{margin-left:auto;font-size:.9em;opacity:.7}.poi-nearby-content{transition:max-height .3s ease-out,opacity .3s ease-out}.poi-popup-actions-footer{position:sticky;bottom:0;background:var(--sidebar-bg);border-top:1px solid var(--border-color);padding-top:8px;z-index:10;display:flex;gap:4px;flex-wrap:nowrap}body.dark-mode .poi-popup-actions-footer{background:#2a2a2a}.poi-popup-btn-navigate,.poi-popup-btn-street,.poi-popup-btn-osm,.poi-popup-btn-coords,.poi-popup-btn-delete{padding:6px 8px;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:3px;transition:background .2s;flex:1;min-width:44px;white-space:nowrap}.poi-popup-btn-navigate i,.poi-popup-btn-street i,.poi-popup-btn-osm i,.poi-popup-btn-coords i,.poi-popup-btn-delete i{font-size:13px;flex-shrink:0}.poi-popup-btn-navigate{background:var(--blue-primary)}.poi-popup-btn-navigate:hover{background:#1565c0}.poi-popup-btn-street{background:var(--primary-green)}.poi-popup-btn-street:hover{background:#45a049}.poi-popup-btn-osm{background:#7092ff}.poi-popup-btn-osm:hover{background:#5a7fe6}.poi-popup-btn-coords{background:#9c27b0}.poi-popup-btn-coords:hover{background:#7b1fa2}.poi-popup-btn-delete{background:#f44336}.poi-popup-btn-delete:hover{background:#e53935}body.dark-mode .poi-popup-btn-navigate{background:#2196f3}body.dark-mode .poi-popup-btn-navigate:hover{background:#42a5f5}body.dark-mode .poi-popup-btn-street{background:var(--light-green)}body.dark-mode .poi-popup-btn-street:hover{background:#81c784}body.dark-mode .poi-popup-btn-osm{background:#8aa7ff}body.dark-mode .poi-popup-btn-osm:hover{background:#a4bbff}body.dark-mode .poi-popup-btn-coords{background:#ab47bc}body.dark-mode .poi-popup-btn-coords:hover{background:#ba68c8}body.dark-mode .poi-popup-btn-delete{background:#ef5350}body.dark-mode .poi-popup-btn-delete:hover{background:#f44336}.poi-popup-btn-fetch-elevation{padding:8px 12px;background:var(--link-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .2s}.poi-popup-btn-fetch-elevation:hover{background:var(--link-hover)}.poi-popup-btn-fetch-elevation i{font-size:14px}.poi-popup-btn-fetch-all-elevations{padding:8px 12px;background:var(--warning-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .2s}.poi-popup-btn-fetch-all-elevations:hover{background:#f57c00}.poi-popup-btn-fetch-all-elevations i{font-size:14px}.poi-popup-btn-show-coords{padding:8px 12px;background:var(--link-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .2s}.poi-popup-btn-show-coords:hover{background:var(--link-hover)}.poi-popup-btn-show-coords i{font-size:14px}.poi-coordinates-section{display:none;background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;padding:8px;margin-top:8px}.poi-coordinates-content{display:flex;gap:8px;align-items:center;font-size:.85em;font-family:monospace}.poi-coordinates-copy-btn{background:transparent;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;color:var(--text-color);transition:all .2s ease;display:inline-flex;align-items:center;gap:4px}.poi-coordinates-copy-btn:hover{background:var(--primary-green);color:#fff}.poi-coordinates-copy-btn i{font-size:12px}.reload-confirm-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:100000;align-items:center;justify-content:center}.reload-confirm-modal.active{display:flex}.reload-confirm-modal-content{background:var(--card-bg);border-radius:12px;width:90%;max-width:480px;box-shadow:0 8px 32px #0000004d;animation:modalSlideIn .3s ease}.reload-confirm-modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color)}.reload-confirm-modal-header h3{margin:0;font-size:20px;color:var(--text-color)}.reload-confirm-modal-body{padding:24px}.reload-confirm-modal-body p{margin:0 0 12px;color:var(--text-color);line-height:1.5}.reload-confirm-modal-body p:first-child{font-size:15px}.reload-confirm-modal-body ul{margin:12px 0 0;padding-left:24px;color:var(--text-secondary);list-style-type:disc}.reload-confirm-modal-body ul li{margin:8px 0;font-size:14px}.reload-confirm-modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}.reload-modal-last-saved{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);margin-bottom:8px;padding:8px 12px;background:var(--surface-alt);border-radius:var(--radius-md);border-left:3px solid var(--primary-color)}.reload-modal-last-saved i{font-size:14px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.reload-confirm-modal-content{width:95%;max-width:none}.reload-confirm-modal-header,.reload-confirm-modal-body,.reload-confirm-modal-footer{padding:16px}.reload-confirm-modal-footer{flex-direction:column-reverse}}.mobile-onboarding-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:100000;align-items:center;justify-content:center}.mobile-onboarding-modal.active{display:flex}.mobile-onboarding-modal-content{background:var(--card-bg);border-radius:16px;width:90%;max-width:360px;box-shadow:0 8px 32px #0006;animation:modalSlideIn .3s ease;overflow:hidden}.mobile-onboarding-modal-header{padding:20px 24px;background:linear-gradient(135deg,var(--blue-primary) 0%,#0d47a1 100%);text-align:center}.mobile-onboarding-modal-header h3{margin:0;font-size:20px;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px}.mobile-onboarding-modal-header i{font-size:24px}.mobile-onboarding-modal-body{padding:24px;text-align:center}.mobile-onboarding-illustration{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}.mobile-onboarding-icon-container{width:56px;height:56px;border-radius:12px;background:var(--surface-alt, #f5f5f5);display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color)}.mobile-onboarding-icon-container i{font-size:28px;color:var(--primary-green)}.mobile-onboarding-arrow{color:var(--text-secondary);font-size:20px}.mobile-onboarding-modal-body p{margin:0;color:var(--text-color);font-size:14px;line-height:1.6}.mobile-onboarding-modal-body strong{color:var(--primary-green)}.mobile-onboarding-modal-footer{padding:16px 24px 20px;display:flex;flex-direction:column;gap:12px;align-items:center}.mobile-onboarding-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.mobile-onboarding-checkbox input{cursor:pointer}.mobile-onboarding-modal-btn{width:100%;padding:12px 24px;border-radius:var(--radius-lg);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;background:var(--primary-green);color:#fff}.mobile-onboarding-modal-btn:hover{background:#45a049;transform:translateY(-1px);box-shadow:0 4px 12px #4caf5066}.mobile-onboarding-modal-btn:active{transform:translateY(0)}.gpx-summary-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;background:var(--card-bg);padding:10px;border-radius:var(--radius-md);border:1px solid var(--border-color)}.gpx-summary-stat{display:flex;flex-direction:row;align-items:center;gap:6px;font-size:11px;padding:6px 8px;background:var(--bg-color);border-radius:4px;min-width:0}.gpx-summary-stat i{font-size:11px;flex-shrink:0}.gpx-summary-stat .stat-label{color:var(--text-secondary);font-weight:500;font-size:10px;white-space:nowrap}.gpx-summary-stat .stat-value{color:var(--link-color);font-weight:600;font-size:11px;white-space:nowrap;flex-shrink:0}@media(max-width:768px){#gpxSummaryModal .modal-content{max-width:95%;margin:20px auto}.gpx-summary-stats-grid{gap:4px;padding:8px}.gpx-summary-stat{padding:4px 6px;gap:4px}.gpx-summary-stat i{font-size:10px}.gpx-summary-stat .stat-label{font-size:9px}.gpx-summary-stat .stat-value{font-size:10px}}@media(min-width:769px){#gpxSummaryModal .modal-content{max-height:95vh}}.custom-flag-marker{pointer-events:auto!important}.simple-flag-marker{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.simple-flag-marker i{font-size:24px;color:var(--blue-primary);filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));line-height:1}.flag-marker{pointer-events:auto!important}.flag-marker i{font-size:28px;filter:drop-shadow(0 2px 3px rgba(0,0,0,.4));line-height:1}.flag-marker.start-flag i{color:#4caf50}.flag-marker.finish-flag i{color:#e53935}#daylightInfoSection .daylight-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}#daylightInfoSection .daylight-icon{font-size:1.1rem;width:24px;text-align:center}#daylightInfoSection .daylight-label{font-weight:500;color:var(--text-color);min-width:90px}#daylightInfoSection .daylight-time{color:var(--text-color);opacity:.85}#daylightInfoSection .daylight-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1rem}#daylightInfoSection .daylight-row-compact{display:flex;align-items:center;gap:.4rem;font-size:11px}#daylightInfoSection .daylight-row-compact .daylight-icon{font-size:1rem;width:20px;text-align:center}#daylightInfoSection .daylight-row-compact .daylight-label{font-weight:500;color:var(--text-color);min-width:auto}#daylightInfoSection .daylight-row-compact .daylight-time{color:var(--text-color);opacity:.85;font-weight:600}#daylightInfoSection .daylight-day-length{grid-column:1 / -1;margin-top:.3rem;padding-top:.5rem;border-top:1px solid var(--border-color)}#addDaylightPOIsBtn{background:var(--link-color);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.3rem}#addDaylightPOIsBtn:hover{background:var(--link-hover);transform:translateY(-1px)}#addDaylightPOIsBtn:active{transform:translateY(0)}.u-hidden{display:none!important}.u-block{display:block!important}.u-flex{display:flex!important}.u-grid{display:grid!important}.u-inline{display:inline!important}.u-inline-block{display:inline-block!important}.u-inline-flex{display:inline-flex!important}.u-flex-center{display:flex;align-items:center}.u-flex-center-between{display:flex;align-items:center;justify-content:space-between}.u-flex-center-justify{display:flex;align-items:center;justify-content:center}.u-align-center{align-items:center!important}.u-justify-center{justify-content:center!important}.u-justify-between{justify-content:space-between!important}.u-justify-end{justify-content:flex-end!important}.u-flex-wrap{flex-wrap:wrap!important}.u-m-0{margin:0!important}.u-mt-0{margin-top:0!important}.u-mr-0{margin-right:0!important}.u-mb-0{margin-bottom:0!important}.u-ml-0{margin-left:0!important}.u-mt-4{margin-top:4px!important}.u-mr-4{margin-right:4px!important}.u-mb-4{margin-bottom:4px!important}.u-ml-4{margin-left:4px!important}.u-mt-6{margin-top:6px!important}.u-mr-6{margin-right:6px!important}.u-ml-6{margin-left:6px!important}.u-mt-8{margin-top:8px!important}.u-mr-8{margin-right:8px!important}.u-ml-8{margin-left:8px!important}.u-mt-10{margin-top:10px!important}.u-mr-10{margin-right:10px!important}.u-ml-10{margin-left:10px!important}.u-mt-12{margin-top:12px!important}.u-mr-12{margin-right:12px!important}.u-mb-12{margin-bottom:12px!important}.u-ml-12{margin-left:12px!important}.u-mt-16{margin-top:16px!important}.u-mr-16{margin-right:16px!important}.u-mb-16{margin-bottom:16px!important}.u-ml-16{margin-left:16px!important}.u-mt-20{margin-top:20px!important}.u-mr-20{margin-right:20px!important}.u-ml-20{margin-left:20px!important}.u-ml-auto{margin-left:auto!important}.u-mr-auto{margin-right:auto!important}.u-p-0{padding:0!important}.u-pt-0{padding-top:0!important}.u-pr-0{padding-right:0!important}.u-pb-0{padding-bottom:0!important}.u-pl-0{padding-left:0!important}.u-p-8{padding:8px!important}.u-p-10{padding:10px!important}.u-p-15{padding:15px!important}.u-p-20{padding:20px!important}.u-gap-4{gap:4px!important}.u-gap-6{gap:6px!important}.u-gap-8{gap:8px!important}.u-gap-10{gap:10px!important}.u-gap-12{gap:12px!important}.u-gap-16{gap:16px!important}.u-gap-20{gap:20px!important}.u-font-12{font-size:12px!important}.u-font-13{font-size:13px!important}.u-font-16{font-size:16px!important}.u-font-18{font-size:18px!important}.u-font-20{font-size:20px!important}.u-font-24{font-size:24px!important}.u-font-normal{font-weight:400!important}.u-font-bold{font-weight:700!important}.u-font-600{font-weight:600!important}.u-text-center{text-align:center!important}.u-text-left{text-align:left!important}.u-text-right{text-align:right!important}.u-w-100{width:100%!important}.u-w-auto{width:auto!important}.u-color-primary{color:var(--link-color)!important}.u-color-secondary{color:var(--text-secondary)!important}.u-color-tertiary{color:var(--text-tertiary)!important}.u-cursor-pointer{cursor:pointer!important}.u-no-wrap{white-space:nowrap!important}.u-valign-middle{vertical-align:middle!important}.u-valign-top{vertical-align:top!important}.u-valign-bottom{vertical-align:bottom!important}.u-checkbox-label{display:flex;align-items:center;cursor:pointer;font-weight:400}.u-modal-footer{padding:15px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.u-icon-mr{margin-right:8px;cursor:pointer}.u-icon-sm{font-size:16px}.u-icon-md{font-size:20px;margin-right:10px}.u-svg-icon-sm{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;margin-right:4px;vertical-align:middle}.u-label-bold{display:block;margin-bottom:8px;font-weight:700}.u-label-bold-13{display:block;margin-bottom:6px;font-weight:600;font-size:13px;color:var(--text-color)}.u-label-bold-12-compact{font-weight:600;font-size:12px;white-space:nowrap;min-width:120px}.u-desc-text{color:var(--text-secondary);margin-bottom:20px;line-height:1.6}.u-desc-text-sm{margin:4px 0 0 22px;font-size:11px;color:var(--text-secondary)}.u-heading-16{font-size:16px;margin-bottom:10px;color:var(--text-color)}.u-max-w-500{max-width:500px!important}.u-max-w-600{max-width:600px!important}.u-max-w-700{max-width:700px!important}.u-max-w-800{max-width:800px!important}.u-link-secondary{color:var(--text-secondary);text-decoration:none;font-size:12px;transition:color .2s}.u-link-primary-no-decoration{color:var(--link-color);text-decoration:none}.u-icon-text-16{font-size:16px;vertical-align:middle;margin-right:4px}.u-icon-text-14{font-size:14px;margin-right:4px;vertical-align:middle}.u-icon-text-12{font-size:12px;margin-right:4px}.u-font-11{font-size:11px!important}.u-input-field{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color)}.u-input-field-14{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color);font-size:14px}.u-input-field-12{width:100%;padding:6px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color);font-size:12px}.u-input-field-time{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;background:var(--bg-color);color:var(--text-color)}.u-pos-absolute{position:absolute!important}.u-pos-relative{position:relative!important}.u-top-15{top:15px!important}.u-right-15{right:15px!important}.u-p-6-8{padding:6px 8px!important}.u-p-8-16{padding:8px 16px!important}.u-p-12-24{padding:12px 24px!important}.u-mb-20{margin-bottom:20px!important}.u-mb-10{margin-bottom:10px!important}.u-mb-8{margin-bottom:8px!important}.u-mb-6{margin-bottom:6px!important}.u-hidden-mb-8{display:none;margin-bottom:8px}.u-flex-1{flex:1!important}.u-font-14{font-size:14px!important}.u-max-w-450{max-width:450px!important}.u-max-w-550{max-width:550px!important}.u-pos-abs-tr-15{position:absolute;right:15px;top:15px}.u-p-12{padding:12px!important}.u-p-w-100-12{width:100%;padding:12px}.u-mt-15{margin-top:15px!important}.u-ml-18{margin-left:18px!important}.u-ml-18-italic{margin-left:18px;font-style:italic}.u-m-0-lh-16{margin:0;line-height:1.6}.u-m-0-16-0-lh-16{margin:0 0 16px;line-height:1.6}.u-m-20-0{margin:20px 0!important}.u-m-25-0-15{margin:25px 0 15px;font-size:18px;font-weight:600;color:var(--text-primary)}.u-font-10-secondary{font-size:10px;color:var(--text-secondary)}.u-font-12-secondary-mb-8{font-size:12px;color:var(--text-secondary);margin-bottom:8px}.u-font-16-mr-6{font-size:16px;margin-right:6px}.u-flex-ai-gap-8{display:flex;align-items:center;gap:8px}.u-flex-ai-flex-1{display:flex;align-items:center;flex:1}.u-flex-jc-sb-12-op7-mt6{display:flex;justify-content:space-between;font-size:12px;opacity:.7;margin-top:6px}.u-flex-ai-mb-8-gap-8{margin-bottom:8px;display:flex;align-items:center;gap:8px}.u-w-100-p-ws-nowrap-p-12-24{white-space:nowrap;padding:12px 24px}.u-modal-scroll-content{max-height:400px;overflow-y:auto;background:var(--card-bg);padding:15px;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.u-label-11-bold-block{font-weight:600;margin-bottom:4px;display:block;font-size:11px}.u-label-12-bold-block-mb-4{display:block;font-weight:600;font-size:12px;margin-bottom:4px}.u-label-14-bold-mb-2{font-weight:600;font-size:14px;margin-bottom:2px}.u-radio-card{flex:1;padding:8px;border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.u-input-flex-1-sm{flex:1;padding:5px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color);font-size:12px}.u-input-flex-1-lg{flex:1;padding:12px;border:2px solid var(--border-color);border-radius:var(--radius-lg);font-size:14px;background:var(--input-bg);color:var(--text-color);transition:border-color .2s}.u-block-max-w-100{display:block;max-width:100%}.u-color-warning{color:var(--warning-color)!important}.u-divider-h{border:none;border-top:1px solid var(--border-color);margin:20px 0}.u-preview-frame{border:1px solid var(--border-color);border-radius:4px;padding:4px;background:var(--card-bg);display:flex;align-items:center;justify-content:center}.search-button-row-single{margin-bottom:8px}.search-button-row-single .btn-primary{width:100%;justify-content:center}.search-button-row-multi{display:flex;gap:8px;flex-wrap:wrap}.deleted-count-badge{display:inline-block;background:#f44336;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;margin-left:6px;min-width:18px;text-align:center}.deleted-pois-list{max-height:400px;overflow-y:auto}.deleted-poi-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:8px;transition:background .2s ease}.deleted-poi-item:hover{background:var(--bg-color)}.deleted-poi-info{flex:1;min-width:0}.deleted-poi-name{font-weight:600;font-size:14px;color:var(--text-color);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deleted-poi-meta{font-size:12px;color:var(--text-secondary);display:flex;gap:12px}.deleted-poi-actions{display:flex;gap:6px}.deleted-poi-restore-btn{padding:6px 12px;background:var(--primary-green);color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s ease;white-space:nowrap}.deleted-poi-restore-btn:hover{background:var(--primary-green-hover)}.time-estimate-warning{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#ff98001a;border-left:3px solid var(--warning-color);border-radius:4px;margin-bottom:12px;font-size:12px;line-height:1.4;color:var(--text-color)}.time-estimate-warning i{color:var(--warning-color);font-size:14px;margin-top:1px;flex-shrink:0}body.dark-mode .time-estimate-warning{background:#ff980026}.time-estimate-input-row{margin-bottom:12px}.time-estimate-speed-input{display:flex;align-items:center;gap:8px}.time-estimate-unit-toggle{display:flex;border:1px solid var(--border-color);border-radius:4px;overflow:hidden}.time-estimate-unit-btn{padding:6px 10px;background:var(--card-bg);border:none;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.time-estimate-unit-btn:not(:last-child){border-right:1px solid var(--border-color)}.time-estimate-unit-btn:hover{background:var(--bg-color)}.time-estimate-unit-btn.active{background:var(--primary-green);color:#fff}body.dark-mode .time-estimate-unit-btn{background:#333}body.dark-mode .time-estimate-unit-btn:hover{background:#444}body.dark-mode .time-estimate-unit-btn.active{background:var(--primary-green)}.time-estimate-terrain-row{margin-bottom:12px}.time-estimate-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-color)}.time-estimate-checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.time-estimate-terrain-info{font-size:11px;color:var(--text-secondary);margin-top:4px;margin-left:24px;font-style:italic}.time-estimate-result{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-top:8px}.time-estimate-result-label{font-size:13px;font-weight:500;color:var(--text-color)}.time-estimate-result-value{font-size:18px;font-weight:600;color:var(--primary-green)}body.dark-mode .time-estimate-result-value{color:var(--light-green)}.time-estimate-result-row{display:flex;align-items:center;gap:12px;margin-top:10px}.time-estimate-result-row .time-estimate-result{flex:1;margin-top:0}.time-estimate-result-row .ps-btn{white-space:nowrap}.map3d-controls-overlay{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;z-index:10}.map3d-control-group{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:10px 12px;display:flex;align-items:center;gap:10px;box-shadow:0 2px 8px #00000026;min-width:180px}.map3d-control-group label{font-size:12px;font-weight:500;color:var(--text-color);white-space:nowrap}.map3d-control-group input[type=range]{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--border-color);border-radius:2px;cursor:pointer}.map3d-control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--primary-green);border-radius:50%;cursor:pointer;transition:transform .1s ease}.map3d-control-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.map3d-control-group input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--primary-green);border:none;border-radius:50%;cursor:pointer}#map3dExaggerationValue{font-size:12px;font-weight:600;color:var(--primary-green);min-width:32px;text-align:right}.map3d-style-select{flex:1;padding:6px 28px 6px 10px;font-size:12px;font-weight:500;color:var(--text-color);background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23666' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;min-width:100px;transition:border-color .15s ease}.map3d-style-select:hover{border-color:var(--primary-green)}.map3d-style-select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 2px #4caf5033}.map3d-style-select option{background-color:var(--bg-color);color:var(--text-color);padding:8px}body.dark-mode .map3d-style-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23aaa' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E")}@media(prefers-color-scheme:dark){body:not(.light-mode) .map3d-style-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23aaa' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E")}}.map3d-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--text-color)}.map3d-toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-green)}.map3d-route-selector{max-height:120px;overflow-y:auto}.map3d-route-checkboxes{display:flex;flex-direction:column;gap:6px;margin-top:4px}.map3d-route-checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:11px;color:var(--text-color);padding:4px 6px;border-radius:4px;transition:background-color .15s ease}.map3d-route-checkbox-label:hover{background:#0000000d}body.dark-mode .map3d-route-checkbox-label:hover{background:#ffffff1a}.map3d-route-checkbox-label input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--primary-green)}.map3d-route-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.map3d-route-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.map3d-reset-btn{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026;transition:all .2s ease;color:var(--text-color)}.map3d-reset-btn:hover{background:var(--primary-green);border-color:var(--primary-green);color:#fff}.map3d-reset-btn i{font-size:16px}#map3dContainer{background:var(--card-bg)}#map3dLoading .loading-spinner{border:3px solid var(--border-color);border-top-color:var(--primary-green);animation:spin 1s linear infinite}body.dark-mode .map3d-control-group,body.dark-mode .map3d-reset-btn{background:#2a2a2a;border-color:#444}body.dark-mode .map3d-reset-btn:hover{background:var(--light-green);border-color:var(--light-green)}body.dark-mode #map3dExaggerationValue{color:var(--light-green)}body.dark-mode .map3d-control-group input[type=range]{background:#444}body.dark-mode .map3d-control-group input[type=range]::-webkit-slider-thumb{background:var(--light-green)}body.dark-mode .map3d-control-group input[type=range]::-moz-range-thumb{background:var(--light-green)}.maplibregl-popup.map3d-popup .maplibregl-popup-content{background:#fff;color:#333;padding:10px;border-radius:4px;box-shadow:0 2px 8px #00000026}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button{color:#333;font-size:18px;padding:4px 8px}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button:hover{background-color:#0000000d}.map3d-popup-content{color:#333}.map3d-popup-category{color:#666}body.dark-mode .maplibregl-popup.map3d-popup .maplibregl-popup-content{background:#2a2a2a;color:#e0e0e0}body.dark-mode .map3d-popup-content{color:#e0e0e0}body.dark-mode .map3d-popup-category{color:#aaa}body.dark-mode .maplibregl-popup.map3d-popup .maplibregl-popup-close-button{color:#e0e0e0}body.dark-mode .maplibregl-popup.map3d-popup .maplibregl-popup-close-button:hover{background-color:#ffffff1a}.maplibregl-marker{left:0!important;top:0!important;position:absolute!important;transition:opacity .2s!important;will-change:transform!important;margin:0!important;padding:0!important;pointer-events:auto!important;box-sizing:content-box!important}@media(max-width:768px){.map3d-controls-overlay{top:8px;right:8px}.map3d-control-group{padding:8px 10px;min-width:150px}.map3d-control-group label,#map3dExaggerationValue{font-size:11px}}@media(prefers-color-scheme:dark){.map3d-control-group,.map3d-reset-btn{background:#2a2a2a;border-color:#444}.map3d-reset-btn:hover{background:var(--light-green);border-color:var(--light-green)}#map3dExaggerationValue{color:var(--light-green)}.map3d-control-group input[type=range]{background:#444}.map3d-control-group input[type=range]::-webkit-slider-thumb{background:var(--light-green)}.map3d-control-group input[type=range]::-moz-range-thumb{background:var(--light-green)}.maplibregl-popup.map3d-popup .maplibregl-popup-content{background:#2a2a2a;color:#e0e0e0}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button{color:#e0e0e0}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button:hover{background-color:#ffffff1a}}.famous-climbs-loading,.famous-climbs-no-route{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-secondary);gap:12px}.famous-climbs-loading i,.famous-climbs-no-route i{font-size:32px;opacity:.5}.famous-climbs-loading i{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.famous-climbs-summary{margin-bottom:8px}.famous-climbs-list{max-height:400px;overflow-y:auto}.road-obstacles-panel{position:fixed;top:0;left:0;width:320px;height:calc(100vh - 52px);background:var(--bg-color);border-right:1px solid var(--border-color);z-index:1001;display:flex;flex-direction:column;box-shadow:4px 0 12px #00000026;transition:width .2s ease-out}.road-obstacles-panel-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.road-obstacles-panel-tab{display:none;position:absolute;top:140px;left:0;width:36px;height:48px;background:var(--bg-color);border:1px solid var(--border-color);border-left:none;border-radius:0 8px 8px 0;box-shadow:2px 0 8px #0000001a;cursor:pointer;align-items:center;justify-content:center;font-size:18px;color:var(--text-color);transition:all .15s ease}.road-obstacles-panel-tab:hover{background:var(--button-hover);width:42px}.road-obstacles-panel.collapsed{width:0;box-shadow:none;border-right:none}.road-obstacles-panel.collapsed .road-obstacles-panel-content{display:none}.road-obstacles-panel.collapsed .road-obstacles-panel-tab{display:flex}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.road-obstacles-panel.closing{animation:slideOutToLeft .2s ease-in forwards}@keyframes slideOutToLeft{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}.road-obstacles-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.road-obstacles-panel-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text-color)}.road-obstacles-panel-title i{font-size:20px;color:var(--primary)}.beta-pill{display:inline-flex;align-items:center;padding:2px 6px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border-radius:10px;cursor:help;margin-left:4px}.beta-pill:hover{background:linear-gradient(135deg,#ffa726,#ff9800)}.road-obstacles-panel-close{background:transparent;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .2s ease}.road-obstacles-panel-close:hover{background:var(--button-hover);color:var(--text-color)}.road-obstacles-panel-close:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media(max-width:768px){.road-obstacles-panel-close{padding:12px}}.road-obstacles-panel-body{flex:1;overflow-y:auto;padding:16px}.road-obstacles-section{margin-bottom:16px}.road-obstacles-search-btn{width:100%;margin-top:8px}.road-obstacles-panel-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.road-obstacles-panel-footer .ps-btn{flex:1}.road-obstacles-panel .road-obstacles-list{max-height:none}.road-obstacles-panel .road-obstacle-item{padding:10px;gap:8px}.road-obstacles-panel .road-obstacles-summary{padding:10px;margin-bottom:12px}.road-obstacles-panel .road-obstacles-summary p{margin:0;font-size:13px}@media(max-width:768px){.road-obstacles-panel{width:100%;height:calc(100vh - 60px)}}.road-obstacles-intro{color:var(--text-secondary);font-size:14px;margin-bottom:16px;line-height:1.5}.road-obstacles-checkboxes{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.road-obstacle-checkbox{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.road-obstacle-checkbox:hover{background:var(--button-hover);border-color:var(--primary)}.road-obstacle-checkbox:focus-within{outline:2px solid var(--primary);outline-offset:2px}.road-obstacle-checkbox input{width:16px;height:16px;cursor:pointer}.obstacle-count-badge{background:var(--primary);color:#fff;font-size:10px;font-weight:600;padding:1px 5px;border-radius:10px;margin-left:4px;min-width:18px;text-align:center}.obstacle-count-badge.zero{background:var(--text-secondary);opacity:.6}.obstacle-settings-btn{background:transparent;border:none;padding:4px;margin-left:auto;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.obstacle-settings-btn:hover{color:var(--primary);background:var(--button-hover)}.obstacle-route-indicators{display:flex;flex-direction:column;gap:2px;position:absolute;left:0;top:0;bottom:0;width:4px}.obstacle-route-indicator{flex:1;width:4px;border-radius:2px 0 0 2px}.road-obstacle-item.has-route-indicator{position:relative;padding-left:12px}.obstacle-settings-btn i{font-size:14px}.steep-settings-content{display:flex;flex-direction:column;gap:20px}.steep-setting-group{display:flex;flex-direction:column;gap:8px}.steep-setting-group>label{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--text-color)}.steep-setting-label{font-weight:500}.steep-setting-value{font-weight:600;color:var(--primary);font-size:16px}.steep-setting-hint{display:block;font-size:12px;color:var(--text-secondary);font-weight:400;margin-top:2px}.steep-setting-toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}.steep-setting-toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer;flex-shrink:0}.steep-setting-group input[type=range]{width:100%;height:8px;-webkit-appearance:none;background:var(--border-color);border-radius:4px;outline:none}.steep-setting-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:var(--primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0003}.steep-setting-group input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--primary);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.steep-setting-range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary)}.road-obstacles-slider-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.road-obstacles-slider-section>label{display:block;font-size:13px;margin-bottom:8px;color:var(--text-secondary)}.road-obstacle-checkbox .obstacle-icon{font-size:16px}.road-obstacles-loading,.road-obstacles-no-route{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-secondary);gap:12px}.road-obstacles-loading .progress-spinner{width:64px;height:64px}.road-obstacles-no-route i{font-size:32px;opacity:.5}.road-obstacles-status{font-size:11px;color:var(--text-secondary);opacity:.8;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.road-obstacles-summary{margin-bottom:8px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius-md)}.road-obstacles-summary-counts{display:flex;flex-wrap:wrap;gap:12px}.road-obstacles-summary-count{display:flex;align-items:center;gap:6px;font-size:14px}.road-obstacles-list{max-height:350px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.road-obstacle-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s ease}.road-obstacle-item:hover{background:var(--button-hover);border-color:var(--primary)}.road-obstacle-item.clickable{cursor:pointer}.road-obstacle-item.highlighted{border-color:var(--primary);box-shadow:0 0 0 2px #1976d233}.road-obstacle-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);font-size:18px}.road-obstacle-icon.tunnel{background:#e5393526;color:#e53935}.road-obstacle-icon.bridge{background:#4169e126;color:#4169e1}.road-obstacle-icon.ford{background:#00ced126;color:#00ced1}.road-obstacle-icon.level_crossing{background:#ff450026;color:#ff4500}.road-obstacle-info{flex:1;min-width:0}.road-obstacle-name{font-weight:500;font-size:14px;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.road-obstacle-details{font-size:12px;color:var(--text-secondary);margin-top:2px}.road-obstacle-actions{display:flex;gap:6px}.road-obstacle-actions button{padding:6px 10px;border:none;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:4px}.road-obstacle-actions .show-btn{background:var(--button-bg);color:var(--text-color)}.road-obstacle-actions .show-btn:hover,.road-obstacle-actions .add-btn{background:var(--primary);color:#fff}.road-obstacle-actions .add-btn:hover{background:var(--primary-hover)}.road-obstacle-actions .add-btn:disabled{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}.obstacle-category-groups{display:flex;flex-direction:column;gap:8px}.obstacle-group{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--card-bg)}.obstacle-group-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--card-bg);cursor:pointer;user-select:none;transition:background .2s}.obstacle-group-header:hover{background:var(--button-hover)}.obstacle-group-header:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.obstacle-group-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-color)}.obstacle-group-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.obstacle-group-count{font-size:11px;color:var(--text-secondary);font-weight:400}.obstacle-group-total-length{font-size:11px;color:var(--primary-green);font-weight:500;margin-left:4px}.obstacle-group-controls{display:flex;align-items:center;gap:8px}.obstacle-group-arrow{font-size:12px;transition:transform .3s;transform:rotate(180deg);display:inline-block}.obstacle-group-arrow.collapsed{transform:rotate(0)}.obstacle-group-content{padding:8px 12px;display:flex;flex-direction:column;gap:6px;max-height:1000px;overflow:visible;transition:all .3s ease}.obstacle-group-content.collapsed{max-height:0;padding:0 12px;overflow:hidden}.obstacle-group-content .road-obstacle-item{padding:8px;gap:8px}.obstacle-group-content .obstacle-info{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px}.obstacle-group-content .obstacle-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px}.obstacle-group-content .obstacle-length{font-size:11px;color:var(--text-secondary);white-space:nowrap}.obstacle-group-content .obstacle-description{width:100%;font-size:11px;color:var(--text-secondary);font-style:italic;line-height:1.3}.obstacle-group-content .obstacle-distance{font-size:12px;color:var(--text-secondary);white-space:nowrap}.obstacle-group-content .obstacle-actions{display:flex;gap:4px}.obstacle-popup-actions{margin:8px 0}.obstacle-popup-actions .ps-btn{width:100%}.surface-info-panel{position:fixed;top:0;left:0;width:320px;height:calc(100vh - 52px);background:var(--bg-color);border-right:1px solid var(--border-color);z-index:1001;display:flex;flex-direction:column;box-shadow:4px 0 12px #00000026;transition:width .2s ease-out}.surface-info-panel-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.surface-info-panel-tab{display:none;position:absolute;top:80px;left:0;width:36px;height:48px;background:var(--bg-color);border:1px solid var(--border-color);border-left:none;border-radius:0 8px 8px 0;box-shadow:2px 0 8px #0000001a;cursor:pointer;align-items:center;justify-content:center;font-size:18px;color:var(--text-color);transition:all .15s ease}.surface-info-panel-tab:hover{background:var(--button-hover);width:42px}.surface-info-panel.collapsed{width:0;box-shadow:none;border-right:none}.surface-info-panel.collapsed .surface-info-panel-content{display:none}.surface-info-panel.collapsed .surface-info-panel-tab{display:flex}.surface-info-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.surface-info-panel-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text-color)}.surface-info-panel-title i{font-size:20px;color:var(--primary)}.surface-info-panel-close{background:transparent;border:none;padding:8px;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .2s ease}.surface-info-panel-close:hover{background:var(--button-hover);color:var(--text-color)}.surface-info-panel-body{flex:1;overflow-y:auto;padding:16px}.surface-info-section{margin-bottom:16px}.surface-info-intro{color:var(--text-secondary);font-size:14px;margin-bottom:16px;line-height:1.5}.surface-info-checkboxes{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.surface-info-checkbox{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.surface-info-checkbox:hover{background:var(--button-hover);border-color:var(--primary)}.surface-info-checkbox input{width:16px;height:16px;cursor:pointer}.surface-info-checkbox span{display:flex;align-items:center;gap:8px;flex:1}.surface-info-checkbox i{font-size:16px;color:var(--text-secondary)}.surface-count-badge{background:var(--primary);color:#fff;font-size:10px;font-weight:600;padding:1px 5px;border-radius:10px;margin-left:auto;min-width:18px;text-align:center}.surface-count-badge.zero{background:var(--text-secondary);opacity:.6}.surface-info-search-btn{width:100%;margin-top:8px}.surface-info-loading,.surface-info-no-route{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-secondary);gap:12px}.surface-info-loading .progress-spinner{width:64px;height:64px}.surface-info-no-route i{font-size:32px;opacity:.5}.surface-info-panel-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.surface-info-panel-footer .ps-btn{flex:1}.surface-info-summary{margin-bottom:16px}.surface-stats{display:flex;gap:12px;flex-wrap:wrap}.surface-stat{flex:1;min-width:80px;padding:12px;background:var(--bg-secondary);border-radius:var(--radius-md);text-align:center}.surface-stat-value{font-size:20px;font-weight:600;color:var(--primary);display:block}.surface-stat-label{font-size:11px;color:var(--text-secondary);display:block;margin-top:4px}.surface-display-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.surface-type-buttons{display:flex;flex-direction:column;gap:6px}.surface-type-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-size:13px;color:var(--text-color);text-align:left}.surface-type-btn:hover{background:var(--button-hover);border-color:var(--primary)}.surface-type-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.surface-type-btn i{font-size:16px}.surface-legend{background:var(--bg-color);padding:12px;border-radius:var(--radius-md);box-shadow:0 2px 8px #00000026;max-width:200px;max-height:300px;overflow-y:auto;margin-top:50px;margin-right:50px;z-index:1001}.surface-legend-header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13px;color:var(--text-color);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.surface-legend-header i{color:var(--primary)}.surface-legend-items{display:flex;flex-direction:column;gap:6px}.surface-legend-item{display:flex;align-items:center;gap:8px;font-size:12px}.surface-legend-color{width:16px;height:8px;border-radius:2px;flex-shrink:0}.surface-legend-label{flex:1;color:var(--text-color)}.surface-legend-count{color:var(--text-secondary);font-size:11px}.surface-popup{min-width:180px}.surface-popup-row{display:flex;justify-content:space-between;gap:12px;padding:3px 0;font-size:13px}.surface-popup-row span:first-child{color:var(--text-secondary)}@media(max-width:768px){.surface-info-panel{width:100%;height:calc(100vh - 60px)}.surface-info-panel-close{padding:12px}}.climb-db-controls{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.climb-db-search{flex:1;min-width:200px;position:relative}.climb-db-search i{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.climb-db-search input{width:100%;padding:10px 12px 10px 36px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-color);font-size:14px}.climb-db-filters{display:flex;gap:8px}.climb-db-filters select{padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-color);font-size:14px;cursor:pointer}.climb-db-stats{font-size:13px;color:var(--text-secondary);margin-bottom:12px}.climb-db-table-wrapper{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-md)}.climb-db-table{width:100%;border-collapse:collapse;font-size:14px}.climb-db-table thead{position:sticky;top:0;background:var(--bg-tertiary);z-index:1}.climb-db-table th{padding:12px;text-align:left;font-weight:600;border-bottom:2px solid var(--border-color)}.climb-db-table td{padding:10px 12px;border-bottom:1px solid var(--border-color)}.climb-db-table tbody tr:hover{background:var(--button-hover)}.climb-db-table .climb-name{font-weight:500}.climb-db-table .climb-country{white-space:nowrap}.climb-db-table .climb-source{font-size:12px;padding:2px 8px;border-radius:4px;background:var(--bg-tertiary)}.climb-db-table .climb-actions{white-space:nowrap}.climb-db-table .climb-actions button{padding:4px 8px;margin-right:4px;border:none;border-radius:4px;background:var(--primary);color:#fff;cursor:pointer;font-size:12px}.climb-db-table .climb-actions button:hover{opacity:.9}.climb-db-table .climb-actions a{padding:4px 8px;border-radius:4px;background:var(--card-bg);color:var(--text-color);text-decoration:none;font-size:12px}.climb-db-table .climb-actions a:hover{background:var(--button-hover)}.climb-db-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:16px}.climb-db-pagination button{padding:6px 12px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-color);cursor:pointer}.climb-db-pagination button:hover:not(:disabled){background:var(--button-hover)}.climb-db-pagination button:disabled{opacity:.5;cursor:not-allowed}.climb-db-pagination span{font-size:14px;color:var(--text-secondary)}.flyover-elevation-container{height:100px;background:var(--card-bg);border-top:1px solid var(--border-color);position:relative;padding:8px 12px}.flyover-elevation-container canvas{width:100%!important;height:100%!important}.flyover-elevation-marker{position:absolute;width:2px;background:#ff5722;pointer-events:none;z-index:5;display:none}.flyover-controls-overlay{position:absolute;inset:0 0 100px;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;z-index:10}.flyover-settings-group{display:flex;flex-direction:column;gap:6px;padding:12px;pointer-events:auto;max-width:200px}.flyover-control-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px 10px;display:flex;align-items:center;gap:8px;box-shadow:0 2px 6px #00000026}.flyover-control-item label{font-size:11px;font-weight:500;color:var(--text-color);white-space:nowrap}.flyover-select{flex:1;padding:4px 24px 4px 8px;font-size:11px;color:var(--text-color);background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23666' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.flyover-select:focus{outline:none;border-color:var(--primary-green)}.flyover-select-sm{min-width:60px}.flyover-toggle-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:11px;color:var(--text-color)}.flyover-toggle-label input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--primary-green)}.flyover-fullscreen-btn{cursor:pointer;justify-content:center;min-width:auto;padding:8px 12px}.flyover-fullscreen-btn i{font-size:14px}.flyover-record-btn{cursor:pointer;justify-content:center;min-width:auto;padding:8px 12px}.flyover-record-btn i{font-size:14px;color:#ccc;transition:color .2s ease}.flyover-record-btn:hover i{color:#f44}.flyover-record-btn.recording{background:#ff44444d}.flyover-record-btn.recording i{color:#f44;animation:pulse-record 1s infinite}@keyframes pulse-record{0%,to{opacity:1}50%{opacity:.5}}.flyover-playback-controls{background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.4) 70%,transparent 100%);padding:16px 16px 12px;pointer-events:auto}.flyover-progress-container{position:relative;height:6px;margin-bottom:12px}.flyover-progress-bar{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:#fff3;border-radius:3px;cursor:pointer;position:relative;z-index:2}.flyover-progress-bar::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 4px #0000004d;transition:transform .1s ease}.flyover-progress-bar::-webkit-slider-thumb:hover{transform:scale(1.2)}.flyover-progress-bar::-moz-range-thumb{width:14px;height:14px;background:#fff;border:none;border-radius:50%;cursor:pointer;box-shadow:0 1px 4px #0000004d}.flyover-progress-fill{position:absolute;top:0;left:0;height:6px;background:var(--primary-green);border-radius:3px 0 0 3px;pointer-events:none;z-index:1}.flyover-controls-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.flyover-info{color:#fff;font-size:12px;font-weight:500;display:flex;align-items:center;gap:8px;min-width:120px}.flyover-info-separator{opacity:.5}.flyover-play-controls{display:flex;align-items:center;gap:8px}.flyover-btn{background:#ffffff26;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:background .15s ease,transform .1s ease}.flyover-btn:hover{background:#ffffff40;transform:scale(1.05)}.flyover-btn i{font-size:16px}.flyover-btn-play{width:48px;height:48px;background:var(--primary-green)}.flyover-btn-play:hover{background:#43a047}.flyover-btn-play i{font-size:22px}.flyover-speed-control{display:flex;align-items:center;gap:8px;color:#fff;font-size:12px;min-width:100px;justify-content:flex-end}.flyover-speed-control label{opacity:.7}.flyover-speed-control .flyover-select{background-color:#ffffff26;border-color:#fff3;color:#fff}.flyover-speed-control .flyover-select option{background-color:var(--bg-color);color:var(--text-color)}.flyover-position-marker{position:relative;width:24px;height:24px}.flyover-marker-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:var(--primary-green);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 6px #0000004d}.flyover-marker-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;background:#4caf5066;border-radius:50%;animation:flyover-pulse 1.5s ease-out infinite}@keyframes flyover-pulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:1}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.flyover-poi-marker{cursor:pointer;transition:transform .15s ease}.flyover-poi-marker:hover{transform:scale(1.15)}.flyover-position-popup{position:absolute;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:6px 10px;box-shadow:0 2px 8px #0003;z-index:20;pointer-events:none}.flyover-popup-content{display:flex;gap:12px;font-size:12px;color:var(--text-color)}body.dark-mode .flyover-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23aaa' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E")}@media(prefers-color-scheme:dark){body:not(.light-mode) .flyover-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23aaa' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E")}}@media(max-width:600px){.flyover-settings-group{flex-direction:row;flex-wrap:wrap;max-width:none}.flyover-control-item{padding:6px 8px}.flyover-controls-row{flex-wrap:wrap;justify-content:center}.flyover-info{order:3;width:100%;justify-content:center;margin-top:8px}.flyover-speed-control{min-width:auto}.flyover-elevation-container{height:80px}.flyover-controls-overlay{bottom:80px}}.route-animation-position-marker{position:relative;width:24px;height:24px}.route-animation-poi-marker{transition:transform .3s ease,opacity .3s ease;transform-origin:center bottom}.route-animation-poi-marker.hidden{transform:scale(0);opacity:0}.route-animation-poi-marker.visible{transform:scale(1);opacity:1}.route-animation-tip{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:15;max-width:500px;width:calc(100% - 24px)}.route-animation-tip-content{display:flex;align-items:center;gap:12px;background:var(--info-bg, #e3f2fd);border:1px solid var(--info-border, #2196F3);border-radius:8px;padding:10px 14px;box-shadow:0 2px 8px #00000026}.route-animation-tip-content>i{font-size:20px;color:var(--info-border, #2196F3);flex-shrink:0}.route-animation-tip-text{flex:1;font-size:13px;line-height:1.4;color:var(--text-color)}.route-animation-tip-text strong{display:block;margin-bottom:2px;color:var(--text-color)}.route-animation-tip-close{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-secondary);flex-shrink:0;border-radius:4px;transition:background .2s ease,color .2s ease}.route-animation-tip-close:hover{background:#0000001a;color:var(--text-color)}body.dark-mode .route-animation-tip-content{background:#1a3a4a;border-color:#64b5f6}body.dark-mode .route-animation-tip-content>i{color:#64b5f6}body.dark-mode .route-animation-tip-close:hover{background:#ffffff1a}@media(prefers-color-scheme:dark){.route-animation-tip-content{background:#1a3a4a;border-color:#64b5f6}.route-animation-tip-content>i{color:#64b5f6}.route-animation-tip-close:hover{background:#ffffff1a}}#routeAnimationMapContainer{width:100%;height:100%}#routeAnimationMapContainer .leaflet-container{width:100%;height:100%;background:var(--background-color, #f5f5f5)}.onboarding-hint{position:fixed;z-index:10000;animation:hintFadeIn .3s ease}@keyframes hintFadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.onboarding-hint-content{background:var(--card-bg);border:2px solid var(--primary-green);border-radius:8px;padding:12px 16px;max-width:240px;box-shadow:0 4px 20px #00000040;position:relative}.onboarding-hint-content p{margin:0 0 8px;font-size:13px;color:var(--text-color);line-height:1.4}.onboarding-hint-content p:last-of-type{margin-bottom:12px}.onboarding-hint-arrow{position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid var(--primary-green)}.onboarding-hint-btn{background:var(--primary-green);color:#fff;border:none;padding:6px 16px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;width:100%;transition:background .2s ease}.onboarding-hint-btn:hover{background:var(--dark-green)}.onboarding-hint--blue .onboarding-hint-content{border-color:var(--blue-primary)}.onboarding-hint--blue .onboarding-hint-arrow{border-top-color:var(--blue-primary)}.onboarding-hint--blue .onboarding-hint-btn{background:var(--blue-primary)}.onboarding-hint--blue .onboarding-hint-btn:hover{background:var(--blue-light)}.hint-pulse{animation:hintPulse 1.5s ease-in-out infinite}@keyframes hintPulse{0%,to{box-shadow:0 0 #4caf5080}50%{box-shadow:0 0 0 8px #4caf5000}}.hint-pulse-blue{animation:hintPulseBlue 1.5s ease-in-out infinite}@keyframes hintPulseBlue{0%,to{box-shadow:0 0 #1976d280}50%{box-shadow:0 0 0 8px #1976d200}}.draft-recovery-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%) translateY(20px);z-index:10001;opacity:0;transition:opacity .3s ease,transform .3s ease;pointer-events:none}.draft-recovery-container.visible{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.draft-recovery-prompt{display:flex;align-items:center;gap:12px;background:var(--card-bg);border:1px solid var(--border-color);border-left:4px solid var(--blue-primary);border-radius:8px;padding:12px 16px;box-shadow:0 4px 20px #00000026;max-width:90vw}.draft-recovery-icon{font-size:24px;color:var(--blue-primary)}.draft-recovery-content{flex:1;min-width:0}.draft-recovery-content strong{display:block;font-size:14px;color:var(--text-color);margin-bottom:2px}.draft-recovery-content p{margin:0;font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.draft-recovery-actions{display:flex;gap:8px;flex-shrink:0}@media(max-width:480px){.draft-recovery-prompt{flex-wrap:wrap}.draft-recovery-actions{width:100%;justify-content:flex-end;margin-top:8px}}.poi-context-menu{position:fixed;z-index:10010;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 20px #0003;min-width:180px;padding:6px 0;opacity:0;transform:scale(.95);transition:opacity .15s ease,transform .15s ease;pointer-events:none}.poi-context-menu.visible{opacity:1;transform:scale(1);pointer-events:auto}.poi-context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 12px;border:none;background:transparent;color:var(--text-color);font-size:13px;text-align:left;cursor:pointer;transition:background .15s ease}.poi-context-menu-item:hover{background:var(--hover-bg, rgba(0, 0, 0, .05))}.poi-context-menu-item i{font-size:14px;width:16px;text-align:center;color:var(--text-secondary)}.poi-context-menu-item:hover i{color:var(--text-color)}.poi-context-menu-item--danger,.poi-context-menu-item--danger i{color:var(--danger-red, #dc3545)}.poi-context-menu-item--danger:hover{background:#dc35451a}.poi-context-menu-divider{height:1px;background:var(--border-color);margin:4px 0}.poi-context-menu-header{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:600;color:var(--text-color);background:var(--surface-hover, rgba(0, 0, 0, .03));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.poi-context-menu-header i{color:var(--primary-green);font-size:14px}body.dark-mode .poi-context-menu-item:hover{background:#ffffff14}@media(prefers-color-scheme:dark){.poi-context-menu-item:hover{background:#ffffff14}}.poi-icon-picker{min-width:280px}.poi-icon-picker-title{font-weight:600;font-size:14px;margin-bottom:12px;color:var(--text-color)}.poi-icon-picker-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:12px}.poi-icon-option{width:44px;height:44px;font-size:22px;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg, #fff);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.poi-icon-option:hover{background:var(--hover-bg, #f0f0f0);border-color:var(--primary-green);transform:scale(1.1)}.poi-icon-picker-custom{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border-color)}.poi-icon-picker-custom input{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:16px;background:var(--input-bg, #fff);color:var(--text-color)}.poi-icon-picker-custom button{padding:8px 16px;background:var(--primary-green);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.poi-icon-picker-custom button:hover{background:var(--dark-green)}.poi-marker-moving{animation:poi-marker-pulse 1s ease-in-out infinite;filter:drop-shadow(0 0 12px #ff9800) drop-shadow(0 0 20px #ff9800)!important;z-index:10000!important}@keyframes poi-marker-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 12px #ff9800) drop-shadow(0 0 20px #ff9800)}50%{transform:scale(1.2);filter:drop-shadow(0 0 16px #ff9800) drop-shadow(0 0 28px #ff9800)}}.poi-move-mode,.poi-move-mode *{cursor:crosshair!important}.map-context-menu{position:fixed;z-index:10010;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 20px #0003;min-width:220px;padding:6px 0;opacity:0;transform:scale(.95);transition:opacity .15s ease,transform .15s ease;pointer-events:none}.map-context-menu.visible{opacity:1;transform:scale(1);pointer-events:auto}.map-context-menu-coords{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:12px;color:var(--text-secondary);font-family:monospace}.map-context-menu-coords i{color:var(--primary-green)}.map-context-menu-address{display:flex;align-items:flex-start;gap:8px;padding:4px 12px 8px;font-size:11px;color:var(--text-tertiary);line-height:1.3}.map-context-menu-address i{color:var(--text-tertiary);flex-shrink:0;margin-top:2px}.map-context-menu-address-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.map-context-menu-address-text{word-break:break-word;max-width:200px}.map-context-menu-address-details{font-size:10px;color:var(--text-tertiary);opacity:.85;display:none}.map-context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 12px;border:none;background:transparent;color:var(--text-color);font-size:13px;cursor:pointer;text-align:left;transition:background-color .15s}.map-context-menu-item:hover{background:var(--surface-hover, rgba(0, 0, 0, .05))}.map-context-menu-item:disabled{color:var(--text-secondary);cursor:not-allowed}.map-context-menu-item:disabled:hover{background:transparent}.map-context-menu-item i{font-size:14px;color:var(--text-secondary);width:18px;text-align:center}.map-context-menu-item span:first-of-type{flex:1}.map-context-menu-value{font-size:12px;color:var(--text-secondary);font-weight:500;min-width:50px;text-align:right}.map-context-menu-value.loading{color:var(--primary-green)}.map-context-menu-value.success{color:var(--primary-green);font-weight:600}.map-context-menu-value.error{color:var(--danger-red)}.map-context-menu-divider{height:1px;background:var(--border-color);margin:4px 0}.map-context-menu-header{display:flex;align-items:center;gap:6px;padding:5px 12px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--primary-green);background:var(--surface-hover, rgba(76, 175, 80, .08))}.map-context-menu-header i{font-size:12px}.map-context-menu-copy-btn{margin-left:auto;padding:4px 6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .15s;display:flex;align-items:center}.map-context-menu-copy-btn:hover{background:var(--surface-hover, rgba(0, 0, 0, .08));color:var(--primary-green)}.map-context-menu-copy-btn i{font-size:12px}.map-context-menu-zoom-row{display:flex;gap:4px;padding:4px 8px}.map-context-menu-zoom-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 10px;border:1px solid var(--border-color);background:var(--input-bg, #fff);color:var(--text-color);font-size:12px;cursor:pointer;border-radius:5px;transition:all .15s}.map-context-menu-zoom-btn:hover{background:var(--surface-hover, rgba(0, 0, 0, .05));border-color:var(--primary-green);color:var(--primary-green)}.map-context-menu-zoom-btn i{font-size:14px}body.dark-mode .map-context-menu-item:hover{background:#ffffff14}body.dark-mode .map-context-menu-zoom-btn{background:var(--card-bg)}body.dark-mode .map-context-menu-zoom-btn:hover{background:#ffffff14}.live-position-marker{background:transparent;border:none}.live-position-marker-outer{position:relative;width:24px;height:24px}.live-position-marker-inner{position:absolute;top:50%;left:50%;width:14px;height:14px;background:var(--tracking-color);border:2px solid white;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 6px rgba(var(--tracking-color-rgb),.4);z-index:2}.live-position-marker-pulse{position:absolute;top:50%;left:50%;width:24px;height:24px;background:rgba(var(--tracking-color-rgb),.3);border-radius:50%;transform:translate(-50%,-50%);animation:live-pulse 1.5s ease-out infinite;z-index:1}@keyframes live-pulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:1}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.live-position-marker-arrow{position:absolute;top:-8px;left:50%;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:12px solid var(--tracking-color);transform-origin:center 20px;margin-left:-6px;z-index:3;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.footer-tracking-container{display:none;align-items:center;gap:6px;padding:0 8px;margin-left:8px;border-left:1px solid var(--border-color)}.footer-tracking-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);padding:4px 8px;background:rgba(var(--tracking-color-rgb),.1);border-radius:12px}.footer-tracking-indicator .tracking-pulse{width:8px;height:8px;background:var(--tracking-color);border-radius:50%;animation:tracking-blink 1s ease-in-out infinite}@keyframes tracking-blink{0%,to{opacity:1}50%{opacity:.3}}.footer-tracking-buttons{display:flex;align-items:center}.footer-tracking-buttons button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-color);background:var(--button-bg);color:var(--text-color);border-radius:0;cursor:pointer;transition:all .2s;margin-left:-1px;position:relative}.footer-tracking-buttons button:first-child{border-radius:6px 0 0 6px;margin-left:0}.footer-tracking-buttons button:last-child{border-radius:0 6px 6px 0}.footer-tracking-buttons button:hover{background:var(--button-hover);border-color:#2196f3;color:#2196f3;z-index:1}.footer-tracking-buttons button.active{background:#2196f326;border-color:#2196f3;color:#2196f3;z-index:1}.footer-tracking-buttons button i{font-size:14px}.live-tracking-option{display:flex;flex-direction:column;gap:4px;margin-top:12px;padding-top:12px;border-top:1px dashed var(--border-color)}.live-tracking-option label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-color);cursor:pointer}.live-tracking-option label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#2196f3}.live-tracking-option small{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-tertiary);margin-left:24px}.live-tracking-option small i{color:#ff9800}.live-tracking-option.u-hidden{display:none}body.dark-mode .footer-tracking-indicator{background:#2196f333}body.dark-mode .footer-tracking-buttons button.active{background:#2196f340}@media(max-width:768px){.footer-stats{position:relative}.footer-tracking-container{position:absolute;top:-44px;left:50%;transform:translate(-50%);padding:6px 12px;margin-left:0;gap:10px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 2px 8px #00000026;z-index:100}.footer-tracking-indicator{padding:3px 8px;font-size:11px;background:#2196f326}.footer-tracking-indicator span:last-child{display:inline}.footer-tracking-buttons button{width:30px;height:30px}.footer-tracking-buttons button i{font-size:13px}}.street-photos-loading{text-align:center;padding:40px 20px}.street-photos-loading .spinner-border{width:3rem;height:3rem}.street-photos-error{text-align:center;padding:20px}.street-photos-info{border-bottom:1px solid var(--border-color);padding-bottom:15px;margin-bottom:15px}.street-photos-info p{font-size:14px;margin-bottom:5px}.street-photos-info i{width:16px;margin-right:6px;color:var(--text-secondary)}.street-photos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;max-height:60vh;overflow-y:auto}.street-photo-item{border:1px solid var(--border-color);border-radius:8px;overflow:hidden;background:var(--card-bg);transition:transform .2s ease,box-shadow .2s ease}.street-photo-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.street-photo-image{width:100%;height:200px;object-fit:cover;cursor:pointer}.street-photo-info{padding:12px;font-size:12px;color:var(--text-secondary)}.street-photo-direction{display:flex;align-items:center;gap:4px;margin-top:4px}.street-photo-direction i{color:var(--primary-green)}.street-photo-distance{display:flex;align-items:center;gap:4px;margin-bottom:4px;color:var(--text-secondary)}.street-photo-distance i{color:var(--primary-green)}.street-photo-coordinates{font-family:monospace;margin-top:4px;cursor:pointer;color:var(--accent-color);transition:color .2s;display:flex;align-items:center;gap:4px;font-size:11px}.street-photo-coordinates:hover{color:var(--dark-green)}.street-photo-coordinates i{font-size:10px}.street-photo-timestamp{font-size:11px;color:var(--text-secondary);margin-top:4px;display:flex;align-items:center;gap:4px}.street-photo-timestamp i{font-size:10px}.street-photo-description{margin-top:6px;font-size:11px;color:var(--text-muted);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}@media(prefers-color-scheme:dark){.street-photo-item:hover{box-shadow:0 4px 12px #ffffff1a}}body.dark-mode .street-photo-item:hover{box-shadow:0 4px 12px #ffffff1a}.temp-photo-marker{background:var(--accent-color);border-radius:50%;border:2px solid white;box-shadow:0 2px 8px #0000004d;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .3s ease}.temp-photo-marker:hover{background:var(--dark-green);transform:scale(1.1)}.photo-popup-content{min-width:250px}.photo-popup-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.photo-popup-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;margin-left:auto;border-radius:2px;transition:all .2s}.photo-popup-close:hover{background:var(--button-hover);color:var(--text-color)}.photo-popup-image{width:100%;height:120px;object-fit:cover;border-radius:4px;margin-bottom:8px}.photo-popup-title{font-weight:600;margin-bottom:4px;font-size:14px}.photo-popup-description{font-size:12px;color:var(--text-secondary);margin-bottom:8px;line-height:1.3}.photo-popup-coordinates{font-size:11px;color:var(--text-secondary);margin-bottom:12px;font-family:monospace}.photo-popup-actions{display:flex;gap:8px;flex-wrap:wrap}.photo-popup .ps-btn--compact{padding:4px 8px;font-size:11px}@media(max-width:768px){.street-photos-grid{grid-template-columns:1fr;max-height:300px}.street-photo-image{height:180px}}.location-explorer{position:fixed;top:0;left:0;bottom:38px;width:400px;background:var(--sidebar-bg);border-right:1px solid var(--border-color);box-shadow:2px 0 10px var(--shadow);z-index:1002;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.location-explorer.visible{transform:translate(0)}.location-explorer__tab{display:none;position:absolute;top:20px;left:0;width:40px;height:52px;background:var(--bg-color);border:1px solid var(--border-color);border-left:none;border-radius:0 var(--radius-lg) var(--radius-lg) 0;box-shadow:2px 0 8px var(--shadow);cursor:pointer;align-items:center;justify-content:center;font-size:20px;color:var(--primary-green);transition:all .2s ease}.location-explorer__tab:hover{background:var(--button-hover);width:46px;box-shadow:3px 0 12px var(--shadow)}.location-explorer__tab i{color:#fff}.location-explorer.collapsed{width:0;box-shadow:none;border-right:none}.location-explorer.collapsed .location-explorer__container{display:none}.location-explorer.collapsed .location-explorer__tab{display:flex}.location-explorer__container{display:flex;flex-direction:column;height:100%;overflow:hidden}.location-explorer__header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.location-explorer__header-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--text-color)}.location-explorer__header-title i{color:var(--primary-green);font-size:20px}.location-explorer__header-title h3{margin:0;font-size:18px}.location-explorer__header-actions{display:flex;align-items:center;gap:8px}.location-explorer__close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:var(--radius-md);transition:all .2s ease;font-size:18px;display:flex;align-items:center;justify-content:center}.location-explorer__close:hover{background:var(--button-hover);color:var(--text-color)}.location-explorer__nav{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.location-explorer__nav-item{flex:1;background:none;border:none;padding:14px 16px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:500;border-bottom:3px solid transparent;position:relative}.location-explorer__nav-item:hover{color:var(--text-color);background:var(--button-hover)}.location-explorer__nav-item.active{color:var(--primary-green);border-bottom-color:var(--primary-green);background:var(--surface-alt);font-weight:600}.location-explorer__nav-item i{font-size:16px}.location-explorer__location{padding:12px 16px;background:var(--surface-alt);border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);flex-shrink:0}.location-explorer__location i{color:var(--primary-green);font-size:14px}.location-explorer__content{flex:1;overflow:hidden;position:relative}.location-explorer__tab-pane{display:none;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden}.location-explorer__tab-pane.active{display:flex}.location-explorer__loading{padding:48px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.location-explorer__loading .spinner-border{width:48px;height:48px;color:var(--primary-green)}.location-explorer__loading p{margin:0;color:var(--text-secondary);font-size:14px}.location-explorer__error{padding:32px 24px;text-align:center}.location-explorer__error .alert{margin:0;display:flex;align-items:center;gap:8px;justify-content:center}.location-explorer__info{padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.location-explorer__info p{margin:0;font-size:13px;color:var(--text-secondary)}.location-explorer__info i{margin-right:6px;color:var(--primary-green)}.location-explorer__info-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.location-explorer__route-search{margin-top:12px}.location-explorer__route-search .ps-btn{width:100%;justify-content:center}.location-explorer__search-options{padding:16px;text-align:center;border-top:1px solid var(--border-color);background:var(--surface-alt)}.location-explorer__search-buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.location-explorer__search-buttons .ps-btn{min-width:140px;flex:0 0 auto}.location-explorer__route-search-section{border-bottom:1px solid var(--border-color)}.location-explorer__route-search-section .ps-btn{width:100%;max-width:200px}.location-explorer__article-compact.has-route-indicator{position:relative;padding-left:16px}.location-explorer__route-indicator{position:absolute;left:0;top:4px;bottom:4px;width:4px;border-radius:2px}.location-explorer__photos{display:flex;flex-direction:column;flex:1}.location-explorer__photos-list{display:flex;flex-direction:column;gap:12px;padding:16px;flex:1}.location-explorer__photo-item{display:flex;gap:12px;padding:12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all .2s ease;cursor:pointer}.location-explorer__photo-item:hover,.location-explorer__photo-item.highlighted{background:var(--button-hover);border-color:var(--primary-green);box-shadow:0 2px 8px var(--shadow)}.location-explorer__photo-thumbnail{flex-shrink:0;width:100px;height:100px;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;background:var(--surface-alt)}.location-explorer__photo-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.location-explorer__photo-thumbnail:hover img{transform:scale(1.08)}.location-explorer__photo-info{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.location-explorer__photo-title{font-size:14px;font-weight:500;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.location-explorer__photo-description{font-size:12px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.location-explorer__photo-meta{display:flex;gap:12px;font-size:11px;color:var(--text-tertiary);flex-wrap:wrap}.location-explorer__photo-meta i{margin-right:3px}.location-explorer__photo-distance{color:var(--primary-green);font-weight:500}.location-explorer__photo-actions{display:flex;gap:6px;margin-top:6px}.location-explorer__articles{display:flex;flex-direction:column;flex:1}.location-explorer__articles-list{display:flex;flex-direction:column;padding:16px;gap:0;flex:1}.location-explorer__article-item{display:flex;flex-direction:column;padding:16px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.location-explorer__article-item:last-child{border-bottom:none}.location-explorer__article-item:hover{background:var(--surface-alt)}.location-explorer__article-item.highlighted{background:var(--primary-green-light);border-left:4px solid var(--primary-green);padding-left:12px}.location-explorer__article-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}.location-explorer__article-thumbnail{width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;background:var(--surface-alt);display:flex;align-items:center;justify-content:center}.location-explorer__article-thumbnail img{width:100%;height:100%;object-fit:cover}.location-explorer__article-thumbnail .placeholder{color:var(--text-secondary);font-size:26px}.location-explorer__article-content{flex:1;min-width:0}.location-explorer__article-title{font-size:15px;font-weight:600;color:var(--text-color);margin:0 0 6px;line-height:1.3;word-wrap:break-word}.location-explorer__article-extract{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.location-explorer__article-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--text-secondary)}.location-explorer__article-distance{display:flex;align-items:center;gap:4px}.location-explorer__article-distance i{color:var(--primary-green)}.location-explorer__article-actions{display:flex;align-items:center;gap:8px;margin-top:12px}.location-explorer__article-compact{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color .2s ease}.location-explorer__article-compact:last-child{border-bottom:none}.location-explorer__article-compact:hover{background:var(--surface-alt)}.location-explorer__article-compact.highlighted{background:var(--primary-green-light);border-left:3px solid var(--primary-green);padding-left:9px}.location-explorer__article-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#0645ad;color:#fff;font-size:12px;flex-shrink:0}.location-explorer__article-info{display:flex;flex-direction:column;flex:1;min-width:0;gap:2px}.location-explorer__article-compact .location-explorer__article-title{font-size:14px;font-weight:500;color:var(--text-color);margin:0;line-height:1.3;word-wrap:break-word}.location-explorer__article-compact .location-explorer__article-distance{font-size:11px;color:var(--text-secondary)}.location-explorer__article-compact .location-explorer__article-actions{display:flex;gap:4px;margin:0}.location-explorer__article-compact .ps-btn--icon{width:28px;height:28px;padding:0;border-radius:4px;display:flex;align-items:center;justify-content:center}.location-explorer__wider-search{padding:24px 16px;text-align:center;border-top:1px solid var(--border-color);background:var(--surface-alt)}.location-explorer__wider-search p{margin:0 0 12px;color:var(--text-secondary);font-size:13px}.location-explorer__wider-search i{margin-right:6px}.location-explorer__footer{padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.location-explorer__footer .ps-btn{width:100%}.location-explorer-photo-marker{background:var(--primary-green);color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 8px #0000004d;cursor:pointer;transition:all .2s ease;font-size:16px}.location-explorer-photo-marker:hover,.location-explorer-photo-marker.highlighted{transform:scale(1.15);background:var(--dark-green);box-shadow:0 4px 12px #0006;z-index:1000}.location-explorer-article-marker{background:#0645ad;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:16px;border:2px solid white;box-shadow:0 2px 8px #0006;transition:all .2s ease;cursor:pointer}.location-explorer-article-marker:hover{transform:scale(1.15);z-index:1000;box-shadow:0 4px 12px #00000080}.location-explorer-article-marker.highlighted{background:var(--warning-color);transform:scale(1.2);z-index:1001;box-shadow:0 4px 16px #ff980099}.location-explorer-marker-popup{min-width:220px;max-width:280px}.location-explorer-marker-popup__header{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-weight:600;color:var(--text-color);font-size:14px}.location-explorer-marker-popup__header i{color:var(--primary-green);font-size:16px}.location-explorer-marker-popup__image{width:100%;max-height:160px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:10px;cursor:pointer;transition:opacity .2s}.location-explorer-marker-popup__image:hover{opacity:.9}.location-explorer-marker-popup__title{font-size:13px;font-weight:500;color:var(--text-color);margin-bottom:6px;line-height:1.3}.location-explorer-marker-popup__description{font-size:12px;color:var(--text-secondary);margin-bottom:12px;line-height:1.4}.location-explorer-marker-popup__actions{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:768px){.location-explorer{width:100%;max-width:400px}.location-explorer__photo-item{flex-direction:column}.location-explorer__photo-thumbnail{width:100%;height:200px}.location-explorer__photo-actions{flex-direction:column}.location-explorer__photo-actions .ps-btn{width:100%}.location-explorer__article-actions{flex-direction:column}.location-explorer__article-actions .ps-btn{width:100%}}body.dark-mode .location-explorer{background:var(--sidebar-bg);border-right-color:var(--border-color)}body.dark-mode .location-explorer__tab{background:var(--bg-color);border-color:var(--border-color)}body.dark-mode .location-explorer-photo-marker,body.dark-mode .location-explorer-article-marker{border-color:var(--bg-color)}@media(prefers-color-scheme:dark){.location-explorer{background:var(--sidebar-bg);border-right-color:var(--border-color)}.location-explorer__tab{background:var(--bg-color);border-color:var(--border-color)}.location-explorer-photo-marker,.location-explorer-article-marker{border-color:var(--bg-color)}}.help-mode-icon{display:none;align-items:center;justify-content:center;width:18px;height:18px;padding:0;margin-left:6px;background:#ff9800;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;box-shadow:0 0 8px #ff980099,0 0 16px #ff98004d;transition:transform .2s ease,box-shadow .2s ease;vertical-align:middle;flex-shrink:0}.help-mode-icon i{font-size:11px}.help-mode-icon:hover{transform:scale(1.15);box-shadow:0 0 12px #ff9800,0 0 24px #ff980099}.help-mode-icon:focus{outline:2px solid #ff9800;outline-offset:2px}body.help-mode-active .help-mode-icon{display:inline-flex;animation:helpIconAppear .3s ease-out}@keyframes helpIconAppear{0%{opacity:0;transform:scale(.5);box-shadow:0 0 #ff980000}to{opacity:1;transform:scale(1);box-shadow:0 0 8px #ff980099,0 0 16px #ff98004d}}.help-mode-indicator{position:fixed;bottom:70px;right:20px;display:none;align-items:center;gap:10px;padding:10px 16px;background:#ff9800;color:#fff;border-radius:24px;box-shadow:0 4px 16px #ff980066,0 0 20px #ff98004d;z-index:10001;font-size:14px;font-weight:500;animation:slideInUp .3s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.help-mode-indicator-content{display:flex;align-items:center;gap:10px}.help-mode-indicator-content>i{font-size:20px}.help-mode-indicator-text{display:flex;flex-direction:column;line-height:1.2}.help-mode-indicator-text span{font-weight:600}.help-mode-indicator-text small{font-size:11px;opacity:.9;font-weight:400}.help-mode-indicator button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;margin-left:4px;background:#fff3;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .2s ease}.help-mode-indicator button:hover{background:#ffffff4d}.help-mode-indicator button i{font-size:14px}body.help-mode-active .help-mode-indicator{display:flex}.help-mode-checkmark{margin-left:auto;color:#ff9800;font-weight:700}body.dark-mode .help-mode-icon{background:#ffb74d;box-shadow:0 0 8px #ffb74d99,0 0 16px #ffb74d4d}body.dark-mode .help-mode-indicator{background:#ffb74d;color:#1a1a1a;box-shadow:0 4px 16px #ffb74d66,0 0 20px #ffb74d4d}.footer-tools-btn .help-mode-icon,.footer-download-btn .help-mode-icon,.footer-info-btn .help-mode-icon{background:#fff;color:#ff9800;width:16px;height:16px;margin-left:4px;box-shadow:0 0 6px #ff980080}.footer-tools-btn .help-mode-icon i,.footer-download-btn .help-mode-icon i,.footer-info-btn .help-mode-icon i{font-size:10px}.footer-tools-btn .help-mode-icon:hover,.footer-download-btn .help-mode-icon:hover,.footer-info-btn .help-mode-icon:hover{background:#fff3e0;box-shadow:0 0 10px #ff9800cc,0 2px 6px #0003}.ps-modal__title .help-mode-icon{margin-left:8px}.footer-tools-option-title .help-mode-icon,.footer-download-option-title .help-mode-icon{width:14px;height:14px;margin-left:6px;vertical-align:middle}.footer-tools-option-title .help-mode-icon i,.footer-download-option-title .help-mode-icon i{font-size:9px}.leaflet-control-layers+.help-mode-icon,.leaflet-control-zoom+.help-mode-icon{position:absolute;right:-24px;top:50%;transform:translateY(-50%)}.footer-help-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;margin-right:8px;background:#ffffff26;border:1px solid rgba(255,152,0,.5);border-radius:50%;color:#ff9800;font-size:18px;cursor:pointer;transition:all .2s ease}.footer-help-btn:hover{background:#ff980033;border-color:#ff9800;box-shadow:0 0 12px #ff980080;transform:translateY(-1px)}body.help-mode-active .footer-help-btn{background:#ff9800;color:#fff;border-color:#ff9800;box-shadow:0 0 16px #ff980099,0 0 24px #ff98004d;animation:helpBtnPulse 2s ease-in-out infinite}@keyframes helpBtnPulse{0%,to{box-shadow:0 0 16px #ff980099,0 0 24px #ff98004d}50%{box-shadow:0 0 20px #ff9800cc,0 0 32px #ff980080}}@media(max-width:768px){.help-mode-indicator{bottom:80px;right:10px;left:10px;justify-content:center;border-radius:20px}.help-mode-icon{width:22px;height:22px;font-size:14px}.help-mode-icon i{font-size:13px}.footer-tools-btn .help-mode-icon,.footer-download-btn .help-mode-icon,.footer-info-btn .help-mode-icon{display:none!important}.footer-help-btn{width:32px;height:32px;font-size:16px;margin-right:6px}}
