*{margin:0;padding:0;box-sizing:border-box}:root{--bg-color:#f5f5f5;--bg-secondary:#ffffff;--text-color:#333;--text-secondary:#666;--text-tertiary:#999;--border-color:#e0e0e0;--shadow:rgba(0,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;--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:#ff9800;--elevation-warning-bg:#fff3e0;--link-color:#4caf50;--warning-color:#ff9800;--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,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;--info-section-bg:#2d2d2d;--info-section-border:#404040;--side-left-color:#42a5f5;--side-right-color:#ffa726;--elevation-warning-bg:#3a2a1a;--link-color:#66bb6a;--warning-color:#ffa726;--danger-color:#ef5350}}body.light-mode{--bg-color:#f5f5f5;--bg-secondary:#ffffff;--text-color:#333;--text-secondary:#666;--text-tertiary:#999;--border-color:#e0e0e0;--shadow:rgba(0,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;--info-section-bg:#f8f9fa;--info-section-border:#e0e0e0;--side-left-color:#2196f3;--side-right-color:#ff9800;--elevation-warning-bg:#fff3e0;--link-color:#4caf50;--warning-color:#ff9800;--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,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;--info-section-bg:#2d2d2d;--info-section-border:#404040;--side-left-color:#42a5f5;--side-right-color:#ffa726;--elevation-warning-bg:#3a2a1a;--link-color:#66bb6a;--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}.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:6px;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 rgba(76,175,80,.3)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px rgba(76,175,80,.3)}.btn-secondary{background:0 0;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:rgba(76,175,80,.05)}.btn-secondary:active:not(:disabled){background:rgba(76,175,80,.1)}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#b71c1c;transform:translateY(-1px);box-shadow:0 2px 8px rgba(211,47,47,.3)}.btn-danger:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px rgba(211,47,47,.3)}.btn-icon{width:36px;height:36px;padding:0;background:0 0;border:1px solid var(--border-color)}.btn-icon:hover:not(:disabled){border-color:var(--primary-green);color:var(--primary-green);background:rgba(76,175,80,.05)}.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;top:45px;left:0;right:0;bottom:0;overflow-x:visible;overflow-y:hidden;z-index:1}#map{width:100%;height:100%;z-index:1}.sidebar-overlay{position:absolute!important;top:0!important;left:0!important;right:auto!important;bottom:38px!important;width:350px!important;max-height:none!important;height:auto!important;background:var(--bg-color);box-shadow:2px 0 12px rgba(0,0,0,.15);z-index:100;transition:transform 150ms ease!important;overflow:hidden!important;display:block!important;padding:6px 20px 0 20px;box-sizing:border-box}.sidebar-overlay.collapsed{transform:translateX(-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 rgba(0,0,0,.15);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:left 150ms ease,transform 150ms ease;z-index:150;opacity:.9;color:#333}.sidebar-toggle-tab:hover{background:var(--hover-bg,#f0f0f0);opacity:1;box-shadow:2px 0 12px rgba(0,0,0,.2)}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 150ms 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:translateX(-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:fixed;top:15px;left:15px;width:44px;height:44px;background:var(--bg-color);border:2px solid var(--border-color);border-radius:8px;align-items:center;justify-content:center;cursor:pointer;z-index:1100;box-shadow:0 2px 8px var(--shadow);transition:left 150ms ease,all .3s ease}body.sidebar-collapsed .sidebar-toggle{left:15px}.sidebar-toggle:hover{background:var(--hover-bg,#f0f0f0);border-color:#4caf50;box-shadow:0 4px 12px rgba(76,175,80,.3)}.sidebar-toggle svg{width:24px;height:24px;stroke:var(--text-color);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}body.dark-mode .sidebar-toggle{background:var(--card-bg)}body.dark-mode .sidebar-toggle:hover{background:#66bb6a;border-color:#66bb6a}body.dark-mode .sidebar-toggle:hover svg{stroke:#1a1a1a}}.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:1000;isolation:isolate}header.compact{padding:8px 20px}header.compact h1{font-size:16px;margin-bottom:0}header.compact .tagline{display:none}.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:rgba(0,0,0,.9);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 rgba(0,0,0,.3)}#projectNameText[data-full-name]:hover::before{content:'';position:absolute;bottom:100%;left:10px;border:5px solid transparent;border-top-color:rgba(0,0,0,.9);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:rgba(0,0,0,.9);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 rgba(0,0,0,.3);pointer-events:none}#projectNameSubtitleText[data-full-name]:hover::before{content:'';position:absolute;top:100%;left:10px;border:5px solid transparent;border-bottom-color:rgba(0,0,0,.9);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;top:0;left:0;right:0;bottom: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 rgba(220,53,69,.3);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 rgba(244,67,54,.4)}.landing-language-selector{position:absolute;top:15px;right:20px;z-index:10001;display:flex;align-items:center;gap:.5rem}.landing-language-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;color:#fff;backdrop-filter:blur(10px)}.landing-language-btn:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.5);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}#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-selector{top:8px}header.compact .landing-language-btn{padding:.35rem .8rem}.language-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.1);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.2);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:0 0;border:none;cursor:pointer;transition:background .2s ease;font-size:14px;text-align:left;color:#333}.language-dropdown-item:hover{background:rgba(76,175,80,.1)}.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:#4caf50;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:rgba(76,175,80,.1)}.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{from{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:8px;padding:20px 20px 0 20px;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:translateX(-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:8px;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:#2e7d32;transform:scale(1.05);box-shadow:0 4px 16px rgba(46,125,50,.3)}.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:#2e7d32}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}}.arrow-icon,.hamburger-icon{transition:all .3s ease;position:absolute}body.sidebar-collapsed .hamburger-icon{opacity:0;transform:scale(.8)}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:8px;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}.elevation-container{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-radius:0;padding:0;box-shadow:0 -2px 12px rgba(0,0,0,.15);display:none;z-index:90;transition:left 150ms ease,transform 150ms 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:20px;left:auto;width:220px}.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:6px 6px 0 0;box-shadow:0 -2px 8px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 150ms ease;z-index:91;opacity:.9}.elevation-toggle-icon svg{transition:transform 150ms ease}.elevation-toggle-icon:hover{opacity:1;box-shadow:0 -2px 12px rgba(0,0,0,.2);transform:translateY(-2px)}.elevation-container.collapsed .elevation-toggle-icon{right:80px}body.dark-mode .elevation-toggle-icon:hover{background:#66bb6a;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:6px 6px 0 0;box-shadow:0 -2px 8px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 150ms ease;z-index:91;opacity:.9;color:var(--text-secondary);padding:0}.elevation-map-sync-btn:hover{opacity:1;box-shadow:0 -2px 12px rgba(0,0,0,.2);transform:translateY(-2px)}.elevation-map-sync-btn:active{transform:translateY(0)}.elevation-map-sync-btn.active{background:#ff9800;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:#66bb6a;color:#1a1a1a}body.dark-mode .elevation-map-sync-btn.active{background:#ff9800;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 150ms 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 #4caf50;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:#4caf50}.elevation-mini-stat.descent{border-left-color:#03a9f4}.elevation-mini-stat.max{border-left-color:#4caf50}.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:6px;padding:6px;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 150ms ease;overflow:hidden;box-sizing:border-box}.elevation-mini-chart-container:hover{border-color:#66bb6a;box-shadow:0 2px 8px rgba(102,187,106,.2);transform:translateY(-1px)}.elevation-mini-chart-container canvas{display:block;pointer-events:none;max-width:100%;max-height:100%}.elevation-content{padding:10px 20px 10px 20px;transition:max-height 250ms ease,padding 250ms 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-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:6px;border-left:4px solid #4caf50}.elevation-stat-card.distance{border-left-color:#2196f3}.elevation-stat-card.gain{border-left-color:#4caf50}.elevation-stat-card.descent{border-left-color:#03a9f4}.elevation-stat-card.max{border-left-color:#4caf50}.elevation-stat-card.min{border-left-color:#2196f3}.elevation-stat-card.avg-grade{border-left-color:#607d8b}.elevation-stat-card.steepest{border-left-color:#1976d2}.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:6px;padding:10px;border:2px solid var(--border-color);margin-bottom:0}.elevation-chart-wrapper canvas{cursor:crosshair;position:relative;z-index:1}.elevation-crosshair{position:absolute;top:0;bottom:0;width:2px;background:rgba(33,150,243,.6);pointer-events:none;display:none;z-index:100}.elevation-crosshair-label{position:absolute;top:-25px;left:50%;transform:translateX(-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 150ms 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:#ff9800;stroke-width:1.5}.elevation-poi-tooltip{position:absolute;background:var(--sidebar-bg);border:2px solid var(--border-color);border-radius:6px;padding:8px 12px;font-size:12px;white-space:nowrap;pointer-events:none;display:none;z-index:100;box-shadow:0 4px 12px rgba(0,0,0,.2)}.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:6px;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:#4caf50;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:6px;border-left:3px solid #4caf50;flex:1;min-width:140px}.elevation-stat-card.descent{border-left-color:#2196f3}.elevation-stat-card.max{border-left-color:#4caf50}.elevation-stat-card.min{border-left-color:#2196f3}.elevation-stat-card.avg-grade{border-left-color:#607d8b}.elevation-stat-card.steepest{border-left-color:#1976d2}.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:rgba(255,152,0,.6);height:100%}.elevation-crosshair-tooltip{position:absolute;background:rgba(0,0,0,.85);color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;white-space:nowrap;pointer-events:none;transform:translate(-50%,-100%);margin-top:-10px;box-shadow:0 2px 8px rgba(0,0,0,.3)}body.dark-mode .elevation-crosshair-tooltip{background:rgba(255,255,255,.95);color:#1a1a1a}.elevation-grade-label{position:absolute;background:rgba(244,67,54,.9);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:rgba(255,152,0,.9)}.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,#2e7d32 0,#1976d2 100%);opacity:0;transition:opacity .3s ease}.option-card:hover{border-color:#2e7d32;transform:translateY(-4px);box-shadow:0 12px 32px rgba(46,125,50,.15)}.option-card:hover::before{opacity:1}body.dark-mode .option-card:hover{box-shadow:0 12px 32px rgba(102,187,106,.2)}.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:#2e7d32}body.dark-mode .option-card:hover .icon-mono svg{stroke:#66bb6a}.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::after,.option-divider::before{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}.additional-options-wrapper{max-height:0;overflow:hidden;opacity:0;transition:max-height .4s ease,opacity .3s ease}.additional-options-wrapper.expanded{max-height:2000px;opacity:1}.show-more-options-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 20px;margin:24px 0;background:var(--card-bg);border:2px dashed var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.show-more-options-btn::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(46,125,50,.05) 0,rgba(25,118,210,.05) 100%);opacity:0;transition:opacity .3s ease}.show-more-options-btn:hover::before{opacity:1}.show-more-options-btn:hover{border-color:#2e7d32;color:#2e7d32;transform:translateY(-1px);box-shadow:0 4px 12px rgba(46,125,50,.15)}body.dark-mode .show-more-options-btn:hover{border-color:#66bb6a;color:#66bb6a;box-shadow:0 4px 12px rgba(102,187,106,.2)}.show-more-options-btn svg{transition:transform .3s ease}.show-more-options-btn.expanded svg{transform:rotate(180deg)}.show-more-options-btn .btn-text-more{display:inline}.show-more-options-btn .btn-text-less{display:none}.show-more-options-btn.expanded .btn-text-more{display:none}.show-more-options-btn.expanded .btn-text-less{display:inline}.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}.landing-help-link{display:inline-flex;align-items:center;gap:12px;padding:14px 28px;background:rgba(76,175,80,.08);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:rgba(76,175,80,.15);border-color:var(--link-color);transform:translateY(-2px);box-shadow:0 4px 12px rgba(76,175,80,.2)}.landing-help-link svg{flex-shrink:0;stroke:currentColor}body.dark-mode .landing-help-link{background:rgba(102,187,106,.1);border-color:rgba(102,187,106,.3);color:#66bb6a}body.dark-mode .landing-help-link:hover{background:rgba(102,187,106,.18);border-color:#66bb6a;box-shadow:0 4px 12px rgba(102,187,106,.25)}.upload-hint{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:8px 14px;background:rgba(46,125,50,.08);border-radius:6px;font-size:13px;color:#2e7d32;font-weight:500}body.dark-mode .upload-hint{background:rgba(102,187,106,.12);color:#66bb6a}body.dark-mode .option-card{background:var(--card-bg);border-color:var(--border-color)}body.dark-mode .option-card:hover{border-color:#66bb6a}body.dark-mode .option-card::before{background:linear-gradient(90deg,#66bb6a 0,#64b5f6 100%)}body.dark-mode .btn-primary{background:linear-gradient(135deg,#388e3c 0,#4caf50 100%)}body.dark-mode .btn-primary:hover{background:linear-gradient(135deg,#2e7d32 0,#388e3c 100%);box-shadow:0 4px 12px rgba(102,187,106,.35)}body.dark-mode .btn-secondary{background:linear-gradient(135deg,#1976d2 0,#42a5f5 100%)}body.dark-mode .btn-secondary:hover{background:linear-gradient(135deg,#1565c0 0,#1976d2 100%);box-shadow:0 4px 12px rgba(66,165,245,.35)}body.dark-mode .upload-icon{color:#66bb6a}@media (prefers-color-scheme:dark){.option-card{background:var(--card-bg);border-color:var(--border-color)}.option-card:hover{border-color:#66bb6a}.option-card::before{background:linear-gradient(90deg,#66bb6a 0,#64b5f6 100%)}.btn-primary{background:linear-gradient(135deg,#388e3c 0,#4caf50 100%)}.btn-primary:hover{background:linear-gradient(135deg,#2e7d32 0,#388e3c 100%);box-shadow:0 4px 12px rgba(102,187,106,.35)}.btn-secondary{background:linear-gradient(135deg,#1976d2 0,#42a5f5 100%)}.btn-secondary:hover{background:linear-gradient(135deg,#1565c0 0,#1976d2 100%);box-shadow:0 4px 12px rgba(66,165,245,.35)}.upload-icon{color:#66bb6a}.upload-hint{background:rgba(102,187,106,.12);color:#66bb6a}input[type=text]:focus{border-color:#66bb6a;box-shadow:0 0 0 3px rgba(102,187,106,.15)}}.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;top:0;left:0;right:0;bottom: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:#2e7d32;background:linear-gradient(to bottom,rgba(46,125,50,.05),rgba(46,125,50,.1));transform:translateY(-2px);box-shadow:0 8px 24px rgba(46,125,50,.12)}body.dark-mode .file-upload:hover{background:linear-gradient(to bottom,rgba(102,187,106,.08),rgba(102,187,106,.15));box-shadow:0 8px 24px rgba(102,187,106,.15)}.file-upload.dragover{border-color:#2e7d32;background:#e8f5e9;transform:scale(1.02);box-shadow:0 8px 32px rgba(46,125,50,.2)}body.dark-mode .file-upload.dragover{background:#2a4a2a}.upload-icon{font-size:32px;color:#2e7d32;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 auto;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 rgba(76,175,80,.3)}.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}.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:50px;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-description,.workflow-card-side .card-list li,.workflow-card-side .card-title{color:#666}body.dark-mode .workflow-card-side .card-description,body.dark-mode .workflow-card-side .card-list li,body.dark-mode .workflow-card-side .card-title{color:#999}@media (prefers-color-scheme:dark){.workflow-card-side .card-description,.workflow-card-side .card-list li,.workflow-card-side .card-title{color:#999}}.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-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%,100%{transform:translateX(0);opacity:1}50%{transform:translateX(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}.workflow-steps-container{flex-direction:column;align-items:center;margin-bottom:2rem;gap:.75rem}.workflow-card-center,.workflow-card-side{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%,100%{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:8px;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:rgba(255,255,255,.2);transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease}.btn:active::before{width:300px;height:300px}.btn-primary{background:linear-gradient(135deg,#2e7d32 0,#388e3c 100%);color:#fff;box-shadow:0 2px 8px rgba(46,125,50,.25)}.btn-primary:hover{background:linear-gradient(135deg,#1b5e20 0,#2e7d32 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(46,125,50,.35)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,#1976d2 0,#2196f3 100%);color:#fff;box-shadow:0 2px 8px rgba(25,118,210,.25)}.btn-secondary:hover{background:linear-gradient(135deg,#1565c0 0,#1976d2 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(25,118,210,.35)}.btn-secondary:active{transform:translateY(0)}.btn-danger{background:#d32f2f;color:#fff}.btn-danger:hover{background:#c62828}.btn-outline{background:var(--button-bg);color:#2e7d32;border:1px solid #2e7d32}.btn-outline:hover{background:#2e7d32;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:0;border-color:#2e7d32;box-shadow:0 0 0 3px rgba(46,125,50,.1)}body.dark-mode input[type=text]:focus{border-color:#66bb6a;box-shadow:0 0 0 3px rgba(102,187,106,.15)}input[type=number]:focus,select:focus{outline:0;border-color:#2e7d32;box-shadow:0 0 0 3px rgba(46,125,50,.1)}.slider-container{display:flex;flex-direction:column;gap:0}.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:6px;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:#2e7d32}.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:0;-webkit-appearance:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer}input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2e7d32;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:0;cursor:pointer;background:linear-gradient(to right,#c8e6c9 0,#81c784 50%,#4caf50 100%)}#searchRadius::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;box-shadow:0 2px 4px rgba(0,0,0,.2)}#searchRadius::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;border:none;box-shadow:0 2px 4px rgba(0,0,0,.2)}#poiCountLimitSlider{flex:1;height:6px;border-radius:3px;outline:0;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%,#4caf50 100%)}#poiCountLimitSlider:enabled::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;box-shadow:0 2px 4px rgba(0,0,0,.2)}#poiCountLimitSlider:enabled::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;border:none;box-shadow:0 2px 4px rgba(0,0,0,.2)}#poiCountLimitSlider:disabled::-moz-range-thumb,#poiCountLimitSlider:disabled::-webkit-slider-thumb{background:#ccc;cursor:not-allowed}#categoryCountSlider{flex:1;height:6px;border-radius:3px;outline:0;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%,#4caf50 100%)}#categoryCountSlider:enabled::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;box-shadow:0 2px 4px rgba(0,0,0,.2)}#categoryCountSlider:enabled::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;border:none;box-shadow:0 2px 4px rgba(0,0,0,.2)}#categoryCountSlider:disabled::-moz-range-thumb,#categoryCountSlider:disabled::-webkit-slider-thumb{background:#ccc;cursor:not-allowed}body.dark-mode #searchRadius{background:linear-gradient(to right,#454545,#2e7d32)}body.dark-mode #poiCountLimitSlider:enabled{background:linear-gradient(to right,#454545,#2e7d32)}body.dark-mode #categoryCountSlider:enabled{background:linear-gradient(to right,#454545,#2e7d32)}input[type=checkbox]{width:18px;height:18px;min-width:18px;min-height:18px;cursor:pointer;accent-color:#4caf50;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 #666;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:#4caf50}body.dark-mode input[type=checkbox]:checked::after{content:'';position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid #4caf50;border-width:0 2px 2px 0;transform:rotate(45deg)}body.dark-mode input[type=checkbox]:focus{outline:2px solid #4caf50;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 #666;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:#4caf50}body:not(.light-mode) input[type=checkbox]:checked::after{content:'';position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid #4caf50;border-width:0 2px 2px 0;transform:rotate(45deg)}body:not(.light-mode) input[type=checkbox]:focus{outline:2px solid #4caf50;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:8px;padding:12px;display:flex;gap:10px;align-items:center;border-left:3px solid #4caf50;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:#1976d2}.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:6px;padding:10px;border-left:3px solid #4caf50}.segment-item.steep-climb{border-left-color:#2e7d32}.segment-item.climb{border-left-color:#4caf50}.segment-item.steep-descent{border-left-color:#1976d2}.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-category-groups{display:flex;flex-direction:column;gap:8px;margin-top:1px}.poi-group{border:1px solid var(--border-color);border-radius:6px;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:rgba(46,125,50,.1)}body.dark-mode .poi-group-header:hover{background:rgba(76,175,80,.15)}.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}.category-label svg,.poi-group-icon svg{width:16px;height:16px}.category-label svg path:not([fill]),.poi-group-icon svg path:not([fill]){fill:none;stroke:var(--text-color);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.category-label svg:not(:has(path[fill])),.poi-group-icon 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:#2e7d32;padding:4px 8px;border-radius:3px;background:var(--button-bg);border:1px solid #2e7d32;cursor:pointer;transition:all .2s}.poi-group-toggle-all:hover{background:#2e7d32;color:#fff}body.dark-mode .poi-group-toggle-all{color:#66bb6a;border-color:#66bb6a}body.dark-mode .poi-group-toggle-all:hover{background:#66bb6a;color:#1a1a1a}.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 rgba(0,0,0,.15);border-radius:6px;border:1px solid var(--border-color);display:flex;flex-direction:column}body.dark-mode .poi-section-overlay{box-shadow:0 2px 12px rgba(0,0,0,.4)}.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:hidden}.poi-section-overlay.minimized .poi-list{flex:1;min-height:0;max-height:none;overflow-y:auto}.poi-section-overlay:not(.minimized){position:absolute;top:0;left:0;right:0;bottom: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:hidden;display:flex;flex-direction:column;background:var(--sidebar-bg)}.poi-section-overlay.hidden{display:none!important}.sidebar-sections-container::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0);pointer-events:none;transition:background .3s ease;z-index:5}.sidebar-sections-container.poi-expanded::before{background:rgba(0,0,0,.05)}body.dark-mode .sidebar-sections-container.poi-expanded::before{background:rgba(0,0,0,.15)}.sidebar-sections-container.poi-expanded #searchSection{pointer-events:none}.category-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 8px;border-radius:4px;transition:background .2s;min-height:28px}.category-item:hover{background:rgba(46,125,50,.1)}body.dark-mode .category-item:hover{background:rgba(76,175,80,.15)}.category-item input[type=checkbox]{margin-right:8px}.category-label{cursor:pointer;user-select:none;flex:1;line-height:1.3}.edit-distance-btn{flex-shrink:0;opacity:.6;color:#666;transition:opacity .2s,color .2s}.edit-distance-btn:hover{opacity:1;color:#1976d2!important}.edit-distance-btn.has-custom-distance{opacity:1;color:#1976d2!important}body.dark-mode .edit-distance-btn{color:#999}body.dark-mode .edit-distance-btn.has-custom-distance{color:#1976d2!important}.category-poi-count-badge{display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--text-secondary);background:rgba(46,125,50,.1);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:rgba(76,175,80,.15);border-color:rgba(76,175,80,.4)}.category-poi-count-badge:not([data-count="0"]){color:#2e7d32;background:rgba(46,125,50,.15);border-color:rgba(46,125,50,.4)}body.dark-mode .category-poi-count-badge:not([data-count="0"]){color:#66bb6a;background:rgba(76,175,80,.2);border-color:rgba(76,175,80,.5)}.category-poi-count-badge[data-count="0"]{opacity:.3}.viewport-filter-btn{background:0 0;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:#4caf50;background:rgba(76,175,80,.1)}.viewport-filter-btn.active i::before{content:"\f341"}body.dark-mode .viewport-filter-btn.active{color:#66bb6a;background:rgba(76,175,80,.15)}.batch-elevation-btn{background:0 0;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:0 0;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:8px;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:rgba(46,125,50,.1);border-color:#2e7d32}body.dark-mode .quick-action-btn:hover{background:rgba(76,175,80,.15);border-color:#66bb6a}.quick-action-btn-reset{background:#1976d2;color:#fff;border-color:#1976d2}.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:#1976d2;border-color:#1976d2}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:#2e7d32;color:#2e7d32}body.dark-mode .preset-btn:hover{background:#1e3a1e!important;border-color:#4caf50;color:#66bb6a}.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:0 0;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:6px;cursor:pointer;transition:all .2s}.preset-item:hover{background:rgba(25,118,210,.05);border-color:#1976d2;transform:translateX(4px)}body.dark-mode .preset-item:hover{background:rgba(25,118,210,.1)}.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:0 0;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}.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:6px;text-align:center}.stat-value{font-size:24px;font-weight:600;color:#2e7d32;display:block}body.dark-mode .stat-value{color:#66bb6a}.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-category-section{margin-bottom:15px}.poi-category-header{display:flex;justify-content:space-between;align-items:center;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-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:rgba(46,125,50,.1)}body.dark-mode .poi-item:hover{background:rgba(76,175,80,.15)}.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:#2e7d32;font-weight:500}body.dark-mode .poi-distance{color:#66bb6a}.poi-actions{display:flex;gap:5px}.poi-action-btn{background:0 0;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 #4caf50;padding:8px 12px;display:none;flex-direction:column;gap:6px;z-index:100;box-shadow:0 -2px 10px rgba(0,0,0,.1)}body.dark-mode .poi-selection-footer{box-shadow:0 -2px 10px rgba(0,0,0,.3)}.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:#4caf50;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:#4caf50;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 rgba(0,0,0,.15)}.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:#4caf50;color:#fff}.poi-selection-action-btn.keep:not(:disabled):hover{background:#2e7d32}@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:20px;right:20px;padding:15px 20px;border-radius:4px;box-shadow:0 2px 10px rgba(0,0,0,.2);z-index:9999;display:none;animation:slideIn .3s;display:flex;align-items:center;gap:10px;pointer-events:none}.message.error,.message.info,.message.success,.message.warning{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{from{transform:translateX(400px);opacity:0}to{transform:translateX(0);opacity:1}}.message.success{background:#4caf50;color:#fff}.message.error{background:#f44336;color:#fff}.message.warning{background:#ff9800;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 #2e7d32;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 10px}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.filter-controls{display:flex;gap:10px;margin-bottom:10px;flex-shrink:0}.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:#2e7d32;color:#fff;border-color:#2e7d32}.sidebar-tab-bar{display:flex;gap:4px;padding:8px;background:var(--card-bg);border-radius:8px;margin-bottom:16px}.sidebar-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:0 0;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);position:relative;transition:all .2s ease}.sidebar-tab:hover:not(.active){background:rgba(0,0,0,.05);color:var(--text-color)}body.dark-mode .sidebar-tab:hover:not(.active){background:rgba(255,255,255,.05)}.sidebar-tab.active{background:var(--primary-green);color:#fff;box-shadow:0 2px 8px rgba(76,175,80,.3)}body.dark-mode .sidebar-tab.active{background:var(--primary-green);box-shadow:0 2px 8px rgba(76,175,80,.4)}.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}.poi-section-static-header .section-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-color)}@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:translateX(-50%);background:#333;color:#fff;padding:12px 20px;border-radius:4px;box-shadow:0 2px 10px rgba(0,0,0,.3);display:none;z-index:10000;animation:slideUp .3s}@keyframes slideUp{from{transform:translateX(-50%) translateY(100px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}@keyframes darkness-pulse{0%,100%{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:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;margin-left:10px;font-size:12px}.undo-btn:hover{background:#45a049}.modal{display:none;position:fixed;z-index:10001;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);animation:fadeIn .3s}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.progress-modal-content{background-color:var(--sidebar-bg);margin:15% auto;padding:20px;border-radius:8px;width:90%;max-width:320px;box-shadow:0 4px 20px rgba(0,0,0,.3);animation:slideDown .3s;text-align:center}.progress-spinner{width:60px;height:60px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center}#bicycleWheelSpinner,#queryBicycleWheelSpinner{width:100%;height:100%;animation:spin 2.5s linear infinite;display:block}.progress-spinner.complete #bicycleWheelSpinner,.progress-spinner.complete #queryBicycleWheelSpinner{display:none}.progress-spinner.complete{border:none;font-size:48px;color:#4caf50;font-weight:700;animation:none}.progress-title{font-size:16px;font-weight:600;margin-bottom:10px;line-height:1.3;color:var(--text-color)}.progress-status{font-size:13px;color:var(--text-secondary);margin-bottom:0;min-height:18px;line-height:1.4}.progress-bar-container{width:100%;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:10px}.progress-bar{height:100%;background:linear-gradient(90deg,#2e7d32,#4caf50);transition:width .3s ease;border-radius:4px}.progress-details{font-size:12px;color:var(--text-tertiary)}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.modal-content{background-color:var(--sidebar-bg);margin:10% auto;padding:25px;border-radius:8px;width:90%;max-width:450px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 4px 20px rgba(0,0,0,.3);animation:slideDown .3s;color:var(--text-color)}@keyframes slideDown{from{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{font-size:20px;font-weight:600;margin-bottom:20px;color:var(--text-color);display:flex;align-items:center;gap:10px;flex-shrink:0;position:relative}.modal-header svg{width:20px;height:20px;flex-shrink:0;vertical-align:middle;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.modal-title{flex:1;font-size:18px;font-weight:600;color:var(--text-color)}.modal-close-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);width:28px;height:28px;background:var(--button-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.modal-close-btn:hover{background:var(--button-hover);border-color:#2e7d32}.modal-close-btn i{font-size:14px;color:var(--text-color)}#customDistanceCategory{font-size:16px!important;line-height:1.5;display:flex;align-items:center;gap:8px;color:var(--text-color)}#customDistanceCategory svg{width:18px;height:18px;vertical-align:middle;flex-shrink:0;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.modal-body{margin-bottom:20px;overflow-y:auto;flex:1 1 auto;min-height:0}.modal-field{margin-bottom:15px}.modal-field label{display:block;margin-bottom:5px;font-weight:500;color:var(--text-secondary);font-size:14px}.modal-field input[type=text]{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;box-sizing:border-box;background:var(--input-bg);color:var(--text-color)}.modal-field input[type=text]:focus{outline:0;border-color:#2e7d32}.modal-location{font-size:12px;color:var(--text-secondary);background:var(--card-bg);padding:8px;border-radius:4px;font-family:monospace}.type-selector{display:flex;gap:10px}.type-option{flex:1;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)}.type-option:hover{border-color:var(--text-tertiary)}.type-option.selected{border-width:2px}.type-option.info.selected{background:#e3f2fd;border-color:#2196f3;color:#1976d2}body.dark-mode .type-option.info.selected{background:#1a3a4a;border-color:#64b5f6;color:#64b5f6}.type-option.alert.selected{background:#e3f2fd;border-color:#1976d2;color:#1565c0}body.dark-mode .type-option.alert.selected{background:#1a3a4a;border-color:#64b5f6;color:#64b5f6}.type-option.danger.selected{background:#ffebee;border-color:#f44336;color:#c62828}body.dark-mode .type-option.danger.selected{background:#3a1a1a;border-color:#ef5350;color:#ef5350}.type-option.event-sticker.selected{background:#f3e5f5;border-color:#9c27b0;color:#6a1b9a}body.dark-mode .type-option.event-sticker.selected{background:#2a1a3a;border-color:#ba68c8;color:#ba68c8}.modal-footer{display:flex;gap:10px;justify-content:flex-end;flex-shrink:0}.modal-btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.modal-btn-primary{background:#2e7d32;color:#fff}.modal-btn-primary:hover{background:#1b5e20}.modal-btn-secondary{background:var(--button-bg);color:var(--text-color);border:1px solid var(--border-color)}.modal-btn-secondary:hover{background:var(--button-hover)}.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 #2e7d32}.services-section.optional h4{border-left-color:#1976d2}.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:6px;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:6px;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 #1976d2;border-radius:4px;font-size:11px;color:var(--text-secondary);line-height:1.5}.services-attribution a{color:#1976d2;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}.gradient-legend{display:flex;align-items:center;gap:15px;padding:10px;background:var(--card-bg);border-radius:4px;margin-top:10px;font-size:12px}.legend-item{display:flex;align-items:center;gap:5px}.legend-color{width:20px;height:12px;border-radius:2px}.distance-marker-icon{background:0 0!important;border:none!important}.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:#66bb6a}body.dark-mode .leaflet-popup-close-button{color:#e0e0e0!important}body.dark-mode .leaflet-popup-close-button:hover{color:#fff!important}.leaflet-control-layers,.leaflet-control-zoom{background:#f8f9fa!important;border:1px solid rgba(0,0,0,.2)!important;box-shadow:0 2px 6px rgba(0,0,0,.1)!important}.leaflet-control-layers-toggle,.leaflet-control-zoom a{background-color:#fff!important;color:#333!important;border-bottom:1px solid rgba(0,0,0,.1)!important}.leaflet-control-layers-toggle:hover,.leaflet-control-zoom a:hover{background-color:#f0f0f0!important}.leaflet-control-zoom{z-index:1000}.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-bar,body.dark-mode .leaflet-control-attribution,body.dark-mode .leaflet-control-layers,body.dark-mode .leaflet-control-scale,body.dark-mode .leaflet-control-zoom{background:#2a2a2a!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px rgba(0,0,0,.3)!important}body.dark-mode .leaflet-bar a,body.dark-mode .leaflet-control-layers-toggle,body.dark-mode .leaflet-control-zoom a{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-bar a:hover,body.dark-mode .leaflet-control-layers-toggle:hover,body.dark-mode .leaflet-control-zoom a:hover{background-color:#404040!important;background-image:none!important}body.dark-mode .leaflet-bar a:active,body.dark-mode .leaflet-control-layers-toggle:active,body.dark-mode .leaflet-control-zoom a:active{background-color:#4a4a4a!important;background-image:none!important}body.dark-mode .leaflet-bar a:focus,body.dark-mode .leaflet-control-layers-toggle:focus,body.dark-mode .leaflet-control-zoom a:focus{outline:2px solid rgba(255,255,255,.3)!important;outline-offset:-2px!important}body.dark-mode .leaflet-control-zoom-in.leaflet-disabled,body.dark-mode .leaflet-control-zoom-out.leaflet-disabled,body.dark-mode .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-line{background:rgba(42,42,42,.8)!important;border:2px solid rgba(255,255,255,.3)!important;color:#e0e0e0!important}.leaflet-control-scale{bottom:60px!important}.leaflet-control-zoom-level{background:#fff;border:2px solid rgba(0,0,0,.2);border-radius:4px;padding:4px 8px;font-size:11px;font-weight:600;color:#333;box-shadow:0 1px 5px rgba(0,0,0,.1);margin-top:2px;line-height:1.4}body.dark-mode .leaflet-control-zoom-level{background:var(--card-bg);color:var(--text-color);border-color:var(--border-color)}.leaflet-control-map-features{background:#fff;border:2px solid rgba(0,0,0,.2);border-radius:4px;box-shadow:0 1px 5px rgba(0,0,0,.1);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 rgba(0,0,0,.3)!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:rgba(255,152,0,.3)!important;border-left:4px solid #ff9800!important}.map-feature-btn:disabled{opacity:.4;cursor:not-allowed}.query-poi-marker .poi-marker-circle{background-color:#ff9800!important;opacity:.85}.query-poi-marker:hover .poi-marker-circle{background-color:#f57c00!important}.query-results-section{background:linear-gradient(135deg,#fff8f0 0,#fff 100%);border:2px solid #ff9800;border-radius:8px;margin-bottom:16px;padding:16px;flex:1;display:flex;flex-direction:column;overflow-y:auto;min-height:0}.marker-cluster-small{background-color:rgba(110,204,57,.6)}.marker-cluster-small div{background-color:rgba(110,204,57,.8)}.marker-cluster-medium{background-color:rgba(255,196,0,.6)}.marker-cluster-medium div{background-color:rgba(255,196,0,.8)}.marker-cluster-large{background-color:rgba(253,156,115,.6)}.marker-cluster-large div{background-color:rgba(253,156,115,.8)}.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:rgba(76,175,80,.6)}body.dark-mode .marker-cluster-small div{background-color:rgba(76,175,80,.8)}body.dark-mode .marker-cluster-medium{background-color:rgba(255,152,0,.6)}body.dark-mode .marker-cluster-medium div{background-color:rgba(255,152,0,.8)}body.dark-mode .marker-cluster-large{background-color:rgba(244,67,54,.6)}body.dark-mode .marker-cluster-large div{background-color:rgba(244,67,54,.8)}body.dark-mode .query-results-section{background:linear-gradient(135deg,#2a2420 0,#1e1e1e 100%);border-color:#ff9800}@media (prefers-color-scheme:dark){body:not(.light-mode) .query-results-section{background:linear-gradient(135deg,#2a2420 0,#1e1e1e 100%);border-color:#ff9800}}.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:#ff9800}.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 #4caf50;background:0 0;color:#4caf50;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.query-action-btn:hover{background:#4caf50;color:#fff;transform:translateY(-1px)}.query-action-btn i{font-size:1rem}body.dark-mode .query-action-btn{border-color:#66bb6a;color:#66bb6a}body.dark-mode .query-action-btn:hover{background:#66bb6a;color:#1a1a1a}@media (prefers-color-scheme:dark){body:not(.light-mode) .query-action-btn{border-color:#66bb6a;color:#66bb6a}body:not(.light-mode) .query-action-btn:hover{background:#66bb6a;color:#1a1a1a}}.query-category-group{margin-bottom:12px}.query-category-group h4{font-size:.95rem;margin:8px 0 6px 0;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:6px;margin-bottom:4px;transition:all .2s;cursor:pointer}.query-poi-item:hover{background:var(--surface-alt);border-color:#ff9800;box-shadow:0 2px 8px rgba(255,152,0,.2)}.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:0 0;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}@media (prefers-color-scheme:dark){.elevation-crosshair-tooltip{background:rgba(255,255,255,.95);color:#1a1a1a}.file-upload:hover{background:linear-gradient(to bottom,rgba(102,187,106,.08),rgba(102,187,106,.15));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:rgba(76,175,80,.15)}.quick-action-btn:hover{background:rgba(76,175,80,.15);border-color:#66bb6a}.quick-action-btn-reset{background:#1976d2;border-color:#1976d2}.quick-action-btn-reset:hover{background:#1565c0;border-color:#1565c0}.preset-btn:hover{background:#1e3a1e;border-color:#4caf50;color:#66bb6a;transform:translateY(-1px)}.preset-btn:active{background:#2a4a2a;transform:translateY(0)}.stat-value{color:#66bb6a}.poi-distance{color:#90caf9}.progress-spinner{border-color:rgba(255,255,255,.1);border-top-color:#66bb6a}.type-option.info.selected{background:rgba(33,150,243,.2)}.type-option.alert.selected{background:rgba(255,152,0,.2)}.type-option.danger.selected{background:rgba(244,67,54,.2)}.leaflet-popup-content-wrapper{background-color:#2a2a2a;color:var(--text-color)}body.dark-mode .leaflet-popup-content-wrapper{background-color:#2a2a2a}.leaflet-popup-tip{background-color:#2a2a2a}body.dark-mode .leaflet-popup-tip{background-color:#2a2a2a}.leaflet-popup-content{color:var(--text-color)}.leaflet-popup-content a{color:#66bb6a}.leaflet-popup-close-button{color:#e0e0e0!important}.leaflet-popup-close-button:hover{color:#fff!important}.leaflet-bar,.leaflet-control-attribution,.leaflet-control-layers,.leaflet-control-scale,.leaflet-control-zoom{background:#2a2a2a!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px rgba(0,0,0,.3)!important}.leaflet-bar a,.leaflet-control-layers-toggle,.leaflet-control-zoom a{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-bar a:hover,.leaflet-control-layers-toggle:hover,.leaflet-control-zoom a:hover{background-color:#404040!important;background-image:none!important}.leaflet-bar a:active,.leaflet-control-layers-toggle:active,.leaflet-control-zoom a:active{background-color:#4a4a4a!important;background-image:none!important}.leaflet-bar a:focus,.leaflet-control-layers-toggle:focus,.leaflet-control-zoom a:focus{outline:2px solid rgba(255,255,255,.3)!important;outline-offset:-2px!important}.leaflet-control-zoom-in.leaflet-disabled,.leaflet-control-zoom-out.leaflet-disabled,.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:rgba(42,42,42,.8)!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 rgba(0,0,0,.3)!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}.landing-language-selector{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{from{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.gradient-legend{flex-direction:column;align-items:flex-start;gap:8px}.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:15px}.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:#1976d2;border:2px solid #1976d2;border-radius:5px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.footer-info-btn:hover{background:#1976d2;border-color:#000;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(25,118,210,.4)}.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:6px;box-shadow:0 4px 12px rgba(0,0,0,.15);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:6px 6px 0 0}.footer-info-option:last-child{border-radius:0 0 6px 6px}.footer-info-option:hover{background:rgba(76,175,80,.15)}body.dark-mode .footer-info-option:hover{background:rgba(76,175,80,.15)}.footer-info-option-icon{font-size:16px;color:var(--text-secondary)}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-stats-group{display:flex;align-items:center;gap:2px;background:rgba(255,255,255,.05);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:rgba(255,255,255,.1);border-radius:3px;transition:all .2s ease}.footer-stat-item.clickable{cursor:pointer;padding:7px 12px;border:1px solid #2e7d32;background:rgba(255,255,255,.15);transition:all .2s ease}.footer-stat-item.clickable:hover{background:rgba(46,125,50,.2);border-color:#4caf50;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%,100%{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))}100%{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:0 0;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%,100%{transform:scale(1);filter:drop-shadow(0 0 8px #ff9800)}50%{transform:scale(1.2);filter:drop-shadow(0 0 16px #ff9800)}}.poi-marker-highlighted>div>svg path{fill:#ff9800!important}.poi-item.active{background:rgba(76,175,80,.2)!important;border-left:4px solid #4caf50;padding-left:8px}body.dark-mode .poi-item.active{background:rgba(76,175,80,.25)!important}.footer-actions{display:flex;align-items:center;gap:9px}.footer-download-container{position:relative}.footer-tools-container{position:relative}.footer-tools-btn{display:flex;align-items:center;gap:5px;padding:7px 10px;background:rgba(255,255,255,.15);border:1px solid #2e7d32;border-radius:3px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.footer-tools-btn:hover{background:rgba(46,125,50,.2);border-color:#4caf50;transform:translateY(-1px);box-shadow:0 2px 8px rgba(76,175,80,.3)}.footer-tools-btn svg{width:15px;height:15px;fill:white;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:rgba(255,255,255,.15);border:1px solid #2e7d32;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:rgba(46,125,50,.2);border-color:#4caf50;transform:translateY(-1px);box-shadow:0 2px 8px rgba(76,175,80,.3);z-index:1}#undoBtn:hover:not(:disabled){border-right-color:rgba(76,175,80,.6)}.footer-undo-redo-btn:disabled{opacity:.3;cursor:not-allowed;background:rgba(255,255,255,.05);border-color:rgba(46,125,50,.3)}#undoBtn:disabled{border-right-color:rgba(46,125,50,.3)}.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:6px;box-shadow:0 4px 16px var(--shadow);min-width:240px;display:none;z-index:1000}.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:rgba(46,125,50,.1)}body.dark-mode .footer-tools-option:hover{background:rgba(76,175,80,.15)}.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:rgba(46,125,50,.15)}body.dark-mode .footer-tools-option.submenu-item:hover{background:rgba(76,175,80,.2)}#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}.saved-projects-section{margin-bottom:20px;padding:12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px}.saved-projects-section h4{margin:0 0 16px 0;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:6px;padding:8px;margin-bottom:0;cursor:pointer;transition:all .2s ease;height:auto;min-height:45px}.saved-project-card:hover{background:rgba(46,125,50,.1);border-color:#4caf50;transform:translateX(2px)}body.dark-mode .saved-project-card:hover{background:rgba(76,175,80,.15)}.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:#4caf50;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:0 0;border:none;color:#4caf50;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:#66bb6a}@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:6px;padding:16px;margin-bottom:12px;transition:all .2s ease}.project-item:hover{background:rgba(46,125,50,.1);border-color:#4caf50}body.dark-mode .project-item:hover{background:rgba(76,175,80,.15)}.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:rgba(76,175,80,.15);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:#4caf50;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:rgba(255,193,7,.1);border:1px solid rgba(255,193,7,.3);border-radius:6px;padding:12px;margin-bottom:16px;font-size:13px;color:var(--text-color)}.project-warning-box strong{display:block;margin-bottom:4px;color:#ffc107}.project-summary-box{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:6px;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:#1976d2;border:2px solid #1976d2;border-radius:3px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.footer-download-btn:hover{background:#1976d2;border-color:#000;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(25,118,210,.4)}.footer-download-btn svg{width:14px;height:14px;stroke:white;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.footer-download-btn:hover svg{stroke:white}.footer-download-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:6px;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:rgba(46,125,50,.1)}.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}body.dark-mode .footer-download-option:hover{background:rgba(76,175,80,.15)}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:rgba(255,255,255,.15);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:rgba(255,255,255,.3)}.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)}.poi-stats-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:10001;align-items:center;justify-content:center}.poi-stats-modal.active{display:flex}.poi-stats-modal-content{background:var(--sidebar-bg);border-radius:12px;padding:14px 16px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.3)}.poi-stats-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.poi-stats-modal-title{font-size:18px;font-weight:600;color:var(--text-color)}.poi-stats-modal-close{width:28px;height:28px;background:var(--button-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.poi-stats-modal-close:hover{background:var(--button-hover);border-color:#2e7d32}.poi-stats-modal-close svg{width:16px;height:16px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.poi-stats-warning{background:#fff3e0;border-left:3px solid #ff9800;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 #2e7d32}.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}.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:0 0;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}.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:6px;background:var(--card-bg);color:var(--text-color);font-size:14px;transition:all .2s ease}.search-location-input:focus{outline:0;border-color:var(--link-color);box-shadow:0 0 0 3px rgba(76,175,80,.1)}.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}.search-location-results{margin-top:16px;padding:12px;background:var(--card-bg);border-radius:6px;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:6px;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:6px;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 #4caf50;border-radius:6px;color:#2e7d32;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-details,.search-location-result-item.highlighted .search-location-result-name{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:6px;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:rgba(76,175,80,.1);border-color:var(--link-color)}.search-action-show{color:#ff9800;border-color:#ff9800}.search-action-show:hover{background:rgba(255,152,0,.1);border-color:#ff9800}.copy-coords-btn{padding:6px 10px;background:0 0;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:rgba(255,255,255,.5);color:#fff}.search-location-result-item.highlighted .copy-coords-btn:hover{background:rgba(255,255,255,.2);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:6px;border:1px solid var(--border-color)}.radius-toggle-btn{width:100%;padding:10px 12px;background:0 0;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:0;-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:6px;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:0;-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:0 0}.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 #fff;box-shadow:0 2px 6px rgba(0,0,0,.3);transition:all .2s ease}.search-preview-marker-inner i{transform:rotate(45deg);color:#fff;font-size:14px}.search-preview-marker-inner:hover{background:#1976d2;transform:rotate(-45deg) scale(1.1);box-shadow:0 4px 12px rgba(33,150,243,.5)}.distance-markers-modal-body{padding:8px 0}.distance-markers-description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin-bottom:20px;padding:0}.distance-markers-input-group{margin-bottom:20px}.distance-markers-combined-row{display:flex;gap:16px;align-items:flex-end;justify-content:space-between}.distance-markers-interval-section{flex:0 1 200px;min-width:150px}.distance-markers-unit-section{flex:0 1 auto}.distance-markers-label{display:block;font-size:14px;font-weight:500;color:var(--text-color);margin-bottom:8px}.distance-markers-input{width:100%;padding:10px 12px;background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-size:14px;transition:all .2s ease}.distance-markers-input:focus{outline:0;border-color:#2e7d32;box-shadow:0 0 0 3px rgba(46,125,50,.1)}.distance-markers-unit-buttons{display:flex;gap:8px}.distance-markers-unit-btn{padding:10px 16px;background:var(--button-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:110px}.distance-markers-unit-btn:hover{background:var(--button-hover);border-color:#2e7d32}.distance-markers-unit-btn.active{background:#2e7d32;border-color:#2e7d32;color:#fff}.distance-markers-preview{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;padding:12px;margin-bottom:20px;display:flex;gap:10px;align-items:flex-start}.distance-markers-preview-icon{font-size:20px;line-height:1;flex-shrink:0}.distance-markers-preview-text{color:var(--text-secondary);font-size:13px;line-height:1.5;flex:1}.distance-markers-preview.has-data{background:rgba(46,125,50,.05);border-color:rgba(46,125,50,.2)}.distance-markers-preview.has-data .distance-markers-preview-text{color:var(--text-color);font-weight:500}.distance-markers-actions{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}.distance-markers-btn{padding:12px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.distance-markers-btn-secondary{background:var(--button-bg);color:var(--text-color);border:1px solid var(--border-color);flex:0 0 auto}.distance-markers-btn-secondary:hover{background:var(--button-hover);border-color:#2e7d32}.distance-markers-btn-primary{background:#2e7d32;color:#fff;flex:1}.distance-markers-btn-primary:hover{background:#1b5e20}.distance-markers-btn-primary:disabled{background:var(--button-bg);color:var(--text-secondary);cursor:not-allowed;border:1px solid var(--border-color)}.distance-markers-btn-danger{background:#d32f2f;color:#fff;flex:1}.distance-markers-btn-danger:hover{background:#b71c1c}@media (max-width:480px){.distance-markers-combined-row{flex-direction:column;gap:16px;align-items:stretch}.distance-markers-interval-section{flex:1 1 auto;min-width:0}.distance-markers-unit-section{flex:1 1 auto}.distance-markers-unit-btn{flex:1;min-width:0}}@media (max-width:768px){.footer-bar{padding:0 9px;height:auto;min-height:38px}.footer-info-btn{padding:5px 7px;font-size:11px}.footer-info-btn span{display:none}.footer-info-container{margin-right:7px}.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}.footer-bar:not(.has-pois) #footerDistance,.footer-bar:not(.has-pois) #footerElevation{display:flex}.footer-bar.has-pois #footerDistance,.footer-bar.has-pois #footerElevation{display:none}.footer-bar.has-pois #footerPOI{display:flex}.footer-bar:not(.has-pois) #footerPOI{display:none}.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-stats-modal-content{padding:12px;width:95%}.poi-stats-grid{grid-template-columns:repeat(2,1fr);gap:6px}.poi-stats-modal-title{font-size:16px}.poi-stats-section-title{font-size:11px}.poi-popup-wrapper{min-width:280px;max-width:95vw;max-height:400px}.poi-popup-content{max-height:300px}.leaflet-popup-content-wrapper{max-height:350px}.poi-info-grid-2col{grid-template-columns:1fr}.poi-name-edit{gap:4px}.poi-popup-input{font-size:16px}.poi-popup-cancel-btn,.poi-popup-save-btn{min-width:36px;padding:8px}.poi-popup-cancel-btn svg,.poi-popup-save-btn svg{width:18px;height:18px}}.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{background-color:var(--sidebar-bg)}.leaflet-popup-tip{background-color:var(--sidebar-bg)}body.dark-mode .leaflet-popup-content-wrapper{background-color:#2a2a2a}body.dark-mode .leaflet-popup-tip{background-color:#2a2a2a}.leaflet-popup{margin-bottom:60px}.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:#1976d2}.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-popup-edit-btn{background:0 0;border:none;cursor:pointer;padding:4px;color:#1976d2;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-cancel-btn,.poi-popup-save-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-cancel-btn svg,.poi-popup-save-btn svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}.poi-popup-save-btn{background:#4caf50;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:#66bb6a}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}.poi-info-section{background:var(--info-section-bg);border:1px solid var(--info-section-border);border-radius:6px;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:#4caf50;font-weight:500}.nearby-poi-far{color:#ff9800;font-weight:500}body.dark-mode .nearby-poi-close{color:#66bb6a}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-delete,.poi-popup-btn-navigate,.poi-popup-btn-osm,.poi-popup-btn-street{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-delete svg,.poi-popup-btn-navigate svg,.poi-popup-btn-osm svg,.poi-popup-btn-street svg{width:13px;height:13px;fill:currentColor;flex-shrink:0}.poi-popup-btn-navigate{background:#1976d2}.poi-popup-btn-navigate:hover{background:#1565c0}.poi-popup-btn-street{background:#4caf50}.poi-popup-btn-street:hover{background:#45a049}.poi-popup-btn-osm{background:#7092ff}.poi-popup-btn-osm:hover{background:#5a7fe6}.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:#66bb6a}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-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:#ff9800;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}@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.reload-confirm-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);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 rgba(0,0,0,.3);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 0;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 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:6px;border-left:3px solid var(--primary-color)}.reload-modal-last-saved i{font-size:14px}.reload-modal-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;gap:6px}.reload-modal-btn i{font-size:15px}.reload-modal-btn-cancel{background:var(--surface-alt);color:var(--text-color);border:1px solid var(--border-color)}.reload-modal-btn-cancel:hover{background:var(--border-color)}.reload-modal-btn-save{background:var(--primary-color);color:#fff}.reload-modal-btn-save:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 8px rgba(46,125,50,.3)}.reload-modal-btn-confirm{background:#f44336;color:#fff}.reload-modal-btn-confirm:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 4px 8px rgba(244,67,54,.3)}@keyframes modalSlideIn{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.poi-tip-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:100000;align-items:center;justify-content:center}.poi-tip-modal.active{display:flex}.poi-tip-modal-content{background:var(--card-bg);border-radius:12px;width:90%;max-width:520px;box-shadow:0 8px 32px rgba(0,0,0,.3);animation:modalSlideIn .3s ease}.poi-tip-modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,#4caf50 0,#2e7d32 100%);border-radius:12px 12px 0 0}.poi-tip-modal-header h3{margin:0;font-size:20px;color:#fff;display:flex;align-items:center;gap:10px}.poi-tip-modal-header i{font-size:24px}.poi-tip-modal-body{padding:24px}.poi-tip-modal-body p{margin:0 0 12px 0;color:var(--text-color);line-height:1.6}.poi-tip-modal-body ul{margin:15px 0 15px 0;padding-left:24px;color:var(--text-color);list-style-type:disc}.poi-tip-modal-body ul li{margin:10px 0;font-size:14px;line-height:1.5}.poi-tip-modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}.poi-tip-modal-btn{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;gap:6px}.poi-tip-modal-btn-dismiss{background:var(--card-bg);color:var(--text-color);border:1px solid var(--border-color)}.poi-tip-modal-btn-dismiss:hover{background:var(--surface-alt);border-color:var(--text-secondary)}.poi-tip-modal-btn-ok{background:#4caf50;color:#fff}.poi-tip-modal-btn-ok:hover{background:#45a049;transform:translateY(-1px);box-shadow:0 4px 8px rgba(76,175,80,.3)}@media (max-width:768px){.poi-tip-modal-content{width:95%;max-width:none;margin:20px}.poi-tip-modal-header{padding:16px 20px}.poi-tip-modal-header h3{font-size:18px}.poi-tip-modal-body{padding:20px}.poi-tip-modal-footer{padding:12px 20px;flex-direction:column}.poi-tip-modal-btn{width:100%;justify-content:center}}@media (max-width:480px){.reload-confirm-modal-content{width:95%;max-width:none}.reload-confirm-modal-body,.reload-confirm-modal-footer,.reload-confirm-modal-header{padding:16px}.reload-confirm-modal-footer{flex-direction:column-reverse}.reload-modal-btn{width:100%;justify-content:center}}.gpx-summary-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--card-bg);padding:12px;border-radius:6px;border:1px solid var(--border-color)}.gpx-summary-stat{display:flex;align-items:center;gap:4px;font-size:11px;padding:0 8px}.gpx-summary-stat:not(:nth-child(3n+1)){border-left:1px solid var(--border-color)}.gpx-summary-stat i{font-size:13px;flex-shrink:0}.gpx-summary-stat .stat-label{color:var(--text-secondary);font-weight:500;white-space:nowrap;font-size:10px;text-transform:uppercase;letter-spacing:.02em}.gpx-summary-stat .stat-value{color:var(--text-color);font-weight:600;margin-left:auto;font-size:11px}@media (max-width:768px){#gpxSummaryModal .modal-content{max-width:95%;margin:20px auto}.gpx-summary-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}}@media (min-width:769px){#gpxSummaryModal .modal-content{max-height:95vh}}.custom-flag-marker{pointer-events:auto!important}.flag-marker-pin{width:30px;height:30px;background:#1976d2;border:2px solid #fff;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px rgba(0,0,0,.4);position:absolute;top:0;left:0}.flag-marker-icon{font-size:16px;line-height:1;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;color:#fff}#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:6px;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)}