@keyframes shimmer{0%{background-position:200%0}to{background-position:-200%0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUpBanner{0%{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@font-face{font-family:"Nunito";src:url(https://cdn.foxride.app/fonts/nunito-latin.woff2)format("woff2");font-weight:400 800;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"Nunito";src:url(https://cdn.foxride.app/fonts/nunito-latin-ext.woff2)format("woff2");font-weight:400 800;font-style:normal;font-display:swap;unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"Nunito";src:url(https://cdn.foxride.app/fonts/nunito-italic.woff2)format("woff2");font-weight:400;font-style:italic;font-display:swap}*{margin:0;padding:0;box-sizing:border-box}:root{--color-accent:#4FC3F7;--color-accent-light:#81D4FA;--color-accent-rgb:79, 195, 247;--color-text-primary:#1a1a1a;--color-text-secondary:#888;--color-text-muted:#999;--color-text-light:#666;--color-bg-primary:#f5f5f5;--color-bg-surface:#ffffff;--color-bg-hover:#f8f8f8;--color-bg-input:#f5f5f5;--color-border:#eee;--color-border-medium:#e8e8e8;--color-border-light:#f0f0f0;--color-bg-subtle:#fafafa;--color-btn-primary-bg:#4FC3F7;--color-btn-primary-text:#ffffff;--color-btn-primary-hover:#39a8d8;--color-skeleton:#e8e8e8;--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--color-error-light:#fee2e2;--color-error-dark:#dc2626;--color-marker-start:#00d4aa;--color-marker-end:#4FC3F7;--color-marker-via:#141c24;--color-poi-bicycle:#22c55e;--color-poi-parking:#64748b;--color-poi-cafe:#f59e0b;--color-poi-restaurant:#ef4444;--color-poi-water:#4FC3F7;--color-poi-toilets:#8b5cf6;--color-poi-supermarket:#10b981;--color-poi-pharmacy:#ec4899;--color-poi-hotel:#6366f1;--shadow-sm:0 2px 8px rgba(0, 0, 0, 0.08);--shadow-md:0 8px 32px rgba(0, 0, 0, 0.12);--shadow-lg:0 20px 60px rgba(0, 0, 0, 0.15);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--focus-ring:0 0 0 3px rgba(79, 195, 247, 0.4);--focus-ring-offset:0 0 0 2px var(--color-bg-surface)}body{font-family:"Nunito",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--color-bg-primary);overflow:hidden;height:100vh;height:100dvh;width:100vw}.skip-to-content{position:absolute;top:-100%;left:16px;z-index:100000;padding:12px 24px;background:var(--color-accent);color:#fff;font-weight:700;font-size:.875rem;border-radius:var(--radius-sm);text-decoration:none;transition:top .2s ease}.skip-to-content:focus{top:16px}#map,.top-progress-bar{position:fixed;top:0;left:0}#map{width:100vw;height:100vh;height:100dvh;z-index:1}.top-progress-bar{right:0;height:3px;background:rgba(0,0,0,.05);z-index:10000;opacity:0;visibility:hidden;transition:opacity .3s ease}.top-progress-bar.active{opacity:1;visibility:visible}.top-progress-fill{height:100%;background:var(--color-accent);width:0%;border-radius:0 2px 2px 0;transition:width .3s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .top-progress-bar{background:rgba(255,255,255,.05)}[data-theme=dark] .top-progress-fill{background:#81d4fa}.floating-panel,.icon-strip,body{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.floating-panel{position:fixed;top:20px;left:20px;bottom:20px;z-index:100;display:flex;background:var(--color-bg-surface);border-radius:20px;box-shadow:var(--shadow-md);overflow:hidden}.icon-strip{width:56px;background:var(--color-bg-subtle);border-right:1px solid var(--color-border-medium);display:flex;flex-direction:column;padding:0}.icon-strip-top{padding:0 8px;display:flex;justify-content:center;align-items:center;height:64px}.icon-strip-top .user-btn{position:relative}.icon-strip-top .user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.icon-strip-top .login-icon{display:block}.icon-strip-top .user-btn.logged-in .login-icon{display:none}.icon-strip-top .user-btn.logged-in .user-avatar{display:block!important}.icon-strip-center,.icon-strip-top .user-initial{display:flex;align-items:center;justify-content:center}.icon-strip-top .user-initial{width:36px;height:36px;border-radius:50%;background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text);font-size:14px;font-weight:600}.icon-strip-center{flex:1;flex-direction:column;gap:4px;padding:0 8px}.icon-strip-bottom{padding:0 8px 16px;display:flex;justify-content:center}.icon-strip-item{width:40px;height:40px;border:0;background:0 0;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:all .2s ease;text-decoration:none;font-size:18px}.icon-strip-item:hover{background:var(--color-bg-hover);color:var(--color-text-light)}.icon-strip-item.active{background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text)}.sidebar-content{width:300px;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{position:relative;padding:0 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #e0e0e0;height:64px}.sidebar-logo{width:32px;height:32px;border-radius:8px}.sidebar-title{font-size:17px;font-weight:600;color:var(--color-text-primary);flex:1}#calc-route-mobile{display:none!important}.header-action-btn{display:none;padding:6px 12px;font-size:12px;white-space:nowrap}.sidebar-title span{font-weight:400;color:var(--color-text-secondary)}.menu-btn{width:36px;height:36px;border:0;background:0 0;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-light);transition:background .2s}.menu-btn:hover{background:var(--color-bg-primary)}.filter-chips{display:flex;gap:8px;padding:16px 20px}.chip{flex:1;padding:10px 16px;border:0;background:var(--color-bg-primary);border-radius:20px;font-size:13px;font-weight:500;color:var(--color-text-light);cursor:pointer;transition:all .2s ease}.chip:hover{background:var(--color-border-medium)}.chip.active{background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text)}.panel-content{flex:1;padding:16px 20px 20px;overflow-y:auto;display:none;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.panel-content::-webkit-scrollbar{width:6px}.panel-content::-webkit-scrollbar-track{background:0 0}.panel-content::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:3px}.panel-content::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.25)}.panel-content.active{display:flex!important}.waypoints-list{display:flex;flex-direction:column;gap:8px}.add-stop-btn,.profile-scroll-bar,.waypoint-dot-col{display:none}.waypoint-content{flex:1;min-width:0}.waypoint-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-bg-subtle);border:1px solid var(--color-border-medium);border-radius:10px;transition:border-color .2s}.waypoint-item:hover{border-color:#d0d0d0}.waypoint-item.highlighted{border-color:#4fc3f7;background:#e0f2fe}.waypoint-marker{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.waypoint-marker.start{background:#22c55e}.waypoint-marker.end{background:#4fc3f7}.waypoint-marker.via{background:#f59e0b}.waypoint-marker.poi{border-radius:8px;font-size:14px;font-weight:400}.waypoint-info{flex:1;min-width:0}.waypoint-label{font-size:12px;font-weight:600;color:var(--color-text-primary)}.waypoint-coords{font-size:11px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.waypoint-coords.empty{color:#bbb;font-style:italic}.waypoint-remove{width:24px;height:24px;border:0;background:0 0;border-radius:6px;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.waypoint-remove:hover{background:var(--color-error-light);color:var(--color-error-dark)}.waypoints-hint{font-size:12px;color:var(--color-text-secondary);text-align:center;padding:8px}.card{background:var(--color-bg-subtle);border:1px solid var(--color-border-medium);border-radius:12px;padding:16px;transition:border-color .2s}.card:hover,.profile-compact:hover{border-color:#d0d0d0}#routes-list,.card-header{display:flex;flex-direction:column;gap:8px}.card-title{font-size:14px;font-weight:600;color:var(--color-text-primary)}.card-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;width:fit-content}.badge-waiting{background:var(--color-bg-primary);color:var(--color-text-secondary)}.badge-progress{background:#fff3cd;color:#856404}.badge-ready{background:#d4f5e9;color:#0d6f4c}.profile-compact{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--color-bg-subtle);border:1px solid var(--color-border-medium);border-radius:12px;cursor:pointer;transition:border-color .2s}.profile-compact-icon{font-size:20px}.profile-compact-text{flex:1;display:flex;flex-direction:column;gap:2px}.profile-compact-name{font-size:14px;font-weight:500;color:var(--color-text-primary)}.profile-compact-desc{font-size:12px;color:var(--color-text-light)}.profile-compact svg{color:var(--color-text-muted)}.sidebar-actions{display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:16px}.sidebar-actions .btn-primary,.sidebar-actions .btn-secondary{width:100%}.sidebar-actions .btn-reset{order:-1}.btn-primary{flex:1;padding:12px 20px;background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text);border:0;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;text-align:center;text-decoration:none;display:inline-block}.btn-primary:hover:not(:disabled){background:var(--color-btn-primary-hover)}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-loading{position:relative;pointer-events:none;opacity:.7}.bottom-bar-btn.btn-loading::after,.btn-loading::after{content:"";position:absolute;width:14px;height:14px;top:50%;right:12px;margin-top:-7px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}.btn-success{transition:background .3s ease}.bottom-bar-btn.btn-loading{opacity:.7;pointer-events:none;position:relative}.bottom-bar-btn.btn-loading::after{width:12px;height:12px;right:8px;margin-top:-6px}.bottom-bar-btn.btn-success,.btn-success{background:#22c55e!important;pointer-events:none}.bottom-bar-btn.btn-success{color:#fff!important}.btn-secondary{padding:12px 20px;background:var(--color-bg-primary);color:var(--color-text-light);border:0;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:var(--color-border-medium)}.account-login-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 20px;gap:8px}.account-login-icon{color:var(--color-text-secondary);margin-bottom:8px}.account-login-title{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0}.account-login-desc{font-size:13px;color:var(--color-text-secondary);margin:0 0 12px;line-height:1.4}.account-login-btn{display:inline-block;text-decoration:none;cursor:pointer;padding:10px 24px;font-size:14px}.panel-title{font-size:14px;font-weight:600;color:#333;margin:0 0 12px;padding:0}.routes-empty{text-align:center;padding:40px 20px;color:var(--color-text-muted);font-size:14px}.route-item,.route-item-icon{display:flex;align-items:center}.route-item{gap:12px;padding:12px 14px;background:var(--color-bg-subtle);border:1px solid var(--color-border-medium);border-radius:10px;cursor:pointer;transition:all .2s}.route-item:hover{background:#f0f0f0;border-color:#d0d0d0}.route-item-icon{font-size:20px;width:32px;height:32px;justify-content:center;background:#f0f0f0;border-radius:8px;flex-shrink:0}.route-item-info{flex:1;min-width:0}.route-item-name{font-size:14px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-item-stats{font-size:12px;color:var(--color-text-light);margin-top:2px}.route-item-delete{background:0 0;border:0;padding:6px;cursor:pointer;font-size:14px;opacity:.5;transition:opacity .2s;border-radius:6px}.route-item-delete:hover{opacity:1;background:rgba(239,68,68,.1)}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.route-item.skeleton-item{pointer-events:none;opacity:.6}.route-item.skeleton-item .route-item-icon,.route-item.skeleton-item .route-item-name{background:var(--color-skeleton);color:transparent}.route-item.skeleton-item .route-item-name{border-radius:4px;width:60%;display:inline-block}.route-item.skeleton-item .route-item-stats{border-radius:4px;width:40%;display:inline-block;margin-top:4px}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#2a2a2a 25%,#333 50%,#2a2a2a 75%);background-size:200% 100%}[data-theme=dark] .poi-list-item.skeleton-item .poi-list-icon,[data-theme=dark] .poi-list-item.skeleton-item .poi-list-name,[data-theme=dark] .poi-list-item.skeleton-item .poi-list-type,[data-theme=dark] .route-item.skeleton-item .route-item-icon,[data-theme=dark] .route-item.skeleton-item .route-item-name,[data-theme=dark] .route-item.skeleton-item .route-item-stats{background:#333}.poi-list-item.skeleton-item{pointer-events:none;opacity:.6;flex:1;min-height:40px}.poi-list-item.skeleton-item .poi-list-icon,.route-item.skeleton-item .route-item-stats{background:var(--color-skeleton);color:transparent}.poi-list-item.skeleton-item .poi-list-name,.poi-list-item.skeleton-item .poi-list-type{background:var(--color-skeleton);color:transparent;border-radius:4px;width:70%;display:inline-block}.poi-list-item.skeleton-item .poi-list-type{width:40%;margin-top:4px}.bottom-bar{position:fixed;bottom:20px;left:396px;right:20px;background:var(--color-bg-surface);border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,.12);z-index:100;display:none;flex-wrap:nowrap;align-items:center;padding:16px 24px;gap:24px;opacity:0;transform:translateY(20px);transition:opacity .4s ease,transform .4s ease}.bottom-bar.visible{opacity:1;transform:translateY(0)}.bottom-bar-left{display:flex;align-items:center;gap:16px;flex-shrink:0}.bottom-bar-title{font-size:18px;font-weight:700;color:var(--color-text-primary)}.bottom-bar-btn{padding:10px 16px;background:var(--color-btn-primary-bg);border:0;border-radius:10px;font-size:13px;font-weight:600;color:var(--color-btn-primary-text);cursor:pointer;transition:all .2s}.bottom-bar-btn:hover{background:var(--color-btn-primary-hover)}.bottom-bar-stats{display:flex;gap:16px;padding:0 16px;border-left:1px solid var(--color-border-medium);flex-shrink:0;justify-content:center}.stat-item{display:flex;flex-direction:column;gap:2px;white-space:nowrap;text-align:center}.stat-label{font-size:10px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;font-weight:500}.stat-value{font-size:18px;font-weight:700;color:var(--color-text-primary)}.bottom-bar-credits,.bottom-bar-elevation{border-left:1px solid var(--color-border-medium)}.bottom-bar-elevation{flex:1;min-width:200px;height:60px;padding:0 16px;position:relative}.bottom-bar-elevation canvas{width:100%!important;height:100%!important}.bottom-bar-credits{font-size:10px;color:var(--color-text-secondary);padding-left:16px;flex-shrink:0;white-space:nowrap;margin-left:auto;align-self:stretch;display:flex;align-items:flex-end;justify-content:center}.bottom-bar-credits a,.floating-credits a{color:var(--color-text-light);text-decoration:none}.bottom-bar-credits a:hover,.floating-credits a:hover{text-decoration:underline}.floating-credits,.loading-overlay{position:fixed;background:rgba(255,255,255,.9)}.floating-credits{bottom:20px;right:20px;padding:8px 14px;border-radius:8px;font-size:10px;color:var(--color-text-secondary);z-index:90;box-shadow:var(--shadow-sm);display:flex;align-items:flex-end}.loading-overlay{top:0;left:0;right:0;bottom:0;z-index:1000;display:none;align-items:center;justify-content:center}.loading-overlay.visible{display:flex}.spinner{width:40px;height:40px;border:3px solid var(--color-border-medium);border-top-color:var(--color-text-primary);border-radius:50%;animation:spin .8s linear infinite}.modal-header h3,.toast{color:var(--color-text-primary)}.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--color-bg-surface);padding:12px 24px;border-radius:10px;font-size:14px;font-weight:500;z-index:2000;opacity:0;visibility:hidden;transition:all .3s ease;box-shadow:0 4px 16px rgba(0,0,0,.15);border:1px solid rgba(0,0,0,.1)}.toast.visible{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.toast.above-bar{bottom:140px}.toast-content{display:flex;align-items:center;gap:12px}.toast-action{padding:4px 12px;background:rgba(0,0,0,.1);border:0;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;color:inherit;font-family:inherit;transition:background .2s;white-space:nowrap}.toast-action:hover{background:rgba(0,0,0,.2)}[data-theme=dark] .toast{background:#2a2a2a;color:#f5f5f5;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 16px rgba(0,0,0,.4)}[data-theme=dark] .toast-action{background:rgba(255,255,255,.1)}[data-theme=dark] .toast-action:hover{background:rgba(255,255,255,.2)}.offline-banner{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:var(--color-error);color:#fff;font-size:13px;font-weight:600;z-index:3000;transform:translateY(-100%);transition:transform .3s ease}.offline-banner.visible{transform:translateY(0)}.offline-banner svg{flex-shrink:0}.stagger-item{animation:fadeInUp .3s ease forwards;opacity:0}.leaflet-dragging .leaflet-marker-icon{filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));transition:filter .15s ease}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:0 0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .25s ease,background .25s ease,visibility .25s}.modal-overlay.visible{opacity:1;visibility:visible;background:rgba(0,0,0,.5)}.modal{background:var(--color-bg-surface);border-radius:16px;width:100%;max-width:400px;box-shadow:0 8px 40px rgba(0,0,0,.2);overflow:hidden;transform:scale(.95) translateY(10px);transition:transform .25s ease}.modal-overlay.visible .modal{transform:scale(1) translateY(0)}.modal-wide{max-width:600px}.modal-close,.modal-header{display:flex;align-items:center}.modal-header{justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e0e0e0}.modal-header h3{font-size:18px;font-weight:600}.modal-close{width:32px;height:32px;border:0;background:var(--color-bg-primary);border-radius:8px;font-size:20px;color:var(--color-text-light);cursor:pointer;justify-content:center;transition:background .2s}.modal-close:hover{background:var(--color-border-medium)}.modal-body{padding:24px}.modal-input{width:100%;padding:14px 16px;border:1px solid #e0e0e0;border-radius:10px;font-size:15px;font-family:inherit;transition:border-color .2s}.modal-input:focus{outline:0;border-color:var(--color-text-primary)}.modal-footer{display:flex;gap:12px;padding:16px 24px 24px}.modal-footer .btn-primary,.modal-footer .btn-secondary{flex:1}.btn-danger{flex:1;padding:12px 20px;background:#dc3545;color:#fff;border:0;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-danger:hover{background:#c82333}.pro-features{list-style:none;margin-top:16px}.pro-features li{padding:8px 0;color:#333;font-size:14px}.profile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.profile-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;background:var(--color-bg-subtle);border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:center}.profile-option:hover{background:#f0f0f0}.profile-option.active{border-color:var(--color-text-primary);background:var(--color-bg-surface)}.profile-icon{font-size:24px}.app-promo-text strong,.profile-name{font-size:13px;font-weight:600;color:var(--color-text-primary)}.profile-desc{font-size:11px;color:var(--color-text-secondary)}.user-dropdown{position:absolute;top:100%;right:20px;background:var(--color-bg-surface);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);min-width:200px;z-index:200;display:none;overflow:hidden}.user-dropdown.visible{display:block}.leaflet-control-zoom{border:0!important;box-shadow:0 2px 12px rgba(0,0,0,.15)!important;border-radius:10px!important;overflow:hidden}.leaflet-control-zoom a{width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important;color:#333!important;background:#fff!important;border:0!important}.leaflet-control-zoom a:hover{background:#f5f5f5!important}.leaflet-control-attribution{display:none!important}.custom-marker{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-weight:700;font-size:12px;box-shadow:0 2px 8px rgba(0,0,0,.2);border:2px solid #fff;transition:transform .2s ease,box-shadow .2s ease}.custom-marker-highlighted{transform:scale(1.5);box-shadow:0 0 12px 4px rgba(59,130,246,.5)}.custom-div-icon:has(.custom-marker-highlighted){z-index:1000!important}.custom-marker.start{background:#22c55e;color:#fff}.custom-marker.end{background:#4fc3f7;color:#fff}.custom-marker.via{background:#f59e0b;color:#fff}.layer-switcher-control{margin-top:10px!important}.leaflet-touch .layer-switcher-control{border:0!important;box-shadow:none!important}.layer-switcher-btn{width:36px!important;height:36px!important;background:#fff!important;border:0!important;border-radius:10px!important;display:flex!important;align-items:center;justify-content:center;font-size:16px;cursor:pointer;box-shadow:0 2px 12px rgba(0,0,0,.15)!important}.layer-switcher-dropdown{display:none;position:absolute;top:0;right:46px;background:var(--color-bg-surface);border-radius:10px;overflow:hidden;min-width:160px;box-shadow:0 4px 16px rgba(0,0,0,.12)}.layer-switcher-dropdown.visible{display:block}.layer-option{padding:12px 16px;font-size:13px;color:var(--color-text-light);cursor:pointer;transition:all .15s ease;border-bottom:1px solid #e0e0e0}.layer-option:last-child{border-bottom:none}.layer-option:hover{background:var(--color-bg-primary);color:var(--color-text-primary)}.layer-option.active{background:var(--color-bg-hover);color:var(--color-text-primary);font-weight:500}.mobile-elevation-slot,.mobile-tab-bar{display:none}@media (max-width:768px){.floating-panel{top:auto;left:0;right:0;bottom:0;width:100%;max-height:55vh;border-radius:20px 20px 0 0;flex-direction:column;transition:max-height .3s cubic-bezier(.4,0,.2,1)}.floating-panel.sheet-collapsed{max-height:120px;overflow:hidden}.floating-panel.sheet-half{max-height:55vh}.floating-panel.sheet-expanded{max-height:85vh}.icon-strip{display:none}.sidebar-content{width:100%;min-height:0;overflow:hidden}.sidebar-header{flex-shrink:0;padding:0 16px;border-bottom:1px solid #e0e0e0;cursor:grab;user-select:none;-webkit-user-select:none}.sidebar-header:active{cursor:grabbing}.sidebar-header::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);background:#d0d0d0;border-radius:2px;width:32px;height:4px;opacity:.4}.mobile-tab-bar{display:flex;gap:4px;padding:8px 16px;border-bottom:1px solid var(--color-border-medium);background:var(--color-bg-surface);flex-shrink:0}.mobile-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;border:0;background:0 0;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;font-family:inherit}.mobile-tab.active{background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text)}.mobile-tab svg{flex-shrink:0}#calc-route-mobile{display:block!important}.header-action-btn{display:block;flex:none;flex-shrink:0;margin-left:auto;white-space:nowrap}.header-action-btn.btn-reset-mobile{background:rgba(239,68,68,.15);color:#ef4444;border:0}.sidebar-title{flex:1}.panel-content{gap:10px;overflow-y:auto;flex:1;min-height:0}.profile-compact{padding:10px 14px;flex-shrink:0}.waypoints-list{flex-shrink:0;max-height:none}.waypoints-hint{padding:8px 0;flex-shrink:0}.sidebar-actions{display:none}.btn-primary,.btn-secondary{padding:12px 20px;font-size:14px}.bottom-bar{left:0;right:0;bottom:0;border-radius:0;padding:10px 16px;gap:10px;flex-direction:row;flex-wrap:nowrap;align-items:center;z-index:150;border-top:1px solid #404040}.bottom-bar-left{gap:8px;order:2;flex-shrink:0}.bottom-bar-stats{flex:1;justify-content:space-around;gap:4px;flex-wrap:nowrap;border:0;padding:0;order:1}.stat-item{min-width:auto;align-items:center;flex:1}.stat-label{font-size:8px}.stat-value{font-size:11px}.bottom-bar-elevation{display:none}.mobile-elevation-slot{display:block}.mobile-elevation-slot .bottom-bar-elevation{display:block;width:100%;height:100px;padding:0;border:0;border-top:1px solid #e0e0e0;margin-top:8px;border-radius:8px;overflow:hidden}.bottom-bar-credits{display:none}.floating-credits{bottom:8px;right:8px;padding:6px 10px;font-size:9px}.modal{max-width:none;max-height:85vh}.modal,.modal-wide{width:calc(100% - 32px)}.modal-body,.modal-footer,.modal-header{padding:16px 20px}.profile-grid{grid-template-columns:repeat(2,1fr);gap:10px}.profile-option{padding:12px}.profile-icon{font-size:24px}.profile-name{font-size:12px}.profile-desc{font-size:10px}.floating-panel.has-bottom-bar{max-height:50vh;transition:max-height .3s cubic-bezier(.4,0,.2,1),bottom .4s ease}.floating-panel.has-bottom-bar.sheet-collapsed{max-height:120px}.floating-panel.has-bottom-bar.sheet-expanded{max-height:65vh}.sidebar-header{height:48px;min-height:48px}.sidebar-logo{width:24px;height:24px}.sidebar-title{font-size:14px}.header-action-btn,.mobile-tab{padding:6px 14px;font-size:11px;border-radius:20px}.mobile-tab{border-radius:10px;padding:7px 4px}.mobile-tab.active{background:rgba(59,130,246,.15);color:#4fc3f7}#profile-selector{display:none!important}.profile-scroll-bar{display:flex;gap:6px;padding:2px 0 10px;overflow-x:auto;overflow-y:hidden;flex-shrink:0;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth}.profile-scroll-bar::-webkit-scrollbar{display:none}.profile-chip{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;border:1.5px solid #d0d0d0;background:0 0;color:#666;font-size:12px;font-weight:500;white-space:nowrap;cursor:pointer;flex-shrink:0;font-family:inherit;transition:all .2s ease}.profile-chip:active{transform:scale(.96)}.profile-chip.active{border-color:var(--color-accent);background:rgba(59,130,246,.15);color:var(--color-text-primary)}.profile-chip-icon{font-size:14px;line-height:1}.waypoints-list{padding:0;gap:0}.waypoint-item{display:flex;align-items:stretch;gap:12px;padding:4px 0;background:0 0;border:0;border-radius:0;animation:fadeInWaypoint .2s ease}.waypoint-item:hover{border-color:transparent}@keyframes fadeInWaypoint{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.waypoint-dot-col{display:flex;flex-direction:column;align-items:center;width:24px;flex-shrink:0;padding-top:4px}.waypoint-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.waypoint-dot.start{background:#22c55e}.waypoint-dot.end{background:#4fc3f7}.waypoint-dot.via{background:#f59e0b}.waypoint-dot.poi-dot{border-radius:4px}.waypoint-line{flex:1;width:2px;background:repeating-linear-gradient(to bottom,#ccc 0,#ccc 4px,transparent 4px,transparent 8px);margin:4px 0;min-height:12px}.waypoint-content{flex:1;min-width:0}.waypoint-marker{display:none}.waypoint-label{font-size:12px;font-weight:500;color:#555}.waypoint-search-input{background:0 0;border:1px solid var(--color-border-medium);border-radius:8px;color:var(--color-text-primary);font-size:13px;padding:8px 10px}.waypoint-search-input:focus{border-color:#4fc3f7;box-shadow:0 0 0 2px rgba(59,130,246,.15)}.waypoint-search-input::placeholder{color:#aaa}.waypoint-remove{width:28px;height:28px;justify-content:center;border-radius:50%;color:#888;align-self:center}.waypoint-remove:active{background:rgba(239,68,68,.2);color:#ef4444}.add-stop-btn,.add-stop-icon,.waypoint-remove{display:flex;align-items:center}.add-stop-btn{gap:8px;padding:6px 0 6px 36px;border:0;background:0 0;color:#4fc3f7;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;width:100%;transition:opacity .2s ease}.add-stop-btn:active{opacity:.7}.add-stop-icon{width:20px;height:20px;border-radius:50%;border:1.5px dashed #4fc3f7;justify-content:center;font-size:14px;line-height:1}.panel-content{padding:8px 16px 16px}.waypoints-hint{font-size:11px;color:#666}}@media (max-width:480px){.floating-panel{max-height:50vh}.bottom-bar-stats{gap:4px}.stat-item{min-width:calc(33% - 8px)}.profile-grid{grid-template-columns:repeat(2,1fr)}}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#252525;--bg-tertiary:#303030;--text-primary:#f5f5f5;--text-secondary:#a0a0a0;--border-color:#404040;--color-accent:#4FC3F7;--color-accent-light:#81D4FA;--color-text-primary:#f5f5f5;--color-text-secondary:#a0a0a0;--color-text-muted:#707070;--color-text-light:#909090;--color-bg-primary:#1a1a1a;--color-bg-surface:#252525;--color-bg-hover:#3a3a3a;--color-bg-input:#303030;--color-border:#404040;--color-border-medium:#404040;--color-border-light:#353535;--color-bg-subtle:#303030;--color-btn-primary-bg:#4FC3F7;--color-btn-primary-text:#1a1a1a;--color-btn-primary-hover:#81D4FA;--color-skeleton:#333;--color-error-light:rgba(239, 68, 68, 0.15);--color-error-dark:#f87171;--shadow-sm:0 2px 8px rgba(0, 0, 0, 0.2);--shadow-md:0 8px 32px rgba(0, 0, 0, 0.3);--shadow-lg:0 20px 60px rgba(0, 0, 0, 0.4);--focus-ring:0 0 0 3px rgba(79, 195, 247, 0.5);--focus-ring-offset:0 0 0 2px var(--color-bg-surface)}[data-theme=dark] body{background:var(--bg-primary);color:var(--text-primary)}[data-theme=dark] .floating-panel{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .icon-strip{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .icon-strip-item,[data-theme=dark] .sidebar-title span{color:var(--text-secondary)}[data-theme=dark] .icon-strip-item.active,[data-theme=dark] .icon-strip-item:hover{background:var(--bg-secondary);color:var(--text-primary)}[data-theme=dark] .sidebar-header{border-color:var(--border-color)}[data-theme=dark] .sidebar-title{color:var(--text-primary)}[data-theme=dark] .profile-compact,[data-theme=dark] .route-item,[data-theme=dark] .waypoint-item{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .profile-compact:hover,[data-theme=dark] .route-item:hover{background:#3a3a3a;border-color:#505050}[data-theme=dark] .waypoint-item.highlighted{border-color:#4fc3f7;background:rgba(59,130,246,.15)}[data-theme=dark] .profile-compact-name,[data-theme=dark] .route-item-name,[data-theme=dark] .waypoint-label{color:var(--text-primary)}[data-theme=dark] .profile-compact-desc,[data-theme=dark] .route-item-stats,[data-theme=dark] .waypoint-coords{color:var(--text-secondary)}[data-theme=dark] .route-item-icon{background:var(--bg-secondary)}[data-theme=dark] .waypoints-hint{color:var(--text-secondary)}[data-theme=dark] .btn-primary{background:#4fc3f7}[data-theme=dark] .btn-secondary{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .btn-secondary:hover{background:#3a3a3a}[data-theme=dark] .header-action-btn.btn-reset-mobile{background:rgba(239,68,68,.15);color:#f87171}[data-theme=dark] .bottom-bar{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .bottom-bar-title{color:var(--text-primary)}[data-theme=dark] .bottom-bar-elevation,[data-theme=dark] .bottom-bar-stats{border-color:var(--border-color)}[data-theme=dark] .bottom-bar-credits a,[data-theme=dark] .floating-credits a,[data-theme=dark] .modal-body p,[data-theme=dark] .stat-label{color:var(--text-secondary)}[data-theme=dark] .modal-header h3,[data-theme=dark] .pro-features li,[data-theme=dark] .stat-value{color:var(--text-primary)}[data-theme=dark] .bottom-bar-btn{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .bottom-bar-btn:hover,[data-theme=dark] .modal-close:hover,[data-theme=dark] .profile-option:hover{background:#3a3a3a}[data-theme=dark] .bottom-bar-credits{border-color:var(--border-color)}[data-theme=dark] .floating-credits{background:rgba(30,30,30,.9)}[data-theme=dark] .modal-overlay{background:rgba(0,0,0,.7)}[data-theme=dark] .modal{background:var(--bg-secondary)}[data-theme=dark] .modal,[data-theme=dark] .modal-header{border-color:var(--border-color)}[data-theme=dark] .modal-close{background:var(--bg-tertiary);color:var(--text-secondary)}[data-theme=dark] .modal-input{color:var(--text-primary)}[data-theme=dark] .modal-input,[data-theme=dark] .profile-option{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .profile-option.active{border-color:#4fc3f7;background:rgba(59,130,246,.1)}[data-theme=dark] .profile-name{color:var(--text-primary)}[data-theme=dark] .profile-desc{color:var(--text-secondary)}[data-theme=dark] .account-login-title{color:var(--text-primary)}[data-theme=dark] .account-login-desc,[data-theme=dark] .account-login-icon{color:var(--text-secondary)}[data-theme=dark] .profile-chip{border-color:#444;color:#aaa}[data-theme=dark] .profile-chip.active{border-color:#4fc3f7;background:rgba(59,130,246,.15);color:#fff}[data-theme=dark] .waypoint-line{background:repeating-linear-gradient(to bottom,#555 0,#555 4px,transparent 4px,transparent 8px)}[data-theme=dark] .waypoint-search-input{border-color:#404040;color:#f5f5f5}[data-theme=dark] .mobile-tab.active{background:rgba(59,130,246,.15);color:#4fc3f7}[data-theme=dark] .mobile-tab-bar{border-color:var(--border-color);background:var(--bg-secondary)}@media (max-width:768px){[data-theme=dark] .waypoint-item{background:0 0;border-color:transparent}[data-theme=dark] .waypoint-label{color:#ccc}}[data-theme=dark] .loading-overlay{background:rgba(0,0,0,.8)}[data-theme=dark] .spinner{border-color:#f5f5f5 #404040 #404040}[data-theme=dark] .panel-title{color:var(--text-primary)}[data-theme=dark] .routes-empty{color:var(--text-secondary)}[data-theme=dark] .layer-switcher-btn,[data-theme=dark] .leaflet-control-zoom{box-shadow:0 2px 12px rgba(0,0,0,.4)!important}[data-theme=dark] .leaflet-control-zoom a{color:#f5f5f5!important;background:#2a2a2a!important}[data-theme=dark] .leaflet-control-zoom a:hover{background:#3a3a3a!important}[data-theme=dark] .leaflet-bar a.leaflet-disabled{background:#1a1a1a!important;color:#666!important}[data-theme=dark] .layer-switcher-btn{background:#2a2a2a!important}[data-theme=dark] .layer-switcher-dropdown{background:#2a2a2a;box-shadow:0 4px 16px rgba(0,0,0,.4)}[data-theme=dark] .layer-option{color:#ccc;border-bottom-color:#3a3a3a}[data-theme=dark] .layer-option.active,[data-theme=dark] .layer-option:hover{background:#3a3a3a;color:#f5f5f5}@media (max-width:768px){[data-theme=dark] .sidebar-header::before{background:#505050}[data-theme=dark] .sidebar-header{border-color:var(--border-color)}[data-theme=dark] .mobile-tab-bar{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .mobile-tab{color:var(--text-secondary)}[data-theme=dark] .mobile-tab.active{background:var(--bg-tertiary);color:var(--text-primary)}[data-theme=dark] .mobile-elevation-slot .bottom-bar-elevation{border-color:var(--border-color)}}#poi-panel{flex-direction:column;gap:0}.poi-categories{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding-bottom:12px;border-bottom:1px solid var(--color-border-medium);margin-bottom:12px;overflow:hidden}.poi-category-item{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:all .15s;border:2px solid transparent;min-width:0;overflow:hidden}.poi-category-item:hover{background:#f5f5f5}.poi-category-item.active{border-color:#4fc3f7;background:rgba(59,130,246,.05)}.poi-category-icon{font-size:14px;flex-shrink:0}.poi-category-label{font-size:11px;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.poi-category-item:last-child:nth-child(odd){grid-column:span 2}.poi-list-container{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.15) transparent}.poi-list-container::-webkit-scrollbar{width:6px}.poi-list-container::-webkit-scrollbar-track{background:0 0}.poi-list-container::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:3px}.poi-list-container::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.25)}.poi-error-message{padding:8px 12px;margin-bottom:8px;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;font-size:12px;font-weight:500}.poi-list-header{font-size:11px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;padding:4px 0 8px}.poi-list-icon,.poi-list-item{display:flex;align-items:center}.poi-list-item{gap:10px;padding:10px;border-radius:8px;cursor:pointer;transition:background .15s;margin-bottom:4px}.poi-list-item:hover{background:#f5f5f5}.poi-list-item.highlighted{background:#e0f2fe}.poi-list-icon{width:28px;height:28px;border-radius:6px;justify-content:center;font-size:14px;flex-shrink:0}.poi-list-info{flex:1;min-width:0}.poi-list-name{font-size:13px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.poi-list-add,.poi-list-type{font-size:11px;color:var(--color-text-secondary)}.poi-list-add{padding:6px 10px;background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text);border:0;border-radius:6px;font-weight:500;cursor:pointer;transition:background .15s;flex-shrink:0}.poi-list-add:hover{background:#333}.poi-list-add.pro-locked{background:#e5e5e5;color:#999;cursor:pointer}.poi-list-add.pro-locked:hover{background:#d5d5d5}.poi-empty{text-align:center;padding:20px;color:var(--color-text-muted);font-size:13px}.poi-marker-icon{background:0 0!important;border:0!important;transition:z-index 0s}.poi-marker-icon:has(.poi-marker-highlighted){z-index:1000!important}.poi-marker{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 2px 6px rgba(0,0,0,.25);border:2px solid #fff;transition:transform .2s ease,box-shadow .2s ease}.poi-marker-highlighted{transform:scale(1.5);box-shadow:0 0 12px 4px rgba(59,130,246,.5);z-index:1000!important}.poi-popup-container .leaflet-popup-content-wrapper{border-radius:12px;padding:0;overflow:hidden}.poi-popup-container .leaflet-popup-content{margin:0;min-width:180px}.poi-popup{padding:12px 14px}.poi-popup-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.poi-popup-icon{font-size:18px}.poi-popup-type{font-size:11px;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.3px}.poi-popup-name{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.poi-popup-detail{font-size:12px;color:var(--color-text-light);margin-bottom:4px}.poi-popup-btn{width:100%;margin-top:10px;padding:8px 12px;background:var(--color-btn-primary-bg);color:var(--color-btn-primary-text);border:0;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.poi-popup-btn:hover{background:#333}.waypoint-search-wrapper{position:relative;margin-top:4px}.waypoint-search-wrapper.searching::after{content:"";position:absolute;right:8px;top:50%;margin-top:-6px;width:12px;height:12px;border:2px solid #ccc;border-top-color:#4fc3f7;border-radius:50%;animation:spin .6s linear infinite;z-index:1}.waypoint-search-wrapper.searching .waypoint-search-input{padding-right:28px}.waypoint-search-input{width:100%;padding:6px 8px;border:1px solid var(--color-border-medium);border-radius:6px;font-size:11px;font-family:inherit;color:var(--color-text-primary);background:var(--color-bg-surface);transition:border-color .2s}.waypoint-search-input:focus{outline:0;border-color:var(--color-accent)}.waypoint-search-input::placeholder{color:var(--color-text-muted)}.search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--color-bg-surface);border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:200;max-height:200px;overflow-y:auto;margin-top:4px;display:none}.search-dropdown.visible{display:block}.search-dropdown-item{padding:10px 12px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--color-border-light)}.search-dropdown-item:last-child{border-bottom:none}.search-dropdown-item.active,.search-dropdown-item:hover{background:var(--color-bg-primary)}.search-item-name{font-size:13px;font-weight:500;color:var(--color-text-primary)}.search-item-detail{font-size:11px;color:var(--color-text-light);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-dropdown-empty{padding:16px;text-align:center;color:var(--color-text-muted);font-size:13px}[data-theme=dark] .poi-categories{border-bottom-color:var(--border-color)}[data-theme=dark] .poi-category-item:hover{background:var(--bg-tertiary)}[data-theme=dark] .poi-category-item.active{border-color:#4fc3f7;background:rgba(59,130,246,.1)}[data-theme=dark] .poi-category-label{color:var(--text-primary)}[data-theme=dark] .poi-list-header{color:var(--text-secondary)}[data-theme=dark] .poi-list-item:hover{background:var(--bg-tertiary)}[data-theme=dark] .poi-list-item.highlighted{background:rgba(59,130,246,.15)}[data-theme=dark] .poi-list-name{color:var(--text-primary)}[data-theme=dark] .poi-list-type{color:var(--text-secondary)}[data-theme=dark] .poi-list-add{background:#4fc3f7}[data-theme=dark] .poi-list-add:hover{background:#2563eb}[data-theme=dark] .poi-list-add.pro-locked{background:#333;color:#666}[data-theme=dark] .poi-empty{color:var(--text-secondary)}[data-theme=dark] .panel-content{scrollbar-color:rgba(255,255,255,.15) transparent}[data-theme=dark] .panel-content::-webkit-scrollbar-thumb,[data-theme=dark] .poi-list-container::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15)}[data-theme=dark] .panel-content::-webkit-scrollbar-thumb:hover,[data-theme=dark] .poi-list-container::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.25)}[data-theme=dark] .poi-error-message{background:rgba(220,38,38,.1);color:#f87171;border-color:rgba(220,38,38,.25)}[data-theme=dark] .poi-list-container{scrollbar-color:rgba(255,255,255,.15) transparent}[data-theme=dark] .poi-popup{background:var(--bg-secondary)}[data-theme=dark] .poi-popup-name{color:var(--text-primary)}[data-theme=dark] .poi-popup-detail,[data-theme=dark] .poi-popup-type{color:var(--text-secondary)}[data-theme=dark] .poi-popup-btn{background:#4fc3f7}[data-theme=dark] .poi-popup-btn:hover{background:#2563eb}[data-theme=dark] .leaflet-popup-content-wrapper{background:var(--bg-secondary);color:var(--text-primary)}[data-theme=dark] .leaflet-popup-tip{background:var(--bg-secondary)}[data-theme=dark] .waypoint-search-input{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .waypoint-search-input::placeholder{color:#666}[data-theme=dark] .waypoint-search-input:focus{border-color:#4fc3f7}[data-theme=dark] .search-dropdown{background:var(--bg-secondary);border-color:var(--border-color);box-shadow:0 4px 16px rgba(0,0,0,.4)}[data-theme=dark] .search-dropdown-item{border-color:var(--border-color)}[data-theme=dark] .search-dropdown-item.active,[data-theme=dark] .search-dropdown-item:hover{background:var(--bg-tertiary)}[data-theme=dark] .search-item-name{color:var(--text-primary)}[data-theme=dark] .search-dropdown-empty,[data-theme=dark] .search-item-detail{color:var(--text-secondary)}@media (max-width:768px){.poi-categories{display:flex;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px;scrollbar-width:none;flex-shrink:0}.poi-categories::-webkit-scrollbar{display:none}.poi-category-item{flex-shrink:0;padding:6px 10px;min-width:auto;overflow:visible}.poi-category-item:last-child:nth-child(odd){grid-column:unset}.poi-category-label{font-size:11px;overflow:visible;text-overflow:unset}.poi-list-item{padding:12px 10px;min-height:48px}.poi-list-add{padding:8px 14px;font-size:12px;min-height:36px}.route-item{padding:14px 12px;min-height:56px}.route-item-delete{padding:10px;font-size:16px;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.waypoint-search-input{font-size:14px;padding:8px 10px}.search-dropdown{max-height:150px}}.btn-danger:focus-visible,.btn-primary:focus-visible,.btn-secondary:focus-visible{outline:0;box-shadow:var(--focus-ring)}.icon-strip-item:focus-visible,.mobile-tab:focus-visible{outline:0;box-shadow:var(--focus-ring);border-radius:var(--radius-sm)}.modal-close:focus-visible{outline:0;box-shadow:var(--focus-ring)}.modal-input:focus-visible,.waypoint-search-input:focus-visible{outline:0;border-color:var(--color-accent);box-shadow:var(--focus-ring)}.profile-chip:focus-visible,.profile-option:focus-visible{outline:0;box-shadow:var(--focus-ring)}.poi-category-item:focus-visible{border-radius:var(--radius-md)}.poi-category-item:focus-visible,.poi-list-item:focus-visible,.route-item:focus-visible{outline:0;box-shadow:var(--focus-ring)}.search-dropdown-item:focus-visible{background:var(--color-bg-hover)}.app-promo-btn:focus-visible,.app-promo-close:focus-visible,.bottom-bar-btn:focus-visible,.card:focus-visible,.chip:focus-visible,.layer-option:focus-visible,.layer-switcher-btn:focus-visible,.menu-btn:focus-visible,.profile-compact:focus-visible,.search-dropdown-item:focus-visible,.toast-action:focus-visible,.user-btn:focus-visible,.waypoint-item:focus-visible{outline:0;box-shadow:var(--focus-ring)}.app-promo-banner{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);z-index:200;max-width:480px;width:calc(100% - 32px);animation:slideUpBanner .4s ease-out;transition:bottom .4s ease}.bottom-bar.visible~.app-promo-banner{bottom:130px}.app-promo-banner.hidden{display:none}.app-promo-content{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}.app-promo-icon{width:32px;height:32px;border-radius:8px;flex-shrink:0}.app-promo-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.app-promo-text span{font-size:12px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-promo-btn{flex-shrink:0;padding:8px 16px;background:var(--color-text-primary);color:var(--color-bg-surface);border:0;border-radius:var(--radius-sm);font-size:13px;font-weight:600;text-decoration:none;transition:opacity .2s}.app-promo-btn:hover{opacity:.85}.app-promo-close{flex-shrink:0;width:28px;height:28px;border:0;background:0 0;border-radius:6px;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.app-promo-close:hover{background:var(--color-bg-hover)}.bottom-bar-credits,.floating-credits{flex-direction:column;text-align:right}.powered-link{font-size:9px;opacity:.7;transition:opacity .2s}.powered-link:hover{opacity:1}@media (max-width:768px){.bottom-bar.visible~.app-promo-banner{bottom:80px}}@media (prefers-reduced-motion:reduce){*,::after,::before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}