#location-sheet-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;z-index:10004;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out}#location-sheet-backdrop.visible{opacity:1;visibility:visible}#location-sheet{position:fixed;background:#fff;z-index:10005;overflow-y:auto;transition:transform .3s ease-in-out;bottom:0;left:0;right:0;max-height:90vh;border-radius:24px 24px 0 0;box-shadow:0 -4px 12px #00000026;transform:translateY(100%)}#location-sheet.visible{transform:translateY(0)}@media(min-width:768px){#location-sheet{top:0;bottom:0;left:auto;right:0;width:400px;max-width:90vw;max-height:none;border-radius:24px 0 0 24px;box-shadow:-4px 0 12px #00000026;transform:translate(100%)}#location-sheet.visible{transform:translate(0)}}.location-sheet-content{padding:20px 20px 40px}.location-sheet-header{display:flex;align-items:center;padding:20px 20px 16px;border-bottom:1px solid #E5E7EB;position:sticky;top:0;background:#fff;z-index:10}.location-color-dot{width:12px;height:12px;border-radius:6px;margin-right:12px;flex-shrink:0}.location-sheet-title{flex:1;font-size:18px;font-weight:600;color:#111827;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.location-sheet-close{width:32px;height:32px;border:none;background:transparent;border-radius:16px;font-size:20px;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background-color .2s}.location-sheet-close:hover{background-color:#f3f4f6}.location-sheet-close:active{background-color:#e5e7eb}.location-section{margin-bottom:24px}.location-section:last-child{margin-bottom:0}.location-section-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#6b7280;margin-bottom:8px}.location-section-icon{font-size:16px;line-height:1}.location-section-value{font-size:16px;font-weight:400;color:#111827;line-height:1.5;word-wrap:break-word}.location-coordinates{font-family:SF Mono,Monaco,Menlo,Consolas,monospace;font-size:15px;letter-spacing:.3px}.location-section-empty{font-size:14px;color:#9ca3af;font-style:italic}.location-sheet-handle{width:36px;height:4px;background-color:#d1d5db;border-radius:2px;margin:8px auto 12px}@media(min-width:768px){.location-sheet-handle{display:none}}#location-sheet::-webkit-scrollbar{width:8px}#location-sheet::-webkit-scrollbar-track{background:transparent}#location-sheet::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}#location-sheet::-webkit-scrollbar-thumb:hover{background:#9ca3af}.transport-config-btn{width:100%;display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;font-size:15px;font-weight:500;color:#111827;cursor:pointer;transition:background-color .2s;text-align:left}.transport-config-btn:hover{background:#f3f4f6}.transport-config-btn:active{background:#e5e7eb}.transport-config-btn .chevron{margin-left:auto;font-size:18px;color:#9ca3af;transition:transform .2s}.transport-config-content{margin-top:16px}.transport-config{display:flex;flex-direction:column;gap:20px}.transport-section{display:flex;flex-direction:column;gap:12px}.transport-section-label{font-size:14px;font-weight:600;color:#374151}.transport-source-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 0;-webkit-overflow-scrolling:touch}.transport-source-scroll::-webkit-scrollbar{height:6px}.transport-source-scroll::-webkit-scrollbar-track{background:#f3f4f6;border-radius:3px}.transport-source-scroll::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.source-location-chip{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1.5px solid #E5E7EB;border-radius:20px;font-size:14px;color:#374151;white-space:nowrap;cursor:pointer;transition:all .2s;flex-shrink:0}.source-location-chip:hover{border-color:#3b82f6;background:#eff6ff}.source-location-chip.selected{background:#eff6ff;border-color:#3b82f6;color:#1e40af}.source-location-dot{width:10px;height:10px;border-radius:5px;flex-shrink:0}.source-location-name{font-weight:500}.transport-empty{font-size:14px;color:#9ca3af;font-style:italic;padding:12px 0}.transport-mode-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.transport-mode-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:#fff;border:1.5px solid #E5E7EB;border-radius:8px;cursor:pointer;transition:all .2s}.transport-mode-btn:hover{border-color:#3b82f6;background:#eff6ff}.transport-mode-btn.selected{background:#eff6ff;border-color:#3b82f6}.transport-mode-icon{font-size:24px;line-height:1}.transport-mode-label{font-size:13px;font-weight:500;color:#374151}.transport-mode-btn.selected .transport-mode-label{color:#1e40af}.transport-route-info{display:flex;gap:16px;padding:16px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px}.route-stat{flex:1;display:flex;flex-direction:column;gap:4px}.route-stat-label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.route-stat-value{font-size:18px;font-weight:600;color:#111827}.route-loading{font-size:14px;color:#6b7280;font-style:italic;text-align:center;padding:12px 0}.location-sheet-entering{animation:slideIn .3s ease-in-out forwards}.location-sheet-exiting{animation:slideOut .3s ease-in-out forwards}@keyframes slideIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideOut{0%{transform:translateY(0)}to{transform:translateY(100%)}}@media(min-width:768px){@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOut{0%{transform:translate(0)}to{transform:translate(100%)}}}
