:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,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}h1{font-size:3.2em;line-height:1.1}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100dvh;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f9fafb;overflow-x:hidden}.togather-app{width:100%;height:100dvh;display:flex!important;flex-direction:column!important;background:#f9fafb;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.app-header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;z-index:20;flex-shrink:0}.header-content{padding:16px;display:flex;align-items:center;justify-content:space-between}.header-logo{display:flex;align-items:center;gap:12px}.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,#3b82f6,#4f46e5);border-radius:8px;display:flex;align-items:center;justify-content:center}.logo-text{font-size:20px;font-weight:700;color:#111827}.header-stats{display:none;align-items:center;gap:16px;font-size:14px;color:#6b7280}.stat-item{display:flex;align-items:center;gap:4px}.main-content{flex:1!important;display:flex!important;flex-direction:column!important;overflow:hidden;min-height:0}.form-panel{display:flex!important;flex-direction:column!important;flex:1 1 auto!important;min-height:0!important;height:100%!important;width:100%!important;background:#fff;border-right:1px solid #e5e7eb;overflow:hidden}.mobile-map-preview{height:200px;position:relative;background:linear-gradient(135deg,#dbeafe,#c7d2fe);flex-shrink:0}.togather-app--input-focused .mobile-map-preview,.togather-app--address-focused .venue-section{display:none}.mobile-map-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to top,rgba(0,0,0,.1),transparent)}.expand-map-btn{position:absolute;bottom:12px;right:12px;background:#fff;color:#3b82f6;padding:6px 12px;border-radius:20px;font-size:14px;font-weight:500;box-shadow:0 4px 6px #0000001a;border:none;cursor:pointer}.form-content{flex:1!important;padding:24px!important;overflow-y:auto!important;min-height:0}.form-footer{flex:0 0 auto!important;padding:16px 24px calc(16px + env(safe-area-inset-bottom))!important;background:#fff!important;border-top:1px solid #f3f4f6!important}.venue-section{margin-bottom:24px}.venue-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.venue-input-container{position:relative}.venue-input{width:100%;padding:12px 16px 12px 40px;border:1px solid #d1d5db;border-radius:12px;background:#f9fafb;transition:all .2s;font-size:16px;color:#111827!important}.venue-input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.venue-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af}.error-message{margin-bottom:24px;padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;font-size:14px}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding:12px 12px 12px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#b91c1c}.error-banner-left{display:flex;align-items:center;gap:8px;min-width:0}.error-banner-text{font-size:14px;line-height:1.4;color:#7f1d1d}.error-dismiss{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:6px;color:#b91c1c;cursor:pointer;flex-shrink:0;transition:background-color .15s ease,color .15s ease}.error-dismiss:hover{background:#fee2e2;color:#7f1d1d}.starting-points-section{margin-bottom:24px}.section-title{font-size:18px;font-weight:600;color:#111827;margin-bottom:16px}.locations-list{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.location-item{width:100%}.location-card{display:flex!important;align-items:center!important;gap:12px!important;padding:16px!important;background:#f9fafb!important;border-radius:12px!important;border:1px solid #e5e7eb!important;transition:border-color .2s;width:100%!important}.location-card:hover{border-color:#d1d5db}.location-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.location-input-container{flex:1;position:relative;min-width:0}.location-input{width:100%!important;padding:8px 12px 8px 36px!important;background:#fff!important;border:1px solid #e5e7eb!important;border-radius:8px!important;font-size:14px!important;transition:all .2s;color:#111827!important}.location-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.location-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af}.transport-btn{display:flex!important;align-items:center!important;justify-content:center!important;width:40px!important;height:40px!important;border-radius:8px!important;border:none!important;cursor:pointer!important;transition:transform .2s!important;flex-shrink:0!important;color:#fff!important}.transport-btn>svg{color:#fff!important;stroke:#fff!important;fill:none!important;width:18px!important;height:18px!important}.location-card .transport-btn svg{color:#fff!important;stroke:#fff!important}.transport-walking{background:#10b981!important;color:#fff!important}.transport-walking svg{color:#fff!important;stroke:#fff!important}.transport-bicycling{background:#f59e0b!important;color:#fff!important}.transport-bicycling svg{color:#fff!important;stroke:#fff!important}.transport-transit{background:#8b5cf6!important;color:#fff!important}.transport-transit svg{color:#fff!important;stroke:#fff!important}.transport-driving{background:#3b82f6!important;color:#fff!important}.transport-driving svg{color:#fff!important;stroke:#fff!important}.remove-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:#9ca3af;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s;flex-shrink:0}.remove-btn:hover{color:#ef4444;background:#fef2f2}.add-person-btn{width:100%!important;padding:16px!important;border:2px dashed #d1d5db!important;border-radius:12px!important;color:#6b7280!important;background:transparent!important;cursor:pointer!important;transition:all .2s!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;font-weight:500!important;margin:0!important}.add-person-btn:hover{border-color:#60a5fa;color:#2563eb;background:#dbeafe}.find-btn{width:100%!important;background:linear-gradient(135deg,#10b981,#059669)!important;color:#fff!important;padding:16px!important;border-radius:12px!important;font-weight:600!important;font-size:18px!important;box-shadow:0 4px 6px #10b98133!important;border:none!important;cursor:pointer!important;transition:all .2s!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;margin:0!important}.find-btn:hover{background:linear-gradient(135deg,#059669,#047857)!important;box-shadow:0 8px 15px #10b9814d}.find-btn:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.results-section{margin-top:24px;background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 4px 6px #0000000d;overflow:hidden}.results-header{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:16px}.results-header-content{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.results-title{font-weight:600;font-size:18px}.results-time-badge{display:flex;align-items:center;gap:4px;background:#fff3;padding:4px 8px;border-radius:8px;font-size:14px;font-weight:500}.results-navigation{display:flex;align-items:center;justify-content:center;gap:12px}.nav-btn{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.nav-btn:hover{background:#ffffff4d}.results-dots{display:flex;gap:6px;align-items:center}.result-dot{width:8px;height:8px;border-radius:50%;background:#fff6;border:none;cursor:pointer;padding:0;transition:all .2s}.result-dot:hover{background:#fff9;transform:scale(1.2)}.result-dot.active{background:#fff;width:10px;height:10px}.results-content{padding:16px}.venue-name{font-weight:600;font-size:20px;color:#111827!important;margin-bottom:4px}.venue-address{color:#6b7280;font-size:14px;margin-bottom:12px}.venue-rating{display:flex;align-items:center;gap:8px;margin-bottom:16px}.rating-stars{display:flex;align-items:center}.rating-text{margin-left:4px;font-weight:500;font-size:14px;color:#1f2937}.rating-count{color:#6b7280;font-size:14px}.travel-times-section{margin-bottom:16px}.travel-times-title{font-weight:500;color:#374151;font-size:14px;margin-bottom:8px}.travel-times-list{display:flex;flex-direction:column;gap:8px}.travel-time-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#f9fafb;border-radius:8px}.travel-time-from{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.travel-time-color{width:8px;height:8px;border-radius:50%;flex-shrink:0}.travel-time-address{font-size:14px;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.travel-time-details{display:flex;align-items:center;gap:8px;font-size:14px;flex-shrink:0}.travel-time-value{font-weight:500;color:#1f2937}.travel-mode-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff}.share-buttons{display:flex;gap:8px}.share-btn{flex:1;background:#3b82f6;color:#fff;padding:12px;border-radius:8px;font-family:inherit;font-size:14px;line-height:1.2;font-weight:500;border:none;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px}.share-btn:hover{background:#2563eb}.share-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:share-fade-in .12s ease-out}.share-sheet{position:relative;background:#fff;border-radius:18px;width:100%;max-width:420px;padding:24px;box-shadow:0 20px 60px #0f172a40;animation:share-pop-in .16s cubic-bezier(.2,.9,.3,1.2)}@keyframes share-fade-in{0%{opacity:0}to{opacity:1}}@keyframes share-pop-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.share-sheet-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:#f1f5f9;color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s}.share-sheet-close:hover{background:#e2e8f0}.share-sheet-header{margin-bottom:16px;padding-right:32px}.share-sheet-eyebrow{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:6px}.share-sheet-title{font-size:22px;font-weight:700;color:#0f172a;margin:0 0 8px;line-height:1.2}.share-sheet-meta{display:inline-flex;align-items:center;gap:6px;background:#ecfdf5;color:#047857;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:500}.share-sheet-points{background:#f8fafc;border-radius:12px;padding:12px 14px;margin-bottom:16px;display:flex;flex-direction:column;gap:8px}.share-sheet-point{display:flex;align-items:center;gap:10px;font-size:14px}.share-sheet-point-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.share-sheet-point-addr{color:#334155;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-sheet-point-time{color:#0f172a;font-weight:600;font-variant-numeric:tabular-nums}.share-sheet-message{background:#f1f5f9;border-left:3px solid #3b82f6;border-radius:8px;padding:10px 12px;font-size:13px;color:#475569;margin:0 0 16px;line-height:1.45}.share-sheet-actions{display:flex;flex-direction:column;gap:8px}.share-sheet-btn{width:100%;padding:13px;border-radius:10px;font-size:15px;font-weight:600;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .15s,transform .05s}.share-sheet-btn:active{transform:translateY(1px)}.share-sheet-btn.primary{background:#3b82f6;color:#fff}.share-sheet-btn.primary:hover{background:#2563eb}.share-sheet-btn.secondary{background:#f1f5f9;color:#0f172a}.share-sheet-btn.secondary:hover{background:#e2e8f0}.map-display{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dbeafe,#c7d2fe);color:#6b7280}.map-placeholder{text-align:center}.map-panel{display:none;flex:1;position:relative;background:linear-gradient(135deg,#dbeafe,#c7d2fe)}@media (min-width: 768px){.main-content{flex-direction:row!important}.form-panel{flex:none!important;width:400px!important;max-width:400px!important}.mobile-map-preview{display:none!important}.header-stats,.map-panel{display:flex!important}}.location-card .transport-btn{background-color:unset!important;padding:0!important;font-size:inherit!important;border:none!important}.transport-btn.transport-walking{background-color:#10b981!important}.transport-btn.transport-bicycling{background-color:#f59e0b!important}.transport-btn.transport-transit{background-color:#8b5cf6!important}.transport-btn.transport-driving{background-color:#3b82f6!important}.venue-link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:inherit;transition:color .2s ease}.venue-link-icon{color:#9ca3af;transition:color .2s ease}.venue-link:hover .venue-name,.venue-link:hover .venue-link-icon{color:#2563eb}.address-history-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1000;margin-top:4px;overflow:hidden}.address-history-dropdown--hidden{display:none}.address-history-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:none;border:none;cursor:pointer;text-align:left;font-size:13px;color:#374151;transition:background .15s}.address-history-item:hover{background:#f3f4f6}.address-history-icon{flex-shrink:0;color:#9ca3af}.address-history-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.travel-times-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:6px}.travel-times-hint{font-size:12px;font-weight:400;color:#6b7280}.travel-time-item{cursor:pointer;border:1px solid transparent;transition:border-color .15s,background-color .15s,box-shadow .15s}.travel-time-item:hover{background:#f3f4f6}.travel-time-item:focus-visible{outline:none;border-color:#3b82f6}.travel-time-item--claimed{background:#eff6ff;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.travel-time-item--claimed:hover{background:#dbeafe}.travel-time-chevron{color:#cbd5e1;flex-shrink:0;transition:color .15s,transform .15s}.travel-time-item:hover .travel-time-chevron{color:#64748b;transform:translate(2px)}.you-chip{display:inline-flex;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:#fff;background:#3b82f6;border-radius:999px;flex-shrink:0}.directions-btn{flex:1;background:#10b981;color:#fff;padding:12px;border-radius:8px;font-family:inherit;font-size:14px;line-height:1.2;font-weight:500;border:none;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}.directions-btn:hover{background:#059669}.add-yourself-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;margin-bottom:12px;background:linear-gradient(135deg,#eef2ff,#e0f2fe);border:1px solid #bfdbfe;border-radius:10px}.add-yourself-banner-text{display:flex;flex-direction:column;gap:2px;min-width:0}.add-yourself-banner-text strong{font-size:14px;color:#1e3a8a}.add-yourself-banner-text span{font-size:13px;color:#1e40af}.add-yourself-banner-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.add-yourself-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.add-yourself-btn:hover{background:#2563eb}.add-yourself-dismiss{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:6px;color:#475569;cursor:pointer;transition:background .15s}.add-yourself-dismiss:hover{background:#0f172a0f}.transport-btn-wrapper{position:relative;flex-shrink:0}.transport-btn{position:relative}.transport-btn:active{transform:scale(.94)!important}.transport-btn-caret{position:absolute;right:-3px;bottom:-3px;width:16px;height:16px;background:#fff;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:#475569!important;box-shadow:0 0 0 1.5px #fff,0 1px 2px #0000002e;pointer-events:none}.transport-btn-caret>svg{width:10px!important;height:10px!important;color:#475569!important;stroke:#475569!important}.mode-popover{position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:#fff;border-radius:10px;border:1px solid #e2e8f0;box-shadow:0 10px 28px #0f172a2e;padding:4px;z-index:50;display:flex;flex-direction:column;gap:2px;animation:mode-pop-in .11s ease-out}@keyframes mode-pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.mode-option{display:flex;align-items:center;gap:10px;padding:8px 10px;border:none;background:transparent;border-radius:6px;cursor:pointer;text-align:left;font-size:14px;color:#1f2937;transition:background .12s}.mode-option:hover{background:#f1f5f9}.mode-option--active{background:#eff6ff;color:#1e3a8a;font-weight:600}.mode-option-icon{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;flex-shrink:0;color:#fff}.mode-option-icon>svg{color:#fff!important;stroke:#fff!important}.mode-option-label{flex:1}.mode-option-check{color:#1e40af}.form-content{padding:16px!important}.meeting-area{margin-bottom:10px}.meeting-area-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;font-size:13px;color:#334155;cursor:pointer;transition:background .15s,border-color .15s}.meeting-area-chip:hover{background:#e2e8f0;border-color:#cbd5e1}.meeting-area-chip strong{color:#0f172a;font-weight:600}.meeting-area-caret{color:#94a3b8}.meeting-area-picker{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #3b82f6;border-radius:10px;box-shadow:0 0 0 3px #3b82f61f}.meeting-area-icon{color:#64748b;flex-shrink:0}.meeting-area-input{flex:1;border:none;outline:none;font-size:14px;background:transparent;color:#0f172a;min-width:0}.meeting-area-cancel{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;cursor:pointer;color:#94a3b8;padding:4px;transition:color .15s}.meeting-area-cancel:hover{color:#475569}.venue-section--compact{margin-bottom:14px}.venue-section--compact .venue-input{padding:10px 14px 10px 36px;font-size:14px;border-radius:10px}.venue-section--compact .venue-input-icon{left:12px}.starting-points-section{margin-bottom:12px!important}.starting-points-section .section-title{font-size:13px!important;font-weight:500!important;color:#64748b!important;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px!important}.mobile-map-drawer{margin:4px 0 14px;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff}.mobile-map-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:#fff;border:none;cursor:pointer;font-size:13px;font-weight:500;color:#334155;transition:background .15s}.mobile-map-toggle:hover{background:#f8fafc}.mobile-map-toggle>span{flex:1;text-align:left}.mobile-map-toggle-caret{transition:transform .2s ease;color:#94a3b8}.mobile-map-drawer--open .mobile-map-toggle-caret{transform:rotate(180deg)}.mobile-map-canvas{height:240px;position:relative;background:linear-gradient(135deg,#dbeafe,#c7d2fe)}.mobile-map-canvas .map-display,.mobile-map-canvas>div{width:100%;height:100%}.togather-app--input-focused .mobile-map-drawer{display:none}@media (min-width: 768px){.mobile-map-drawer{display:none!important}}
