:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:100vw;min-height:100dvh;width:100vw;height:100dvh;background-color:#fff;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{margin:0;padding:0;width:100vw;height:100dvh;overflow:hidden;background:#fff;font-family:sans-serif}.home-container{display:flex;flex-direction:column;height:100dvh;width:100%;overflow:hidden;position:relative}.header{text-align:center;background-color:#fff;z-index:1}.header h1{margin:0;color:#2563eb}.header p{margin:4px 0 12px;font-size:.95rem;color:#444}.map-container{flex:1;width:100%;position:relative;z-index:0}.map-content{width:100%;height:100%;min-height:300px}.destination-input{position:fixed;bottom:16px;left:12px;right:12px;display:flex;align-items:center;background:#fff;border-radius:25px;box-shadow:0 2px 8px #0003;padding:6px 12px;z-index:10}.destination-input input{flex:1;border:none;font-size:1rem;color:#000;background-color:#fff;padding:8px;outline:none}.destination-input input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.destination-input button{background-color:#2563eb;color:#fff;border:none;border-radius:50%;font-size:1.2rem;width:36px;height:36px}.destination-input button:disabled{background-color:#aaa;cursor:not-allowed}.custom-info{background:#2563eb;color:#fff;padding:10px 14px;border-radius:10px;width:260px;text-align:center;font-size:.9rem}.pac-container{transform:translateY(-100%);margin-top:-40px;z-index:9999}.destination-input .send-button{width:42px;height:42px;background-color:#1d1f23;color:#fff;font-size:20px;border:none;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer}.send-button:disabled{background-color:#aaa;cursor:not-allowed}.centered-container{width:70%;margin:0 auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;gap:1rem;align-items:center}.centered-container input{width:100%;padding:.5rem;font-size:1rem;border:1px solid #ccc;border-radius:4px}.centered-container button{padding:.5rem 1.2rem;background-color:#2563eb;color:#fff;border:none;border-radius:4px;cursor:pointer}.centered-container button:disabled{background-color:#aaa;cursor:not-allowed}.map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:16px;background:#fffffff2;padding:24px;border-radius:12px;box-shadow:0 4px 12px #0000001a;z-index:5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2)}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #2563eb;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.map-loading p{margin:0;color:#444;font-size:1rem;font-weight:500}.map-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:16px;background:#fffffff2;padding:24px;border-radius:12px;box-shadow:0 4px 12px #0000001a;z-index:5;text-align:center;max-width:300px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2)}.map-error p{margin:0;color:#dc2626;font-size:.95rem;font-weight:500}.retry-button{background-color:#2563eb;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.retry-button:hover{background-color:#1d4ed8}.retry-button:active{background-color:#1e40af}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:2rem;text-align:center;background:#f8fafc}.error-boundary h2{color:#dc2626;margin-bottom:1rem}.error-boundary p{color:#64748b;margin-bottom:2rem;max-width:400px}.error-boundary button{background-color:#2563eb;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;cursor:pointer;transition:background-color .2s}.error-boundary button:hover{background-color:#1d4ed8}.critical-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:2rem;text-align:center;background:#fef2f2}.critical-error h2{color:#dc2626;margin-bottom:1rem}.critical-error p{color:#7f1d1d;margin-bottom:2rem;max-width:400px}.critical-error button{background-color:#dc2626;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;cursor:pointer;transition:background-color .2s}.critical-error button:hover{background-color:#b91c1c}.eta-container{position:relative;width:100vw;height:100vh;font-family:sans-serif;overflow:hidden}.map-section{width:100%;height:68%;background:url(/your-map-screenshot.png) center/cover no-repeat;position:relative}.eta-popup{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#06f;color:#fff;padding:6px 12px;border-radius:10px;font-weight:700;font-size:14px}.bottom-sheet{position:absolute;bottom:0;width:100%;background:#fff;border-top-left-radius:20px;border-top-right-radius:20px;padding-left:1px;padding-right:1px;padding-top:16px;box-shadow:0 -2px 1px #0000001a;overflow-y:auto;height:55%;-webkit-overflow-scrolling:touch}.drag-indicator{width:40px;height:4px;background:#ccc;border-radius:2px;margin:0 auto 12px}.destination-title{text-align:center;font-size:14px;color:#999;margin-bottom:4px}.destination-name{text-align:center;font-size:16px;color:#1d1d1f;font-weight:600;margin-bottom:12px}.invite-box{display:flex;justify-content:space-between;align-items:center;background:#1d1d1f;color:#fff;padding:8px 12px;border-radius:8px;font-size:13px;margin-bottom:16px}.close-button{background:none;border:none;color:#fff;font-size:16px;cursor:pointer}.guest-actions{display:flex;justify-content:center;gap:32px;margin-bottom:4px}.circle-button{width:60px;height:60px;background:#f1f1f1;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer}.guest-labels{display:flex;justify-content:center;gap:60px;font-size:12px;color:#777;margin-bottom:20px}.start-button{width:100%;background:#06f;color:#fff;padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;display:flex;justify-content:center;align-items:center;z-index:10}.modal{background:#fff;width:90%;max-width:360px;border-radius:16px;padding:24px 16px;text-align:center;position:relative}.modal-close{position:absolute;top:10px;left:10px;font-size:20px;background:none;border:none;cursor:pointer}.modal-title{font-size:16px;color:#06f;font-weight:700;margin-bottom:4px}.modal-subtitle{font-size:13px;color:#666;margin-bottom:16px}.modal-photo-placeholder{width:80px;height:80px;background:#f3f3f3;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:28px;margin:0 auto 12px}.modal-input{width:90%;padding:10px;border:none;border-bottom:1px solid #ccc;font-size:14px;margin-bottom:20px;text-align:center}.modal-save{width:100%;background-color:#06f;color:#fff;padding:12px;border:none;border-radius:10px;font-weight:700;cursor:pointer;font-size:15px}.participants-section{padding:8px 16px}.participants-title{font-size:16px;font-weight:600;margin-bottom:16px;text-align:center}.participants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:16px;padding:0 8px}.participant-circle{display:flex;flex-direction:column;align-items:center;text-align:center}.participant-info{margin-top:8px;display:flex;flex-direction:column;gap:4px}.participant-name{font-size:14px;color:#1d1d1f;font-weight:500}.participant-eta{font-size:12px;color:#666}.participant-initial{font-size:20px;font-weight:500;color:#1d1d1f}.open-maps-button-wrapper{display:flex;justify-content:center;margin-top:16px;margin-left:8px;margin-right:8px}.open-maps-button{background-color:#4285f4;color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:16px;cursor:pointer;transition:background-color .2s ease}.open-maps-button:hover{background-color:#3367d6}.invite-prompt{display:flex;flex-direction:column;align-items:center;text-align:center;height:80vh;justify-content:center;background-color:#fff}.app-title{font-size:28px;font-weight:700;color:#007bff;margin-bottom:8px}.invited-by{color:#888;font-size:16px;margin-bottom:24px}.invite-icon{font-size:64px;margin-bottom:24px;color:#ccc}.invite-heading{font-size:18px;font-weight:600;color:#036;margin-bottom:8px}.invite-subheading{font-size:14px;color:#666;margin-bottom:32px;max-width:300px}.name-input{padding:10px 14px;border:1px solid #ccc;border-radius:8px;font-size:16px;width:100%;max-width:280px;margin-bottom:16px}.start-button{background-color:#007bff;color:#fff;border:none;padding:12px 20px;font-size:16px;border-radius:10px;width:100%;max-width:90%;margin-bottom:12px;cursor:pointer}.cancel-button-invitation{background-color:#d6d7dd;color:#000;border:none;padding:12px 20px;font-size:16px;border-radius:10px;width:100%;max-width:280px;margin-bottom:12px;cursor:pointer}.cancel-button{background-color:#e0e0e0;color:#333;border:none;padding:12px 20px;font-size:16px;border-radius:10px;width:100%;max-width:280px;cursor:pointer}.start-button:disabled{background-color:#a0c9f7;cursor:not-allowed;opacity:.8}.participant-popup{position:fixed;bottom:0;width:100%;height:50%;max-width:100vw;background-color:#fff;border-top-left-radius:20px;border-top-right-radius:20px;box-shadow:0 -4px 10px #0003;z-index:20;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.popup-header{position:relative;display:flex;align-items:center;padding:16px;border-top-left-radius:20px;border-top-right-radius:20px;background-color:#1d1d1f;color:#fff;overflow:hidden}.popup-progress-bar{position:absolute;top:0;left:0;height:100%;background-color:#06f;z-index:0;transition:width .3s ease;border-top-left-radius:20px;border-top-right-radius:20px}.popup-title-bar,.popup-close,.circle-button{position:relative;z-index:1}.popup-close{background:none;border:none;color:#fff;font-size:24px;margin-right:12px;cursor:pointer}.popup-title-bar{display:flex;flex-direction:column}.popup-title{font-size:22px;font-weight:700}.popup-sub{font-size:16px;opacity:.9}.popup-image{width:100%;height:auto;object-fit:cover}.floating-directions-button{position:absolute;top:60px;left:50%;transform:translate(-50%);background-color:#1a73e8;color:#fff;border:none;border-radius:22px;padding:10px 18px;font-size:16px;font-weight:500;box-shadow:0 2px 6px #0003;z-index:3;cursor:pointer}.floating-directions-button:hover{background-color:#1558c1}.directions-list{padding:16px;background:#fff;max-height:60vh;overflow-y:auto}.direction-step{margin-bottom:16px;font-size:14px;border-bottom:1px solid #eee;padding-bottom:10px}.direction-step:last-child{border-bottom:none}.step-distance{font-size:12px;color:#555;margin-top:4px}.profile-preview{width:100%;height:100%;object-fit:cover;border-radius:50%;box-sizing:border-box;padding:2px}.share-sheet-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000004d;z-index:30;display:flex;justify-content:center;align-items:flex-end}.share-sheet{height:40%;background:#fff;width:100%;max-width:500px;border-top-left-radius:20px;border-top-right-radius:20px;padding:24px 16px;box-shadow:0 -2px 10px #00000026;animation:slideUp .3s ease}.share-title{text-align:center;font-size:18px;color:#06f;font-weight:600;margin-bottom:8px}.share-subtitle{font-size:14px;color:#555;text-align:center;margin-bottom:20px}.share-link-box{display:flex;justify-content:space-between;align-items:center;background:#f3f3f3;border-radius:12px;padding:12px 16px;font-size:15px}.share-link{overflow-x:auto;white-space:nowrap;color:#333;font-weight:500}.copy-button{background:#06f;color:#fff;border:none;padding:8px 16px;border-radius:10px;font-weight:700;font-size:14px;cursor:pointer}.cancellation-overlay{position:fixed;top:0;left:0;width:20vw;height:20vw;background-color:#fff;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px}.cancellation-title{font-size:20px;font-weight:700;margin-bottom:10px;color:#555}.cancellation-sub{font-size:14px;color:#888}.cancel-button{background-color:#ff3b30;color:#fff;font-size:20px;font-weight:700;border:none;position:absolute;top:12px;left:12px;width:25px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0003;cursor:pointer;z-index:2;transition:background-color .2s ease}.cancel-button.circle-button{color:#fff}.cancel-button:hover{background-color:#e02620}.participant-progress-ring{padding:3px;background-size:cover;background-position:center;background-repeat:no-repeat}.participant-progress-inner{width:100%;height:100%;background:#fff;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center}.bubble-container{display:flex;width:100%;margin-bottom:8px;margin-left:30px}.bubble-message{position:relative;background-color:#1d1d1f;color:#fff;padding:8px 16px;border-radius:20px;font-size:13px;display:flex;align-items:center;max-width:200px;word-break:break-word}.bubble-message:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:#1d1d1f transparent transparent transparent}.bubble-close{background:none;border:none;color:#fff;font-size:16px;cursor:pointer;margin-left:8px;padding:0}
