.map-container[data-v-0bd366dd]{height:100%;position:relative;width:100%}.connection-status[data-v-0bd366dd]{align-items:center;background:#fffffff2;border-bottom:1px solid #ddd;display:flex;font-size:14px;gap:8px;left:0;padding:8px 16px;position:absolute;right:0;top:0;z-index:1001}.connection-status.connected[data-v-0bd366dd]{background:#4caf501a;border-bottom-color:#4caf50}.connection-status.error[data-v-0bd366dd]{background:#f443361a;border-bottom-color:#f44336}.status-indicator[data-v-0bd366dd]{background:#ccc;border-radius:50%;height:8px;width:8px}.status-indicator.pulse[data-v-0bd366dd]{animation:pulse-0bd366dd 2s infinite;background:#4caf50}.connection-status.error .status-indicator[data-v-0bd366dd]{background:#f44336}.last-update[data-v-0bd366dd]{color:#666;font-size:12px;margin-left:auto}.map[data-v-0bd366dd]{border:1px solid #ddd;border-radius:8px;height:100%;margin-top:40px;min-height:400px;width:100%}.error[data-v-0bd366dd],.loading[data-v-0bd366dd]{border-radius:8px;left:50%;padding:16px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:10}.loading[data-v-0bd366dd]{background-color:#fffffff2}.error[data-v-0bd366dd]{background-color:#ffebee;color:#c62828}.reconnect-btn[data-v-0bd366dd]{border:none;border-radius:4px;margin-top:8px;padding:4px 12px}.reconnect-btn[data-v-0bd366dd],.reconnect-btn-small[data-v-0bd366dd]{background:#f44336;color:#fff;cursor:pointer}.reconnect-btn-small[data-v-0bd366dd]{border:none;border-radius:3px;font-size:12px;margin-left:8px;padding:2px 8px}.debug-panel[data-v-0bd366dd]{background:#fffffff2;border-radius:6px;box-shadow:0 2px 8px #0000001a;font-size:12px;left:10px;max-width:300px;padding:12px;position:absolute;top:50px;z-index:1001}.debug-panel h4[data-v-0bd366dd]{color:#333;font-size:14px;margin:0 0 8px}.debug-panel p[data-v-0bd366dd]{color:#666;margin:4px 0}.loading-overlay[data-v-0bd366dd]{align-items:center;background:#ffffffe6;display:flex;flex-direction:column;justify-content:center;inset:0;position:absolute;z-index:1002}.loading-spinner[data-v-0bd366dd]{animation:spin-0bd366dd 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;margin-bottom:16px;width:40px}@keyframes spin-0bd366dd{0%{transform:rotate(0)}to{transform:rotate(1turn)}}.map-controls[data-v-0bd366dd]{display:flex;flex-direction:column;gap:5px;position:absolute;right:10px;top:10px;z-index:1000}.control-btn[data-v-0bd366dd]{align-items:center;background:#fff;border:2px solid #ccc;border-radius:6px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;font-size:16px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.control-btn[data-v-0bd366dd]:hover{background:#f0f0f0;border-color:#999}.control-btn.active[data-v-0bd366dd]{background:#4caf50;border-color:#4caf50;color:#fff}.status-panel[data-v-0bd366dd]{background:#fffffff2;border-radius:8px;bottom:10px;box-shadow:0 4px 12px #00000026;font-size:13px;left:10px;max-width:300px;min-width:250px;padding:16px;position:absolute;transition:all .3s ease;z-index:1000}.status-panel.moving[data-v-0bd366dd]{border-left:4px solid #4caf50}.status-panel.arrived[data-v-0bd366dd]{border-left:4px solid #ff9800}.panel-header[data-v-0bd366dd]{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.movement-indicator[data-v-0bd366dd]{align-items:center;display:flex;font-weight:600;gap:6px}.movement-indicator.moving[data-v-0bd366dd]{color:#4caf50}.movement-indicator.stationary[data-v-0bd366dd]{color:#666}.movement-indicator.approaching[data-v-0bd366dd]{color:#ff9800}.movement-indicator.arrived[data-v-0bd366dd]{color:#2196f3}.gps-quality[data-v-0bd366dd]{border-radius:10px;font-size:10px;font-weight:600;padding:2px 6px;text-transform:uppercase}.gps-quality.excellent[data-v-0bd366dd]{background:#4caf50;color:#fff}.gps-quality.good[data-v-0bd366dd]{background:#8bc34a;color:#fff}.gps-quality.fair[data-v-0bd366dd]{background:#ff9800;color:#fff}.gps-quality.poor[data-v-0bd366dd]{background:#f44336;color:#fff}.status-grid[data-v-0bd366dd]{display:grid;gap:8px;grid-template-columns:1fr 1fr;margin-bottom:12px}.status-item[data-v-0bd366dd]{display:flex;flex-direction:column;gap:2px}.status-item label[data-v-0bd366dd]{color:#666;font-size:11px;font-weight:500;text-transform:uppercase}.status-item .value[data-v-0bd366dd]{color:#333;font-weight:600}.status-item.speed .value[data-v-0bd366dd]{color:#4caf50}.status-item.distance .value[data-v-0bd366dd]{color:#2196f3}.status-item.eta .value[data-v-0bd366dd]{color:#ff9800}.trail-stats[data-v-0bd366dd]{border-top:1px solid #eee;margin-top:12px;padding-top:12px}.trail-stats h4[data-v-0bd366dd]{color:#666;font-size:12px;margin:0 0 8px;text-transform:uppercase}.stats-row[data-v-0bd366dd]{display:flex;gap:8px;justify-content:space-between}.stat[data-v-0bd366dd]{align-items:center;display:flex;flex:1;flex-direction:column}.stat .label[data-v-0bd366dd]{color:#666;font-size:10px;margin-bottom:2px}.stat .value[data-v-0bd366dd]{color:#333;font-size:11px;font-weight:600}.arrival-notification[data-v-0bd366dd]{align-items:center;animation:slideIn-0bd366dd .3s ease;background:linear-gradient(135deg,#4caf50,#45a049);border-radius:6px;color:#fff;display:flex;justify-content:space-between;margin-top:12px;padding:12px}.arrival-content[data-v-0bd366dd]{align-items:center;display:flex;gap:8px}.arrival-icon[data-v-0bd366dd]{font-size:20px}.arrival-text strong[data-v-0bd366dd]{display:block;margin-bottom:2px}.arrival-text p[data-v-0bd366dd]{font-size:12px;margin:0;opacity:.9}.arrival-text small[data-v-0bd366dd]{font-size:10px;opacity:.8}.dismiss-btn[data-v-0bd366dd]{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:20px;justify-content:center;padding:0;transition:background .2s;width:20px}.dismiss-btn[data-v-0bd366dd]:hover{background:#fff3}@keyframes slideIn-0bd366dd{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.status-toast[data-v-0bd366dd]{animation:slideIn-0bd366dd .3s ease-out;border-radius:6px;color:#fff;font-weight:500;padding:12px 16px;position:absolute;right:10px;top:60px;z-index:1002}.toast-success[data-v-0bd366dd]{background:#4caf50}.toast-warning[data-v-0bd366dd]{background:#ff9800}.toast-info[data-v-0bd366dd]{background:#2196f3}[data-v-0bd366dd] .current-location-marker{background:transparent;transition:all .3s ease}[data-v-0bd366dd] .marker-pulse{animation:pulse-0bd366dd 2s infinite;background:#4caf50;border-radius:50%;height:20px;position:relative;transition:all .3s ease;width:20px}[data-v-0bd366dd] .marker-pulse:before{animation:pulse-ring-0bd366dd 2s infinite;background:#4caf504d;border-radius:50%;content:"";height:30px;left:-5px;position:absolute;top:-5px;width:30px}[data-v-0bd366dd] .current-location-marker.moving .marker-pulse{animation:pulse-0bd366dd 1s infinite;background:#4caf50}[data-v-0bd366dd] .current-location-marker.stationary .marker-pulse{animation:none;background:#666}[data-v-0bd366dd] .current-location-marker.approaching .marker-pulse{animation:pulse-0bd366dd .5s infinite;background:#ff9800}[data-v-0bd366dd] .current-location-marker.arrived .marker-pulse{animation:celebration-0bd366dd 2s infinite;background:#2196f3}@keyframes pulse-0bd366dd{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes pulse-ring-0bd366dd{0%{opacity:1;transform:scale(.8)}to{opacity:0;transform:scale(2)}}@keyframes celebration-0bd366dd{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.2) rotate(5deg)}75%{transform:scale(1.2) rotate(-5deg)}}[data-v-0bd366dd] .destination-marker{animation:bounce-0bd366dd 2s infinite;background:transparent;font-size:20px;text-align:center}@keyframes bounce-0bd366dd{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}#app{font-family:Arial,sans-serif;margin:0 auto;max-width:1200px;padding:20px}header{margin-bottom:30px;text-align:center}header h1{color:#333}.container{flex-direction:column}.container,.controls{display:flex;gap:20px}.controls{align-items:center;background-color:#f5f5f5;border-radius:8px;padding:20px}.start-btn,.stop-btn{border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:10px 20px}.start-btn{background-color:#4caf50;color:#fff}.start-btn:hover{background-color:#45a049}.start-btn:disabled,.stop-btn:disabled{background-color:#ccc;cursor:not-allowed}.stop-btn{background-color:#f44336;color:#fff}.stop-btn:hover{background-color:#da190b}.status{font-weight:700}.info-panel{background-color:#e3f2fd;border-radius:8px;padding:20px}.info-panel h2{margin-top:0}.info-item{display:flex;justify-content:space-between;margin-bottom:8px}.info-item span{color:#666}.status-item{border-top:1px solid #eee;margin-top:8px;padding-top:8px}.status-badge{border-radius:4px;font-size:12px;font-weight:500;padding:4px 8px;text-transform:uppercase}.status-success{background:#e8f5e8;color:#2e7d32}.status-warning{background:#fff3e0;color:#f57c00}.status-info{background:#e3f2fd;color:#1976d2}.status-default{background:#f5f5f5;color:#666}.map-section{flex:1}.map-section h2{margin-bottom:10px}.map-placeholder{align-items:center;background-color:#f0f0f0;border:1px solid #ddd;border-radius:8px;color:#666;display:flex;height:400px;justify-content:center;width:100%}
