body{font-family:Arial,sans-serif;margin:0;padding:0;background-color:#f5f5f5;min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column}.nav-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:0;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:1000}.nav-content{max-width:1800px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;height:70px}.nav-title h1{margin:0;font-size:24px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.3);color:#fff}.nav-location{flex:1;display:flex;align-items:center;justify-content:center;margin:0 20px}.location-info{background:#fff;color:#374151;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;text-align:center;box-shadow:0 2px 8px #0000001a;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-location-full{width:100%;background:#fff;border-top:1px solid rgba(255,255,255,.2)}.location-info-full{color:#374151;padding:12px 20px;font-size:14px;font-weight:500;text-align:center;width:100%;box-sizing:border-box}.disclaimer-text{font-size:11px;font-style:italic;color:#6b7280;margin-top:2px;opacity:.8}.nav-auth{display:flex;align-items:center;gap:16px}.main-container{flex:1;display:flex;justify-content:center;align-items:flex-start;padding:20px;min-height:calc(100vh - 70px)}@media (max-width: 768px){.nav-content{padding:0 15px;height:60px}.nav-title h1{font-size:18px}.login-btn,.logout-btn{padding:6px 12px;font-size:12px}.main-container{padding:0;align-items:stretch;min-height:calc(100vh - 60px)}.container{border-radius:0;box-shadow:none;padding:0;margin:0;width:100%;max-width:none}}.auth-status{display:flex;align-items:center;gap:10px;font-size:14px}.icon-btn{width:40px;height:40px;border:none;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background:#fff3;color:#8b5cf6;border:1px solid rgba(255,255,255,.3)}.icon-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px) scale(1.05);box-shadow:0 4px 12px #0003}.logout-icon{background:#ff4757e6;border-color:#ff475780}.logout-icon:hover{background:#ff3742e6;border-color:#ff3742b3;box-shadow:0 4px 12px #ff47574d}.loading-icon{animation:spin 1s linear infinite;font-size:18px;color:#fff}.user-welcome{font-size:12px;margin-right:8px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.login-dialog{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:dialogSlideIn .3s ease-out}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.login-dialog-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px;border-radius:20px 20px 0 0;display:flex;justify-content:space-between;align-items:center}.login-dialog-header h2{margin:0;font-size:24px;font-weight:600}.close-btn{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.close-btn:hover{background:#fff3}.login-dialog-content{padding:30px;text-align:center}.login-icon-large{font-size:60px;margin-bottom:20px}.login-description{font-size:16px;color:#666;margin-bottom:25px;line-height:1.5}.login-features{list-style:none;padding:0;margin:0 0 30px;text-align:left}.login-features li{padding:8px 0;font-size:14px;color:#555;border-bottom:1px solid #f0f0f0}.login-features li:last-child{border-bottom:none}.login-dialog-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.login-dialog-btn{padding:15px 25px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.login-dialog-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.login-dialog-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.login-dialog-btn.secondary{background:#f8f9fa;color:#666;border:1px solid #e9ecef}.login-dialog-btn.secondary:hover{background:#e9ecef;transform:translateY(-1px)}.btn-icon{font-size:18px}.login-note{font-size:12px;color:#999;margin:0;font-style:italic}.shared-map-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column}.shared-map-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px 30px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 20px #0000001a;border-bottom:1px solid rgba(255,255,255,.2)}.shared-map-header h1{margin:0;color:#333;font-size:28px;font-weight:700}.header-info{display:flex;align-items:center;gap:20px}.connection-status{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}.connection-status.error{color:#ef4444}.status-indicator{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.viewer-count{background:#667eea1a;color:#667eea;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600}.shared-location-info{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:20px 30px;padding:20px;border-radius:15px;box-shadow:0 4px 20px #0000001a}.location-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.location-item{display:flex;flex-direction:column;gap:5px}.location-item strong{color:#667eea;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.location-item span{color:#333;font-size:14px;font-weight:500}.shared-map-content{flex:1;padding:0 30px 30px}.shared-map-content .container{max-width:none;margin:0;background:transparent;box-shadow:none;border-radius:0}.shared-map-content .map-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:20px;height:60vh;min-height:400px}.shared-map-content .metro-map-section,.shared-map-content .real-map-section{background:#fff;border-radius:15px;box-shadow:0 8px 30px #0000001a;overflow:hidden}.shared-map-footer{background:#0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:15px 30px;text-align:center;color:#fffc;font-size:12px}.shared-map-footer p{margin:5px 0}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:40px;text-align:center;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:20px 30px;border-radius:20px;box-shadow:0 8px 30px #0000001a}.error-icon{font-size:48px;margin-bottom:20px}.error-container h2{color:#333;margin:0 0 10px;font-size:24px}.error-container p{color:#666;margin:0 0 20px;font-size:16px}.retry-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.nav-auth .share-btn{display:flex;align-items:center;gap:8px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:10px 16px;border-radius:25px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;position:relative}.nav-auth .share-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.nav-auth .share-btn.sharing{background:#10b981e6;border-color:#10b981b3;animation:pulse-sharing 2s infinite}@keyframes pulse-sharing{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 10px #10b98100}}.share-icon{font-size:16px}.share-text{font-size:13px}.viewer-badge{background:#ffffffe6;color:#10b981;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:600;min-width:16px;text-align:center}.share-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.share-modal{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.share-modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 25px;border-radius:20px 20px 0 0;display:flex;justify-content:space-between;align-items:center}.share-modal-header h3{margin:0;font-size:20px;font-weight:600}.share-modal-content{padding:25px}.share-status{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:12px;background:#10b9811a;border-radius:10px;border-left:4px solid #10b981}.share-status .status-indicator{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s infinite}.share-status span{color:#10b981;font-weight:500;font-size:14px}.share-url-container{margin-bottom:20px}.share-url-container label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.url-input-group{display:flex;gap:10px}.url-input{flex:1;padding:12px 15px;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;background:#f9fafb;color:#6b7280}.copy-btn{background:#667eea;color:#fff;border:none;padding:12px 15px;border-radius:10px;cursor:pointer;font-size:16px;transition:all .2s ease;min-width:50px}.copy-btn:hover{background:#5a67d8;transform:translateY(-1px)}.copy-btn.success{background:#10b981}.share-btn-icon{background:#8b5cf6;color:#fff;border:none;padding:12px 15px;border-radius:10px;cursor:pointer;font-size:16px;transition:all .2s ease;min-width:50px;margin-left:8px}.share-btn-icon:hover{background:#7c3aed;transform:translateY(-1px)}.share-actions{display:flex;gap:10px;margin-bottom:20px}.share-action-btn{flex:1;padding:12px 20px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.share-action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.share-action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.share-action-btn.secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.share-action-btn.secondary:hover{background:#e5e7eb;transform:translateY(-1px)}.share-info{background:#f9fafb;padding:15px;border-radius:10px;border-left:4px solid #667eea}.share-info p{margin:5px 0;color:#6b7280;font-size:13px;line-height:1.4}.auth-btn{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.auth-btn:hover{color:#fffc;transform:translateY(-1px)}.auth-btn svg{width:20px;height:20px}.user-name{font-size:14px;font-weight:500;color:#fff;margin-right:8px;text-transform:capitalize}.hamburger-btn{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.hamburger-btn:hover{color:#fffc;transform:translateY(-1px)}.hamburger-btn svg{width:24px;height:24px}.side-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999999;display:flex;align-items:stretch;justify-content:flex-end;animation:fadeIn .3s ease}.side-menu{background:#fff;width:100%;max-width:320px;height:100vh;display:flex;flex-direction:column;animation:slideInRight .3s ease;box-shadow:-10px 0 30px #0000004d}.side-menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.side-menu-header h2{margin:0;font-size:20px;font-weight:600;color:#1f2937}.side-menu-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.side-menu-close:hover{background:#6b72801a;color:#374151}.side-menu-content{flex:1;padding:20px;overflow-y:auto}.menu-item{display:flex;align-items:center;padding:16px 0;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:all .2s ease;color:#374151}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:#8b5cf60d;margin:0 -20px;padding:16px 20px;border-radius:12px}.menu-item svg{color:#8b5cf6;margin-right:16px;flex-shrink:0}.menu-item span{font-size:16px;font-weight:500}.logout-item{border-top:1px solid #e5e7eb;margin-top:8px;padding-top:16px}.logout-item svg{color:#ef4444}.logout-item:hover{background:#0000000d}.side-menu-footer{padding:20px;border-top:1px solid #f3f4f6;background:#f9fafb}.disclaimer{font-size:12px;color:#6b7280;text-align:center;margin:0;line-height:1.4;font-style:italic}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.side-menu{max-width:280px}.side-menu-header,.side-menu-content,.side-menu-footer{padding:16px}.menu-item{padding:14px 0}.menu-item:hover{margin:0 -16px;padding:14px 16px}}.splash-screen{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;z-index:99999;overflow:hidden}.splash-content{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.splash-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;transform:translate(-50%,-50%);object-fit:cover;z-index:2}.splash-fallback{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);z-index:1;display:flex;align-items:center;justify-content:center}.metro-animation{text-align:center;position:relative}.metro-train{font-size:80px;animation:trainMove 3s ease-in-out infinite;margin-bottom:20px}.metro-tracks{position:relative;width:200px;height:20px;margin:0 auto}.track{position:absolute;width:100%;height:4px;background:#ffffff4d;border-radius:2px}.track:nth-child(1){top:0}.track:nth-child(2){bottom:0}@keyframes trainMove{0%,to{transform:translate(-50px)}50%{transform:translate(50px)}}.splash-loading{position:relative;z-index:3;text-align:center;color:#fff;background:#0000004d;padding:30px;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-spinner{margin-bottom:20px}.metro-icon{font-size:48px;animation:pulse 2s infinite;color:#8b5cf6}.splash-loading p{margin:5px 0;font-size:16px;font-weight:500}.splash-duration{font-size:12px!important;opacity:.8!important}.skip-btn{position:absolute;top:20px;right:20px;z-index:4;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:20px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.skip-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.splash-title{position:absolute;bottom:60px;left:50%;transform:translate(-50%);z-index:3;text-align:center;color:#fff;background:#0006;padding:20px 30px;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.splash-title h1{margin:0 0 8px;font-size:28px;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.splash-title p{margin:0;font-size:14px;opacity:.9;text-shadow:1px 1px 2px rgba(0,0,0,.5)}@media (min-width: 769px){.splash-screen{display:none!important}}@media (max-width: 768px){.shared-map-header{padding:15px 20px;flex-direction:column;gap:10px;text-align:center}.shared-map-header h1{font-size:24px}.header-info{flex-direction:column;gap:10px}.shared-location-info{margin:15px 20px;padding:15px}.location-details{grid-template-columns:1fr}.shared-map-content{padding:0 20px 20px}.shared-map-content .map-wrapper{grid-template-columns:1fr;gap:15px;height:auto}.shared-map-content .metro-map-section,.shared-map-content .real-map-section{height:300px}.shared-map-footer{padding:10px 20px;font-size:11px}}.container{max-width:1800px;width:100%;background-color:#fff;border-radius:10px;box-shadow:0 0 20px #0000001a;padding:16px;position:relative;overflow:scroll;margin:0 auto}.map-container{position:relative;overflow:visible;height:auto;max-width:100%}@media (min-width: 768px){.map-container{height:auto;margin-bottom:300px;overflow:visible}}svg{display:block;max-width:100%;height:auto}.legend{background-color:#eee;border-radius:10px;padding:15px;position:absolute;top:20px;right:20px;max-width:200px}.legend-item{display:flex;align-items:center;margin-bottom:8px}.legend-color{width:20px;height:4px;margin-right:10px}.legend-interchange{display:inline-block;width:16px;height:16px;border:2px solid black;border-radius:50%;background-color:#fff;margin-right:10px}.station-name{font-size:10px;fill:#000;text-anchor:start;writing-mode:vertical-lr;text-orientation:mixed;padding-right:10px;transform:translate(0) translateY(12px);pointer-events:none}.map-container.mumbai-metro-map .station-name{font-size:14px}.hyd-station-name{font-size:9px;fill:#000;text-anchor:right;pointer-events:none}.hyd-station-name.interchange{fill:red;font-weight:700}.mum-station-name{font-size:9px;fill:#000;text-anchor:right;dominant-baseline:middle;pointer-events:none}.mum-station-name.interchange{fill:red;font-weight:700}.t-horizontal{writing-mode:horizontal-tb;text-anchor:end;transform:translate(-12px) translateY(0)}.t-horizontal_start{writing-mode:horizontal-tb;text-anchor:start;transform:translate(-12px) translateY(0)}.t-vertical{writing-mode:vertical-rl;text-anchor:end;transform:translate()}.station{cursor:pointer;transition:all .3s ease}.station:hover{stroke-width:3}.station-circle{fill:#fff;stroke-width:1.5}.highlighted{stroke-width:3;animation:pulse 1.5s infinite}.visited{fill:pink}@keyframes pulse{0%{r:5;fill:#ff0}50%{r:16;fill:#ff0}to{r:5;fill:#ff0}}.notification-bell{display:none;pointer-events:none;transform-origin:center;transform-box:fill-box}.station.notification-active+.notification-bell{display:block}@keyframes bellShake{0%{transform:translate(0) scale(1)}15%{transform:translate(2px,-2px) scale(1)}30%{transform:translate(-2px,2px) scale(1)}45%{transform:translate(1px,-1px) scale(1)}60%{transform:translate(-1px,1px) scale(1)}75%{transform:translate(.5px,-.5px) scale(1)}85%{transform:translate(-.5px,.5px) scale(1)}to{transform:translate(0) scale(1)}}.station.notification-active+.notification-bell{animation:bellShake 1s ease}.notification-icon{fill:#ff5722;stroke:#fff;stroke-width:2;opacity:0;transition:opacity .3s ease;pointer-events:none}.notification-active .notification-icon{opacity:1}.station.notification-active{position:relative}.station.notification-active:before{content:"🔔";position:absolute;font-size:14px;top:-20px;left:50%;transform:translate(-50%);z-index:100}@keyframes bellRing{0%{transform:rotate(0)}20%{transform:rotate(15deg)}40%{transform:rotate(-15deg)}60%{transform:rotate(7deg)}80%{transform:rotate(-7deg)}to{transform:rotate(0)}}.station.notification-active:before{animation:bellRing 1s ease}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background-color:#000c;color:#fff;padding:12px 20px;border-radius:4px;z-index:1000;display:none;animation:fadeInOut 4s forwards;min-width:300px;width:90%;max-width:500px}.toast-content{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:16px}.toast-message{flex:1}.dismiss-button{background:#fff280;color:#201a1f;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-weight:500}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,20px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,20px)}}.purple-line{stroke:#8e44ad}.green-line{stroke:#049344}.yellow-line{stroke:#f1c40f}.pink-line{stroke:#e84393}.blue-line{stroke:#3498db}.red-line{stroke:#b4302c}.aqua-line{stroke:#59b7c9}.controls{margin-top:20px;display:flex;justify-content:center;flex-wrap:wrap;gap:10px}select,button{padding:12px 15px;border:1px solid #ddd;border-radius:5px;background-color:#fff;font-size:14px}button{background-color:#3498db;color:#fff;border:none;cursor:pointer;transition:background-color .3s}button:hover{background-color:#2980b9}.current-station-info{text-align:center;margin-top:15px;font-weight:700}.page_title{font-size:20px;margin-bottom:80px;display:block;position:fixed;top:0;left:0;text-align:center;background-color:#f5f5f5;width:100%;z-index:1;padding-top:30px}.search-input{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;margin-bottom:5px}.dropdown{width:100%;max-height:300px;overflow-y:auto;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;display:none;position:absolute;background:#fff;z-index:1000}.dropdown-item{padding:10px;cursor:pointer}.dropdown-item:hover{background-color:#f1f1f1}.dropdown-item.disabled{color:#888;font-weight:700;background-color:#f8f8f8;cursor:default}.selected-display:after{content:"▼";font-size:12px}.line-green{border-left:4px solid #008000}.line-purple{border-left:4px solid #800080}#bottom_controls{background-color:#fff;position:fixed;bottom:0;left:0;width:100vw;display:grid;grid-template-columns:44% 44%;grid-gap:16px;padding:16px}.dropdown-item.google-place{background-color:#f8f9fa;border-left:4px solid #4285f4}.dropdown-item.metro-station{background-color:#fff}.dropdown-item.metro-station.green-line{border-left:4px solid #27ae60}.dropdown-item.metro-station.blue-line{border-left:4px solid #0D78B0}.dropdown-item.metro-station.purple-line{border-left:4px solid #8e44ad}.dropdown-item.metro-station.yellow-line{border-left:4px solid #f1c40f}.dropdown-item.metro-station.red-line{border-left:4px solid #B4302C}.dropdown-item.metro-station.aqua-line{border-left:4px solid #59B7C9}@media (max-width: 768px){body{width:100vw;overflow-x:hidden}.legend{position:relative;top:0;right:0;margin-bottom:20px;max-width:100%}.container{width:100vw;border-radius:0;height:150vh;margin:0!important;background-image:url("data:image/svg+xml,%3Csvg width='393' height='852' viewBox='0 0 393 852' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0_538_4029)'%3E%3Ccircle cx='8.5' cy='95.5' r='213.5' fill='url(%23paint0_radial_538_4029)' fill-opacity='0.8'/%3E%3Cellipse cx='358.5' cy='273' rx='272.5' ry='283' fill='url(%23paint1_radial_538_4029)' fill-opacity='0.7'/%3E%3C/g%3E%3Cdefs%3E%3CradialGradient id='paint0_radial_538_4029' cx='0' cy='0' r='1' gradientUnits='userSpaceOnUse' gradientTransform='translate(8.5 95.5) rotate(90) scale(213.5)'%3E%3Cstop stop-color='%23FEEBDA'/%3E%3Cstop offset='1' stop-color='%23FEEBDA' stop-opacity='0'/%3E%3C/radialGradient%3E%3CradialGradient id='paint1_radial_538_4029' cx='0' cy='0' r='1' gradientUnits='userSpaceOnUse' gradientTransform='translate(358.5 273) rotate(90) scale(283 272.5)'%3E%3Cstop stop-color='%23C3C1EB'/%3E%3Cstop offset='1' stop-color='%23C3C1EB' stop-opacity='0'/%3E%3C/radialGradient%3E%3CclipPath id='clip0_538_4029'%3E%3Crect width='393' height='852' fill='white'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E");background-size:cover;background-position:center;background-repeat:no-repeat}.map-container{position:relative;margin-left:40%;margin-top:70px;width:800px;max-width:1500px;transform:translate(-28%) rotate(270deg);overflow:visible;height:auto}.map-container.mumbai-metro-map{transform:scale(2)!important;transform-origin:top left!important;margin-left:0!important;margin-top:20px!important;margin-bottom:150vh!important;padding-bottom:230px!important;width:auto!important;max-width:none!important;min-height:auto!important;overflow:visible!important}.openstreet-map-container{position:relative;margin-left:50%;margin-top:70px;width:100%;max-width:1500px;transform:translate(-50%) rotate(0)}.page_title{font-size:14px;margin-bottom:80px;display:inline-block;position:fixed;top:0;left:0;text-align:center;background-color:#f5f5f5;width:100vw;z-index:2;padding:16px 0}.controls{margin-top:160px}.dropdown-container{position:fixed;width:100%;top:0;left:0}}.bottom-drawer{box-sizing:border-box;position:fixed;bottom:0;width:100%;max-width:600px;left:50%;transform:translate(-50%);background-color:#fff;box-shadow:0 -4px 12px #0000001a;border-radius:20px 20px 0 0;padding:20px;z-index:1000;max-height:90vh;min-height:160px;overflow-y:auto;transition:all .3s ease-in-out;height:auto}.bottom-drawer.dropdown-open{height:50vh;max-height:50vh}.dropdown-container{position:relative;width:100%;margin-bottom:16px;z-index:1001}#bottom_controls{background-color:transparent;position:absolute;bottom:20px;left:20px;right:20px;width:calc(100% - 40px);display:flex;gap:12px;padding:0;z-index:1003}.bottom-btn{padding:12px 16px;border:none;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;justify-content:center}.bottom-btn:hover{transform:translateY(-2px)}.bottom-btn svg{flex-shrink:0}.book-tickets{background:#8b5cf6;color:#fff;flex:2;box-shadow:0 4px 15px #8b5cf64d}.book-tickets:hover{box-shadow:0 6px 20px #8b5cf666}.play-btn{background:#fff;color:#8b5cf6;border:2px solid #8b5cf6;flex:1}.play-btn:hover{background:#8b5cf61a}.ig-story{background:#fff;color:#8b5cf6;border:2px solid #8b5cf6;flex:1}.ig-story:hover{background:#8b5cf61a}.ig-story.disabled{background:#f3f4f6;color:#9ca3af;border-color:#d1d5db;cursor:not-allowed;opacity:.6}.ig-story.disabled:hover{background:#f3f4f6;color:#9ca3af;border-color:#d1d5db;transform:none}.search-input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;margin-bottom:5px;font-size:16px;background:#fff}.dropdown{width:100%;max-height:300px;overflow-y:auto;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;display:none;position:absolute;background:#fff;z-index:1002;box-shadow:0 4px 12px #0000001a;top:calc(100% + 4px);left:0}.selected-display{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;cursor:pointer;background-color:#f5f5f5;display:flex;justify-content:space-between;align-items:center;font-size:16px;margin-bottom:0;position:relative;z-index:1001}.dropdown-item{padding:12px;cursor:pointer;border-bottom:1px solid #eee}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:#f5f5f5}@media (max-width: 768px){.bottom-drawer{width:100%;max-width:100%;padding:16px;transform:none;left:0;transition:all .3s ease-in-out;height:auto;position:fixed;bottom:0}.bottom-drawer.dropdown-open{height:calc(100vh - 80px);max-height:calc(100vh - 80px);padding-top:20px;overflow:hidden}.dropdown{position:relative;width:100%;max-height:calc(100vh - 200px);overflow-y:auto;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;background:#fff;z-index:1002;box-shadow:0 4px 12px #0000001a;top:calc(100% + 4px);left:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.search-input{padding:10px;font-size:14px;font-size:16px}.selected-display{padding:10px;font-size:14px}#dropdown-items-container{max-height:calc(100vh - 300px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:80px}.bottom-drawer.dropdown-open #bottom_controls{display:none}#bottom_controls{bottom:16px;left:16px;right:16px;width:calc(100% - 32px)}}.openstreet-map-container{position:relative}.map-close-btn{position:absolute;top:5px;right:5px;z-index:1000;background:#ffffffe6;border:1px solid #e5e7eb;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.map-close-btn:hover{background:#fff;border-color:#8b5cf6;transform:scale(1.05)}.map-close-btn svg{color:#6b7280;width:16px;height:16px}.map-close-btn:hover svg{color:#8b5cf6}.ig-story-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.ig-story-header{display:flex;align-items:center;gap:16px;margin-bottom:30px;color:#fff}.back-btn{background:#fff3;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease}.back-btn svg{width:24px;height:24px}.back-btn:hover{background:#ffffff4d;transform:scale(1.05)}.ig-story-header h1{margin:0;font-size:24px;font-weight:600}.login-required{background:#fff;border-radius:16px;padding:40px;text-align:center;color:#374151}.ig-story-content{background:#fff;border-radius:16px;padding:30px;max-width:800px;margin:0 auto}.generation-limit-notice{margin-bottom:20px}.limit-info{background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;color:#6b46c1;font-size:14px;font-weight:500}.limit-info svg{color:#8b5cf6;flex-shrink:0}.result-page-container{min-height:100vh;background:#f8f9fa;display:flex;flex-direction:column}.result-page-header{display:flex;align-items:center;gap:16px;padding:20px;background:#fff;border-bottom:1px solid #e9ecef;position:sticky;top:0;z-index:10}.result-page-header .back-btn{background:#667eea1a;border:1px solid rgba(102,126,234,.2);color:#667eea}.result-page-header .back-btn:hover{background:#667eea33;border-color:#667eea4d;transform:scale(1.05)}.result-page-header h2{margin:0;color:#333;font-size:24px;font-weight:600}.result-page-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:40px}.result-image-full{max-width:400px;width:100%;border-radius:20px;overflow:hidden;box-shadow:0 20px 40px #0000001a;background:#fff}.result-image-full img{width:100%;height:auto;display:block;border-radius:20px}.result-page-actions{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.download-btn-large,.share-btn-large{display:flex;align-items:center;gap:12px;padding:16px 32px;border:none;border-radius:50px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;min-width:140px;justify-content:center}.download-btn-large{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.download-btn-large:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.share-btn-large{background:#fff;color:#667eea;border:2px solid #667eea}.share-btn-large:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 10px 20px #667eea33}.download-btn-large svg,.share-btn-large svg{width:24px;height:24px}@media (max-width: 768px){.result-page-header{padding:16px}.result-page-header h2{font-size:20px}.result-page-content{padding:20px;gap:30px}.result-image-full{max-width:100%}.result-page-actions{flex-direction:column;width:100%;max-width:300px}.download-btn-large,.share-btn-large{width:100%;padding:18px 24px;font-size:18px}}.upload-section,.templates-section,.generate-section,.result-section{margin-bottom:30px}.upload-section h3,.templates-section h3,.result-section h3{margin:0 0 16px;color:#374151;font-size:18px;font-weight:600}.upload-area{border:2px dashed #d1d5db;border-radius:12px;padding:20px;text-align:center;transition:all .2s ease}.upload-area:hover{border-color:#8b5cf6;background:#8b5cf60d}.upload-label{cursor:pointer;display:block}.upload-placeholder{color:#6b7280;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;height:100%}.upload-placeholder p{margin:8px 0 0;font-size:14px;text-align:center}.image-preview{max-width:200px;max-height:200px;border-radius:8px;object-fit:cover}.templates-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.template-card{border:2px solid #e5e7eb;border-radius:12px;padding:0;cursor:pointer;transition:all .2s ease;text-align:center;overflow:hidden;position:relative}.template-card:hover{border-color:#8b5cf6;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf626}.template-card.selected{border-color:#8b5cf6;background:#8b5cf60d}.template-preview{height:300px;display:flex;align-items:center;justify-content:center;border-radius:12px;overflow:hidden;background:#f9fafb;position:relative}.template-preview img{width:100%;height:100%;object-fit:cover}.template-placeholder{color:#9ca3af;display:flex;flex-direction:column;align-items:center;gap:8px}.template-placeholder span{font-size:12px;font-weight:500}.template-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:20px 16px 16px;display:flex;align-items:flex-end;justify-content:center}.template-overlay h4{margin:0;font-size:16px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px;margin-bottom:20px}.error-message p{margin:0;color:#dc2626;font-size:14px}.generate-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:12px;padding:16px 32px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;margin:0 auto}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #8b5cf64d}.generate-btn:disabled{opacity:.6;cursor:not-allowed}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.result-section{border-top:1px solid #e5e7eb;padding-top:30px}.generated-image{text-align:center}.generated-image img{max-width:100%;max-height:400px;border-radius:12px;box-shadow:0 8px 25px #0000001a;margin-bottom:20px}.result-actions{display:flex;gap:12px;justify-content:center}.download-btn,.share-btn{background:#f3f4f6;border:none;border-radius:8px;padding:12px 20px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;color:#374151}.download-btn:hover,.share-btn:hover{background:#e5e7eb;transform:translateY(-1px)}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-content{background:#fff;border-radius:20px;padding:40px;text-align:center;max-width:400px;width:90%;box-shadow:0 20px 40px #0000004d}.loading-spinner-large{width:60px;height:60px;border:4px solid rgba(139,92,246,.2);border-top:4px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.loading-content h3{margin:0 0 12px;color:#374151;font-size:20px;font-weight:600}.loading-content p{margin:0;color:#6b7280;font-size:14px}
