:root{--primary-color:#2563eb;--primary-hover:#1d4ed8;--success-color:#16a34a;--warning-color:#ea580c;--danger-color:#dc2626;--text-primary:#1f2937;--text-secondary:#6b7280;--bg-primary:#fff;--bg-secondary:#f9fafb;--border-color:#e5e7eb;--shadow-sm:0 1px 2px 0 rgba(0,0,0,.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);direction:rtl;overscroll-behavior:none;-webkit-overflow-scrolling:touch}html{height:100dvh;height:100vh;position:fixed;width:100%}body{min-height:100dvh;min-height:100vh;position:fixed}.map-container,body{height:100%;width:100%;top:0;left:0}.map-container{position:absolute;right:0;bottom:0}.control-panel{position:absolute;top:16px;right:16px;width:360px;max-height:calc(100vh - 32px);background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;z-index:1000}@media (max-width:768px){.control-panel{top:auto;bottom:0;right:0;left:0;width:100%;max-height:55vh;border-radius:16px 16px 0 0}.panel-header{padding:12px 16px}.panel-header h1{font-size:1.1rem;margin-bottom:2px}.panel-header p{font-size:.75rem}.panel-content{padding:12px 16px}.form-group{margin-bottom:10px}.form-label{font-size:.8rem;margin-bottom:4px}.form-input{padding:8px 10px;font-size:.8rem}.checkbox-group{flex-direction:row;flex-wrap:wrap;gap:6px 12px}.checkbox-label{font-size:.75rem}.btn{padding:8px 12px;font-size:.8rem}.disclaimer{padding:8px;margin-top:12px}.disclaimer-title{font-size:.75rem}.disclaimer-text{font-size:.65rem}}.panel-header{padding:16px;border-bottom:1px solid var(--border-color);background:var(--bg-primary);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.panel-header-content{flex:1 1;min-width:0}.panel-header h1{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.panel-header p{font-size:.875rem;color:var(--text-secondary)}.panel-toggle-btn{display:none;width:32px;height:32px;padding:4px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;flex-shrink:0;transition:background-color .2s}.panel-toggle-btn:hover{background:var(--border-color)}.panel-toggle-btn svg{width:100%;height:100%;fill:var(--text-secondary)}@media (max-width:768px){.panel-toggle-btn{display:flex;align-items:center;justify-content:center}}.control-panel.minimized{max-height:none}.control-panel.minimized .panel-header{border-bottom:none}.control-panel.minimized .panel-header h1{margin-bottom:0}.panel-content.hidden{display:none}.panel-content{padding:16px;overflow-y:auto;flex:1 1}.form-group{margin-bottom:16px}.form-label{display:block;font-weight:500;margin-bottom:6px}.form-input,.form-label{font-size:.875rem;color:var(--text-primary)}.form-input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(37,99,235,.1)}.form-input::placeholder{color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{background:var(--text-secondary);cursor:not-allowed}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-full{width:100%}.checkbox-group{display:flex;flex-direction:column;gap:8px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-primary);cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-color)}.route-results{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.route-card{background:var(--bg-secondary);border-radius:8px;padding:12px;margin-bottom:12px;cursor:pointer;border:2px solid transparent;transition:border-color .2s}.route-card:hover{border-color:var(--border-color)}.route-card.selected{border-color:var(--primary-color);background:rgba(37,99,235,.05)}.start-walking-btn{margin-top:12px;background:linear-gradient(135deg,var(--success-color) 0,#15803d 100%);font-size:1rem;padding:12px 16px}.start-walking-btn:hover{background:linear-gradient(135deg,#22c55e 0,var(--success-color) 100%)}.route-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.route-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.route-badge{font-size:.75rem;padding:2px 8px;border-radius:4px;font-weight:500}.route-badge.safe{background:rgba(22,163,74,.1);color:var(--success-color)}.route-badge.moderate{background:rgba(234,88,12,.1);color:var(--warning-color)}.route-badge.risky{background:rgba(220,38,38,.1);color:var(--danger-color)}.route-metrics{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:8px;gap:8px}.metric{display:flex;flex-direction:column}.metric-label{font-size:.75rem;color:var(--text-secondary)}.metric-value{font-size:.875rem;font-weight:500;color:var(--text-primary)}.loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;color:var(--text-secondary)}.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.error{background:rgba(220,38,38,.1);color:var(--danger-color);padding:12px;border-radius:8px;font-size:.875rem;margin-bottom:16px}.disclaimer{background:rgba(234,88,12,.1);border:1px solid rgba(234,88,12,.2);border-radius:8px;padding:12px;margin-top:16px}.disclaimer-title{font-size:.875rem;font-weight:600;color:var(--warning-color);margin-bottom:4px}.disclaimer-text{font-size:.75rem;color:var(--text-secondary);line-height:1.5}.disclaimer-link{color:var(--primary-color);text-decoration:none}.disclaimer-link:hover{text-decoration:underline}.panel-footer{padding:12px 16px;border-top:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0}.credit{font-size:.75rem;color:var(--text-secondary);text-align:center}.credit-link{color:var(--primary-color);text-decoration:none;font-weight:500}.credit-link:hover{text-decoration:underline}@media (max-width:768px){.panel-footer{padding:8px 16px}.credit{font-size:.65rem}}.shelter-marker{width:24px;height:24px;border-radius:50%;border:2px solid #fff;box-shadow:var(--shadow-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;transition:all .3s ease}.shelter-marker.accessible{font-size:14px}.shelter-marker svg{width:14px;height:14px;fill:#fff}.shelter-marker.near-route{width:32px;height:32px;border:3px solid #fbbf24;box-shadow:0 0 0 4px rgba(251,191,36,.4),var(--shadow-lg);z-index:100;animation:pulse-highlight 2s ease-in-out infinite}@keyframes pulse-highlight{0%,to{box-shadow:0 0 0 4px rgba(251,191,36,.4),var(--shadow-lg)}50%{box-shadow:0 0 0 8px rgba(251,191,36,.2),var(--shadow-lg)}}.shelter-marker.faded{display:none}.maplibregl-popup-content{padding:12px;border-radius:8px;font-family:inherit;direction:rtl}.popup-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:4px}.popup-address{font-size:.75rem;color:var(--text-secondary);margin-bottom:8px}.popup-type{display:inline-block;font-size:.75rem;padding:2px 8px;border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);margin-left:4px}.popup-type.near-route-badge{background:rgba(251,191,36,.2);color:#b45309;font-weight:500}.popup-navigate-btn{display:block;width:100%;margin-top:8px;padding:8px 12px;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background-color .2s}.popup-navigate-btn:hover{background:var(--primary-hover)}.location-btn{position:absolute;bottom:120px;left:16px;width:40px;height:40px;background:var(--bg-primary);border:none;border-radius:8px;box-shadow:var(--shadow-md);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000}.location-btn:hover{background:var(--bg-secondary)}.location-btn svg{width:20px;height:20px;fill:var(--text-primary)}@media (max-width:768px){.location-btn{bottom:calc(55vh + 16px);left:16px;transition:bottom .3s ease}.location-btn.panel-minimized{bottom:80px}}.compass-permission-btn{position:absolute;bottom:170px;left:16px;padding:8px 12px;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-md);cursor:pointer;font-size:.8rem;font-weight:500;z-index:1000;transition:all .2s ease}.compass-permission-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color)}@media (max-width:768px){.compass-permission-btn{bottom:calc(55vh + 66px);transition:bottom .3s ease}}.sos-btn{position:absolute;top:16px;left:16px;padding:12px 20px;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none;border-radius:12px;box-shadow:0 4px 14px rgba(220,38,38,.4);cursor:pointer;display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;z-index:1000;transition:all .2s ease;min-width:140px;justify-content:center}.sos-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(220,38,38,.5);background:linear-gradient(135deg,#ef4444,#dc2626)}.sos-btn:active:not(:disabled){transform:translateY(0)}.sos-btn:disabled{opacity:.7;cursor:not-allowed}.sos-icon{font-size:1.25rem}.sos-text{white-space:nowrap}.sos-spinner{border-color:#fff hsla(0,0%,100%,.3) hsla(0,0%,100%,.3)}@media (max-width:768px){.sos-btn{top:16px;bottom:auto;left:auto;right:16px;transform:none;padding:10px 16px;font-size:.9rem;min-width:auto;border-radius:12px}.sos-btn:hover:not(:disabled){transform:translateY(-2px)}.sos-btn .sos-icon{font-size:1.1rem}}.user-location-marker{width:24px;height:24px;position:relative}.user-location-dot{width:14px;height:14px;background:#4285f4;border:2px solid #fff;box-shadow:0 2px 4px rgba(0,0,0,.3);z-index:2}.user-location-dot,.user-location-pulse{border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.user-location-pulse{width:24px;height:24px;background:rgba(66,133,244,.3);animation:location-pulse 2s ease-out infinite;z-index:1}@keyframes location-pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}.user-location-cone{position:absolute;width:80px;height:80px;top:50%;left:50%;transform:translate(-50%,-50%) rotate(calc(var(--heading) - 90deg - var(--map-bearing)));background:conic-gradient(from -30deg,transparent 0deg,rgba(66,133,244,.25) 0deg,rgba(66,133,244,.25) 60deg,transparent 60deg);border-radius:50%;pointer-events:none;z-index:0}.point-marker{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.point-marker svg{width:100%;height:100%}.point-marker.origin{color:var(--success-color)}.point-marker.destination{color:var(--danger-color)}.autocomplete-container{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-lg);z-index:1001;max-height:200px;overflow-y:auto;margin-top:4px}.autocomplete-item{padding:10px 12px;font-size:.875rem;color:var(--text-primary);cursor:pointer;border-bottom:1px solid var(--border-color);transition:background-color .15s}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:var(--bg-secondary)}.autocomplete-item:active{background:var(--border-color)}.maplibregl-ctrl-bottom-left{left:16px;bottom:120px}@media (max-width:768px){.maplibregl-ctrl-bottom-left{left:16px;bottom:auto;top:16px}.maplibregl-ctrl-bottom-left .maplibregl-ctrl{margin:0 0 10px}}