*{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,.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,.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,.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,.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}.chart-hover-marker{filter:drop-shadow(0 0 8px rgba(255,107,53,.8)) drop-shadow(0 0 16px rgba(255,107,53,.5))}.bi{color:currentColor;vertical-align:middle;display:inline-block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:var(--spacing-sm) var(--spacing-md);border-radius: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 #4caf504d}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #4caf504d}.btn-secondary{background:transparent;color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){border-color:var(--primary-green);color:var(--primary-green);background:#4caf500d}.btn-secondary:active:not(:disabled){background:#4caf501a}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#b71c1c;transform:translateY(-1px);box-shadow:0 2px 8px #d32f2f4d}.btn-danger:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #d32f2f4d}.btn-icon{width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border-color)}.btn-icon:hover:not(:disabled){border-color:var(--primary-green);color:var(--primary-green);background:#4caf500d}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px;gap:4px}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:15px;gap:8px}.btn-icon.btn-sm{width:28px;height:28px}.btn-icon.btn-lg{width:44px;height:44px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-color);color:var(--text-color);transition:background .3s ease,color .3s ease;padding-top:90px}body:has(.main-content:not(.initial-view)){padding-top:0}.container{max-width:1300px;margin:0 auto;padding:20px}.container:has(.main-content:not(.initial-view)){padding:0;margin:0;max-width:none}.map-view-container{position:fixed;inset:45px 0 0;overflow-x:visible;overflow-y:hidden;z-index:1}#map{width:100%;height:100%;z-index:1}.sidebar-overlay{position:absolute!important;inset:0 auto 38px 0!important;width:350px!important;max-height:none!important;height:auto!important;background:var(--bg-color);box-shadow:2px 0 12px #00000026;z-index:10004;transition:transform .15s ease!important;overflow:hidden!important;display:block!important;padding:6px 20px 0;box-sizing:border-box}.sidebar-overlay.collapsed{transform:translate(-350px)!important}.sidebar-content{height:100%;display:flex;flex-direction:column;overflow:hidden}.sidebar-toggle-tab{position:fixed;left:350px;top:50%;transform:translateY(-50%);width:24px;height:60px;background:var(--bg-color);border:1px solid var(--border-color);border-left:none;border-radius:0 6px 6px 0;box-shadow:2px 0 8px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:left .15s ease,transform .15s ease;z-index:10004;opacity:.9;color:#333}.sidebar-toggle-tab:hover{background:var(--hover-bg, #f0f0f0);opacity:1;box-shadow:2px 0 12px #0003}body.dark-mode .sidebar-toggle-tab{color:#a0a0a0!important}body.dark-mode .sidebar-toggle-tab:hover{background:#404040;color:#f0f0f0}@media(prefers-color-scheme:dark){.sidebar-toggle-tab{color:#a0a0a0}.sidebar-toggle-tab:hover{background:#404040;color:#f0f0f0}}.sidebar-toggle-tab svg{transition:transform .15s ease}body.sidebar-collapsed .sidebar-toggle-tab{left:0!important;transform:translateY(-50%)!important}body:not(.sidebar-collapsed) .sidebar-toggle-tab .arrow-left{display:block}body:not(.sidebar-collapsed) .sidebar-toggle-tab .arrow-right{display:none}body.sidebar-collapsed .sidebar-toggle-tab .arrow-left{display:none}body.sidebar-collapsed .sidebar-toggle-tab .arrow-right{display:block}@media(max-width:768px){.sidebar-overlay{width:100%;bottom:38px!important}.sidebar-overlay.collapsed{transform:translate(-100%)}.sidebar-toggle-tab{display:none!important}}#sidebarOld{display:none!important}.sidebar-toggle{display:none}@media(min-width:769px){.sidebar-toggle,.sidebar-toggle.active{display:none!important}}@media(max-width:768px){.sidebar-toggle.active{display:flex!important;position: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:10004;box-shadow:0 2px 8px var(--shadow);transition:left .15s 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 #4caf504d}.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:10005;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:#000000e6;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:1000;margin-bottom:4px;pointer-events:none;box-shadow:0 2px 8px #0000004d}#projectNameText[data-full-name]:hover:before{content:"";position:absolute;bottom:100%;left:10px;border:5px solid transparent;border-top-color:#000000e6;margin-bottom:-6px;z-index:1000;pointer-events:none}.project-name-display-subtitle{font-size:11px;opacity:.7;font-weight:300;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:22px}#projectNameSubtitleText{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;position:relative}#projectNameSubtitleText[data-full-name]:hover:after{content:attr(data-full-name);position:absolute;top:100%;left:0;background:#000000e6;color:#fff;padding:6px 10px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:1000;margin-top:4px;box-shadow:0 2px 8px #0000004d;pointer-events:none}#projectNameSubtitleText[data-full-name]:hover:before{content:"";position:absolute;top:100%;left:10px;border:5px solid transparent;border-bottom-color:#000000e6;margin-top:-10px;z-index:1001;pointer-events:none}header.compact .project-name-display{font-size:12px;max-width:200px}header.compact .project-name-display i{font-size:14px}header.compact .project-name-display-subtitle{font-size:10px;padding-left:20px}header.compact #headerBackground{opacity:.5}#headerBackground{position:absolute;inset:0;width:100%;height:100%;opacity:1;pointer-events:none;transition:opacity .3s ease;overflow:hidden}header h1,header p{position:relative;z-index:1}header h1{padding-left:55px}h1{font-size:28px;margin-bottom:6px;transition:font-size .3s ease,margin-bottom .3s ease}.tagline{font-size:14px;opacity:.9;transition:opacity .3s ease}.beta-badge{display:inline-flex;align-items:center;justify-content:center;background:#dc3545;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;padding:3px 8px;border-radius:12px;margin-left:8px;vertical-align:middle;text-transform:uppercase;box-shadow:0 2px 4px #dc35454d;transition:all .3s ease}header.compact .beta-badge{font-size:9px;padding:2px 6px;margin-left:6px}body.dark-mode .beta-badge{background:#f44336;box-shadow:0 2px 4px #f4433666}.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:#fff3;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:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 4px 12px #0003}#landingLanguageFlag{font-size:20px;line-height:1;pointer-events:none}#landingLanguageText{font-size:12px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;pointer-events:none}.landing-language-btn .bi-chevron-down{pointer-events:none}header.compact .landing-language-selector{top:8px}header.compact .landing-language-btn{padding:.35rem .8rem}.language-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fffffff2;border:1px solid rgba(0,0,0,.1);border-radius:8px;box-shadow:0 4px 16px #0003;backdrop-filter:blur(10px);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;z-index:10002;min-width:180px;overflow:hidden}.language-dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}.language-dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;background:transparent;border:none;cursor:pointer;transition:background .2s ease;font-size:14px;text-align:left;color:#333}.language-dropdown-item:hover{background:#4caf501a}.language-dropdown-item:not(:last-child){border-bottom:1px solid rgba(0,0,0,.05)}.language-item-flag{font-size:20px;line-height:1;flex-shrink:0}.language-item-name{flex:1;font-weight:500}.language-item-check{color:#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:#4caf501a}.main-content{margin-top:20px;transition:all .3s ease;max-width:100vw;overflow-x:hidden;margin-left:370px;margin-right:20px;width:calc(100vw - 390px)}.main-content.sidebar-collapsed{margin-left:20px;margin-right:20px;width:calc(100vw - 40px)}.main-content.initial-view{display:flex;justify-content:center;align-items:center;min-height:60vh;margin-left:0;margin-right:0;width:auto}@media(max-width:768px){.main-content.initial-view{min-height:auto;padding-top:10px}.project-name-display{display:none!important}}@media(max-width:600px){.clock-time-inputs-row{flex-direction:column!important;gap:8px!important}}.upload-section-wrapper{max-width:1286px;width:100%;background:var(--sidebar-bg);border-radius:12px;padding:24px 32px;box-shadow:0 4px 24px var(--shadow);border:1px solid var(--border-color);transition:box-shadow .3s ease;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.upload-section-wrapper:hover{box-shadow:0 8px 32px var(--shadow)}.option-card:nth-child(3){animation:fadeInUp .6s ease-out .1s both}.option-card:nth-child(5){animation:fadeInUp .6s ease-out .2s both}.option-card:nth-child(7){animation:fadeInUp .6s ease-out .3s both}.feature-list{animation:fadeInUp .6s ease-out .4s both}.sidebar{background:var(--sidebar-bg);border-radius:8px;padding:20px 20px 0;box-shadow:0 2px 10px var(--shadow);max-height:calc(100vh - 165px);height:calc(100vh - 165px);overflow-y:auto;overflow-x:hidden;display:none;transition:all .3s ease;position:fixed;top:90px;left:20px;width:310px;z-index:100;box-sizing:border-box}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:var(--card-bg);border-radius:4px}.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.sidebar.active{display:block}.sidebar.collapsed{transform:translate(-100%);opacity:0;width:0;padding:0;min-width:0;box-shadow:none}.sidebar-toggle{position:absolute;top:5px;left:5px;width:40px;height:40px;background:var(--sidebar-bg);border:2px solid var(--border-color);border-radius: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 #2e7d324d}.sidebar-toggle:active{transform:scale(.95)}.sidebar-toggle.active{display:flex}.sidebar-toggle svg{width:24px;height:24px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.sidebar-toggle:hover svg{stroke:#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}}.hamburger-icon,.arrow-icon{transition:all .3s ease;position:absolute}body.sidebar-collapsed .hamburger-icon,body.sidebar-collapsed .arrow-left{opacity:0;transform:scale(.8)}body.sidebar-collapsed .arrow-right{opacity:1;transform:scale(1)}body:not(.sidebar-collapsed) .hamburger-icon{opacity:0;transform:scale(.8)}body:not(.sidebar-collapsed) .arrow-left{opacity:1;transform:scale(1)}body:not(.sidebar-collapsed) .arrow-right{opacity:0;transform:scale(.8)}.hamburger-icon{opacity:1;transform:scale(1)}.arrow-icon{opacity:0;transform:scale(.8)}.map-section{display:flex;flex-direction:column;gap:5px;display:none;position:relative}.map-section.active{display:flex}.map-container{background:var(--bg-secondary);border-radius: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}.leaflet-container:has(.leaflet-popup){z-index:10003!important}.leaflet-map-pane:has(.leaflet-popup){z-index:1001!important}.elevation-container{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-radius:0;padding:0;box-shadow:0 -2px 12px #00000026;display:none;z-index:90;transition:left .15s ease,transform .15s ease}body:not(.sidebar-collapsed) .elevation-container:not(.collapsed){left:350px}body.sidebar-collapsed .elevation-container:not(.collapsed){left:0}.elevation-container.collapsed{position:fixed;bottom:65px;right:20px;left:auto;width:220px;background:transparent;box-shadow:none}.elevation-toggle-icon{position:absolute;top:-24px;right:20px;width:60px;height:24px;background:var(--bg-color);border:1px solid var(--border-color);border-bottom:none;border-radius:6px 6px 0 0;box-shadow:0 -2px 8px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;z-index:91;opacity:.9}.elevation-toggle-icon svg{transition:transform .15s ease}.elevation-toggle-icon:hover{opacity:1;box-shadow:0 -2px 12px #0003;transform:translateY(-2px)}.elevation-container.collapsed .elevation-toggle-icon{right:80px}body.dark-mode .elevation-toggle-icon:hover{background:#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 #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;z-index:91;opacity:.9;color:var(--text-secondary);padding:0}.elevation-map-sync-btn:hover{opacity:1;box-shadow:0 -2px 12px #0003;transform:translateY(-2px)}.elevation-map-sync-btn:active{transform:translateY(0)}.elevation-map-sync-btn.active{background:#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 .15s ease;box-sizing:border-box}.elevation-mini-view.hidden{display:none}.elevation-mini-stats{flex:1;display:none;gap:8px;align-items:center;flex-wrap:wrap}.elevation-mini-stat{background:var(--card-bg);padding:4px 10px;border-radius:4px;border-left:3px solid #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 .15s ease;overflow:hidden;box-sizing:border-box}.elevation-mini-chart-container:hover{border-color:#66bb6a;box-shadow:0 2px 8px #66bb6a33;transform:translateY(-1px)}.elevation-mini-chart-container canvas{display:block;pointer-events:none;max-width:100%;max-height:100%}.elevation-content{padding:10px 20px;transition:max-height .25s ease,padding .25s ease,opacity .2s ease;opacity:1}.elevation-content.collapsed{max-height:0;overflow:hidden;padding:0;opacity:0}.elevation-content.expanded{max-height:560px;overflow:visible}.elevation-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-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;touch-action:none}.elevation-crosshair{position:absolute;top:0;bottom:0;width:2px;background:#2196f399;pointer-events:none;display:none;z-index:100}.elevation-crosshair-label{position:absolute;top:-25px;left:50%;transform:translate(-50%);background:#2196f3;color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;white-space:nowrap;font-weight:600;z-index:100}.elevation-poi-marker{position:absolute;width:9px;height:12px;transform:translate(-50%,-100%);transform-origin:50% 100%;cursor:pointer;z-index:10;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));transition:transform .15s ease;pointer-events:auto}.elevation-poi-marker svg{position:absolute;top:0;left:0;width:100%;height:100%}.elevation-poi-marker .marker-icon{position:absolute;top:2px;left:0;width:9px;height:6px;display:flex;align-items:center;justify-content:center;font-size:4px;color:#fff;line-height:1;pointer-events:none;z-index:2}.elevation-poi-marker .marker-icon i{display:block;line-height:1}.elevation-poi-marker:hover{transform:translate(-50%,-100%) scale(1.2);z-index:11;filter:drop-shadow(0 3px 6px rgba(0,0,0,.7))}.elevation-poi-marker.highlighted{transform:translate(-50%,-100%) scale(1.3);z-index:1000;filter:drop-shadow(0 0 8px rgba(255,152,0,.8)) drop-shadow(0 3px 6px rgba(0,0,0,.7))}.elevation-poi-marker.highlighted svg path{stroke:#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 #0003}.elevation-poi-tooltip.visible{display:block}.elevation-legend{display:flex;gap:15px;flex-wrap:wrap;justify-content:center;padding:10px;background:var(--card-bg);border-radius: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:#ff980099;height:100%}.elevation-crosshair-tooltip{position:absolute;background:#000000d9;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 #0000004d}body.dark-mode .elevation-crosshair-tooltip{background:#fffffff2;color:#1a1a1a}.elevation-grade-label{position:absolute;background:#f44336e6;color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;pointer-events:none;z-index:5}.elevation-grade-label.moderate{background:#ff9800e6}.elevation-legend{display:flex;gap:15px;margin-top:10px;font-size:11px;color:var(--text-secondary);flex-wrap:wrap}.elevation-legend-item{display:flex;align-items:center;gap:5px}.elevation-legend-color{width:20px;height:12px;border-radius:2px}.section{margin-bottom:15px;flex-shrink:0}.section-title{font-size:16px;font-weight:600;margin-bottom:12px;color:var(--text-color);display:flex;align-items:center;gap:10px}.icon-mono{width:20px;height:20px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.icon-mono svg{width:100%;height:100%;stroke:var(--text-secondary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.section-title .icon-mono svg{stroke:var(--text-color);stroke-width:2.2}.landing-intro{text-align:center;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border-color)}.landing-intro h2{font-size:24px;font-weight:700;color:var(--text-color);margin-bottom:10px;line-height:1.3}.landing-intro p{font-size:14px;color:var(--text-secondary);line-height:1.5;max-width:540px;margin:0 auto}.options-horizontal-container{display:flex;gap:20px;margin-bottom:20px}.option-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;padding:20px;margin-bottom:20px;transition:all .3s ease;position:relative;overflow:hidden;flex:1}.options-horizontal-container .option-card{margin-bottom:0}.option-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#2e7d32,#1976d2);opacity:0;transition:opacity .3s ease}.option-card:hover{border-color:#2e7d32;transform:translateY(-4px);box-shadow:0 12px 32px #2e7d3226}.option-card:hover:before{opacity:1}body.dark-mode .option-card:hover{box-shadow:0 12px 32px #66bb6a33}.option-card-title{font-size:20px;font-weight:600;color:var(--text-color);margin-bottom:8px;display:flex;align-items:center;gap:10px}.option-card-title .emoji{font-size:28px}.option-card-title .icon-mono{width:24px;height:24px;flex-shrink:0}.option-card-title .icon-mono svg{width:100%;height:100%;stroke:var(--text-secondary);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.option-card:hover .icon-mono svg{stroke:#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:before,.option-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 40px);height:1px;background:linear-gradient(to right,transparent,var(--border-color),transparent)}.option-divider:before{left:0}.option-divider:after{right:0}.option-divider-prominent{text-align:center;margin:32px 0 24px;position:relative;font-size:16px;color:var(--primary-green);font-weight:700;letter-spacing:2px}.option-divider-prominent:before,.option-divider-prominent:after{content:"";position:absolute;top:50%;width:calc(50% - 50px);height:2px;background:linear-gradient(to right,transparent,var(--primary-green),transparent)}.option-divider-prominent:before{left:0}.option-divider-prominent:after{right:0}.landing-alternative-options{background:var(--card-bg);border:4px solid var(--primary-green);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px var(--shadow);margin:32px 0;transition:box-shadow .3s ease}.landing-alternative-options:hover{box-shadow:0 4px 12px var(--shadow)}.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-top:32px;margin-bottom:48px;padding-top:32px;border-top:1px dashed var(--border-color)}.feature-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-secondary)}.feature-item .icon{flex-shrink:0;display:flex;align-items:center}.feature-item .icon svg{stroke:var(--text-secondary);transition:stroke .2s ease}.latest-blog-section{margin-top:32px;padding:20px;background:linear-gradient(135deg,#2e7d32,#1976d2);border:1px solid var(--border-color);border-radius:8px;text-align:center}.latest-blog-title{font-size:14px;font-weight:600;color:#fff;margin:0 0 16px;display:flex;align-items:center;justify-content:center;gap:8px}.latest-blog-title i{color:#fff;font-size:16px}.latest-blog-posts{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px}@media(max-width:600px){.latest-blog-posts{grid-template-columns:1fr}}.latest-blog-post{display:flex;flex-direction:column;padding:12px 16px;background:var(--card-bg);border:1px solid var(--border-color);border-left:3px solid var(--primary-green);border-radius:6px;text-decoration:none;text-align:left;transition:all .2s ease}.latest-blog-post:hover{border-color:var(--link-color);border-left-color:var(--primary-green);transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow)}.latest-blog-post-title{font-size:13px;font-weight:600;color:var(--text-color);margin-bottom:6px;line-height:1.4}.latest-blog-post-meta{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;justify-content:flex-start;gap:6px;margin-top:auto}.latest-blog-post-meta i{font-size:11px}.latest-blog-post-separator{opacity:.5}.latest-blog-view-all{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--link-color);text-decoration:none;font-weight:500;transition:color .2s ease}.latest-blog-view-all:hover{color:var(--link-hover)}.latest-blog-view-all i{font-size:11px;transition:transform .2s ease}.latest-blog-view-all:hover i{transform:translate(2px)}@media(max-width:768px){.latest-blog-section{margin-top:24px;padding:16px}.latest-blog-title{font-size:13px}.latest-blog-post{padding:10px 12px}.latest-blog-post-title{font-size:12px}.latest-blog-post-meta{font-size:10px}}.landing-help-link{display:inline-flex;align-items:center;gap:12px;padding:14px 28px;background:#4caf5014;border:2px solid rgba(76,175,80,.3);border-radius:12px;color:var(--link-color);text-decoration:none;font-size:15px;font-weight:500;transition:all .3s ease}.landing-help-link:hover{background:#4caf5026;border-color:var(--link-color);transform:translateY(-2px);box-shadow:0 4px 12px #4caf5033}.landing-help-link svg{flex-shrink:0;stroke:currentColor}body.dark-mode .landing-help-link{background:#66bb6a1a;border-color:#66bb6a4d;color:#66bb6a}body.dark-mode .landing-help-link:hover{background:#66bb6a2e;border-color:#66bb6a;box-shadow:0 4px 12px #66bb6a40}.upload-hint{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:8px 14px;background:#2e7d3214;border-radius:6px;font-size:13px;color:#2e7d32;font-weight:500}body.dark-mode .upload-hint{background:#66bb6a1f;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,#64b5f6)}body.dark-mode .btn-primary{background:linear-gradient(135deg,#388e3c,#4caf50)}body.dark-mode .btn-primary:hover{background:linear-gradient(135deg,#2e7d32,#388e3c);box-shadow:0 4px 12px #66bb6a59}body.dark-mode .btn-secondary{background:linear-gradient(135deg,#1976d2,#42a5f5)}body.dark-mode .btn-secondary:hover{background:linear-gradient(135deg,#1565c0,#1976d2);box-shadow:0 4px 12px #42a5f559}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,#64b5f6)}.btn-primary{background:linear-gradient(135deg,#388e3c,#4caf50)}.btn-primary:hover{background:linear-gradient(135deg,#2e7d32,#388e3c);box-shadow:0 4px 12px #66bb6a59}.btn-secondary{background:linear-gradient(135deg,#1976d2,#42a5f5)}.btn-secondary:hover{background:linear-gradient(135deg,#1565c0,#1976d2);box-shadow:0 4px 12px #42a5f559}.upload-icon{color:#66bb6a}.upload-hint{background:#66bb6a1f;color:#66bb6a}input[type=text]:focus{border-color:#66bb6a;box-shadow:0 0 0 3px #66bb6a26}}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none}.collapse-icon{font-size:12px;transition:transform .3s}.collapse-icon.collapsed{transform:rotate(-90deg)}.file-upload{border:3px dashed var(--border-color);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--card-bg);position:relative;overflow:hidden}.file-upload:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(46,125,50,.03) 100%);opacity:0;transition:opacity .3s ease}.file-upload:hover:before{opacity:1}.file-upload:hover{border-color:#2e7d32;background:linear-gradient(to bottom,#2e7d320d,#2e7d321a);transform:translateY(-2px);box-shadow:0 8px 24px #2e7d321f}body.dark-mode .file-upload:hover{background:linear-gradient(to bottom,#66bb6a14,#66bb6a26);box-shadow:0 8px 24px #66bb6a26}.file-upload.dragover{border-color:#2e7d32;background:#e8f5e9;transform:scale(1.02);box-shadow:0 8px 32px #2e7d3233}body.dark-mode .file-upload.dragover{background:#2a4a2a}.upload-icon{font-size:32px;color:#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;background:linear-gradient(135deg,var(--card-bg) 0%,var(--bg-secondary) 100%);border:2px solid var(--primary-green);border-radius:12px;padding:1.25rem 1.5rem;box-shadow:0 4px 12px var(--shadow);display:flex;align-items:flex-start;gap:1rem}.intro-icon{flex-shrink:0;width:50px;height:50px;background:var(--primary-green);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 8px #4caf504d}.intro-icon i{font-size:24px;color:#fff}.intro-content{flex:1}.intro-content p{margin:0;font-size:.95rem;line-height:1.5;color:var(--text-color);text-align:left}.workflow-steps-container{display:flex;align-items:stretch;justify-content:center;gap:1rem;margin-bottom:4rem}.workflow-card-side{flex:0 0 340px;max-width:340px;min-width:340px}.workflow-card-center{flex:0 0 391px;max-width:391px;min-width:391px}.workflow-card{background:var(--card-bg);border:1px solid var(--border-color);border-left:4px solid var(--primary-green);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px var(--shadow);transition:transform .3s ease,box-shadow .3s ease}.workflow-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px var(--shadow)}.workflow-card-center{border:4px solid var(--primary-green)}.workflow-card-side:last-of-type{border-left:1px solid var(--border-color);border-right:4px solid var(--primary-green)}.card-icon{width:60px;height:60px;background:var(--primary-green);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;transition:transform .3s ease}.card-icon:hover{transform:scale(1.1)}.card-icon i{font-size:28px;color:#fff}.card-title{font-size:1.3rem;font-weight:600;margin-bottom:.6rem;color:var(--text-color);text-align:center}.card-description{font-size:1rem;margin-bottom:1rem;opacity:.85;text-align:center;line-height:1.5}.card-list{list-style:none;padding:0;margin-bottom:0}.card-list li{font-size:.9rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.card-list li:last-child{margin-bottom:0}.card-list li i{color:var(--primary-green);font-size:1rem;flex-shrink:0}.workflow-card-side .card-title,.workflow-card-side .card-description,.workflow-card-side .card-list li{color:#666}body.dark-mode .workflow-card-side .card-title,body.dark-mode .workflow-card-side .card-description,body.dark-mode .workflow-card-side .card-list li{color:#999}@media(prefers-color-scheme:dark){.workflow-card-side .card-title,.workflow-card-side .card-description,.workflow-card-side .card-list li{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-card-clickable{cursor:pointer;transition:background-color .2s ease,transform .2s ease;border-radius:8px;padding:.5rem;margin:-.5rem}.workflow-card-clickable:hover{background-color:#4caf500d}body.dark-mode .workflow-card-clickable:hover{background-color:#4caf5014}.workflow-card-clickable:active{transform:scale(.98)}.workflow-card-clickable .upload-btn{position:relative;z-index:1;cursor:pointer}.workflow-card-clickable .upload-btn:hover{transform:scale(1.05)}.workflow-arrow{color:var(--primary-green);font-size:3rem;align-self:flex-end;margin-bottom:65px;flex-shrink:0;animation:pulseArrow 2s ease-in-out infinite}.workflow-arrow-mobile{display:none}@keyframes pulseArrow{0%,to{transform:translate(0);opacity:1}50%{transform:translate(8px);opacity:.7}}@media(max-width:1250px){.intro-section{padding:1rem 1.25rem;margin-bottom:1.75rem}.intro-content p{font-size:.9rem}.upload-section-wrapper{padding:24px 20px}.workflow-steps-container{gap:.75rem}.workflow-card-side{flex:0 0 280px;max-width:280px;min-width:280px}.workflow-card-center{flex:0 0 322px;max-width:322px;min-width:322px}.workflow-arrow{font-size:2.5rem;margin-bottom:55px}.workflow-card{padding:1.25rem}.card-illustration{width:150px;height:110px}.card-icon{width:50px;height:50px}.card-icon i{font-size:24px}.card-title{font-size:1.15rem}.card-description{font-size:.9rem}.card-list li{font-size:.85rem}}@media(max-width:1100px){.workflow-card-side{flex:0 0 250px;max-width:250px;min-width:250px}.workflow-card-center{flex:0 0 288px;max-width:288px;min-width:288px}.workflow-arrow{font-size:2.25rem}.workflow-card{padding:1rem}.card-illustration{width:130px;height:95px}.card-icon{width:45px;height:45px}.card-icon i{font-size:22px}.card-title{font-size:1.05rem}.card-description{font-size:.85rem}.card-list li{font-size:.8rem}}@media(max-width:950px){.workflow-card-side{flex:0 0 220px;max-width:220px;min-width:220px}.workflow-card-center{flex:0 0 253px;max-width:253px;min-width:253px}.workflow-arrow{font-size:2rem}.workflow-card{padding:.875rem}.card-illustration{width:110px;height:80px}.card-icon{width:40px;height:40px}.card-icon i{font-size:20px}.card-title{font-size:.95rem}.card-description{font-size:.8rem}.card-list li{font-size:.75rem}}@media(max-width:768px){.intro-section{flex-direction:column;align-items:center;text-align:center;padding:1rem;margin-bottom:1.5rem;gap:.75rem}.intro-icon{width:45px;height:45px}.intro-icon i{font-size:22px}.intro-content p{font-size:.9rem;line-height:1.5;text-align:center}.workflow-steps-container{flex-direction:column;align-items:center;margin-bottom:2rem;gap:.75rem}.workflow-card-side,.workflow-card-center{max-width:100%;width:100%}.workflow-card{padding:1rem}.workflow-arrow{display:none}.workflow-arrow-mobile{display:block!important;color:var(--primary-green);font-size:1.5rem;margin:.25rem auto;text-align:center;animation:pulseArrowMobile 2s ease-in-out infinite}@keyframes pulseArrowMobile{0%,to{transform:translateY(0);opacity:1}50%{transform:translateY(8px);opacity:.7}}.card-illustration{display:none}.card-icon{width:50px;height:42px;margin-bottom:.8rem}.card-icon i{font-size:24px}.card-title{font-size:1.2rem;margin-bottom:.5rem}.card-description{font-size:.95rem;margin-bottom:.8rem}.card-list li{font-size:.85rem;margin-bottom:.4rem}}.btn{padding:10px 20px;border:none;border-radius: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:#fff3;transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease}.btn:active:before{width:300px;height:300px}.btn-primary{background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;box-shadow:0 2px 8px #2e7d3240}.btn-primary:hover{background:linear-gradient(135deg,#1b5e20,#2e7d32);transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3259}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,#1976d2,#2196f3);color:#fff;box-shadow:0 2px 8px #1976d240}.btn-secondary:hover{background:linear-gradient(135deg,#1565c0,#1976d2);transform:translateY(-2px);box-shadow:0 4px 12px #1976d259}.btn-secondary:active{transform:translateY(0)}.btn-danger{background:#d32f2f;color:#fff}.btn-danger:hover{background:#c62828}.btn-outline{background:var(--button-bg);color:#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:none;border-color:#2e7d32;box-shadow:0 0 0 3px #2e7d321a}body.dark-mode input[type=text]:focus{border-color:#66bb6a;box-shadow:0 0 0 3px #66bb6a26}input[type=number]:focus,select:focus{outline:none;border-color:#2e7d32;box-shadow:0 0 0 3px #2e7d321a}.slider-container{display:flex;flex-direction:column;gap:0px}.slider-controls{display:flex;align-items:center;gap:10px}.slider-arrow{flex-shrink:0;width:32px;height:32px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-primary);border-radius: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:none;-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:none;cursor:pointer;background:linear-gradient(to right,#c8e6c9,#81c784,#4caf50)}#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 #0003}#searchRadius::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}#poiCountLimitSlider{flex:1;height:6px;border-radius:3px;outline:none;transition:opacity .2s}#poiCountLimitSlider:disabled{opacity:.3;cursor:not-allowed;background:var(--border-color)}#poiCountLimitSlider:enabled{cursor:pointer;background:linear-gradient(to right,#c8e6c9,#81c784,#4caf50)}#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 #0003}#poiCountLimitSlider:enabled::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}#poiCountLimitSlider:disabled::-webkit-slider-thumb,#poiCountLimitSlider:disabled::-moz-range-thumb{background:#ccc;cursor:not-allowed}#categoryCountSlider{flex:1;height:6px;border-radius:3px;outline:none;transition:opacity .2s}#categoryCountSlider:disabled{opacity:.3;cursor:not-allowed;background:var(--border-color)}#categoryCountSlider:enabled{cursor:pointer;background:linear-gradient(to right,#c8e6c9,#81c784,#4caf50)}#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 #0003}#categoryCountSlider:enabled::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2e7d32;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}#categoryCountSlider:disabled::-webkit-slider-thumb,#categoryCountSlider:disabled::-moz-range-thumb{background:#ccc;cursor:not-allowed}body.dark-mode #searchRadius{background:linear-gradient(to right,#454545,#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 #666666;border-radius:3px;background-color:#2a2a2a;cursor:pointer;position:relative;vertical-align:middle;transition:all .2s ease;flex-shrink:0}body.dark-mode input[type=checkbox]:hover{border-color:#888;background-color:#333}body.dark-mode input[type=checkbox]:checked{background-color:#3a3a3a;border-color:#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 #666666;border-radius:3px;background-color:#2a2a2a;cursor:pointer;position:relative;vertical-align:middle;transition:all .2s ease;flex-shrink:0}body:not(.light-mode) input[type=checkbox]:hover{border-color:#888;background-color:#333}body:not(.light-mode) input[type=checkbox]:checked{background-color:#3a3a3a;border-color:#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-categories-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.poi-categories-header>label{margin:0;flex-shrink:0}.category-search-container{display:flex;align-items:center;gap:4px}.category-search-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .2s}.category-search-toggle:hover{background:#2e7d321a;color:var(--primary-color)}.category-search-toggle.active{color:var(--primary-color)}.category-search-input-wrapper{display:flex;align-items:center;width:0;overflow:hidden;opacity:0;transition:width .25s ease,opacity .2s ease}.category-search-input-wrapper.expanded{width:160px;opacity:1}.category-search-input{flex:1;min-width:0;height:28px;padding:4px 28px 4px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:12px;background:var(--card-bg);color:var(--text-color);outline:none;transition:border-color .2s}.category-search-input:focus{border-color:var(--primary-color)}.category-search-input::placeholder{color:var(--text-tertiary)}.category-search-clear{position:absolute;right:4px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;border-radius:2px;opacity:0;transition:opacity .2s,color .2s}.category-search-input-wrapper.expanded .category-search-clear.visible{opacity:1}.category-search-clear:hover{color:var(--text-color)}.category-search-input-wrapper{position:relative}.poi-group.category-search-hidden,.poi-category-item.category-search-hidden{display:none!important}.poi-category-item.category-search-match .category-name{font-weight:600}.category-search-no-results{padding:16px;text-align:center;color:var(--text-secondary);font-size:13px;display:none}.category-search-no-results.visible{display:block}.poi-search-container{display:flex;align-items:center;position:relative}.poi-search-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:4px;transition:all .2s}.poi-search-toggle:hover{background:#2e7d321a;color:var(--primary-color)}.poi-search-toggle.active{color:var(--primary-color)}.poi-search-input-wrapper{position:absolute;right:100%;display:flex;align-items:center;width:0;overflow:hidden;opacity:0;transition:width .25s ease,opacity .2s ease;margin-right:4px}.poi-search-input-wrapper.expanded{width:140px;opacity:1}.poi-search-input{flex:1;min-width:0;height:26px;padding:4px 24px 4px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:12px;background:var(--card-bg);color:var(--text-color);outline:none;transition:border-color .2s}.poi-search-input:focus{border-color:var(--primary-color)}.poi-search-input::placeholder{color:var(--text-tertiary)}.poi-search-clear{position:absolute;right:4px;display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;border-radius:2px;opacity:0;transition:opacity .2s,color .2s}.poi-search-input-wrapper.expanded .poi-search-clear.visible{opacity:1}.poi-search-clear:hover{color:var(--text-color)}.poi-list-item.poi-search-hidden{display:none!important}.poi-list-no-results{padding:16px;text-align:center;color:var(--text-secondary);font-size:13px;display:none}.poi-list-no-results.visible{display:block}.poi-category-groups{display:flex;flex-direction:column;gap:8px;margin-top:1px}.poi-group{border:1px solid var(--border-color);border-radius: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:#2e7d321a}body.dark-mode .poi-group-header:hover{background:#4caf5026}.poi-group-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-color)}.poi-group-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.poi-group-icon svg,.poi-category-label svg{width:16px;height:16px}.poi-group-icon svg path:not([fill]),.poi-category-label svg path:not([fill]){fill:none;stroke:var(--text-color);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.poi-group-icon svg:not(:has(path[fill])),.poi-category-label svg:not(:has(path[fill])){stroke:var(--text-color);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.poi-group-count{font-size:11px;color:var(--text-secondary);font-weight:400;margin-right:4px}.poi-group-controls{display:flex;align-items:center;gap:8px}.poi-group-toggle-all{font-size:11px;color:#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-toggle-all.all-selected{background:#4caf50;color:#fff;border-color:#4caf50}.poi-group-toggle-all.all-selected:hover{background:#2e7d32}body.dark-mode .poi-group-toggle-all.all-selected{background:#66bb6a;color:#1a1a1a;border-color:#66bb6a}body.dark-mode .poi-group-toggle-all.all-selected:hover{background:#4caf50}.poi-group-icon.has-selection{color:#4caf50}body.dark-mode .poi-group-icon.has-selection{color:#66bb6a}.poi-group-arrow{font-size:12px;transition:transform .3s;transform:rotate(180deg);display:inline-block}.poi-group-arrow.collapsed{transform:rotate(0)}.poi-group-content{padding:8px 12px;display:grid;grid-template-columns:1fr;gap:6px;max-height:10000px;overflow:visible;transition:all .3s ease}.poi-group-content.collapsed{max-height:0;padding:0 12px;overflow:hidden}.sidebar-sections-container{position:relative;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}#searchSection{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}#searchSection .collapsible-content{flex:1;min-height:0}.poi-section-overlay{z-index:10;background:var(--sidebar-bg);transition:top .3s ease,bottom .3s ease,transform .3s ease,opacity .3s ease;box-shadow:0 2px 8px #00000026;border-radius:6px;border:1px solid var(--border-color);display:flex;flex-direction:column}body.dark-mode .poi-section-overlay{box-shadow:0 2px 12px #0006}.poi-section-overlay .collapsible-content.collapsed{max-height:0;overflow:hidden;padding:0}.poi-section-overlay:not(.minimized) .collapsible-content{max-height:calc(100vh - 300px);overflow-y:auto;overflow-x:hidden;transition:max-height .3s ease}.poi-section-overlay.minimized{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}.poi-section-overlay.minimized .collapsible-content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:visible}.poi-section-overlay.minimized .poi-list{flex:1;min-height:0;max-height:none;overflow-y:auto}.poi-section-overlay:not(.minimized){position:absolute;inset:0;display:flex;flex-direction:column;margin-bottom:0}.poi-section-overlay:not(.minimized) .collapsible-content{max-height:none;flex:1;min-height:0;overflow:visible;display:flex;flex-direction:column;background:var(--sidebar-bg)}.poi-section-overlay.hidden{display:none!important}.sidebar-sections-container:before{content:"";position:absolute;inset:0;background:#0000;pointer-events:none;transition:background .3s ease;z-index:5}.sidebar-sections-container.poi-expanded:before{background:#0000000d}body.dark-mode .sidebar-sections-container.poi-expanded:before{background:#00000026}.sidebar-sections-container.poi-expanded #searchSection{pointer-events:none}.poi-category-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 8px;border-radius:4px;transition:background .2s;min-height:28px}.poi-category-item:hover{background:#2e7d321a}body.dark-mode .poi-category-item:hover{background:#4caf5026}.poi-category-item input[type=checkbox]{margin-right:8px}.poi-category-label{cursor:pointer;user-select:none;flex:1;line-height:1.3;display:flex;align-items:center;gap:6px}.poi-category-name{display:flex;align-items:center;gap:4px}.poi-category-count{font-size:11px;color:var(--success-color, #4caf50);font-weight:500;margin-left:2px}.poi-category-count[data-count="0"]{color:var(--text-secondary, #999)}.poi-category-cache-btn{flex-shrink:0;opacity:.6;color:#2196f3;background:none;border:none;cursor:pointer;padding:2px 4px;font-size:12px;transition:opacity .2s,color .2s;margin-left:auto}.poi-category-cache-btn:hover{opacity:1;color:#1976d2}body.dark-mode .poi-category-cache-btn{color:#64b5f6}body.dark-mode .poi-category-cache-btn:hover{color:#90caf9}.poi-category-settings-btn{flex-shrink:0;opacity:.6;color:#666;transition:opacity .2s,color .2s;margin-left:0}.poi-category-cache-btn.u-hidden+.poi-category-settings-btn{margin-left:auto}.poi-category-settings-btn:hover{opacity:1;color:#1976d2!important}.poi-category-settings-btn.has-custom-distance,.poi-category-settings-btn.has-custom-settings{opacity:1;color:#2e7d32!important}body.dark-mode .poi-category-settings-btn{color:#999}body.dark-mode .poi-category-settings-btn.has-custom-distance,body.dark-mode .poi-category-settings-btn.has-custom-settings{color:#4caf50!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:#2e7d321a;border:1px solid rgba(46,125,50,.3);border-radius:10px;padding:2px 7px;margin-left:auto;margin-right:4px;min-width:24px;text-align:center;transition:all .2s}body.dark-mode .category-poi-count-badge{background:#4caf5026;border-color:#4caf5066}.category-poi-count-badge:not([data-count="0"]){color:#2e7d32;background:#2e7d3226;border-color:#2e7d3266}body.dark-mode .category-poi-count-badge:not([data-count="0"]){color:#66bb6a;background:#4caf5033;border-color:#4caf5080}.category-poi-count-badge[data-count="0"]{opacity:.3}.poi-sort-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.poi-sort-btn:hover{background:var(--button-hover);color:var(--text-color)}.poi-sort-btn.active{color:#4caf50;background:#4caf501a}body.dark-mode .poi-sort-btn.active{color:#66bb6a;background:#4caf5026}.viewport-filter-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.viewport-filter-btn:hover{background:var(--button-hover);color:var(--text-color)}.viewport-filter-btn.active{color:#4caf50;background:#4caf501a}.viewport-filter-btn.active i:before{content:""}body.dark-mode .viewport-filter-btn.active{color:#66bb6a;background:#4caf5026}.favorites-filter-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.favorites-filter-btn:hover{background:var(--button-hover);color:#ffc107}.favorites-filter-btn.active{color:#ffc107;background:#ffc10726}.favorites-filter-btn.active i:before{content:""}body.dark-mode .favorites-filter-btn.active{color:#ffd54f;background:#ffc10733}.category-favorites-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:2px 6px;margin-left:4px;border-radius:4px;transition:all .2s ease}.category-favorites-btn:hover,.category-favorites-btn.active{color:#ffc107}.category-favorites-btn.disabled,.category-favorites-btn:disabled{color:var(--text-secondary);opacity:.3;cursor:not-allowed}.category-favorites-btn.disabled:hover,.category-favorites-btn:disabled:hover{color:var(--text-secondary)}.category-delete-nonfav-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:2px 6px;margin-left:2px;border-radius:4px;transition:all .2s ease}.category-delete-nonfav-btn:hover{color:#f44336}.icon-trash-star{position:relative;display:inline-flex;align-items:center;justify-content:center}.icon-trash-star .bi-trash{font-size:14px}.icon-trash-star .icon-star-overlay{position:absolute;font-size:7px;top:-2px;right:-4px;color:#ffc107;text-shadow:0 0 2px rgba(0,0,0,.3)}.category-delete-nonfav-btn:hover .icon-star-overlay{color:#ffeb3b}.batch-elevation-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:4px 8px;margin-left:8px;border-radius:4px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;position:relative}.batch-elevation-btn:hover{background:var(--button-hover);color:var(--text-color)}.batch-elevation-btn:disabled{opacity:.3;cursor:not-allowed}.batch-elevation-btn:disabled:hover{background:none;color:var(--text-secondary)}.elevation-count-badge{position:absolute;top:-2px;right:-2px;background:#ff6b6b;color:#fff;font-size:10px;font-weight:600;padding:2px 4px;border-radius: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:#2e7d321a;border-color:#2e7d32}body.dark-mode .quick-action-btn:hover{background:#4caf5026;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:transparent;border:none;cursor:pointer;color:#f57f17;transition:color .2s;font-size:16px;line-height:1}body.dark-mode .clear-preset-btn{color:#ffd54f}.clear-preset-btn:hover{color:#f44336}.preset-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.preset-item{padding:14px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s}.preset-item:hover{background:#1976d20d;border-color:#1976d2;transform:translate(4px)}body.dark-mode .preset-item:hover{background:#1976d21a}.preset-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:15px}.preset-item-details{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--text-secondary);margin-bottom:6px}.preset-item-details span{display:flex;align-items:center;gap:4px}.preset-item-footer{font-size:11px;color:var(--text-tertiary);font-style:italic}.preset-delete-btn{padding:4px 8px;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;color:var(--text-secondary);transition:all .2s;font-size:14px}.preset-delete-btn:hover{background:#f44336;border-color:#f44336;color:#fff}.modal-field{margin-bottom:15px}.modal-field label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-color)}.modal-section{margin-bottom:20px}.modal-section-title{font-size:14px;font-weight:600;color:var(--text-color);margin-bottom:12px;display:flex;align-items:center}.modal-section-divider{height:1px;background:var(--border-color);margin:20px 0;opacity:.5}.distance-unit-input-group{display:flex;gap:8px;align-items:center}.distance-unit-input-group .distance-input{flex:1;min-width:0}.distance-unit-input-group .unit-select{flex-shrink:0;width:auto;min-width:90px;max-width:120px}@media(max-width:480px){.distance-unit-input-group{flex-direction:column;align-items:stretch}.distance-unit-input-group .unit-select{width:100%;max-width:none}}.preset-list-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:10px}.stat-card{background:var(--card-bg);padding:12px;border-radius: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-toggle-icon{font-size:14px;transition:transform .3s ease;transform:rotate(0);display:inline-block}.poi-category-header.collapsed .poi-category-toggle-icon{transform:rotate(-90deg)}.poi-category-title{display:flex;align-items:center;gap:6px;font-weight:600;font-size:13px;color:var(--text-color)}.poi-category-icon{font-size:14px;display:inline-block;opacity:.9}.poi-category-controls{display:flex;align-items:center;gap:8px}.poi-category-arrow{font-size:12px;transition:transform .3s;transform:rotate(180deg);display:inline-block}.poi-category-arrow.collapsed{transform:rotate(0)}.poi-category-items{max-height:10000px;overflow:visible;transition:max-height .3s ease,opacity .3s ease;opacity:1}.poi-category-items.collapsed{max-height:0;overflow:hidden;opacity:0}.poi-item{padding:12px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s;display:flex;justify-content:space-between;align-items:flex-start}.poi-item:hover{background:#2e7d321a}body.dark-mode .poi-item:hover{background:#4caf5026}.poi-info{flex:1}.poi-name{font-weight:600;color:var(--text-color);margin-bottom:4px}.poi-category{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.poi-distance{font-size:12px;color:#2e7d32;font-weight:500}body.dark-mode .poi-distance{color:#66bb6a}.poi-actions{display:flex;gap:5px}.poi-action-btn{background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:4px;font-size:12px;transition:background .2s;color:#f44336}.poi-action-btn:hover{background:var(--button-hover)}.poi-item-checkbox{margin:0}.poi-selection-footer{position:sticky;bottom:0;left:0;right:0;background:var(--card-bg);border-top:2px solid #4caf50;padding:8px 12px;display:none;flex-direction:column;gap:6px;z-index:100;box-shadow:0 -2px 10px #0000001a}body.dark-mode .poi-selection-footer{box-shadow:0 -2px 10px #0000004d}.poi-selection-footer.active{display:flex}.poi-selection-footer-content{display:flex;align-items:center;justify-content:space-between;gap:8px}.poi-selection-footer-info{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.poi-selection-footer-info i{color:#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 #00000026}.poi-selection-action-btn.delete{background:#fff;color:#f44336;border:1px solid #f44336}.poi-selection-action-btn.delete:not(:disabled):hover{background:#f44336;color:#fff}body.dark-mode .poi-selection-action-btn.delete{background:#2a2a2a}body.dark-mode .poi-selection-action-btn.delete:not(:disabled):hover{background:#f44336;color:#fff}.poi-selection-action-btn.keep{background:#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:70px;right:20px;padding:15px 20px;border-radius:4px;box-shadow:0 2px 10px #0003;z-index:10010;display:none;animation:slideIn .3s;display:flex;align-items:center;gap:10px;pointer-events:none}.message.success,.message.error,.message.warning,.message.info{pointer-events:auto}.message-icon{flex-shrink:0;width:18px;height:18px}.message-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.message-text{flex:1}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.message.success{background:#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}.filter-controls{display:flex;gap:10px;margin-bottom:10px;flex-shrink:0}.delete-non-favorites-container{padding:8px 12px;margin-bottom:8px;background:#f4433614;border:1px solid rgba(244,67,54,.2);border-radius:6px}.delete-non-favorites-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;background:transparent;border:1px solid #f44336;border-radius:4px;color:#f44336;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.delete-non-favorites-btn:hover{background:#f44336;color:#fff}body.dark-mode .delete-non-favorites-container{background:#f443361f;border-color:#f443364d}body.dark-mode .delete-non-favorites-btn{color:#ef5350;border-color:#ef5350}body.dark-mode .delete-non-favorites-btn:hover{background:#ef5350;color:#fff}.filter-btn{padding:6px 12px;border:1px solid var(--border-color);background:var(--button-bg);border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s;color:var(--text-color)}.filter-btn:hover{background:var(--button-hover)}.filter-btn.active{background:#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:transparent;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:#0000000d;color:var(--text-color)}body.dark-mode .sidebar-tab:hover:not(.active){background:#ffffff0d}.sidebar-tab.active{background:var(--primary-green);color:#fff;box-shadow:0 2px 8px #4caf504d}body.dark-mode .sidebar-tab.active{background:var(--primary-green);box-shadow:0 2px 8px #4caf5066}.sidebar-tab:disabled,.sidebar-tab.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;color:var(--text-muted)}.sidebar-tab:disabled:hover,.sidebar-tab.disabled:hover{background:var(--button-bg);transform:none}body.dark-mode .sidebar-tab:disabled,body.dark-mode .sidebar-tab.disabled{opacity:.4}.sidebar-tab[data-tab=list][data-count]:not([data-count="0"]):after{content:attr(data-count);position:absolute;top:4px;right:8px;background:#ff5722;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:1.2}.sidebar-tab.active[data-tab=list]:after{display:none}.sidebar-tab i{font-size:16px}.sidebar-tab .tab-badge{position:absolute;top:-6px;right:-6px;background:#f44336;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.poi-section-static-header{padding:12px 16px;border-bottom:1px solid var(--border-color);margin-bottom:0;flex-shrink:0;display:flex;flex-direction:column;gap:8px}.poi-header-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text-color)}.poi-header-actions{display:flex;align-items:center;gap:6px}@media(max-width:768px){.sidebar-tab{font-size:13px;padding:10px 8px}.sidebar-tab span:not(.tab-badge){font-size:12px}}.undo-notification{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:12px 20px;border-radius:4px;box-shadow:0 2px 10px #0000004d;display:none;z-index:11000;animation:slideUp .3s}@keyframes slideUp{0%{transform:translate(-50%) translateY(100px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes darkness-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}#darknessWarningIcon{animation:darkness-pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 3px rgba(255,152,0,.5))}#darknessWarningIcon:hover{animation-play-state:paused}.undo-btn{background:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;margin-left:10px;font-size:12px}.undo-btn:hover{background:#45a049}.ps-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:50000;align-items:center;justify-content:center;padding:20px;overflow-y:auto}.ps-modal:not(.u-hidden){display:flex}.ps-modal__container{background:var(--bg-color);border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:calc(100vh - 40px);display:flex;flex-direction:column;position:relative;width:100%;animation:modalSlideIn .2s ease-out}.ps-modal__container.ps-modal--sm{max-width:350px}.ps-modal__container.ps-modal--md{max-width:500px}.ps-modal__container.ps-modal--lg{max-width:650px}.ps-modal__container.ps-modal--xl{max-width:850px}.ps-modal__container.ps-modal--fullscreen{width:calc(100vw - 32px);height:calc(100vh - 32px);max-width:none;max-height:none}.ps-modal__container.ps-modal--fullscreen .ps-modal__body{flex:1;height:auto;overflow:hidden}.ps-modal__container:not(.ps-modal--sm):not(.ps-modal--md):not(.ps-modal--lg):not(.ps-modal--xl):not(.ps-modal--fullscreen){max-width:500px}.ps-modal__header{display:flex;align-items:center;gap:10px;padding:20px;border-bottom:1px solid var(--border-color);flex-shrink:0}.ps-modal__title{flex:1;font-size:18px;font-weight:600;color:var(--text-color);margin:0}.ps-modal__close{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-secondary);transition:color .2s;flex-shrink:0}.ps-modal__close:hover{color:var(--text-color)}.ps-modal__close svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;stroke-linecap:round}.ps-modal__close i{font-size:18px}.ps-modal__body{padding:20px;overflow-y:auto;flex:1 1 auto;min-height:0}.ps-modal__footer{display:flex;gap:10px;justify-content:flex-end;padding:15px 20px;border-top:1px solid var(--border-color);flex-shrink:0}.ps-modal__field{margin-bottom:15px}.ps-modal__field label{display:block;margin-bottom:5px;font-weight:500;color:var(--text-secondary);font-size:14px}.ps-modal__field input[type=text],.ps-modal__field input[type=number],.ps-modal__field input[type=email],.ps-modal__field input[type=date],.ps-modal__field input[type=time],.ps-modal__field textarea,.ps-modal__field select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;background:var(--input-bg);color:var(--text-color);box-sizing:border-box}.ps-modal__field input:focus,.ps-modal__field textarea:focus,.ps-modal__field select:focus{outline:none;border-color:#2e7d32}.input-with-toggle{display:flex;gap:12px;align-items:stretch}.input-with-toggle input{flex:1;min-width:0}.unit-toggle-buttons{display:flex;gap:0}.unit-toggle-btn{padding:10px 16px;background:var(--button-bg);border:1px solid var(--border-color);color:var(--text-color);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.unit-toggle-btn:first-child{border-radius:6px 0 0 6px}.unit-toggle-btn:last-child{border-radius:0 6px 6px 0;border-left:none}.unit-toggle-btn:hover{background:var(--button-hover)}.unit-toggle-btn.active{background:#2e7d32;border-color:#2e7d32;color:#fff}.preview-info-box{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;padding:12px;display:flex;gap:10px;align-items:flex-start}.preview-info-box__icon{font-size:20px;line-height:1;flex-shrink:0;color:var(--text-secondary)}.preview-info-box__text{color:var(--text-secondary);font-size:13px;line-height:1.5;flex:1}.preview-info-box.has-data{background:#2e7d320d;border-color:#2e7d3233}.preview-info-box.has-data .preview-info-box__icon{color:#2e7d32}.preview-info-box.has-data .preview-info-box__text{color:var(--text-color);font-weight:500}@media(max-width:480px){.input-with-toggle{flex-direction:column;gap:10px}.unit-toggle-buttons{width:100%}.unit-toggle-btn{flex:1}.unit-toggle-btn:first-child{border-radius:6px 0 0 6px}.unit-toggle-btn:last-child{border-radius:0 6px 6px 0;border-left:none}}.type-selector{display:flex;gap:10px;flex-wrap:wrap}.type-option{flex:1;min-width:100px;padding:10px;border:2px solid var(--border-color);border-radius:4px;text-align:center;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;background:var(--button-bg);color:var(--text-color);display:flex;flex-direction:column;align-items:center;gap:4px}.type-option:hover{border-color:var(--text-tertiary);transform:translateY(-1px)}.type-option:active{transform:translateY(0)}.type-option.info{background:#e3f2fd;border-color:#2196f3;color:#1976d2}.type-option.info.selected{border-width:3px;background:#bbdefb;box-shadow:0 0 0 3px #2196f333}.type-option.alert{background:#fff3e0;border-color:#ff9800;color:#f57c00}.type-option.alert.selected{border-width:3px;background:#ffe0b2;box-shadow:0 0 0 3px #ff980033}.type-option.danger{background:#ffebee;border-color:#f44336;color:#c62828}.type-option.danger.selected{border-width:3px;background:#ffcdd2;box-shadow:0 0 0 3px #f4433633}.type-option.event-sticker{background:#f3e5f5;border-color:#9c27b0;color:#6a1b9a}.type-option.event-sticker.selected{border-width:3px;background:#e1bee7;box-shadow:0 0 0 3px #9c27b033}body.dark-mode .type-option{background:var(--card-bg)}body.dark-mode .type-option.info{background:#1a3a4a;border-color:#64b5f6;color:#64b5f6}body.dark-mode .type-option.info.selected{background:#1e4a60;box-shadow:0 0 0 3px #64b5f64d}body.dark-mode .type-option.alert{background:#3a2a1a;border-color:#ffb74d;color:#ffb74d}body.dark-mode .type-option.alert.selected{background:#4a3a2a;box-shadow:0 0 0 3px #ffb74d4d}body.dark-mode .type-option.danger{background:#3a1a1a;border-color:#ef5350;color:#ef5350}body.dark-mode .type-option.danger.selected{background:#4a2a2a;box-shadow:0 0 0 3px #ef53504d}body.dark-mode .type-option.event-sticker{background:#2a1a3a;border-color:#ba68c8;color:#ba68c8}body.dark-mode .type-option.event-sticker.selected{background:#3a2a4a;box-shadow:0 0 0 3px #ba68c84d}@media(prefers-color-scheme:dark){.type-option{background:var(--card-bg)}.type-option.info{background:#1a3a4a;border-color:#64b5f6;color:#64b5f6}.type-option.info.selected{background:#1e4a60;box-shadow:0 0 0 3px #64b5f64d}.type-option.alert{background:#3a2a1a;border-color:#ffb74d;color:#ffb74d}.type-option.alert.selected{background:#4a3a2a;box-shadow:0 0 0 3px #ffb74d4d}.type-option.danger{background:#3a1a1a;border-color:#ef5350;color:#ef5350}.type-option.danger.selected{background:#4a2a2a;box-shadow:0 0 0 3px #ef53504d}.type-option.event-sticker{background:#2a1a3a;border-color:#ba68c8;color:#ba68c8}.type-option.event-sticker.selected{background:#3a2a4a;box-shadow:0 0 0 3px #ba68c84d}}@media(max-width:480px){.type-selector{flex-direction:column}.type-option{flex:none;width:100%}}#poiSearchModal .ps-modal__container,#queryPoiProgressModal .ps-modal__container{padding:32px 24px}.progress-spinner{width:100px;height:100px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center}#bicycleWheelSpinner,#queryBicycleWheelSpinner,#apiTestBicycleWheelSpinner{width:100%;height:100%;animation:spin 2.5s linear infinite;display:block}.progress-spinner.complete #bicycleWheelSpinner,.progress-spinner.complete #queryBicycleWheelSpinner,.progress-spinner.complete #apiTestBicycleWheelSpinner{display:none}.progress-spinner.complete{border:none;font-size:48px;color:#4caf50;font-weight:700;animation:none}.progress-title{font-size:18px;font-weight:600;margin-bottom:12px;line-height:1.3;color:var(--text-color);text-align:center}.progress-status{font-size:14px;color:var(--text-secondary);margin-bottom:16px;min-height:20px;line-height:1.4;text-align:center}.progress-bar-container{width:100%;height:8px;background:var(--border-color);border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-bar{height:100%;background:linear-gradient(90deg,#2e7d32,#4caf50);transition:width .3s ease;border-radius:4px}.progress-details{font-size:13px;color:var(--text-tertiary);text-align:center}.progress-server{font-size:11px;color:var(--text-tertiary);text-align:center;margin-top:8px;opacity:.7;min-height:16px}.progress-server .server-success{color:var(--primary-green)}.progress-server .server-retry{color:#ff9800}.progress-server .server-fail{color:#f44336}body.dark-mode .progress-spinner{border-color:#ffffff1a}@media(prefers-color-scheme:dark){.progress-spinner{border-color:#ffffff1a}}.ps-btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.ps-btn:disabled{opacity:.5;cursor:not-allowed}.ps-btn--primary{background:#2e7d32;color:#fff;border:none}.ps-btn--primary:hover:not(:disabled){background:#1b5e20}.ps-btn--primary:active:not(:disabled){background:#0d3d12}.ps-btn--secondary{background:var(--button-bg);color:var(--text-color);border:1px solid var(--border-color)}.ps-btn--secondary:hover:not(:disabled){background:var(--button-hover)}.ps-btn--danger{background:#f44336;color:#fff;border:none}.ps-btn--danger:hover:not(:disabled){background:#c62828}.ps-btn--danger:active:not(:disabled){background:#8b0000}.ps-btn--compact{padding:6px 12px;font-size:12px}.ps-btn--full{width:100%;justify-content:center}.ps-modal--informative .ps-modal__header i,.ps-modal--informative .ps-modal__title i{color:#1976d2}.ps-modal--informative .ps-btn--primary{background:#1976d2}.ps-modal--informative .ps-btn--primary:hover:not(:disabled){background:#1565c0}.ps-modal--informative .ps-btn--primary:active:not(:disabled){background:#0d47a1}.ps-modal--informative .ps-modal__field input:focus,.ps-modal--informative .ps-modal__field textarea:focus,.ps-modal--informative .ps-modal__field select:focus{border-color:#1976d2}.ps-modal--informative a{color:#1976d2}.ps-modal--informative a:hover{color:#1565c0}.ps-modal--action .ps-modal__header i,.ps-modal--action .ps-modal__title i{color:#2e7d32}.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}@media(max-width:768px){.ps-modal{padding:10px}.ps-modal__container{max-height:calc(100vh - 20px)}.ps-modal__container.ps-modal--sm,.ps-modal__container.ps-modal--md,.ps-modal__container.ps-modal--lg,.ps-modal__container.ps-modal--xl{max-width:100%}.ps-modal__header,.ps-modal__body{padding:15px}.ps-modal__footer{padding:12px 15px;flex-wrap:wrap}.ps-btn{flex:1;justify-content:center;min-width:0}}@media(max-width:768px){.poi-stats-grid{grid-template-columns:repeat(2,1fr);gap:6px}.poi-stats-section-title{font-size:11px}}.services-section{margin-top:24px;padding-top:20px;border-top:2px solid var(--border-color)}.services-section h4{font-size:16px;font-weight:600;color:var(--text-color);margin-bottom:12px;padding-left:12px;border-left:4px solid #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}.distance-marker-icon{background:transparent!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-zoom,.leaflet-control-layers{background:#f8f9fa!important;border:1px solid rgba(0,0,0,.2)!important;box-shadow:0 2px 6px #0000001a!important}.leaflet-control-zoom a,.leaflet-control-layers-toggle{background-color:#fff!important;color:#333!important;border-bottom:1px solid rgba(0,0,0,.1)!important}.leaflet-control-zoom a:hover,.leaflet-control-layers-toggle:hover{background-color:#f0f0f0!important}.leaflet-control-zoom{z-index:1000}.leaflet-control-layers{z-index:999;margin-top:10px}.leaflet-control-layers-toggle{width:30px!important;height:30px!important;background-size:16px 16px!important;background-position:center!important;background-image:none!important;position:relative}.leaflet-control-layers-toggle:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"%3E%3Cg fill="none" stroke="%23333" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"%3E%3Crect x="2" y="2" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="6.5" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="11" width="12" height="3" rx="0.5"/%3E%3C/g%3E%3C/svg%3E');background-size:contain;background-repeat:no-repeat;background-position:center}body.dark-mode .leaflet-control-layers-toggle:before{background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"%3E%3Cg fill="none" stroke="%23e0e0e0" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"%3E%3Crect x="2" y="2" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="6.5" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="11" width="12" height="3" rx="0.5"/%3E%3C/g%3E%3C/svg%3E')}#skipAnimationBtn:hover{background:#1565c0!important}#skipAnimationBtn:active{background:#0d47a1!important}body.dark-mode .leaflet-control-zoom,body.dark-mode .leaflet-control-layers,body.dark-mode .leaflet-bar,body.dark-mode .leaflet-control-attribution,body.dark-mode .leaflet-control-scale{background:#2a2a2a!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}body.dark-mode .leaflet-control-zoom a,body.dark-mode .leaflet-bar a,body.dark-mode .leaflet-control-layers-toggle{background-color:#333!important;background-image:none!important;color:#e0e0e0!important;border-bottom:1px solid rgba(255,255,255,.1)!important}body.dark-mode .leaflet-control-zoom-in,body.dark-mode .leaflet-control-zoom-out{color:#e0e0e0!important;text-shadow:none!important}body.dark-mode .leaflet-control-zoom-in:before,body.dark-mode .leaflet-control-zoom-out:before{filter:invert(1)!important}body.dark-mode .leaflet-control-zoom a:hover,body.dark-mode .leaflet-bar a:hover,body.dark-mode .leaflet-control-layers-toggle:hover{background-color:#404040!important;background-image:none!important}body.dark-mode .leaflet-control-zoom a:active,body.dark-mode .leaflet-bar a:active,body.dark-mode .leaflet-control-layers-toggle:active{background-color:#4a4a4a!important;background-image:none!important}body.dark-mode .leaflet-control-zoom a:focus,body.dark-mode .leaflet-bar a:focus,body.dark-mode .leaflet-control-layers-toggle:focus{outline:2px solid rgba(255,255,255,.3)!important;outline-offset:-2px!important}body.dark-mode .leaflet-disabled,body.dark-mode .leaflet-control-zoom-in.leaflet-disabled,body.dark-mode .leaflet-control-zoom-out.leaflet-disabled{background-color:#2a2a2a!important;color:#666!important;cursor:default!important;opacity:.4!important}body.dark-mode .leaflet-control-layers-expanded{background:#2a2a2a!important;color:#e0e0e0!important;border:1px solid rgba(255,255,255,.2)!important}body.dark-mode .leaflet-control-layers-base label,body.dark-mode .leaflet-control-layers-overlays label{color:#e0e0e0!important}body.dark-mode .leaflet-control-layers-selector{filter:brightness(1.2)!important}body.dark-mode .leaflet-control-layers-separator{border-top:1px solid rgba(255,255,255,.1)!important}body.dark-mode .leaflet-control-attribution,body.dark-mode .leaflet-control-attribution a{background:#2a2a2a!important;color:#999!important}body.dark-mode .leaflet-control-attribution a:hover{color:#e0e0e0!important}body.dark-mode .leaflet-control-scale-line{background:#2a2a2acc!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 #0000001a;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 #0000001a;margin-top:10px}.map-feature-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-bottom:1px solid rgba(0,0,0,.1);cursor:pointer;transition:background .2s ease;padding:0}.map-feature-btn:last-child{border-bottom:none}.map-feature-btn:hover{background:#f4f4f4}.map-feature-btn:active{background:#e8e8e8}.map-feature-btn.hidden{display:none}.map-feature-btn .bi{font-size:16px;color:#333}.map-feature-btn.inactive .bi{opacity:.4}body.dark-mode .leaflet-control-map-features{background:#2a2a2a!important;border:2px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}body.dark-mode .map-feature-btn{background:#333!important;border-bottom:1px solid rgba(255,255,255,.1)!important}body.dark-mode .map-feature-btn:hover{background:#404040!important}body.dark-mode .map-feature-btn:active{background:#4a4a4a!important}body.dark-mode .map-feature-btn .bi{color:#e0e0e0!important}body.dark-mode .map-feature-btn.inactive .bi{opacity:.4!important}.map-feature-btn.query-active{background:#ff98004d!important;border-left:4px solid #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,#fff);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:#6ecc3999}.marker-cluster-small div{background-color:#6ecc39cc}.marker-cluster-medium{background-color:#ffc40099}.marker-cluster-medium div{background-color:#ffc400cc}.marker-cluster-large{background-color:#fd9c7399}.marker-cluster-large div{background-color:#fd9c73cc}.marker-cluster{background-clip:padding-box;border-radius:20px}.marker-cluster div{width:30px;height:30px;margin-left:5px;margin-top:5px;text-align:center;border-radius:15px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center}.marker-cluster span{line-height:30px;font-size:13px}body.dark-mode .marker-cluster-small{background-color:#4caf5099}body.dark-mode .marker-cluster-small div{background-color:#4caf50cc}body.dark-mode .marker-cluster-medium{background-color:#ff980099}body.dark-mode .marker-cluster-medium div{background-color:#ff9800cc}body.dark-mode .marker-cluster-large{background-color:#f4433699}body.dark-mode .marker-cluster-large div{background-color:#f44336cc}body.dark-mode .query-results-section{background:linear-gradient(135deg,#2a2420,#1e1e1e);border-color:#ff9800}@media(prefers-color-scheme:dark){body:not(.light-mode) .query-results-section{background:linear-gradient(135deg,#2a2420,#1e1e1e);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:transparent;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;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 #ff980033}.query-poi-item label{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer}.query-poi-name{font-weight:500}.query-poi-details{display:flex;align-items:center;gap:8px;font-size:.85rem;opacity:.8}.add-query-poi-btn{padding:4px 8px;border:1px solid var(--link-color);background:transparent;color:var(--link-color);border-radius:4px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:4px;transition:all .2s}.add-query-poi-btn:hover{background:var(--link-color);color:#fff}@media(prefers-color-scheme:dark){.elevation-crosshair-tooltip{background:#fffffff2;color:#1a1a1a}.file-upload:hover{background:linear-gradient(to bottom,#66bb6a14,#66bb6a26);transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow)}.poi-group-toggle-all{background:var(--button-bg)}.poi-group-toggle-all:hover{background:var(--button-hover)}.poi-group-header:hover{background:#4caf5026}.quick-action-btn:hover{background:#4caf5026;border-color:#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:#ffffff1a;border-top-color:#66bb6a}.leaflet-popup-content-wrapper{background-color:#2a2a2a;color:var(--text-color)}body.dark-mode .leaflet-popup-content-wrapper,.leaflet-popup-tip,body.dark-mode .leaflet-popup-tip{background-color:#2a2a2a}.leaflet-popup-content{color:var(--text-color)}.leaflet-popup-content a{color:#66bb6a}.leaflet-popup-close-button{color:#e0e0e0!important}.leaflet-popup-close-button:hover{color:#fff!important}.leaflet-control-zoom,.leaflet-control-layers,.leaflet-bar,.leaflet-control-attribution,.leaflet-control-scale{background:#2a2a2a!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}.leaflet-control-zoom a,.leaflet-bar a,.leaflet-control-layers-toggle{background-color:#333!important;background-image:none!important;color:#e0e0e0!important;border-bottom:1px solid rgba(255,255,255,.1)!important}.leaflet-control-zoom-in,.leaflet-control-zoom-out{color:#e0e0e0!important;text-shadow:none!important}.leaflet-control-zoom-in:before,.leaflet-control-zoom-out:before{filter:invert(1)!important}.leaflet-control-zoom a:hover,.leaflet-bar a:hover,.leaflet-control-layers-toggle:hover{background-color:#404040!important;background-image:none!important}.leaflet-control-zoom a:active,.leaflet-bar a:active,.leaflet-control-layers-toggle:active{background-color:#4a4a4a!important;background-image:none!important}.leaflet-control-zoom a:focus,.leaflet-bar a:focus,.leaflet-control-layers-toggle:focus{outline:2px solid rgba(255,255,255,.3)!important;outline-offset:-2px!important}.leaflet-disabled,.leaflet-control-zoom-in.leaflet-disabled,.leaflet-control-zoom-out.leaflet-disabled{background-color:#2a2a2a!important;color:#666!important;cursor:default!important;opacity:.4!important}.leaflet-control-layers-expanded{background:#2a2a2a!important;color:#e0e0e0!important;border:1px solid rgba(255,255,255,.2)!important}.leaflet-control-layers-base label,.leaflet-control-layers-overlays label{color:#e0e0e0!important}.leaflet-control-layers-selector{filter:brightness(1.2)!important}.leaflet-control-layers-separator{border-top:1px solid rgba(255,255,255,.1)!important}.leaflet-control-attribution,.leaflet-control-attribution a{background:#2a2a2a!important;color:#999!important}.leaflet-control-attribution a:hover{color:#e0e0e0!important}.leaflet-control-scale-line{background:#2a2a2acc!important;border:2px solid rgba(255,255,255,.3)!important;color:#e0e0e0!important}.leaflet-control-scale{bottom:75px!important}.leaflet-control-map-features{background:#2a2a2a!important;border:2px solid rgba(255,255,255,.2)!important;box-shadow:0 2px 6px #0000004d!important}.map-feature-btn{background:#333!important;border-bottom:1px solid rgba(255,255,255,.1)!important}.map-feature-btn:hover{background:#404040!important}.map-feature-btn:active{background:#4a4a4a!important}.map-feature-btn .bi{color:#e0e0e0!important}.map-feature-btn.inactive .bi{opacity:.4!important}.leaflet-control-layers-toggle:before{background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"%3E%3Cg fill="none" stroke="%23e0e0e0" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"%3E%3Crect x="2" y="2" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="6.5" width="12" height="3" rx="0.5"/%3E%3Crect x="2" y="11" width="12" height="3" rx="0.5"/%3E%3C/g%3E%3C/svg%3E')}}@media(max-width:768px){body{padding-top:70px}.container{padding:8px}header{padding:12px 15px}.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{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.elevation-content.expanded{max-height:350px}.preset-buttons{grid-template-columns:repeat(2,1fr);gap:5px}.preset-btn{padding:6px 8px;font-size:11px}.slider-arrow{width:36px;height:36px;font-size:18px;touch-action:manipulation}.slider-controls{gap:8px}.elevation-toggle-icon{width:50px;height:22px;top:-22px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.elevation-container.collapsed{width:160px;bottom:55px;right: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 #1976d266}.footer-info-btn i{font-size:14px}.footer-info-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:180px;display:none;z-index:1000}.footer-info-menu.active{display:block}.footer-info-option{padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;color:var(--text-color);transition:background .2s ease;font-size:14px}.footer-info-option:first-child{border-radius:6px 6px 0 0}.footer-info-option:last-child{border-radius:0 0 6px 6px}.footer-info-option:hover,body.dark-mode .footer-info-option:hover{background:#4caf5026}.footer-info-option-icon{font-size:16px;color:var(--text-secondary)}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:#ffffff0d;padding:2px;border-radius:5px}.footer-stat-item{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;white-space:nowrap;padding:5px 9px;background:#ffffff1a;border-radius:3px;transition:all .2s ease}.footer-stat-item.clickable{cursor:pointer;padding:7px 12px;border:1px solid #2e7d32;background:#ffffff26;transition:all .2s ease}.footer-stat-item.clickable:hover{background:#2e7d3233;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%,to{opacity:1}50%{opacity:.5}}@keyframes poi-marker-pulse{0%{transform:scale(1);filter:drop-shadow(0 3px 8px rgba(0,0,0,.4)) drop-shadow(0 0 0 rgba(255,152,0,.7))}50%{transform:scale(1.3);filter:drop-shadow(0 3px 8px rgba(0,0,0,.4)) drop-shadow(0 0 15px rgba(255,152,0,1))}to{transform:scale(1);filter:drop-shadow(0 3px 8px rgba(0,0,0,.4)) drop-shadow(0 0 0 rgba(255,152,0,.7))}}.poi-marker-highlighted{z-index:1000!important}.poi-marker-highlighted>div>svg{animation:poi-marker-pulse 1.5s ease-in-out infinite;transform-origin:center center}.temp-location-marker{background:transparent;border:none}.pulsing-marker{font-size:30px;text-align:center;line-height:1;animation:pulsing-glow 1.5s ease-in-out infinite;transform-origin:center center}@keyframes pulsing-glow{0%,to{transform:scale(1);filter:drop-shadow(0 0 8px #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:#4caf5033!important;border-left:4px solid #4caf50;padding-left:8px}body.dark-mode .poi-item.active{background:#4caf5040!important}.footer-actions{display:flex;align-items:center;gap:9px}.footer-download-container,.footer-tools-container{position:relative}.footer-tools-btn{display:flex;align-items:center;gap:5px;padding:7px 10px;background:#ffffff26;border:1px solid #2e7d32;border-radius:3px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.footer-tools-btn:hover{background:#2e7d3233;border-color:#4caf50;transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.footer-tools-btn svg{width:15px;height:15px;fill:#fff;margin-right:5px}.footer-undo-redo-container{display:flex;gap:0;align-items:center}.footer-undo-redo-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:#ffffff26;border:1px solid #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:#2e7d3233;border-color:#4caf50;transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d;z-index:1}#undoBtn:hover:not(:disabled){border-right-color:#4caf5099}.footer-undo-redo-btn:disabled{opacity:.3;cursor:not-allowed;background:#ffffff0d;border-color:#2e7d324d}#undoBtn:disabled{border-right-color:#2e7d324d}.footer-undo-redo-btn i{font-size:15px}.footer-tools-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius: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:#2e7d321a}body.dark-mode .footer-tools-option:hover{background:#4caf5026}.footer-tools-option-icon{width:16px;height:16px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;margin-right:12px;opacity:.7;flex-shrink:0;transition:opacity .2s ease;vertical-align:middle;display:inline-block}.footer-tools-option:hover .footer-tools-option-icon{opacity:1}.footer-tools-option-title{font-weight:600;font-size:13px;display:block;margin-bottom:2px}.footer-tools-option-description{font-size:11px;color:var(--text-tertiary);display:block}.footer-tools-option.submenu-parent{display:flex;align-items:center;justify-content:space-between}.footer-tools-submenu{display:none;background:var(--surface-alt);border-radius:4px;margin:4px 0;overflow:hidden;max-height:0;opacity:0;transition:max-height .2s ease,opacity .2s ease,margin .2s ease}.footer-tools-submenu.expanded{display:block;max-height:300px;opacity:1;margin:8px 0}.footer-tools-option.submenu-item{padding:10px 16px 10px 32px;font-size:13px;border-bottom:none}.footer-tools-option.submenu-item:hover{background:#2e7d3226}body.dark-mode .footer-tools-option.submenu-item:hover{background:#4caf5033}#languageSubmenu .language-item-flag{font-size:16px;display:inline-block}#languageSubmenu .language-item-name{flex:1}#languageSubmenu .language-item-check{color:var(--primary-green);font-size:14px;display:none}.submenu-arrow{width:14px;height:14px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s ease;opacity:.5}.submenu-arrow.rotated{transform:rotate(90deg)}.footer-tools-option.submenu-parent .footer-tools-option-icon{fill:var(--text-color);stroke:none}.footer-tools-divider{height:1px;background:var(--border-color);margin:8px 0}.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;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:#2e7d321a;border-color:#4caf50;transform:translate(2px)}body.dark-mode .saved-project-card:hover{background:#4caf5026}.project-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:4px}.project-card-buttons{display:flex;gap:0;flex-shrink:0}.project-card-name{font-weight:600;font-size:12px;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-load-btn{padding:4px 12px;background:#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:none;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:#2e7d321a;border-color:#4caf50}body.dark-mode .project-item:hover{background:#4caf5026}.project-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.project-item-header h4{margin:0;font-size:16px;font-weight:600;color:var(--text-color)}.project-item-details{font-size:13px;color:var(--text-secondary);margin-bottom:8px;line-height:1.6}.project-item-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.project-badge{padding:4px 8px;background:#4caf5026;border:1px solid rgba(76,175,80,.3);border-radius:4px;font-size:11px;font-weight:600;color:var(--text-color)}.project-item-actions{display:flex;gap:8px}.project-item-actions button{padding:8px 16px;border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.project-load-btn{background:#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:#ffc1071a;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}.gpx-export-summary{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:6px;padding:16px;margin-top:16px;font-size:14px;color:var(--text-color);display:flex;align-items:center;gap:8px}.gpx-export-summary i{color:var(--primary-color);font-size:18px}.gpx-export-summary #gpxExportCount{font-weight:600;color:var(--primary-color)}.project-summary-box{background:var(--surface-alt);border:1px solid var(--border-color);border-radius: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 #1976d266}.footer-download-btn svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s ease}.footer-download-btn:hover svg{stroke:#fff}.footer-download-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--sidebar-bg);border:1px solid var(--border-color);border-radius: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:#2e7d321a}.footer-download-option-icon{width:16px;height:16px;stroke:var(--text-color);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:.7;flex-shrink:0;transition:opacity .2s ease}.footer-download-option:hover .footer-download-option-icon{opacity:1}.footer-download-option-title{font-weight:600;font-size:13px;display:block;margin-bottom:2px}.footer-download-option-description{font-size:11px;color:var(--text-tertiary);display:block}.footer-download-option-primary{background:linear-gradient(135deg,#2e7d321f,#4caf5014);border-left:4px solid var(--primary-green);padding-left:12px}.footer-download-option-primary .footer-download-option-title{color:var(--primary-green);font-size:14px;font-weight:700}.footer-download-option-primary .footer-download-option-icon{color:var(--primary-green);opacity:1;font-size:18px}.footer-download-option-primary:hover{background:linear-gradient(135deg,#2e7d322e,#4caf501f);border-left-color:#2e7d32}body.dark-mode .footer-download-option-primary{background:linear-gradient(135deg,#4caf5026,#66bb6a1a)}.footer-download-option.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.footer-download-option.disabled:hover{background:transparent}.footer-download-option-primary.disabled{background:#2e7d320d;border-left-color:#2e7d324d}body.dark-mode .footer-download-option-primary:hover{background:linear-gradient(135deg,#4caf5038,#66bb6a26)}@media(prefers-color-scheme:dark){.footer-download-option-primary{background:linear-gradient(135deg,#4caf5026,#66bb6a1a)}.footer-download-option-primary:hover{background:linear-gradient(135deg,#4caf5038,#66bb6a26)}}body.dark-mode .footer-download-option:hover{background:#4caf5026}body.dark-mode .footer-download-btn{background:#64b5f6;color:#1a1a1a;border-color:#64b5f6}body.dark-mode .footer-download-btn svg{stroke:#1a1a1a}body.dark-mode .footer-download-btn:hover{background:#64b5f6;color:#1a1a1a;border-color:#fff}body.dark-mode .footer-download-btn:hover svg{stroke:#1a1a1a}.footer-collapse-toggle{display:none!important;width:32px;height:32px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:4px;color:#fff;cursor:pointer;align-items:center;justify-content:center;transition:all .2s ease;font-size:14px}.footer-collapse-toggle:hover{background:#ffffff4d}.footer-collapse-arrow{transition:transform .3s ease;display:inline-block;transform:rotate(0)}.footer-bar.collapsed{height:30px;justify-content:flex-end}.footer-bar.collapsed .footer-stats{display:none}.footer-bar.collapsed .footer-download-container{display:flex}.footer-bar.collapsed .footer-actions{gap:8px}.footer-bar.collapsed .footer-collapse-arrow{transform:rotate(180deg)}.search-location-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:2px solid var(--border-color)}.search-location-tab{flex:1;padding:10px 12px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.search-location-tab:hover{color:var(--text-color);background:var(--card-bg)}.search-location-tab.active{color:var(--link-color);border-bottom-color:var(--link-color);font-weight:600}.search-location-tab-content{display:none}.search-location-tab-content.active{display:block}@media(max-width:768px){.search-location-tabs-wrapper{position:relative}.search-location-tabs-wrapper:before,.search-location-tabs-wrapper:after{content:"";position:absolute;top:0;bottom:2px;width:60px;pointer-events:none;z-index:2;transition:opacity .3s ease}.search-location-tabs-wrapper:before{left:0;background:linear-gradient(to right,#4caf50 0%,transparent 100%);opacity:0}.search-location-tabs-wrapper:after{right:0;background:linear-gradient(to left,#4caf50 0%,transparent 100%)}.search-location-tabs-wrapper.at-start:before{opacity:0}.search-location-tabs-wrapper.at-end:after{opacity:0}.search-location-tabs-wrapper.can-scroll-left:before{opacity:1}.search-location-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:4px;padding-bottom:2px;padding-right:40px}.search-location-tabs::-webkit-scrollbar{display:none}.search-location-tab{flex:0 0 auto;min-width:90px;padding:10px 8px;font-size:12px}.scroll-hint-arrow{display:flex;align-items:center;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);width:24px;height:24px;color:#fff;font-size:18px;font-weight:700;z-index:3;pointer-events:none;opacity:1;transition:opacity .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.3)}.scroll-hint-left{left:2px}.scroll-hint-right{right:2px;animation:scrollHintPulse 1.5s ease-in-out 2}.search-location-tabs-wrapper.at-start .scroll-hint-left,.search-location-tabs-wrapper.at-end .scroll-hint-right{opacity:0}@keyframes scrollHintPulse{0%,to{transform:translateY(-50%) translate(0);opacity:1}50%{transform:translateY(-50%) translate(3px);opacity:1}}}@media(min-width:769px){.scroll-hint-arrow{display:none!important}}.search-location-input-group{margin-bottom:16px}.search-location-label{display:block;font-size:13px;font-weight:500;color:var(--text-color);margin-bottom:6px}.search-location-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);color:var(--text-color);font-size:14px;transition:all .2s ease}.search-location-input:focus{outline:none;border-color:var(--link-color);box-shadow:0 0 0 3px #4caf501a}.search-location-input::placeholder{color:var(--text-secondary);opacity:.7}.search-location-helper{font-size:11px;color:var(--text-secondary);margin-top:4px;line-height:1.4}.landing-input-button-row{display:flex;gap:10px}@media(max-width:768px){.landing-input-button-row{flex-direction:column;gap:8px}.landing-input-button-row .ps-btn{width:100%;white-space:normal;justify-content:center}}.search-location-results{margin-top:16px;padding:12px;background:var(--card-bg);border-radius: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-name,.search-location-result-item.highlighted .search-location-result-details{color:#fff}.search-result-actions{display:flex;gap:6px;align-items:center;margin-left:auto;padding-left:10px}.search-action-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid var(--border-color);background:var(--surface);border-radius: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:#4caf501a;border-color:var(--link-color)}.search-action-show{color:#ff9800;border-color:#ff9800}.search-action-show:hover{background:#ff98001a;border-color:#ff9800}.copy-coords-btn{padding:6px 10px;background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;color:var(--text-secondary)}.copy-coords-btn:hover{background:var(--surface-alt);color:var(--text-color)}.search-location-result-item.highlighted .copy-coords-btn{border-color:#ffffff80;color:#fff}.search-location-result-item.highlighted .copy-coords-btn:hover{background:#fff3;border-color:#fff}@media(max-width:768px){.search-result-actions{flex-direction:column;gap:4px;width:100%;margin-left:0;margin-top:8px}.search-action-btn{width:100%;justify-content:center}.search-location-result-item{flex-direction:column;align-items:stretch}}.search-radius-section{margin-top:15px;padding:12px;background:var(--card-bg);border-radius:6px;border:1px solid var(--border-color)}.radius-toggle-btn{width:100%;padding:10px 12px;background:transparent;border:none;color:var(--text-color);font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:all .2s ease}.radius-toggle-btn:hover{color:var(--link-color)}.radius-toggle-btn i:last-child{transition:transform .2s ease}.radius-toggle-btn.expanded i:last-child{transform:rotate(180deg)}#modalRadiusControls{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color)}#modalRadiusSlider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;-webkit-appearance:none}#modalRadiusSlider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer}#modalRadiusSlider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer;border:none}.search-location-input-wrapper{position:relative}.route-filter-section{margin-top:15px;padding:12px;background:var(--card-bg);border-radius: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:none;-webkit-appearance:none}#routeFilterSlider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer}#routeFilterSlider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--link-color);cursor:pointer;border:none}#routeFilterSlider:disabled{opacity:.5;cursor:not-allowed}.search-preview-marker{background:transparent}.search-preview-marker-inner{width:24px;height:24px;background:#2196f3;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.search-preview-marker-inner i{transform:rotate(45deg);color:#fff;font-size:14px}.search-preview-marker-inner:hover{background:#1976d2;transform:rotate(-45deg) scale(1.1);box-shadow:0 4px 12px #2196f380}@media(max-width:768px){.footer-bar{padding:0 9px;height:auto;min-height:38px}.footer-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-popup-wrapper{min-width:unset;max-width:calc(100vw - 24px)!important;max-height:400px;width:calc(100vw - 24px)!important;box-sizing:border-box;overflow:hidden}.poi-popup-content{max-height:300px}.leaflet-popup-content-wrapper{max-height:350px;max-width:calc(100vw - 20px)!important;width:auto!important;overflow:hidden}.leaflet-popup-content{margin:6px 8px!important;width:auto!important;max-width:100%!important;overflow:hidden}.poi-popup-content-scrollable{max-width:100%;overflow-x:hidden;box-sizing:border-box}.poi-info-grid-2col{grid-template-columns:1fr;gap:3px;margin-bottom:6px;max-width:100%;box-sizing:border-box}.poi-info-item{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:2px 0}.poi-info-item i{margin-right:3px;font-size:11px}.poi-info-label{font-size:10px}.poi-name-edit{gap:4px}.poi-popup-input{font-size:16px}.poi-popup-save-btn,.poi-popup-cancel-btn{min-width:36px;padding:8px}.poi-popup-save-btn svg,.poi-popup-cancel-btn svg{width:18px;height:18px}.poi-popup-actions-footer{gap:2px;padding-top:6px;max-width:100%;box-sizing:border-box;flex-wrap:wrap}.poi-popup-btn-navigate,.poi-popup-btn-street,.poi-popup-btn-osm,.poi-popup-btn-delete,.poi-popup-btn-coords{padding:6px 8px!important;font-size:0!important;gap:0!important;min-width:unset!important;flex:0 0 auto!important}.poi-popup-btn-navigate span,.poi-popup-btn-street span,.poi-popup-btn-osm span,.poi-popup-btn-delete span,.poi-popup-btn-coords span{display:none!important}.poi-popup-btn-navigate svg,.poi-popup-btn-street svg,.poi-popup-btn-osm svg,.poi-popup-btn-delete svg,.poi-popup-btn-coords svg,.poi-popup-btn-navigate i,.poi-popup-btn-street i,.poi-popup-btn-osm i,.poi-popup-btn-delete i,.poi-popup-btn-coords i{width:14px!important;height:14px!important;font-size:14px!important}.poi-popup-header{margin-bottom:6px}.poi-popup-title{font-size:14px}.poi-popup-badge{padding:1px 6px;font-size:10px;margin-left:4px}.poi-nearby-header{padding:6px 8px;font-size:12px}.poi-nearby-content{max-width:100%;overflow:hidden}.poi-category-row{font-size:11px}}.poi-popup-wrapper{display:flex;flex-direction:column;min-width:380px;max-width:450px;max-height:600px}.poi-popup-content-scrollable{flex:1;overflow-y:visible;overflow-x:hidden;padding-bottom:8px}.leaflet-popup-content-wrapper{max-height:600px}@media(max-width:768px){.leaflet-popup-content-wrapper{max-height:400px}}.leaflet-popup-content{margin:8px 10px!important}.leaflet-popup-content p{margin:3px 0!important}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background-color:var(--sidebar-bg)}body.dark-mode .leaflet-popup-content-wrapper,body.dark-mode .leaflet-popup-tip{background-color:#2a2a2a}.leaflet-popup{margin-bottom:60px;z-index:2000!important}.poi-popup-header{margin-bottom:8px}.poi-name-display{display:flex;align-items:center;gap:8px}.poi-name-edit{display:none;align-items:center;gap:6px;flex-wrap:nowrap!important}.poi-name-edit[style*="display: block"],.poi-name-edit[style*="display: flex"]{display:flex!important}.poi-editing-name .leaflet-popup-close-button{display:none!important}.poi-popup-title{margin:0;flex:1;display:flex;align-items:center;gap:6px;font-size:16px;font-weight:600}.poi-popup-badge{display:inline-block;color:#fff;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:700;margin-left:8px;display:inline-flex;align-items:center;gap:4px}.poi-popup-badge svg{width:14px;height:14px;fill:currentColor}.poi-popup-badge-info{background:#2196f3}.poi-popup-badge-alert{background:#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:none;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-save-btn,.poi-popup-cancel-btn{padding:6px 8px;border:none;border-radius:4px;cursor:pointer;font-size:11px;flex:0 0 auto;min-width:32px;display:flex;align-items:center;justify-content:center;gap:4px;font-weight:500;transition:background .2s}.poi-popup-save-btn svg,.poi-popup-cancel-btn svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}.poi-popup-save-btn{background:#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-navigate,.poi-popup-btn-street,.poi-popup-btn-osm,.poi-popup-btn-coords,.poi-popup-btn-delete{padding:6px 8px;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:3px;transition:background .2s;flex:1;min-width:44px;white-space:nowrap}.poi-popup-btn-navigate i,.poi-popup-btn-street i,.poi-popup-btn-osm i,.poi-popup-btn-coords i,.poi-popup-btn-delete i{font-size:13px;flex-shrink:0}.poi-popup-btn-navigate{background:#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-coords{background:#9c27b0}.poi-popup-btn-coords:hover{background:#7b1fa2}.poi-popup-btn-delete{background:#f44336}.poi-popup-btn-delete:hover{background:#e53935}body.dark-mode .poi-popup-btn-navigate{background:#2196f3}body.dark-mode .poi-popup-btn-navigate:hover{background:#42a5f5}body.dark-mode .poi-popup-btn-street{background:#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-coords{background:#ab47bc}body.dark-mode .poi-popup-btn-coords:hover{background:#ba68c8}body.dark-mode .poi-popup-btn-delete{background:#ef5350}body.dark-mode .poi-popup-btn-delete:hover{background:#f44336}.poi-popup-btn-fetch-elevation{padding:8px 12px;background:var(--link-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .2s}.poi-popup-btn-fetch-elevation:hover{background:var(--link-hover)}.poi-popup-btn-fetch-elevation i{font-size:14px}.poi-popup-btn-fetch-all-elevations{padding:8px 12px;background:#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}.poi-popup-btn-show-coords{padding:8px 12px;background:var(--link-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .2s}.poi-popup-btn-show-coords:hover{background:var(--link-hover)}.poi-popup-btn-show-coords i{font-size:14px}.poi-coordinates-section{display:none;background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;padding:8px;margin-top:8px}.poi-coordinates-content{display:flex;gap:8px;align-items:center;font-size:.85em;font-family:monospace}.poi-coordinates-copy-btn{background:transparent;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;color:var(--text-color);transition:all .2s ease;display:inline-flex;align-items:center;gap:4px}.poi-coordinates-copy-btn:hover{background:var(--primary-green);color:#fff}.poi-coordinates-copy-btn i{font-size:12px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reload-confirm-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:100000;align-items:center;justify-content:center}.reload-confirm-modal.active{display:flex}.reload-confirm-modal-content{background:var(--card-bg);border-radius:12px;width:90%;max-width:480px;box-shadow:0 8px 32px #0000004d;animation:modalSlideIn .3s ease}.reload-confirm-modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color)}.reload-confirm-modal-header h3{margin:0;font-size:20px;color:var(--text-color)}.reload-confirm-modal-body{padding:24px}.reload-confirm-modal-body p{margin:0 0 12px;color:var(--text-color);line-height:1.5}.reload-confirm-modal-body p:first-child{font-size:15px}.reload-confirm-modal-body ul{margin:12px 0 0;padding-left:24px;color:var(--text-secondary);list-style-type:disc}.reload-confirm-modal-body ul li{margin:8px 0;font-size:14px}.reload-confirm-modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}.reload-modal-last-saved{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);margin-bottom:8px;padding:8px 12px;background:var(--surface-alt);border-radius:6px;border-left:3px solid var(--primary-color)}.reload-modal-last-saved i{font-size:14px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.reload-confirm-modal-content{width:95%;max-width:none}.reload-confirm-modal-header,.reload-confirm-modal-body,.reload-confirm-modal-footer{padding:16px}.reload-confirm-modal-footer{flex-direction:column-reverse}}.mobile-onboarding-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:100000;align-items:center;justify-content:center}.mobile-onboarding-modal.active{display:flex}.mobile-onboarding-modal-content{background:var(--card-bg);border-radius:16px;width:90%;max-width:360px;box-shadow:0 8px 32px #0006;animation:modalSlideIn .3s ease;overflow:hidden}.mobile-onboarding-modal-header{padding:20px 24px;background:linear-gradient(135deg,#1976d2,#0d47a1);text-align:center}.mobile-onboarding-modal-header h3{margin:0;font-size:20px;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px}.mobile-onboarding-modal-header i{font-size:24px}.mobile-onboarding-modal-body{padding:24px;text-align:center}.mobile-onboarding-illustration{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}.mobile-onboarding-icon-container{width:56px;height:56px;border-radius:12px;background:var(--surface-alt, #f5f5f5);display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color)}.mobile-onboarding-icon-container i{font-size:28px;color:var(--primary-green)}.mobile-onboarding-arrow{color:var(--text-secondary);font-size:20px}.mobile-onboarding-modal-body p{margin:0;color:var(--text-color);font-size:14px;line-height:1.6}.mobile-onboarding-modal-body strong{color:var(--primary-green)}.mobile-onboarding-modal-footer{padding:16px 24px 20px;display:flex;flex-direction:column;gap:12px;align-items:center}.mobile-onboarding-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.mobile-onboarding-checkbox input{cursor:pointer}.mobile-onboarding-modal-btn{width:100%;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;background:var(--primary-green);color:#fff}.mobile-onboarding-modal-btn:hover{background:#45a049;transform:translateY(-1px);box-shadow:0 4px 12px #4caf5066}.mobile-onboarding-modal-btn:active{transform:translateY(0)}.gpx-summary-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;background:var(--card-bg);padding:10px;border-radius:6px;border:1px solid var(--border-color)}.gpx-summary-stat{display:flex;flex-direction:row;align-items:center;gap:6px;font-size:11px;padding:6px 8px;background:var(--bg-color);border-radius:4px;min-width:0}.gpx-summary-stat i{font-size:11px;flex-shrink:0}.gpx-summary-stat .stat-label{color:var(--text-secondary);font-weight:500;font-size:10px;white-space:nowrap}.gpx-summary-stat .stat-value{color:var(--link-color);font-weight:600;font-size:11px;white-space:nowrap;flex-shrink:0}@media(max-width:768px){#gpxSummaryModal .modal-content{max-width:95%;margin:20px auto}.gpx-summary-stats-grid{gap:4px;padding:8px}.gpx-summary-stat{padding:4px 6px;gap:4px}.gpx-summary-stat i{font-size:10px}.gpx-summary-stat .stat-label{font-size:9px}.gpx-summary-stat .stat-value{font-size:10px}}@media(min-width:769px){#gpxSummaryModal .modal-content{max-height:95vh}}.custom-flag-marker{pointer-events:auto!important}.simple-flag-marker{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.simple-flag-marker i{font-size:24px;color:#1976d2;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));line-height:1}.flag-marker{pointer-events:auto!important}.flag-marker i{font-size:28px;filter:drop-shadow(0 2px 3px rgba(0,0,0,.4));line-height:1}.flag-marker.start-flag i{color:#4caf50}.flag-marker.finish-flag i{color:#e53935}#daylightInfoSection .daylight-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}#daylightInfoSection .daylight-icon{font-size:1.1rem;width:24px;text-align:center}#daylightInfoSection .daylight-label{font-weight:500;color:var(--text-color);min-width:90px}#daylightInfoSection .daylight-time{color:var(--text-color);opacity:.85}#daylightInfoSection .daylight-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1rem}#daylightInfoSection .daylight-row-compact{display:flex;align-items:center;gap:.4rem;font-size:11px}#daylightInfoSection .daylight-row-compact .daylight-icon{font-size:1rem;width:20px;text-align:center}#daylightInfoSection .daylight-row-compact .daylight-label{font-weight:500;color:var(--text-color);min-width:auto}#daylightInfoSection .daylight-row-compact .daylight-time{color:var(--text-color);opacity:.85;font-weight:600}#daylightInfoSection .daylight-day-length{grid-column:1 / -1;margin-top:.3rem;padding-top:.5rem;border-top:1px solid var(--border-color)}#addDaylightPOIsBtn{background:var(--link-color);color:#fff;border:none;border-radius: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)}.u-hidden{display:none!important}.u-block{display:block!important}.u-flex{display:flex!important}.u-grid{display:grid!important}.u-inline{display:inline!important}.u-inline-block{display:inline-block!important}.u-inline-flex{display:inline-flex!important}.u-flex-center{display:flex;align-items:center}.u-flex-center-between{display:flex;align-items:center;justify-content:space-between}.u-flex-center-justify{display:flex;align-items:center;justify-content:center}.u-align-center{align-items:center!important}.u-justify-center{justify-content:center!important}.u-justify-between{justify-content:space-between!important}.u-justify-end{justify-content:flex-end!important}.u-flex-wrap{flex-wrap:wrap!important}.u-m-0{margin:0!important}.u-mt-0{margin-top:0!important}.u-mr-0{margin-right:0!important}.u-mb-0{margin-bottom:0!important}.u-ml-0{margin-left:0!important}.u-mt-4{margin-top:4px!important}.u-mr-4{margin-right:4px!important}.u-mb-4{margin-bottom:4px!important}.u-ml-4{margin-left:4px!important}.u-mt-6{margin-top:6px!important}.u-mr-6{margin-right:6px!important}.u-ml-6{margin-left:6px!important}.u-mt-8{margin-top:8px!important}.u-mr-8{margin-right:8px!important}.u-ml-8{margin-left:8px!important}.u-mt-10{margin-top:10px!important}.u-mr-10{margin-right:10px!important}.u-ml-10{margin-left:10px!important}.u-mt-12{margin-top:12px!important}.u-mr-12{margin-right:12px!important}.u-mb-12{margin-bottom:12px!important}.u-ml-12{margin-left:12px!important}.u-mt-16{margin-top:16px!important}.u-mr-16{margin-right:16px!important}.u-mb-16{margin-bottom:16px!important}.u-ml-16{margin-left:16px!important}.u-mt-20{margin-top:20px!important}.u-mr-20{margin-right:20px!important}.u-ml-20{margin-left:20px!important}.u-ml-auto{margin-left:auto!important}.u-mr-auto{margin-right:auto!important}.u-p-0{padding:0!important}.u-pt-0{padding-top:0!important}.u-pr-0{padding-right:0!important}.u-pb-0{padding-bottom:0!important}.u-pl-0{padding-left:0!important}.u-p-8{padding:8px!important}.u-p-10{padding:10px!important}.u-p-15{padding:15px!important}.u-p-20{padding:20px!important}.u-gap-4{gap:4px!important}.u-gap-6{gap:6px!important}.u-gap-8{gap:8px!important}.u-gap-10{gap:10px!important}.u-gap-12{gap:12px!important}.u-gap-16{gap:16px!important}.u-gap-20{gap:20px!important}.u-font-12{font-size:12px!important}.u-font-13{font-size:13px!important}.u-font-16{font-size:16px!important}.u-font-18{font-size:18px!important}.u-font-20{font-size:20px!important}.u-font-24{font-size:24px!important}.u-font-normal{font-weight:400!important}.u-font-bold{font-weight:700!important}.u-font-600{font-weight:600!important}.u-text-center{text-align:center!important}.u-text-left{text-align:left!important}.u-text-right{text-align:right!important}.u-w-100{width:100%!important}.u-w-auto{width:auto!important}.u-color-primary{color:var(--link-color)!important}.u-color-secondary{color:var(--text-secondary)!important}.u-color-tertiary{color:var(--text-tertiary)!important}.u-cursor-pointer{cursor:pointer!important}.u-no-wrap{white-space:nowrap!important}.u-valign-middle{vertical-align:middle!important}.u-valign-top{vertical-align:top!important}.u-valign-bottom{vertical-align:bottom!important}.u-checkbox-label{display:flex;align-items:center;cursor:pointer;font-weight:400}.u-modal-footer{padding:15px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.u-icon-mr{margin-right:8px;cursor:pointer}.u-icon-sm{font-size:16px}.u-icon-md{font-size:20px;margin-right:10px}.u-svg-icon-sm{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;margin-right:4px;vertical-align:middle}.u-label-bold{display:block;margin-bottom:8px;font-weight:700}.u-label-bold-13{display:block;margin-bottom:6px;font-weight:600;font-size:13px;color:var(--text-color)}.u-label-bold-12-compact{font-weight:600;font-size:12px;white-space:nowrap;min-width:120px}.u-desc-text{color:var(--text-secondary);margin-bottom:20px;line-height:1.6}.u-desc-text-sm{margin:4px 0 0 22px;font-size:11px;color:var(--text-secondary)}.u-heading-16{font-size:16px;margin-bottom:10px;color:var(--text-color)}.u-max-w-500{max-width:500px!important}.u-max-w-600{max-width:600px!important}.u-max-w-700{max-width:700px!important}.u-max-w-800{max-width:800px!important}.u-link-secondary{color:var(--text-secondary);text-decoration:none;font-size:12px;transition:color .2s}.u-link-primary-no-decoration{color:var(--link-color);text-decoration:none}.u-icon-text-16{font-size:16px;vertical-align:middle;margin-right:4px}.u-icon-text-14{font-size:14px;margin-right:4px;vertical-align:middle}.u-icon-text-12{font-size:12px;margin-right:4px}.u-font-11{font-size:11px!important}.u-input-field{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color)}.u-input-field-14{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color);font-size:14px}.u-input-field-12{width:100%;padding:6px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color);font-size:12px}.u-input-field-time{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--bg-color);color:var(--text-color)}.u-pos-absolute{position:absolute!important}.u-pos-relative{position:relative!important}.u-top-15{top:15px!important}.u-right-15{right:15px!important}.u-p-6-8{padding:6px 8px!important}.u-p-8-16{padding:8px 16px!important}.u-p-12-24{padding:12px 24px!important}.u-mb-20{margin-bottom:20px!important}.u-mb-10{margin-bottom:10px!important}.u-mb-8{margin-bottom:8px!important}.u-mb-6{margin-bottom:6px!important}.u-hidden-mb-8{display:none;margin-bottom:8px}.u-flex-1{flex:1!important}.u-font-14{font-size:14px!important}.u-max-w-450{max-width:450px!important}.u-max-w-550{max-width:550px!important}.u-pos-abs-tr-15{position:absolute;right:15px;top:15px}.u-p-12{padding:12px!important}.u-p-w-100-12{width:100%;padding:12px}.u-mt-15{margin-top:15px!important}.u-ml-18{margin-left:18px!important}.u-ml-18-italic{margin-left:18px;font-style:italic}.u-m-0-lh-16{margin:0;line-height:1.6}.u-m-0-16-0-lh-16{margin:0 0 16px;line-height:1.6}.u-m-20-0{margin:20px 0!important}.u-m-25-0-15{margin:25px 0 15px;font-size:18px;font-weight:600;color:var(--text-primary)}.u-font-10-secondary{font-size:10px;color:var(--text-secondary)}.u-font-12-secondary-mb-8{font-size:12px;color:var(--text-secondary);margin-bottom:8px}.u-font-16-mr-6{font-size:16px;margin-right:6px}.u-flex-ai-gap-8{display:flex;align-items:center;gap:8px}.u-flex-ai-flex-1{display:flex;align-items:center;flex:1}.u-flex-jc-sb-12-op7-mt6{display:flex;justify-content:space-between;font-size:12px;opacity:.7;margin-top:6px}.u-flex-ai-mb-8-gap-8{margin-bottom:8px;display:flex;align-items:center;gap:8px}.u-w-100-p-ws-nowrap-p-12-24{white-space:nowrap;padding:12px 24px}.u-modal-scroll-content{max-height:400px;overflow-y:auto;background:var(--card-bg);padding:15px;border-radius:8px;border:1px solid var(--border-color)}.u-label-11-bold-block{font-weight:600;margin-bottom:4px;display:block;font-size:11px}.u-label-12-bold-block-mb-4{display:block;font-weight:600;font-size:12px;margin-bottom:4px}.u-label-14-bold-mb-2{font-weight:600;font-size:14px;margin-bottom:2px}.u-radio-card{flex:1;padding:8px;border:2px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.u-input-flex-1-sm{flex:1;padding:5px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg);color:var(--text-color);font-size:12px}.u-input-flex-1-lg{flex:1;padding:12px;border:2px solid var(--border-color);border-radius:8px;font-size:14px;background:var(--input-bg);color:var(--text-color);transition:border-color .2s}.u-block-max-w-100{display:block;max-width:100%}.u-color-warning{color:#ff9800!important}.u-divider-h{border:none;border-top:1px solid var(--border-color);margin:20px 0}.u-preview-frame{border:1px solid var(--border-color);border-radius:4px;padding:4px;background:var(--card-bg);display:flex;align-items:center;justify-content:center}.search-button-row-single{margin-bottom:8px}.search-button-row-single .btn-primary{width:100%;justify-content:center}.search-button-row-multi{display:flex;gap:8px;flex-wrap:wrap}.deleted-count-badge{display:inline-block;background:#f44336;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;margin-left:6px;min-width:18px;text-align:center}.deleted-pois-list{max-height:400px;overflow-y:auto}.deleted-poi-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;margin-bottom:8px;transition:background .2s ease}.deleted-poi-item:hover{background:var(--bg-color)}.deleted-poi-info{flex:1;min-width:0}.deleted-poi-name{font-weight:600;font-size:14px;color:var(--text-color);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deleted-poi-meta{font-size:12px;color:var(--text-secondary);display:flex;gap:12px}.deleted-poi-actions{display:flex;gap:6px}.deleted-poi-restore-btn{padding:6px 12px;background:var(--primary-green);color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s ease;white-space:nowrap}.deleted-poi-restore-btn:hover{background:var(--primary-green-hover)}.time-estimate-warning{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#ff98001a;border-left:3px solid #ff9800;border-radius:4px;margin-bottom:12px;font-size:12px;line-height:1.4;color:var(--text-color)}.time-estimate-warning i{color:#ff9800;font-size:14px;margin-top:1px;flex-shrink:0}body.dark-mode .time-estimate-warning{background:#ff980026}.time-estimate-input-row{margin-bottom:12px}.time-estimate-speed-input{display:flex;align-items:center;gap:8px}.time-estimate-unit-toggle{display:flex;border:1px solid var(--border-color);border-radius:4px;overflow:hidden}.time-estimate-unit-btn{padding:6px 10px;background:var(--card-bg);border:none;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.time-estimate-unit-btn:not(:last-child){border-right:1px solid var(--border-color)}.time-estimate-unit-btn:hover{background:var(--bg-color)}.time-estimate-unit-btn.active{background:var(--primary-green);color:#fff}body.dark-mode .time-estimate-unit-btn{background:#333}body.dark-mode .time-estimate-unit-btn:hover{background:#444}body.dark-mode .time-estimate-unit-btn.active{background:var(--primary-green)}.time-estimate-terrain-row{margin-bottom:12px}.time-estimate-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-color)}.time-estimate-checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px}.time-estimate-terrain-info{font-size:11px;color:var(--text-secondary);margin-top:4px;margin-left:24px;font-style:italic}.time-estimate-result{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;margin-top:8px}.time-estimate-result-label{font-size:13px;font-weight:500;color:var(--text-color)}.time-estimate-result-value{font-size:18px;font-weight:600;color:var(--primary-green)}body.dark-mode .time-estimate-result-value{color:#66bb6a}.time-estimate-result-row{display:flex;align-items:center;gap:12px;margin-top:10px}.time-estimate-result-row .time-estimate-result{flex:1;margin-top:0}.time-estimate-result-row .ps-btn{white-space:nowrap}.map3d-controls-overlay{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;z-index:10}.map3d-control-group{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:10px;box-shadow:0 2px 8px #00000026;min-width:180px}.map3d-control-group label{font-size:12px;font-weight:500;color:var(--text-color);white-space:nowrap}.map3d-control-group input[type=range]{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--border-color);border-radius:2px;cursor:pointer}.map3d-control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--primary-green);border-radius:50%;cursor:pointer;transition:transform .1s ease}.map3d-control-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.map3d-control-group input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--primary-green);border:none;border-radius:50%;cursor:pointer}#map3dExaggerationValue{font-size:12px;font-weight:600;color:var(--primary-green);min-width:32px;text-align:right}.map3d-style-select{flex:1;padding:6px 28px 6px 10px;font-size:12px;font-weight:500;color:var(--text-color);background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23666' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;min-width:100px;transition:border-color .15s ease}.map3d-style-select:hover{border-color:var(--primary-green)}.map3d-style-select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 2px #4caf5033}.map3d-style-select option{background-color:var(--bg-color);color:var(--text-color);padding:8px}body.dark-mode .map3d-style-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23aaa' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E")}@media(prefers-color-scheme:dark){body:not(.light-mode) .map3d-style-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23aaa' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E")}}.map3d-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:12px;color:var(--text-color)}.map3d-toggle-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-green)}.map3d-reset-btn{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000026;transition:all .2s ease;color:var(--text-color)}.map3d-reset-btn:hover{background:var(--primary-green);border-color:var(--primary-green);color:#fff}.map3d-reset-btn i{font-size:16px}#map3dContainer{background:var(--card-bg)}#map3dLoading .loading-spinner{border:3px solid var(--border-color);border-top-color:var(--primary-green);animation:spin 1s linear infinite}body.dark-mode .map3d-control-group,body.dark-mode .map3d-reset-btn{background:#2a2a2a;border-color:#444}body.dark-mode .map3d-reset-btn:hover{background:#66bb6a;border-color:#66bb6a}body.dark-mode #map3dExaggerationValue{color:#66bb6a}body.dark-mode .map3d-control-group input[type=range]{background:#444}body.dark-mode .map3d-control-group input[type=range]::-webkit-slider-thumb{background:#66bb6a}body.dark-mode .map3d-control-group input[type=range]::-moz-range-thumb{background:#66bb6a}.maplibregl-popup.map3d-popup .maplibregl-popup-content{background:#fff;color:#333;padding:10px;border-radius:4px;box-shadow:0 2px 8px #00000026}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button{color:#333;font-size:18px;padding:4px 8px}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button:hover{background-color:#0000000d}.map3d-popup-content{color:#333}.map3d-popup-category{color:#666}body.dark-mode .maplibregl-popup.map3d-popup .maplibregl-popup-content{background:#2a2a2a;color:#e0e0e0}body.dark-mode .map3d-popup-content{color:#e0e0e0}body.dark-mode .map3d-popup-category{color:#aaa}body.dark-mode .maplibregl-popup.map3d-popup .maplibregl-popup-close-button{color:#e0e0e0}body.dark-mode .maplibregl-popup.map3d-popup .maplibregl-popup-close-button:hover{background-color:#ffffff1a}.maplibregl-marker{left:0!important;top:0!important;position:absolute!important;transition:opacity .2s!important;will-change:transform!important;margin:0!important;padding:0!important;pointer-events:auto!important;box-sizing:content-box!important}@media(max-width:768px){.map3d-controls-overlay{top:8px;right:8px}.map3d-control-group{padding:8px 10px;min-width:150px}.map3d-control-group label,#map3dExaggerationValue{font-size:11px}}@media(prefers-color-scheme:dark){.map3d-control-group,.map3d-reset-btn{background:#2a2a2a;border-color:#444}.map3d-reset-btn:hover{background:#66bb6a;border-color:#66bb6a}#map3dExaggerationValue{color:#66bb6a}.map3d-control-group input[type=range]{background:#444}.map3d-control-group input[type=range]::-webkit-slider-thumb{background:#66bb6a}.map3d-control-group input[type=range]::-moz-range-thumb{background:#66bb6a}.maplibregl-popup.map3d-popup .maplibregl-popup-content{background:#2a2a2a;color:#e0e0e0}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button{color:#e0e0e0}.maplibregl-popup.map3d-popup .maplibregl-popup-close-button:hover{background-color:#ffffff1a}}
