.welcome-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.welcome-tooltip{background:#fff;border-radius:20px;padding:40px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;position:relative;animation:slideIn .3s ease-out}.welcome-tooltip h2{color:#333;margin-bottom:20px;font-size:1.8rem}.welcome-content{color:#666}.welcome-content p{margin-bottom:20px;font-size:1.1rem;line-height:1.6}.instructions{background:#f5f5f5;padding:20px;border-radius:12px;margin:20px 0}.instructions h3{color:#333;margin-bottom:15px;font-size:1.2rem}.instructions ul{list-style:none;padding:0}.instructions li{padding:8px 0;font-size:1rem;color:#555}.access-info{background:#f5f5f5;padding:20px;border-radius:12px;margin:20px 0}.access-info h3{color:#333;margin-bottom:15px;font-size:1.1rem}.access-item{display:flex;align-items:center;gap:10px;padding:8px 0}.access-icon{font-size:1.2rem}.tip{background:#e3f2fd;padding:15px 20px;border-radius:12px;margin:20px 0}.tip p{margin:0;color:#1976d2}.start-button{background:#2196f3;color:#fff;border:none;padding:15px 30px;font-size:1.1rem;border-radius:30px;cursor:pointer;width:100%;margin-top:20px;transition:all .3s ease;font-weight:600}.start-button:hover{background:#1976d2;transform:translateY(-2px);box-shadow:0 5px 15px #2196f34d}@media (max-width: 768px){.welcome-tooltip{padding:30px 20px}.welcome-tooltip h2{font-size:1.5rem}}.region-info-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:2000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.region-info-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffffa;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:20px;border:3px solid #000;padding:30px;width:90%;max-width:400px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 40px #0000004d;z-index:2500;animation:slideInModal .3s ease-out}@keyframes slideInModal{0%{transform:translate(-50%,-50%) scale(.9);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.region-close-button{position:absolute;top:15px;right:15px;background:none;border:none;font-size:25px;cursor:pointer;color:#666;transition:color .2s;width:25px;height:25px;display:flex;align-items:center;justify-content:center}.region-close-button:hover{color:#333}.region-info-panel h2{color:#333;margin-bottom:15px;font-size:1.8rem}.region-status{display:inline-block;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:600;margin-bottom:20px}.region-status.unlocked{background:#e8f5e9;color:#2e7d32}.region-status.locked{background:#ffebee;color:#c62828}.region-details{color:#666}.region-details p{line-height:1.6;margin-bottom:20px}.region-stats{background:#f5f5f5;padding:20px;border-radius:12px;margin-bottom:20px}.region-stats h3{color:#333;margin-bottom:15px;font-size:1.1rem}.region-stats ul{list-style:none;padding:0}.region-stats li{padding:8px 0;font-size:.95rem;color:#555}.region-featured{background:#e3f2fd;padding:20px;border-radius:12px}.region-featured h3{color:#1976d2;margin-bottom:10px;font-size:1.1rem}.region-featured p{margin:0;color:#666;font-size:.95rem}.locked-message{background:#ffebee;padding:20px;border-radius:12px;text-align:center}.locked-message p{color:#c62828;margin-bottom:15px}.unlock-button{background:#ff5252;color:#fff;border:none;padding:12px 24px;border-radius:25px;cursor:pointer;font-weight:600;transition:all .3s ease}.unlock-button:hover{background:#ff1744;transform:translateY(-2px);box-shadow:0 5px 15px #ff52524d}@media (max-width: 768px){.region-info-panel{width:95%;max-width:none;padding:25px;max-height:90vh}.region-close-button{top:12px;right:12px;font-size:22px}}.artwork-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;z-index:3000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;display:flex;flex-direction:column;pointer-events:none}.popup-map-section{position:relative;height:200px;background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0;pointer-events:none}.image-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:12px}.loading-spinner{width:40px;height:40px;border:3px solid #e3e3e3;border-top:3px solid #5B2EFF;border-radius:50%;animation:spin 1s linear infinite}.popup-back-btn-container{position:fixed;top:18px;left:18px;z-index:5000;width:auto;display:flex;justify-content:flex-start;pointer-events:auto}.popup-back-btn{background:#3416d8;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #5b2eff2e;transition:background .2s,transform .2s}.popup-back-btn:hover{background:#3a1bb3;transform:scale(1.05)}.back-arrow{color:#fff;font-size:2rem;font-weight:700;line-height:1}.map-pin-indicator{display:flex;align-items:center;justify-content:center;pointer-events:none}.pin-marker{width:30px;height:30px;background:#dc2626;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:3px solid white;box-shadow:0 3px 10px #0006;position:relative;pointer-events:none}.pin-marker:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg);width:10px;height:10px;background:#fff;border-radius:50%}.popup-artwork-image{flex:1;background:#f5f5f5;display:flex;align-items:center;justify-content:center;overflow:hidden;pointer-events:auto}.artwork-img{width:100%;height:100%;object-fit:cover}.artwork-image-placeholder{width:100%;height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden;background-size:400% 400%;animation:gradientShift 8s ease infinite}.artwork-image-placeholder img{width:100%;height:100%;object-fit:cover}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media (max-width: 480px){.artwork-image-placeholder{height:260px}}.street-art-placeholder{text-align:center;padding:20px;background:#000000b3;border-radius:10px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.graffiti-text{font-size:24px;font-weight:900;color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.8);letter-spacing:2px;margin-bottom:8px;font-family:Impact,Arial Black,sans-serif}.graffiti-subtext{font-size:14px;color:#ff6b6b;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.8);letter-spacing:1px;font-family:Arial,sans-serif}.popup-content-section{background:gold;padding:24px 20px;border-radius:0;min-height:200px;display:flex;flex-direction:column;gap:8px;flex-shrink:0;pointer-events:auto}.artist-label{color:#3416d8;font-size:18px;font-weight:900;margin:0;text-transform:none;font-family:PPNeueMachina-PlainUltrabold,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.artwork-title{color:#3416d8;font-size:36px;font-weight:900;margin:0 0 8px;line-height:1.1;text-transform:uppercase;letter-spacing:1px;font-family:PPNeueMachina-PlainUltrabold,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.artwork-description{color:#000;font-size:18px;font-weight:400;margin:0 0 16px;line-height:1.4;font-family:PPNeueMachina-InktrapRegular,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.artwork-details{display:flex;flex-direction:column;gap:6px;margin-top:8px}.detail-item{font-size:12px;color:#000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.detail-label{font-weight:600;color:#4285f4}@media (max-width: 480px){.popup-map-section{height:200px}.popup-back-btn{width:44px;height:44px;left:16px;top:16px}.back-arrow{font-size:20px}.popup-content-section{padding:20px 16px;min-height:220px}.artwork-description{font-size:14px}}@media (max-width: 380px){.popup-content-section{padding:16px 12px}.artwork-title{font-size:20px}.artwork-description{font-size:13px}}.artwork-popup-overlay .popup-map-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0000000d;pointer-events:none}.artwork-popup-bottom-sheet{position:fixed;left:0;right:0;bottom:0;max-width:480px;margin:0 auto;background:#fff;box-shadow:0 -4px 24px #0000002e;z-index:4000;overflow:hidden;display:flex;flex-direction:column;pointer-events:auto}.popup-header-row{display:flex;align-items:center;padding:16px 20px 0;gap:12px}.sama-logo.clickable{height:32px;cursor:pointer}.popup-region-title{font-size:1.2rem;font-weight:700;color:#222;margin-left:8px}@media (max-width: 600px){.artwork-popup-bottom-sheet{max-width:100vw}.popup-header-row{padding:12px 12px 0}}.artwork-popup-bottom-sheet .artwork-image-placeholder{position:relative}@font-face{font-family:PPNeueMachina-PlainUltrabold;src:url(/fonts/PPNeueMachina-PlainUltrabold.otf) format("opentype");font-weight:900;font-style:normal}@font-face{font-family:PPNeueMachina-InktrapRegular;src:url(/fonts/PPNeueMachina-InktrapRegular.otf) format("opentype");font-weight:400;font-style:normal}.popup-content-scrollable{overflow-y:auto;max-height:calc(100vh - 440px)}@media (max-width: 480px){.popup-content-scrollable{max-height:calc(100vh - 280px)}}.navigate-btn:hover{background:#2200b8;transform:translateY(-1px);box-shadow:0 6px 16px #3416d866}.unlock-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.unlock-prompt{background:#fff;border-radius:20px;padding:40px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.close-button{position:absolute;top:20px;right:20px;background:none;border:none;font-size:30px;cursor:pointer;color:#666;transition:color .2s;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.unlock-icon{font-size:60px;text-align:center;margin-bottom:20px}.unlock-prompt h2{text-align:center;color:#333;margin-bottom:20px;font-size:2rem}.unlock-description{text-align:center;color:#666;margin-bottom:30px;font-size:1.1rem;line-height:1.6}.district-highlights{background:#f8f9fa;padding:25px;border-radius:15px;margin-bottom:30px}.district-highlights h3{color:#333;margin-bottom:20px;font-size:1.2rem}.highlights-list{list-style:none;padding:0;margin-bottom:20px}.highlights-list li{padding:10px 0;color:#555;font-size:1rem;display:flex;align-items:center;gap:10px}.featured-info{border-top:1px solid #e0e0e0;padding-top:20px;margin-top:20px}.featured-info h4{color:#333;margin-bottom:10px;font-size:1rem}.featured-info p{color:#666;font-size:.95rem;line-height:1.5;margin:0}.unlock-single-option{text-align:center;padding:30px;background:linear-gradient(to bottom,#f8f9ff,#fff);border-radius:15px;border:2px solid #667eea}.price-display{margin-bottom:25px}.price{font-size:3rem;font-weight:700;color:#667eea;display:block}.price-label{color:#666;font-size:.95rem;margin-top:5px;display:block}.unlock-button{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:18px 35px;border-radius:30px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:15px}.unlock-button:hover{transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.unlock-note{color:#666;font-size:.9rem;margin:0}.continue-free{text-align:center;margin-top:25px}.text-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:.95rem;text-decoration:underline;transition:color .2s}.text-button:hover{color:#5a67d8}@media (max-width: 768px){.unlock-prompt{padding:30px 20px}.unlock-prompt h2{font-size:1.6rem}.price{font-size:2.5rem}.district-highlights{padding:20px}}.navigation-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.navigation-popup{background:#fff;border-radius:20px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.close-button{position:absolute;top:20px;right:20px;background:none;border:none;font-size:30px;cursor:pointer;color:#666;transition:color .2s;width:30px;height:30px;display:flex;align-items:center;justify-content:center;z-index:10}.close-button:hover{color:#333}.navigation-header{padding:30px 30px 20px}.navigation-image{width:100%;height:250px;object-fit:cover;border-radius:12px;margin-bottom:20px}.navigation-header h2{color:#333;margin-bottom:15px;font-size:1.8rem;padding-right:40px}.artwork-info{display:flex;align-items:center;gap:15px;margin-bottom:15px;flex-wrap:wrap}.artwork-type{display:inline-block;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.artwork-type.gallery,.artwork-type.museum{background:#e1f5fe;color:#0277bd}.artwork-type.legal-wall{background:#f3e5f5;color:#6a1b9a}.artwork-type.artwork{background:#e8f5e9;color:#2e7d32}.distance-info{background:#fff3e0;color:#e65100;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600}.artwork-artist{font-style:italic;color:#666;margin-bottom:15px;font-size:1.05rem}.artwork-description{color:#555;line-height:1.6;margin-bottom:20px;font-size:.95rem}.address-section,.hours-section{background:#f5f5f5;padding:15px;border-radius:10px;margin-bottom:15px}.address-section h3,.hours-section h3{color:#333;font-size:1rem;margin-bottom:8px;display:flex;align-items:center;gap:8px}.address-section p,.hours-section p{margin:0;color:#666;font-size:.9rem}.navigation-actions{padding:20px 30px 30px;border-top:1px solid #e0e0e0}.navigation-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.navigate-button{width:100%;border:none;padding:16px 20px;border-radius:12px;font-size:1rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:15px;text-align:left}.navigate-button.in-app{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.navigate-button.in-app:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.navigate-button.external{background:#f5f5f5;color:#333;border:2px solid #e0e0e0}.navigate-button.external:hover{background:#e8e8e8;border-color:#d0d0d0;transform:translateY(-1px)}.button-icon{font-size:1.5rem;flex-shrink:0}.button-text{display:flex;flex-direction:column;gap:2px}.button-title{font-weight:600;font-size:1rem}.button-subtitle{font-size:.85rem;opacity:.8}.navigate-button.external .button-subtitle{color:#666}.view-details-button{width:100%;background:#fff;color:#666;border:2px solid #e0e0e0;padding:14px 30px;border-radius:30px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.view-details-button:hover{background:#f5f5f5;border-color:#d0d0d0}.location-required{background:#fff3e0;padding:20px;border-radius:12px;margin-bottom:20px;text-align:center}.location-required p{color:#e65100;margin-bottom:15px;font-weight:500}.enable-location-button{background:#ff6b6b;color:#fff;border:none;padding:12px 24px;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease}.enable-location-button:hover{background:#ff5252;transform:translateY(-2px);box-shadow:0 5px 15px #ff6b6b4d}@media (max-width: 768px){.navigation-popup{margin:20px;max-height:calc(100vh - 40px)}.navigation-header{padding:25px 20px 15px}.navigation-header h2{font-size:1.5rem}.navigation-image{height:200px}.navigation-actions{padding:20px}.navigate-button{padding:14px 16px}.button-icon{font-size:1.3rem}}.enhanced-navigation{position:fixed;bottom:20px;left:20px;right:20px;z-index:1500;pointer-events:none}.nav-panel{background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000004d;border:3px solid #000;overflow:hidden;pointer-events:all;max-width:600px;margin:0 auto}.nav-status{position:relative}.recalculating-banner,.off-route-banner{background:#ff9800;color:#fff;padding:12px 20px;text-align:center;font-weight:700;font-size:14px;animation:slideDown .3s ease}.off-route-banner{background:#f44336}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.current-instruction{display:flex;align-items:center;padding:25px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;gap:20px}.instruction-icon{width:60px;height:60px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;border:2px solid white;flex-shrink:0}.instruction-details{flex:1}.instruction-text{font-size:20px;font-weight:700;margin-bottom:8px;line-height:1.3}.instruction-distance{font-size:32px;font-weight:900;color:#ff0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.street-name{padding:15px 20px;background:#f8f9fa;border-bottom:2px solid #dee2e6;font-size:16px;color:#495057;text-align:center}.street-name strong{color:#333}.progress-container{padding:15px 20px;background:#f8f9fa;border-bottom:2px solid #dee2e6}.progress-bar{height:8px;background:#dee2e6;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width .5s ease;border-radius:4px}.progress-text{text-align:center;font-size:14px;color:#6c757d;font-weight:600}.route-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;padding:20px;background:#fff;border-bottom:2px solid #f0f0f0}.summary-item{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.summary-icon{font-size:24px;margin-bottom:5px}.summary-text{font-size:14px;font-weight:700;color:#333}.next-steps-preview{background:#fff;border-bottom:2px solid #f0f0f0}.toggle-steps{width:100%;padding:15px 20px;background:none;border:none;font-weight:600;color:#667eea;cursor:pointer;transition:background .3s ease;font-size:14px}.toggle-steps:hover{background:#f8f9fa}.steps-list{padding:0 20px 20px;display:flex;flex-direction:column;gap:12px}.step-item{display:flex;align-items:center;gap:15px;padding:12px;background:#f8f9fa;border-radius:10px;border:1px solid #dee2e6}.step-icon{width:35px;height:35px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;border:2px solid #dee2e6;flex-shrink:0}.step-text{flex:1}.step-instruction{font-size:14px;font-weight:600;color:#333;margin-bottom:4px}.step-distance{font-size:12px;color:#6c757d}.nav-controls{display:flex;gap:0;background:#fff}.nav-button{flex:1;padding:18px 20px;border:none;font-weight:700;font-size:16px;cursor:pointer;transition:all .3s ease;border-top:2px solid #f0f0f0}.nav-button.secondary{background:#f8f9fa;color:#495057;border-right:1px solid #dee2e6}.nav-button.secondary:hover{background:#e9ecef}.nav-button.primary{background:#dc3545;color:#fff}.nav-button.primary:hover{background:#c82333;transform:translateY(-1px)}@media (max-width: 768px){.enhanced-navigation{bottom:10px;left:10px;right:10px}.nav-panel{border-radius:15px}.current-instruction{padding:20px 15px;gap:15px}.instruction-icon{width:50px;height:50px;font-size:24px}.instruction-text{font-size:18px}.instruction-distance{font-size:28px}.route-summary{grid-template-columns:repeat(3,1fr);gap:10px;padding:15px}.summary-icon{font-size:20px}.summary-text{font-size:12px}.nav-button{padding:16px 15px;font-size:14px}}@media (max-width: 480px){.current-instruction{flex-direction:column;text-align:center;padding:20px 15px}.instruction-details{width:100%}.route-summary{grid-template-columns:1fr;gap:15px}.summary-item{flex-direction:row;justify-content:center;gap:10px}.nav-controls{flex-direction:column}.nav-button.secondary{border-right:none;border-bottom:1px solid #dee2e6}}.smart-navigation{position:relative}.turn-arrow{width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin:0 auto}.smart-banner{position:relative;overflow:hidden}.smart-banner .banner-content{display:flex;align-items:center;gap:8px;position:relative;z-index:2}.pulse-animation{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:pulse-slide 2s infinite}@keyframes pulse-slide{0%{left:-100%}to{left:100%}}.quality-indicator{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff1a;border-radius:20px;margin:8px 0;font-size:14px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.quality-icon{font-size:16px;animation:quality-pulse 2s infinite}@keyframes quality-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.distance-from-route{font-size:12px;opacity:.8;margin-left:4px}.smart-panel{background:linear-gradient(135deg,#fffffff2,#ffffffe6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #0000001a}.smart-instruction{display:flex;align-items:center;gap:20px;padding:24px;border-bottom:1px solid rgba(0,0,0,.1)}.smart-arrow{transition:all .5s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.instruction-content{flex:1;display:flex;flex-direction:column;gap:8px}.heading-info{display:flex;align-items:center;gap:8px;font-size:14px;color:#666;margin-top:4px}.heading-label{font-weight:500}.heading-value{font-weight:600;color:#007cbf}.heading-deviation{color:#f97316;font-size:12px}.smart-street{padding:12px 24px;background:#007cbf1a;border-left:4px solid #007cbf;font-size:16px;color:#1a1a1a}.smart-progress{padding:20px 24px;position:relative}.progress-markers{position:absolute;top:0;left:0;right:0;height:100%;pointer-events:none}.progress-marker{position:absolute;top:50%;transform:translate(-50%) translateY(-50%);width:8px;height:8px;border-radius:50%;background:#ffffff80;border:2px solid #ddd;transition:all .3s ease}.progress-marker.passed{background:#fff;border-color:#10b981;box-shadow:0 0 8px #10b98166}.wrong-turn-count{color:#f97316;font-weight:500;font-size:12px}.smart-summary{padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.1)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px}.summary-item{display:flex;align-items:center;gap:12px;padding:12px;background:#007cbf0d;border-radius:12px;border:1px solid rgba(0,124,191,.1);transition:all .3s ease}.summary-item:hover{background:#007cbf1a;transform:translateY(-2px);box-shadow:0 4px 12px #007cbf33}.summary-content{display:flex;flex-direction:column;gap:2px}.summary-label{font-size:12px;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.summary-value{font-size:14px;font-weight:600;color:#1a1a1a}.smart-steps{padding:20px 24px}.smart-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#007cbf,#0056b3);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #007cbf4d}.smart-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 16px #007cbf66}.toggle-icon{font-size:18px}.toggle-arrow{font-size:14px;transition:transform .3s ease}.smart-steps-list{margin-top:16px;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.1);background:#fffc}.smart-step{display:flex;align-items:center;gap:16px;padding:16px;border-bottom:1px solid rgba(0,0,0,.05);transition:all .3s ease}.smart-step:last-child{border-bottom:none}.smart-step:hover{background:#007cbf0d}.step-number{width:24px;height:24px;border-radius:50%;background:#007cbf;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.step-content{flex:1}.step-details{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.step-street{font-style:italic}.smart-controls{display:flex;gap:12px;padding:20px 24px;background:#00000005}.smart-button{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;border:2px solid transparent;min-height:44px}.smart-button:hover{transform:translateY(-2px)}.smart-button.primary{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef44444d}.smart-button.primary:hover{box-shadow:0 6px 16px #ef444466}.smart-button.secondary{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;box-shadow:0 4px 12px #6b72804d}.smart-button.secondary:hover{box-shadow:0 6px 16px #6b728066}.smart-button.tertiary{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 4px 12px #f59e0b4d}.smart-button.tertiary:hover{box-shadow:0 6px 16px #f59e0b66}.button-icon{font-size:16px}.debug-info{margin-top:20px;padding:16px;background:#0000000d;border-radius:8px;border-left:4px solid #f59e0b}.debug-info h4{margin:0 0 8px;font-size:14px;color:#1a1a1a}.debug-info p{margin:4px 0;font-size:12px;color:#666}.location-permission{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2500;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideIn .3s ease}.permission-card{background:#fff;border-radius:20px;border:3px solid #000;box-shadow:0 20px 40px #0000004d;overflow:hidden}.permission-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:25px;display:flex;align-items:center;gap:20px}.status-icon{font-size:32px;background:#fff3;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white;flex-shrink:0}.status-details{flex:1}.status-title{margin:0 0 8px;font-size:20px;font-weight:900}.location-details{display:flex;flex-direction:column;gap:4px;font-size:14px;opacity:.9}.coordinates{font-family:Courier New,monospace;font-size:12px}.accuracy{font-weight:600;padding:2px 8px;border-radius:10px;font-size:11px;align-self:flex-start}.accuracy.good{background:#28a7454d;color:#28a745}.accuracy.fair{background:#ffc1074d;color:#ffc107}.accuracy.poor{background:#dc35454d;color:#dc3545}.permission-content{padding:30px}.error-message{display:flex;align-items:flex-start;gap:12px;background:#ffebee;border:2px solid #f44336;border-radius:10px;padding:15px;margin-bottom:20px}.error-icon{font-size:20px;flex-shrink:0;margin-top:2px}.error-text{font-size:14px;color:#c62828;line-height:1.5}.request-section{text-align:center}.permission-explanation{font-size:16px;margin-bottom:20px;line-height:1.6;color:#333}.benefits-list{text-align:left;margin:20px 0;padding-left:0;list-style:none}.benefits-list li{padding:8px 0;font-size:14px;color:#555;display:flex;align-items:center;gap:8px}.action-buttons{display:flex;gap:12px;margin-top:20px}.request-button.primary{flex:2;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:2px solid #000;border-radius:15px;padding:15px 30px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:5px 5px #000;display:flex;align-items:center;justify-content:center;gap:10px}.request-button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:7px 7px #000}.request-button.primary:disabled{opacity:.7;cursor:not-allowed;transform:none}.skip-button{flex:1;background:#f8f9fa;color:#6c757d;border:2px solid #6c757d;border-radius:15px;padding:15px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:3px 3px #6c757d}.skip-button:hover{background:#e9ecef;transform:translateY(-1px);box-shadow:5px 5px #6c757d}@media (max-width: 480px){.action-buttons{flex-direction:column;gap:10px}.request-button.primary,.skip-button{flex:none;padding:12px 20px;font-size:14px}}.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}.denied-section{text-align:center}.denied-explanation{font-size:16px;margin-bottom:20px;line-height:1.6;color:#333}.settings-instructions{background:#f8f9fa;border:2px solid #dee2e6;border-radius:10px;padding:20px;margin:20px 0;text-align:left}.settings-instructions h4{margin:0 0 15px;color:#495057;font-size:16px}.settings-instructions ol{margin:0;padding-left:20px}.settings-instructions li{margin-bottom:8px;color:#6c757d;line-height:1.5}.denied-actions{display:flex;gap:10px;margin:20px 0}.retry-button,.settings-button{flex:1;padding:12px 20px;border:2px solid #000;border-radius:10px;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.retry-button{background:#007bff;color:#fff;box-shadow:3px 3px #000}.retry-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:5px 5px #000}.settings-button{background:#fff;color:#495057;border-color:#6c757d}.settings-button:hover{background:#f8f9fa;transform:translateY(-1px)}.detailed-instructions{background:#fff3cd;border:2px solid #ffc107;border-radius:10px;padding:20px;margin-top:20px;text-align:left}.detailed-instructions h4{margin:0 0 15px;color:#856404}.instruction-steps{margin-bottom:15px}.step{margin-bottom:10px;padding:8px 0;color:#856404;line-height:1.5}.alternative-note{background:#ffc1071a;padding:12px;border-radius:8px;font-size:14px;color:#856404;line-height:1.5}.granted-section{text-align:center}.success-message{background:#d4edda;border:2px solid #28a745;border-radius:10px;padding:15px;color:#155724;font-size:16px;margin-bottom:20px}.accuracy-warning{background:#fff3cd;border:2px solid #ffc107;border-radius:10px;padding:12px;color:#856404;font-size:14px;margin-bottom:20px;line-height:1.5}.location-status{background:#f8f9fa;border:1px solid #dee2e6;border-radius:10px;padding:15px}.status-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.status-item:last-child{margin-bottom:0}.label{font-weight:600;color:#495057;font-size:14px}.value{font-family:Courier New,monospace;font-size:12px;color:#6c757d}.unsupported-section{text-align:center}.unsupported-message{font-size:16px;color:#6c757d;line-height:1.6;margin:0}.permission-footer{background:#f8f9fa;padding:15px 25px;border-top:1px solid #dee2e6;text-align:center}.privacy-note{margin:0;font-size:12px;color:#6c757d;line-height:1.4}@media (max-width: 768px){.location-permission{width:95%;max-height:95vh}.permission-header{padding:20px;flex-direction:column;text-align:center;gap:15px}.status-icon{width:50px;height:50px;font-size:28px}.permission-content{padding:20px}.denied-actions{flex-direction:column}.settings-instructions,.detailed-instructions{padding:15px}}@media (max-width: 480px){.permission-card{border-radius:15px}.permission-header{padding:15px}.status-title{font-size:18px}.permission-content{padding:15px}.permission-explanation{font-size:14px}.benefits-list li{font-size:13px}.request-button{padding:12px 20px;font-size:14px}.permission-footer{padding:12px 15px}.privacy-note{font-size:11px}}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.navigation-compass{position:fixed;top:90px;right:20px;width:100px;height:100px;z-index:1600;pointer-events:none}.compass-background{position:absolute;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,#ffffffe6,#ffffffb3);border:3px solid #000;transition:transform .3s ease;box-shadow:0 4px 12px #0000004d}.north-indicator{position:absolute;top:5px;left:50%;transform:translate(-50%);font-weight:900;font-size:12px;color:#dc3545;text-shadow:1px 1px 2px rgba(255,255,255,.8)}.compass-marks{position:absolute;width:100%;height:100%}.compass-mark{position:absolute;background:#666;transform-origin:50px 50px}.compass-mark.major{width:2px;height:15px;top:0;left:49px;background:#333}.compass-mark.minor{width:1px;height:8px;top:0;left:49.5px;background:#999}.direction-arrow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10}.arrow-head{font-size:24px;color:#667eea;text-shadow:2px 2px 0px #000,-2px -2px 0px #000,2px -2px 0px #000,-2px 2px 0px #000;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.next-turn-indicator{position:absolute;top:15px;left:50%;transform:translate(-50%);transition:transform .5s ease;z-index:5}.turn-arrow{font-size:18px;color:#ff0;text-shadow:1px 1px 0px #000,-1px -1px 0px #000,1px -1px 0px #000,-1px 1px 0px #000;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.bearing-display{position:absolute;bottom:-25px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:4px 8px;border-radius:8px;font-size:11px;font-weight:700;font-family:Courier New,monospace;border:1px solid #333;box-shadow:0 2px 4px #0000004d}.bearing-value{display:block;min-width:35px;text-align:center}@media (max-width: 768px){.navigation-compass{top:70px;right:15px;width:80px;height:80px}.compass-mark.major{height:12px;transform-origin:40px 40px;left:39px}.compass-mark.minor{height:6px;transform-origin:40px 40px;left:39.5px}.north-indicator{font-size:10px;top:3px}.arrow-head{font-size:20px}.turn-arrow{font-size:16px}.next-turn-indicator{top:12px}.bearing-display{bottom:-20px;font-size:10px;padding:3px 6px}}@media (max-width: 480px){.navigation-compass{width:70px;height:70px;top:60px;right:10px}.compass-mark.major{height:10px;transform-origin:35px 35px;left:34px}.compass-mark.minor{height:5px;transform-origin:35px 35px;left:34.5px}.arrow-head{font-size:18px}.turn-arrow{font-size:14px}.bearing-display{font-size:9px;padding:2px 4px}}.navigation-compass.hidden{opacity:0;pointer-events:none;transition:opacity .3s ease}.navigation-compass.visible{opacity:1;transition:opacity .3s ease}.route-navigator-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2000;animation:overlayFadeIn .3s ease-out}.route-navigator{background:#fff;width:100%;height:100%;overflow-y:auto;display:flex;flex-direction:column}.navigator-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 10px #0000001a}.header-content{flex:1}.navigator-title{margin:0 0 4px;font-size:1.8rem;font-weight:800;letter-spacing:-.5px}.navigator-subtitle{margin:0;font-size:1rem;opacity:.9;font-weight:400}.close-navigator{background:#fff3;border:none;color:#fff;width:44px;height:44px;border-radius:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:1.2rem;font-weight:700}.close-navigator:hover{background:#ffffff4d;transform:scale(1.05)}.filter-section{background:#f8f9fa;padding:16px 20px;border-bottom:1px solid #dee2e6;position:sticky;top:80px;z-index:99}.filter-pills{display:flex;gap:8px;overflow-x:auto;padding:4px 0;scrollbar-width:none;-ms-overflow-style:none}.filter-pills::-webkit-scrollbar{display:none}.filter-pill{background:#fff;border:2px solid #e9ecef;border-radius:20px;padding:8px 16px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:6px;color:#6c757d}.filter-pill:hover{border-color:#667eea;color:#667eea;transform:translateY(-1px)}.filter-pill.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 2px 8px #667eea4d}.pill-count{background:#ffffff4d;border-radius:10px;padding:2px 8px;font-size:.8rem;font-weight:700}.filter-pill.active .pill-count{background:#ffffff4d}.filter-pill:not(.active) .pill-count{background:#f8f9fa;color:#667eea}.routes-feed{flex:1;padding:20px;max-width:800px;margin:0 auto;width:100%;box-sizing:border-box}.route-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;margin-bottom:16px;transition:all .2s ease;border:1px solid #e0e0e0}.route-card:hover{box-shadow:0 4px 12px #00000026}.route-card.locked{opacity:.7}.route-image-placeholder{position:relative;height:200px;background:silver;background-image:linear-gradient(45deg,#d0d0d0 25%,transparent 25%),linear-gradient(-45deg,#d0d0d0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#d0d0d0 75%),linear-gradient(-45deg,transparent 75%,#d0d0d0 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;display:flex;align-items:center;justify-content:center}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;display:flex;align-items:center;justify-content:center}.route-icon{font-size:3rem;opacity:.8}.lock-badge{position:absolute;top:12px;right:12px;background:#000000b3;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1rem}.route-card-content{padding:20px;position:relative}.route-card-title{margin:0 0 8px;font-size:1.4rem;font-weight:700;color:#333;line-height:1.3}.route-card-description{margin:0 0 16px;font-size:1rem;color:#666;line-height:1.4}.route-card-button{position:absolute;bottom:20px;right:20px;background:transparent;border:none;color:#666;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;padding:0;text-decoration:underline;text-underline-offset:2px}.route-card-button.unlock-button{color:#e74c3c;text-decoration-color:#e74c3c}.route-card-button.start-button{color:#666;text-decoration-color:#666}.route-card-button:hover{opacity:.7;transform:translateY(-1px)}.empty-state{text-align:center;padding:60px 20px;color:#6c757d}.empty-icon{font-size:4rem;margin-bottom:16px;opacity:.5}.empty-state h3{margin:0 0 8px;font-size:1.4rem;color:#495057}.empty-state p{margin:0 0 20px;font-size:1rem;line-height:1.5}.reset-filters-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.reset-filters-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}@media (max-width: 768px){.route-navigator{padding-top:0}.navigator-header{padding:16px}.navigator-title{font-size:1.5rem}.navigator-subtitle{font-size:.9rem}.filter-section{padding:12px 16px}.routes-feed,.route-card-content{padding:16px}.route-card-button{bottom:16px;right:16px}}@media (max-width: 480px){.navigator-header{padding:12px;flex-direction:column;align-items:flex-start;gap:12px}.header-content{width:100%}.close-navigator{position:absolute;top:12px;right:12px}.route-image-placeholder{height:160px}.route-icon{font-size:2.5rem}.route-card-title{font-size:1.2rem}}.active-route-container{position:fixed;top:0;right:0;width:400px;max-height:100vh;background:#fff;border:3px solid #000;border-radius:15px 0 0 15px;box-shadow:-10px 0 20px #0000004d;z-index:1500;overflow-y:auto}.route-header-bar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px 20px;border-radius:12px 0 0;display:flex;justify-content:space-between;align-items:center;border-left:5px solid #667eea;border-bottom:3px solid #000}.route-info{display:flex;align-items:center;gap:12px;flex:1}.route-icon-small{font-size:24px;background:#fff3;width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid white}.route-details{flex:1}.route-title{margin:0 0 5px;font-size:18px;font-weight:900}.route-meta{font-size:12px;opacity:.9;display:flex;gap:8px;align-items:center}.end-route-btn{background:#fff3;border:2px solid white;color:#fff;border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease}.end-route-btn:hover{background:#fff;color:#667eea}.route-progress-bar{height:8px;background:#f0f0f0;position:relative;border-bottom:2px solid #000}.progress-fill{height:100%;background:#667eea;transition:width .5s ease;position:relative}.progress-fill:after{content:"";position:absolute;right:0;top:0;width:3px;height:100%;background:#fff;box-shadow:1px 0 3px #0000004d}.current-stop-card{padding:20px;border-bottom:2px solid #f0f0f0}.stop-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.stop-number{background:#667eea;color:#fff;padding:8px 16px;border-radius:20px;font-weight:700;font-size:14px;border:2px solid #000}.distance-indicator{background:#f8f9fa;color:#495057;padding:6px 12px;border-radius:15px;font-size:12px;font-weight:600;border:1px solid #dee2e6}.stop-content{margin-bottom:20px}.stop-title{margin:0 0 5px;font-size:20px;font-weight:900;color:#333}.stop-artist{margin:0 0 10px;color:#667eea;font-weight:600;font-size:16px}.stop-description{margin:0 0 15px;color:#666;line-height:1.5;font-size:14px}.stop-address,.stop-hours{background:#f8f9fa;padding:8px 12px;border-radius:8px;margin-bottom:8px;font-size:13px;color:#495057;border:1px solid #dee2e6}.stop-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.navigate-btn{font-family:PP Neue Machina Inktrap Ultrabold,Inter,Arial,sans-serif;font-size:17px;background:#3416d8;color:#fff;border:none;padding:18px 32px;cursor:pointer;font-weight:800;text-align:center;transition:background .2s;display:block;width:70%;margin:20px auto 0;position:sticky;bottom:20px;z-index:1000;border-radius:8px;box-shadow:0 4px 12px #3416d84d}.navigate-btn:hover{background:#2200b8}.complete-btn{background:#28a745;color:#fff;border:2px solid #000;border-radius:8px;padding:10px 15px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:3px 3px #000}.complete-btn:hover{transform:translateY(-2px);box-shadow:5px 5px #000}.complete-btn.completed{background:#20c997;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.skip-btn{background:#6c757d;color:#fff;border:2px solid #000;border-radius:8px;padding:10px 15px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:3px 3px #000}.skip-btn:hover{transform:translateY(-2px);box-shadow:5px 5px #000}.next-stop-preview{padding:15px 20px;background:#f8f9fa;border-bottom:2px solid #dee2e6}.next-stop-preview h5{margin:0 0 8px;font-size:14px;color:#495057;font-weight:700}.next-stop-info{display:flex;flex-direction:column;gap:2px}.next-stop-title{font-weight:600;color:#333;font-size:14px}.next-stop-artist{color:#666;font-size:12px}.route-complete{padding:25px 20px;background:linear-gradient(135deg,#28a745,#20c997);color:#fff;text-align:center;border-bottom:2px solid #000}.completion-celebration h3{margin:0 0 10px;font-size:24px;font-weight:900}.completion-celebration p{margin:0 0 20px;font-size:16px;opacity:.9}.share-completion-btn{background:#fff;color:#28a745;border:2px solid #000;border-radius:10px;padding:12px 20px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:3px 3px #000}.share-completion-btn:hover{transform:translateY(-2px);box-shadow:5px 5px #000}.route-overview{border-bottom:2px solid #f0f0f0}.route-overview details{background:#f8f9fa}.route-overview summary{padding:15px 20px;cursor:pointer;font-weight:700;color:#495057;border-bottom:1px solid #dee2e6;transition:background .3s ease}.route-overview summary:hover{background:#e9ecef}.route-overview[open] summary{background:#e9ecef}.stops-list{max-height:300px;overflow-y:auto}.stop-item{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:all .3s ease;border-bottom:1px solid #dee2e6}.stop-item:hover{background:#e9ecef}.stop-item.current{background:#e3f2fd;border-left:4px solid #1976d2}.stop-item.completed{background:#e8f5e8;opacity:.8}.stop-marker{width:35px;height:35px;border-radius:50%;background:#f8f9fa;border:2px solid #dee2e6;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.stop-item.current .stop-marker{background:#1976d2;color:#fff;border-color:#1976d2}.stop-item.completed .stop-marker{background:#28a745;color:#fff;border-color:#28a745}.stop-details{flex:1}.stop-details h6{margin:0 0 2px;font-size:14px;font-weight:600;color:#333}.stop-details p{margin:0;font-size:12px;color:#666}.stop-type{font-size:20px;opacity:.7}@media (max-width: 768px){.active-route-container{position:fixed;top:auto;bottom:0;right:0;left:0;width:100%;max-height:60vh;border-radius:15px 15px 0 0;border:3px solid #000;box-shadow:0 -10px 20px #0000004d}.route-header-bar{border-radius:12px 12px 0 0}.stop-actions{grid-template-columns:1fr;gap:8px}.navigate-btn{grid-column:1}.route-overview details{max-height:200px}}@media (max-width: 480px){.active-route-container{max-height:70vh}.current-stop-card{padding:15px}.route-header-bar{padding:12px 15px}.route-title{font-size:16px}.stop-title{font-size:18px}}.mobile-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#000000f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);padding:0}.mobile-header-content{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;min-height:60px}.mobile-title h1{color:#fff;font-size:1.1rem;font-weight:700;margin:0;line-height:1.2}.hamburger-menu{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:8px;width:40px;height:40px;align-items:center;justify-content:center;border-radius:8px;transition:all .3s ease}.hamburger-menu:hover{background:#ffffff1a}.hamburger-menu span{width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s ease;transform-origin:center}.hamburger-menu.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger-menu.open span:nth-child(2){opacity:0;transform:scale(0)}.hamburger-menu.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-navigation-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#e74c3cf2;border-top:1px solid rgba(255,255,255,.1)}.mobile-navigation-bar .navigation-info h3{color:#fff;font-size:.9rem;font-weight:600;margin:0}.mobile-navigation-bar .stop-navigation-button{background:#fff3;color:#fff;border:none;padding:6px 12px;border-radius:16px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease}.mobile-navigation-bar .stop-navigation-button:hover{background:#ffffff4d}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2000;display:flex;animation:overlayFadeIn .3s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu{background:#fff;width:85%;max-width:350px;height:100%;border-top-right-radius:20px;border-bottom-right-radius:20px;box-shadow:5px 0 25px #0000004d;overflow-y:auto;animation:menuSlideIn .3s ease-out;display:flex;flex-direction:column}@keyframes menuSlideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px;background:linear-gradient(135deg,#8b7bd8,#9f7aea);color:#fff;border-top-right-radius:20px}.mobile-menu-header h2{margin:0;font-size:1.5rem;font-weight:700}.close-menu{background:#fff3;color:#fff;border:none;width:36px;height:36px;border-radius:18px;font-size:1.2rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-weight:600}.close-menu:hover{background:#ffffff4d}.mobile-menu-content{flex:1;padding:20px;display:flex;flex-direction:column;gap:24px}.menu-section h3{margin:0 0 12px;font-size:.9rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.user-info-card{display:flex;align-items:center;gap:12px;padding:16px;background:#f9fafb;border-radius:12px;margin-bottom:12px;border:1px solid #F3F4F6}.user-avatar{width:48px;height:48px;background:linear-gradient(135deg,#8b7bd8,#9f7aea);border-radius:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-icon{font-size:1.5rem;color:#fff}.user-details{flex:1;min-width:0}.user-email{font-weight:600;font-size:1rem;color:#111827;margin-bottom:2px;word-break:break-word}.access-status{font-size:.85rem;color:#059669;font-weight:500;margin-bottom:2px}.days-remaining{font-size:.75rem;color:#6b7280;font-weight:500}.menu-button.primary{width:100%;padding:16px 20px;border:none;border-radius:16px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#8b7bd8,#9f7aea);color:#fff;box-shadow:0 4px 12px #8b7bd84d}.menu-button.primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #8b7bd866}.menu-button{width:100%;padding:12px 16px;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:12px;background:#f9fafb;color:#374151;margin-bottom:8px}.menu-button:last-child{margin-bottom:0}.menu-button:hover{background:#f3f4f6;transform:translateY(-1px)}.menu-button.logout-button{background:#fef2f2;color:#dc2626;border:1px solid #FECACA}.menu-button.logout-button:hover{background:#fee2e2}.regions-grid{display:flex;flex-direction:column;gap:8px}.region-badge{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:16px;font-size:1rem;font-weight:600;transition:all .2s ease}.region-badge.unlocked{background:#d1fae5;color:#065f46}.region-badge.locked{background:#fee2e2;color:#991b1b}.region-icon{font-size:1.2rem}.region-name{flex:1;font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-item{text-align:center;padding:16px 12px;background:#f9fafb;border-radius:12px}.stat-number{font-size:1.8rem;font-weight:800;color:#8b7bd8;margin-bottom:4px;display:block}.stat-label{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-weight:600}@media (min-width: 769px){.mobile-header{display:none}}@media (max-width: 480px){.mobile-menu{width:90%}.mobile-header-content{padding:10px 14px;min-height:55px}.mobile-title h1{font-size:1rem}.regions-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(3,1fr);gap:8px}.stat-number{font-size:1.3rem}.menu-section{padding:16px}}.mapbox-token-settings{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;z-index:1000}.mapbox-token-settings:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:-1}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0}.settings-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333}.close-button{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:4px;line-height:1;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#f0f0f0;color:#333}.settings-content{padding:24px}.current-token-info{margin-bottom:32px}.current-token-info h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#333}.token-display{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px}.token-type{margin-bottom:8px}.token-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:uppercase}.token-badge.custom{background:#e3f2fd;color:#1976d2}.token-badge.default{background:#f3e5f5;color:#7b1fa2}.token-value{margin-bottom:8px}.token-value code{background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:8px 12px;font-family:Monaco,Consolas,monospace;font-size:.875rem;display:block;word-break:break-all}.expiry-info{color:#28a745;font-size:.875rem}.expiry-warning{color:#dc3545;font-size:.875rem;font-weight:500}.token-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}.btn{padding:10px 16px;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn-primary{background:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3}.btn-primary:disabled{background:#6c757d;cursor:not-allowed}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#545b62}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-cancel{margin-top:12px}.token-input-section{margin-bottom:32px}.token-input-section h4{margin:0 0 8px;font-size:1rem;font-weight:600;color:#333}.token-help{margin:0 0 16px;color:#666;font-size:.875rem;line-height:1.5}.token-help a{color:#007bff;text-decoration:none}.token-help a:hover{text-decoration:underline}.input-group{display:flex;gap:8px;margin-bottom:16px}.token-input{flex:1;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:.875rem;font-family:Monaco,Consolas,monospace}.token-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.token-input:disabled{background:#f8f9fa;color:#6c757d}.validation-result{padding:12px;border-radius:6px;font-size:.875rem;font-weight:500;margin-top:12px}.validation-result.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.validation-result.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.token-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:16px}.token-info h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#333}.token-info ul{margin:0;padding-left:20px}.token-info li{margin-bottom:6px;color:#666;font-size:.875rem;line-height:1.4}@media (max-width: 768px){.mapbox-token-settings{width:95%;max-height:90vh}.settings-content{padding:16px}.input-group,.token-actions{flex-direction:column}.btn{width:100%}}@font-face{font-family:PPNeueMachinaUltrabold;src:url(/fonts/PPNeueMachina-PlainUltrabold.otf) format("opentype");font-weight:800;font-style:normal}@font-face{font-family:PPNeueMachinaRegular;src:url(/fonts/PPNeueMachina-PlainRegular.otf) format("opentype");font-weight:400;font-style:normal}.magic-link-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.magic-link-modal{font-family:PPNeueMachinaRegular,Arial,sans-serif;background:#fff;padding:32px 24px 24px;max-width:400px;margin:0 auto;animation:modalSlideIn .3s ease-out;max-height:90vh;overflow-y:auto}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0}.modal-header h2{font-family:PPNeueMachinaUltrabold,Arial,sans-serif;font-size:27px;color:#3416d8;margin-bottom:18px;letter-spacing:.01em}.close-button{background:none;border:none;font-size:1.5rem;color:#95a5a6;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s;line-height:1}.close-button:hover{background:#f8f9fa;color:#2c3e50}.modal-content{padding:0 24px 24px}.email-step{text-align:center;background-color:#d2e3f2;padding:20px 20px 0}.email-step h3{font-family:PPNeueMachinaUltrabold,Arial,sans-serif;font-size:16px;color:#3416d8;margin-bottom:8px;padding-top:30px}.email-step p{font-family:PPNeueMachinaRegular,Arial,sans-serif;font-size:14px;color:#3416d8;margin-bottom:18px}.email-form{margin-bottom:20px;padding:20px}.input-group{display:flex;flex-direction:column;gap:16px}.email-input{flex:1;padding:14px 16px;font-size:1rem;transition:all .2s;background:#fff}.email-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 4px #3498db1a}.email-input:disabled{background:#f8f9fa;color:#6c757d}.send-button{background:#3416d8;color:#fff;font-family:PPNeueMachinaUltrabold,Arial,sans-serif;font-size:16px;border:none;padding:12px 0;width:100%;margin-top:10px;cursor:pointer;transition:background .2s}.send-button:hover:not(:disabled){background:linear-gradient(135deg,#2980b9,#21618c);transform:translateY(-1px);box-shadow:0 4px 12px #3498db4d}.send-button:disabled{background:#bfc6e6;color:#fff;cursor:not-allowed}.message{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem;text-align:center}.message.info{background:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.info-box{background:#fae0df;padding:20px;text-align:left}.info-box h4{font-family:PPNeueMachinaUltrabold,Arial,sans-serif;font-size:16px;color:#3416d8;margin-bottom:10px}.info-box ul{margin:0;padding-left:20px}.info-box ul li{font-family:PPNeueMachinaRegular,Arial,sans-serif;font-size:14px;color:#3416d8;margin-bottom:6px}.sent-step{text-align:center}.email-icon{font-size:4rem;margin-bottom:16px}.sent-step h3{margin:0 0 12px;font-size:1.4rem;font-weight:600;color:#27ae60}.sent-step p{margin:0 0 12px;color:#7f8c8d}.email-display{background:#e8f5e8;border:1px solid #c3e6c3;color:#155724;padding:12px 16px;border-radius:8px;font-weight:600;margin-bottom:24px}.instructions{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:20px;margin-bottom:24px;text-align:left}.instructions h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#2c3e50}.instructions ol{margin:0;padding-left:20px}.instructions li{margin-bottom:8px;color:#5d6d7e;line-height:1.5}.action-buttons{display:flex;gap:12px;justify-content:center}.primary-button{background:#3416d8;color:#fff;border:none;padding:20px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.primary-button:hover{background:linear-gradient(135deg,#219a52,#1e8449);transform:translateY(-1px)}.secondary-button{background:#d2e3f2;color:#2c3e50;border:none;padding:20px;border-radius:0;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;min-width:120px}.secondary-button:hover{background:#d5dbdb}.no-purchase-step{text-align:center}.no-purchase-icon{font-size:4rem;margin-bottom:16px;opacity:.8}.no-purchase-step h3{margin:0 0 12px;font-size:1.4rem;font-weight:600;color:#e74c3c}.no-purchase-step p{margin:0 0 12px;color:#7f8c8d}.no-purchase-step .email-display{background:#fff3cd;border:1px solid #ffeaa7;color:#856404;padding:12px 16px;border-radius:8px;font-weight:600;margin-bottom:24px}.explanation{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:20px;margin-bottom:20px;text-align:left}.explanation h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#2c3e50}.explanation ul{margin:0;padding-left:20px}.explanation li{margin-bottom:6px;color:#5d6d7e;line-height:1.4}.options{margin-bottom:20px;text-align:left}.options h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#2c3e50;text-align:center}.option-buttons{display:flex;gap:12px;justify-content:center;margin-top:16px}.text-button{background:none;border:none;color:#6c757d;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:underline;padding:8px 0}.text-button:hover{color:#495057}@media (max-width: 768px){.option-buttons{flex-direction:column}.no-purchase-step h3{font-size:1.2rem}}@media (max-width: 768px){.magic-link-overlay{padding:10px;overflow-y:auto}.magic-link-modal{max-height:96vh;overflow-y:auto}.modal-header,.modal-content{padding-left:16px;padding-right:16px}.input-group{flex-direction:column}.email-input{margin-bottom:12px}.action-buttons{flex-direction:column}.email-step h3{font-size:1.2rem}}.open-gmail-section{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:8px}.open-gmail-btn{background:#ea4335;color:#fff;border:none;border-radius:24px;padding:12px 28px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #ea433526;transition:background .2s,transform .2s}.open-gmail-btn:hover{background:#c5221f;transform:translateY(-2px) scale(1.03)}.open-gmail-tip{color:#555;font-size:13px;text-align:center;margin-top:4px}.sent-card{background:#fff;padding:32px 24px 28px;max-width:400px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:18px}.sent-icon{font-size:44px;margin-bottom:8px}.sent-title{font-size:1.5rem;font-weight:700;color:#3416d8;margin-bottom:2px;text-align:center}.sent-email-label{font-size:1rem;color:#444;margin-bottom:0;text-align:center}.sent-email-display{background:#e8f5e9;color:#222;font-size:1.1rem;font-weight:700;border-radius:0;padding:20px;margin-bottom:0;text-align:center}.sent-instructions-box{background:#d2e3f2;padding:18px 16px;width:100%;color:#222;font-size:1rem;margin-bottom:0}.sent-instructions-box h4{font-size:1.05rem;font-weight:700;color:#3416d8;margin:0 0 8px}.sent-instructions-box ul{margin:0 0 0 18px;padding:0;font-size:1rem;font-size:14px;text-align:left;line-height:2}.sent-primary-btn{width:100%;margin-top:8px;margin-bottom:0;font-size:1.1rem;padding:20px 0;background:#3416d8;color:#fff;font-weight:700;border:none;cursor:pointer;transition:background .2s,transform .2s}.sent-primary-btn:hover{background:#c5221f;transform:translateY(-2px) scale(1.03)}.sent-tip{color:#555;font-size:13px;text-align:center;margin-top:4px;margin-bottom:0}.sent-action-buttons{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:12px}.sent-action-buttons .secondary-button,.sent-action-buttons .primary-button{width:100%;border-radius:24px;font-size:1rem;padding:12px 0}@media (max-width: 480px){.sent-card{padding:20px 8px 18px;max-width:98vw}}.neighborhood-overlay{background:#ff0;padding:8px 10px;border-radius:6px;max-width:120px;min-width:100px;font-family:Arial,sans-serif;box-shadow:0 3px 8px #00000040;border:2px solid #000;position:relative;transform:rotate(-2deg);transition:all .3s ease;cursor:pointer;font-size:10px}.neighborhood-overlay:hover{transform:rotate(0) scale(1.05);z-index:1000}.neighborhood-overlay.locked{opacity:.8;filter:grayscale(20%)}.overlay-header{display:flex;align-items:center;gap:4px;margin-bottom:4px}.category-icon{font-size:12px;line-height:1}.neighborhood-title{font-size:14px;font-weight:700;margin:0;color:#000;font-family:Comic Sans MS,cursive,sans-serif;text-transform:capitalize;letter-spacing:.5px;transform:rotate(-1deg);flex:1;line-height:1.1}.neighborhood-description{font-size:9px;line-height:1.2;margin:0 0 6px;color:#333;font-weight:500}.qr-code-container{display:flex;justify-content:center;margin-top:4px;padding:2px;background:#ff0;border-radius:3px;border:none}.unlock-badge{position:absolute;top:-6px;right:-6px;background:#f44;color:#fff;font-size:10px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 2px 4px #0000004d}.neighborhood-overlay:nth-child(2n){transform:rotate(2deg)}.neighborhood-overlay:nth-child(3n){transform:rotate(-1deg)}.neighborhood-overlay:nth-child(4n){transform:rotate(3deg)}.neighborhood-overlay:nth-child(5n){transform:rotate(-3deg)}.mobile-region-header{position:absolute;top:20px;left:20px;z-index:1000;background:#fffffff2;border-radius:16px;padding:16px 20px;box-shadow:0 4px 20px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:200px}.navigation-compass{display:none!important}.mapboxgl-ctrl-top-right{position:absolute;top:150px!important}.mapboxgl-ctrl-icon,.mapboxgl-ctrl-attrib{display:none}.sama-header-stack{padding-top:20px}.mobile-header-content{display:flex;align-items:center;gap:12px;margin-bottom:8px}.mobile-sama-logo{width:32px;height:32px}.mobile-header-text{display:flex;flex-direction:column;line-height:1}.mobile-sama-subtitle{font-size:10px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.mobile-region-title{color:#3416d8;font-size:24px;font-weight:800;margin:0;line-height:1}@media (max-width: 768px){.mobile-region-header{display:none}}.magic-link-button{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #e74c3c4d}.magic-link-button:hover{background:linear-gradient(135deg,#c0392b,#a93226);transform:translateY(-1px);box-shadow:0 4px 12px #e74c3c66}.user-status{display:flex;align-items:center;gap:12px;background:#fffffff2;padding:8px 16px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.user-email{font-weight:600;color:#2c3e50;font-size:.9rem}.access-info{font-size:.8rem;color:#7f8c8d}.logout-button{background:#ecf0f1;color:#2c3e50;border:none;padding:6px 12px;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.logout-button:hover{background:#d5dbdb}.magic-link-status{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;animation:statusFadeIn .3s ease-out}@keyframes statusFadeIn{0%{opacity:0}to{opacity:1}}.status-content{background:#fff;border-radius:16px;padding:40px;text-align:center;max-width:400px;width:90%;box-shadow:0 25px 50px #0000004d;animation:statusSlideIn .4s ease-out}@keyframes statusSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.status-content h3{margin:0 0 12px;font-size:1.5rem;font-weight:600;color:#2c3e50}.status-content p{margin:0 0 20px;color:#7f8c8d;font-size:1rem}.magic-link-status.verifying .loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 24px}.magic-link-status.success .success-icon{font-size:4rem;margin-bottom:16px}.magic-link-status.success h3{color:#27ae60}.premium-notice{background:#d4edda;border:1px solid #c3e6cb;color:#155724;padding:12px 16px;border-radius:8px;font-size:.9rem;font-weight:500;margin-top:16px}.magic-link-status.error .error-icon{font-size:4rem;margin-bottom:16px}.magic-link-status.error h3{color:#e74c3c}.retry-button{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:16px}.retry-button:hover{background:linear-gradient(135deg,#2980b9,#21618c);transform:translateY(-1px)}@media (max-width: 768px){.user-status{flex-direction:column;gap:8px;padding:12px}.magic-link-button{padding:10px 16px;font-size:.85rem}.status-content{padding:30px 20px;margin:20px}.status-content h3{font-size:1.3rem}}.map-container{position:relative;width:100%;height:100vh}.map-container.region-view{padding-top:0;height:100vh}@media (max-width: 768px){.map-container{padding-top:60px;height:100vh;box-sizing:border-box}}.map-header{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;justify-content:space-between;gap:20px;background:#000000e6;padding:15px 25px;border-radius:30px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:500px;box-shadow:0 4px 20px #0000004d}@media (max-width: 768px){.map-header{min-width:90%;padding:10px 15px;flex-direction:column;gap:10px}.map-title{font-size:1.2rem}.header-controls{flex-direction:row;flex-wrap:wrap;justify-content:center}}.header-controls{display:flex;gap:15px;align-items:center}.street-art-marker.route-stop .marker-dot{display:none}.marker.route-stop .marker-content{border-width:4px;box-shadow:0 0 0 3px #ffffff80}.route-marker{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;box-shadow:0 2px 8px #0000004d}.map-title{color:#fff;font-size:1.5rem;margin:0}.user-location-marker{position:relative;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.user-location-dot{width:12px;height:12px;background:#2196f3;border:2px solid white;border-radius:50%;box-shadow:0 2px 8px #2196f380;z-index:2;position:relative}.user-location-pulse{position:absolute;width:40px;height:40px;background:#2196f34d;border-radius:50%;animation:pulse 2s ease-out infinite}@keyframes pulse{0%{transform:scale(.5);opacity:1}to{transform:scale(1.5);opacity:0}}.street-art-marker{cursor:pointer;transition:all .3s ease;z-index:1000;position:relative}.street-art-marker.locked{opacity:1}.street-art-marker:hover{transform:scale(1.2);z-index:1001}.street-art-marker.destination{animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.marker-dot{width:28px;height:28px;border:none!important;transition:all .2s ease;position:relative}.marker-dot.marker-with-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:3px solid #fff}.marker-icon{font-size:30px!important;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.3);z-index:1}.street-art-marker:hover .marker-dot{transform:scale(1.1)}.street-art-marker.locked .marker-dot{opacity:1}.street-art-marker.destination .marker-dot{background:#667eea;border-color:#5a67d8;box-shadow:0 4px 15px #667eea66}.marker{cursor:pointer;transition:all .2s ease;z-index:1000;position:relative}.marker.locked{opacity:.5}.marker:hover{transform:scale(1.2);z-index:1001}.marker.destination{animation:bounce 2s ease-in-out infinite}.marker.destination .marker-content{background:#667eea;border-color:#5a67d8;box-shadow:0 4px 15px #667eea66}.marker-content{width:32px;height:32px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 3px 12px #0006;border:3px solid #000;transition:all .2s ease}.marker:hover .marker-content{transform:scale(1.1);box-shadow:0 4px 16px #00000080}.marker.locked .marker-content{background:#f5f5f5;border-color:#999;opacity:.7}.map-legend{display:none}.navigation-bar{position:absolute;top:80px;left:50%;transform:translate(-50%);background:#000000e6;color:#fff;padding:15px 25px;border-radius:30px;display:flex;align-items:center;gap:20px;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 5px 20px #0000004d;max-width:90%}.navigation-info h3{margin:0;font-size:1.1rem;font-weight:600}.navigation-info p{margin:5px 0 0;font-size:.9rem;opacity:.9}.stop-navigation-button{background:#ff5252;color:#fff;border:none;padding:10px 20px;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.stop-navigation-button:hover{background:#ff1744;transform:translateY(-2px);box-shadow:0 5px 15px #ff52524d}.mapboxgl-ctrl-top-right{top:100px;right:20px;z-index:1500}.mapboxgl-ctrl{z-index:1500}.mapboxgl-ctrl-group{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;border:2px solid #000;box-shadow:0 4px 12px #00000026}.mapboxgl-ctrl-group button{background:transparent;border:none;cursor:pointer;transition:all .2s ease}.mapboxgl-ctrl-group button:hover{background:#0000001a}@media (max-width: 768px){.navigation-bar{display:none}.mapboxgl-ctrl-top-right{top:80px;right:10px}.mapboxgl-ctrl-top-right .mapboxgl-ctrl{margin:5px 0}.map-legend{bottom:20px;left:10px;padding:12px;font-size:.8rem;background:#fffffff2;border-radius:8px;box-shadow:0 2px 10px #0000001a}}@media (max-width: 480px){.map-header{top:5px;padding:8px 12px;border-radius:15px}.map-title{font-size:1rem}.navigation-bar{top:50px;padding:10px 12px}.navigation-info h3{font-size:.9rem}.navigation-info p{font-size:.8rem}.stop-navigation-button{padding:10px 16px;font-size:.8rem}}@media (max-width: 600px){.map-title{font-size:1.1rem;text-align:center;margin:0 0 10px}.header-controls{width:100%;justify-content:center;gap:12px;flex-wrap:nowrap}.navigation-bar{top:70px}.mapboxgl-ctrl-top-right{top:90px;right:10px}.map-container{padding-top:70px;box-sizing:border-box}}.custom-mobile-header{background:transparent!important;box-shadow:none!important;border:none!important;position:absolute;top:0;left:0;right:0;bottom:0;z-index:1;height:50px;width:80%}.mapboxgl-map{font:12px/20px Helvetica Neue,Arial,Helvetica,sans-serif;overflow:hidden;position:relative;-webkit-tap-highlight-color:rgb(0 0 0/0)}.mapboxgl-canvas{left:0;position:absolute;top:0}.mapboxgl-map:-webkit-full-screen{height:100%;width:100%}.mapboxgl-canary{background-color:salmon}.mapboxgl-canvas-container.mapboxgl-interactive,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass{cursor:grab;-webkit-user-select:none;user-select:none}.mapboxgl-canvas-container.mapboxgl-interactive.mapboxgl-track-pointer{cursor:pointer}.mapboxgl-canvas-container.mapboxgl-interactive:active,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass:active{cursor:grabbing}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate .mapboxgl-canvas{touch-action:pan-x pan-y}.mapboxgl-canvas-container.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:pinch-zoom}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:none}.mapboxgl-ctrl-bottom,.mapboxgl-ctrl-bottom-left,.mapboxgl-ctrl-bottom-right,.mapboxgl-ctrl-left,.mapboxgl-ctrl-right,.mapboxgl-ctrl-top,.mapboxgl-ctrl-top-left,.mapboxgl-ctrl-top-right{pointer-events:none;position:absolute;z-index:2}.mapboxgl-ctrl-top-left{left:0;top:0}.mapboxgl-ctrl-top{left:50%;top:0;transform:translate(-50%)}.mapboxgl-ctrl-top-right{right:0;top:0}.mapboxgl-ctrl-right{right:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl-bottom-right{bottom:0;right:0}.mapboxgl-ctrl-bottom{bottom:0;left:50%;transform:translate(-50%)}.mapboxgl-ctrl-bottom-left{bottom:0;left:0}.mapboxgl-ctrl-left{left:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl{clear:both;pointer-events:auto;transform:translate(0)}.mapboxgl-ctrl-top-left .mapboxgl-ctrl{float:left;margin:10px 0 0 10px}.mapboxgl-ctrl-top .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-top-right .mapboxgl-ctrl{float:right;margin:10px 10px 0 0}.mapboxgl-ctrl-bottom-right .mapboxgl-ctrl,.mapboxgl-ctrl-right .mapboxgl-ctrl{float:right;margin:0 10px 10px 0}.mapboxgl-ctrl-bottom .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl,.mapboxgl-ctrl-left .mapboxgl-ctrl{float:left;margin:0 0 10px 10px}.mapboxgl-ctrl-group{background:#fff;border-radius:4px}.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px #0000001a}@media (-ms-high-contrast:active){.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px ButtonText}}.mapboxgl-ctrl-group button{background-color:initial;border:0;box-sizing:border-box;cursor:pointer;display:block;height:29px;outline:none;overflow:hidden;padding:0;width:29px}.mapboxgl-ctrl-group button+button{border-top:1px solid #ddd}.mapboxgl-ctrl button .mapboxgl-ctrl-icon{background-position:50%;background-repeat:no-repeat;display:block;height:100%;width:100%}@media (-ms-high-contrast:active){.mapboxgl-ctrl-icon{background-color:initial}.mapboxgl-ctrl-group button+button{border-top:1px solid ButtonText}}.mapboxgl-ctrl-attrib-button:focus,.mapboxgl-ctrl-group button:focus{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl button:disabled{cursor:not-allowed}.mapboxgl-ctrl button:disabled .mapboxgl-ctrl-icon{opacity:.25}.mapboxgl-ctrl-group button:first-child{border-radius:4px 4px 0 0}.mapboxgl-ctrl-group button:last-child{border-radius:0 0 4px 4px}.mapboxgl-ctrl-group button:only-child{border-radius:inherit}.mapboxgl-ctrl button:not(:disabled):hover{background-color:#0000000d}.mapboxgl-ctrl-group button:focus:focus-visible{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl-group button:focus:not(:focus-visible){box-shadow:none}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23999'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23000' viewBox='0 0 29 29'%3E%3Cpath d='M10.5 14l4-8 4 8h-8z'/%3E%3Cpath id='south' d='M10.5 16l4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23333'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23aaa'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-waiting .mapboxgl-ctrl-icon{animation:mapboxgl-spin 2s linear infinite}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23fff'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23999'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2' display='none'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23000'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' display='none'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23666'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle id='dot' cx='10' cy='10' r='2'/%3E%3Cpath id='stroke' d='M14 5l1 1-9 9-1-1 9-9z' fill='%23f00'/%3E%3C/svg%3E")}}@keyframes mapboxgl-spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='0.3' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='0.9' fill='%23fff'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;cursor:pointer;display:block;height:23px;margin:0 0 -4px -4px;overflow:hidden;width:88px}a.mapboxgl-ctrl-logo.mapboxgl-compact{width:23px}@media (-ms-high-contrast:active){a.mapboxgl-ctrl-logo{background-color:initial;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='1' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='1' fill='%23fff'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='logo' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 013.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='text' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 00-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 004.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 01-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 01.3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 01-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='clip'%3E%3Crect x='0' y='0' width='100%25' height='100%25' fill='white'/%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/mask%3E%3Cg id='outline' opacity='1' stroke='%23fff' stroke-width='3' fill='%23fff'%3E%3Ccircle mask='url(%23clip)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23text' mask='url(%23clip)'/%3E%3C/g%3E%3Cg id='fill' opacity='1' fill='%23000'%3E%3Cuse xlink:href='%23logo'/%3E%3Cuse xlink:href='%23text'/%3E%3C/g%3E%3C/svg%3E")}}.mapboxgl-ctrl.mapboxgl-ctrl-attrib{background-color:#ffffff80;margin:0;padding:0 5px}@media screen{.mapboxgl-ctrl-attrib.mapboxgl-compact{background-color:#fff;border-radius:12px;box-sizing:initial;margin:10px;min-height:20px;padding:2px 24px 2px 0;position:relative}.mapboxgl-ctrl-attrib.mapboxgl-compact-show{padding:2px 28px 2px 8px;visibility:visible}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show{border-radius:12px;padding:2px 8px 2px 28px}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-inner{display:none}.mapboxgl-ctrl-attrib-button{background-color:#ffffff80;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E");border:0;border-radius:12px;box-sizing:border-box;cursor:pointer;display:none;height:24px;outline:none;position:absolute;right:0;top:0;width:24px}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-top-left .mapboxgl-ctrl-attrib-button{left:0}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-inner{display:block}.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-button{background-color:#0000000d}.mapboxgl-ctrl-bottom-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;right:0}.mapboxgl-ctrl-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0}.mapboxgl-ctrl-top-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0;top:0}.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0;top:0}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;left:0}.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0}}@media screen and (-ms-high-contrast:active){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd' fill='%23fff'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}@media screen and (-ms-high-contrast:black-on-white){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}.mapboxgl-ctrl-attrib a{color:#000000bf;text-decoration:none}.mapboxgl-ctrl-attrib a:hover{color:inherit;text-decoration:underline}.mapboxgl-ctrl-attrib .mapbox-improve-map{font-weight:700;margin-left:2px}.mapboxgl-attrib-empty{display:none}.mapboxgl-ctrl-scale{background-color:#ffffffbf;border:2px solid #333;border-top:#333;box-sizing:border-box;color:#333;font-size:10px;padding:0 5px;white-space:nowrap}.mapboxgl-popup{display:flex;left:0;pointer-events:none;position:absolute;top:0;will-change:transform}.mapboxgl-popup-anchor-top,.mapboxgl-popup-anchor-top-left,.mapboxgl-popup-anchor-top-right{flex-direction:column}.mapboxgl-popup-anchor-bottom,.mapboxgl-popup-anchor-bottom-left,.mapboxgl-popup-anchor-bottom-right{flex-direction:column-reverse}.mapboxgl-popup-anchor-left{flex-direction:row}.mapboxgl-popup-anchor-right{flex-direction:row-reverse}.mapboxgl-popup-tip{border:10px solid #0000;height:0;width:0;z-index:1}.mapboxgl-popup-anchor-top .mapboxgl-popup-tip{align-self:center;border-bottom-color:#fff;border-top:none}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom-color:#fff;border-left:none;border-top:none}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom-color:#fff;border-right:none;border-top:none}.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip{align-self:center;border-bottom:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom:none;border-left:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom:none;border-right:none;border-top-color:#fff}.mapboxgl-popup-anchor-left .mapboxgl-popup-tip{align-self:center;border-left:none;border-right-color:#fff}.mapboxgl-popup-anchor-right .mapboxgl-popup-tip{align-self:center;border-left-color:#fff;border-right:none}.mapboxgl-popup-close-button{background-color:initial;border:0;border-radius:0 3px 0 0;cursor:pointer;position:absolute;right:0;top:0}.mapboxgl-popup-close-button:hover{background-color:#0000000d}.mapboxgl-popup-content{background:#fff;border-radius:3px;box-shadow:0 1px 2px #0000001a;padding:10px 10px 15px;pointer-events:auto;position:relative}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-content{border-top-left-radius:0}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-content{border-top-right-radius:0}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-content{border-bottom-left-radius:0}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-content{border-bottom-right-radius:0}.mapboxgl-popup-track-pointer{display:none}.mapboxgl-popup-track-pointer *{pointer-events:none;-webkit-user-select:none;user-select:none}.mapboxgl-map:hover .mapboxgl-popup-track-pointer{display:flex}.mapboxgl-map:active .mapboxgl-popup-track-pointer{display:none}.mapboxgl-marker{left:0;opacity:1;position:absolute;top:0;transition:opacity .2s;will-change:transform}.mapboxgl-user-location-dot,.mapboxgl-user-location-dot:before{background-color:#1da1f2;border-radius:50%;height:15px;width:15px}.mapboxgl-user-location-dot:before{animation:mapboxgl-user-location-dot-pulse 2s infinite;content:"";position:absolute}.mapboxgl-user-location-dot:after{border:2px solid #fff;border-radius:50%;box-shadow:0 0 3px #00000059;box-sizing:border-box;content:"";height:19px;left:-2px;position:absolute;top:-2px;width:19px}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading{height:0;width:0}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after,.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-bottom:7.5px solid #4aa1eb;content:"";position:absolute}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-left:7.5px solid #0000;transform:translateY(-28px) skewY(-20deg)}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after{border-right:7.5px solid #0000;transform:translate(7.5px,-28px) skewY(20deg)}@keyframes mapboxgl-user-location-dot-pulse{0%{opacity:1;transform:scale(1)}70%{opacity:0;transform:scale(3)}to{opacity:0;transform:scale(1)}}.mapboxgl-user-location-dot-stale{background-color:#aaa}.mapboxgl-user-location-dot-stale:after{display:none}.mapboxgl-user-location-accuracy-circle{background-color:#1da1f233;border-radius:100%;height:1px;width:1px}.mapboxgl-crosshair,.mapboxgl-crosshair .mapboxgl-interactive,.mapboxgl-crosshair .mapboxgl-interactive:active{cursor:crosshair}.mapboxgl-boxzoom{background:#fff;border:2px dotted #202020;height:0;left:0;opacity:.5;position:absolute;top:0;width:0}@media print{.mapbox-improve-map{display:none}}.mapboxgl-scroll-zoom-blocker,.mapboxgl-touch-pan-blocker{align-items:center;background:#000000b3;color:#fff;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;height:100%;justify-content:center;left:0;opacity:0;pointer-events:none;position:absolute;text-align:center;top:0;transition:opacity .75s ease-in-out;transition-delay:1s;width:100%}.mapboxgl-scroll-zoom-blocker-show,.mapboxgl-touch-pan-blocker-show{opacity:1;transition:opacity .1s ease-in-out}.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page,.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page .mapboxgl-canvas{touch-action:pan-x pan-y}@font-face{font-family:PP Neue Machina Plain Ultrabold;src:url(/fonts/PPNeueMachina-PlainUltrabold.otf) format("opentype");font-weight:800;font-style:normal}@font-face{font-family:PP Neue Machina Plain Regular;src:url(/fonts/PPNeueMachina-PlainRegular.otf) format("opentype");font-weight:400;font-style:normal}.payment-container-new{position:relative;width:100vw;min-height:100vh;background:#ef0;font-family:Inter,Arial,sans-serif;overflow-x:hidden;overflow-y:auto;z-index:3000}.payment-content-new{padding:60px 24px 80px;max-width:400px;margin:0 auto;display:flex;flex-direction:column;gap:24px;min-height:80vh}.unlock-title{color:#3416d8;font-size:23px;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif;font-weight:800;text-align:center;margin:0;line-height:1.1;letter-spacing:-.02em}.featured-highlight{background:#d2e3f2;border-radius:0;padding:20px}.highlight-title{color:#3416d8;font-size:16px;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif;font-weight:700;margin:0 0 8px}.highlight-description{color:#3416d8;font-size:16px;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;font-weight:500;margin:0;line-height:1.4;white-space:pre-line}.included-section{background:#ffffffe6;padding:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.included-title{color:#3416d8;font-size:16px;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif;font-weight:700;margin:0 0 16px}.stats-list-new{display:flex;flex-direction:column;gap:12px}.stat-item-new{display:flex;align-items:center;gap:12px}.stat-icon-new{font-size:16px;flex-shrink:0}.stat-text-new{color:#7c3aed;font-size:16px;font-weight:500}.price-section{background:#fae0df;border-radius:0;padding:32px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.lock-icon{font-size:32px;margin-bottom:8px}.price-large{font-size:44px;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif;font-weight:800;line-height:1;margin:0;color:#3416d8}.price-subtitle{font-size:16px;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;margin:0;color:#3416d8}.price-description{font-size:16px;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;color:#3416d8;line-height:1.3;text-align:center;margin-top:8px}.error-message-new{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:12px;font-size:14px;text-align:center}.unlock-button{border-radius:0;font-family:PPNeueMachina-InktrapUltrabold,PPNeueMachina,Arial,sans-serif;font-size:18px;color:#fff;background:#3416d8;border:none;padding:15px;cursor:pointer;transition:all .2s ease;text-transform:none;letter-spacing:.02em;width:100%}.unlock-button:hover:not(:disabled){background:#1d4ed8;transform:translateY(-2px);box-shadow:0 8px 20px #1e40af4d}.unlock-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.bottom-indicator{position:fixed;bottom:8px;left:50%;transform:translate(-50%);width:134px;height:5px;background:#a3a3a3;border-radius:3px}@media (max-width: 480px){.payment-content-new{padding:60px 20px 100px;min-height:90vh}.unlock-title{font-size:23px}.price-large{font-size:40px}.featured-highlight,.included-section,.price-section{padding:16px}}@media (max-width: 380px){.payment-content-new{padding:32px 16px 120px;min-height:95vh}.unlock-title{font-size:26px}.price-large{font-size:36px}.included-row{display:flex;align-items:center;width:60%!important;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;font-size:13px;color:#3416d8;font-weight:400;letter-spacing:.01em;flex-wrap:wrap;margin-top:12px}}.payment-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;display:flex;align-items:center;justify-content:center}.payment-wrapper{width:100%;max-width:600px;position:relative}.back-button{position:absolute;top:-40px;left:0;background:#fff3;border:none;color:#fff;padding:10px 20px;border-radius:25px;cursor:pointer;font-size:1rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-button:hover{background:#ffffff4d;transform:translate(-5px)}.payment-content{background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 40px #0000001a}.payment-content h1{text-align:center;color:#333;margin-bottom:30px;font-size:2rem}.purchase-summary{background:#f8f9fa;padding:30px;border-radius:15px;margin-bottom:30px}.purchase-summary h2{color:#333;margin-bottom:20px;font-size:1.5rem}.district-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px}.stat-item{text-align:center;padding:20px 10px;background:#fff;border-radius:12px}.stat-icon{font-size:2rem;display:block}.stat-number{font-size:1.8rem;font-weight:700;color:#667eea;display:block;margin-bottom:5px}.stat-label{font-size:.85rem;color:#666;display:block}.districts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:20px}.district-item{background:#e8f5e9;color:#2e7d32;padding:8px 12px;border-radius:8px;font-size:.9rem;font-weight:500;text-align:center}.features-list{list-style:none;padding:0;margin-bottom:20px}.features-list li{padding:10px 0;color:#666;font-size:1.05rem}.price-box{text-align:center;padding:20px;background:#fff;border-radius:12px;margin-top:20px}.price{font-size:2.5rem;font-weight:700;color:#667eea;display:block}.price-note{color:#666;font-size:.9rem;margin-top:5px;display:block}.checkout-form{margin-top:30px}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:.95rem}.email-input{width:100%;padding:12px 16px;font-size:1rem;transition:border-color .3s ease}.email-input:focus{outline:none;border-color:#667eea}.input-help{font-size:.85rem;color:#666;margin-top:5px}.card-element-wrapper{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .3s ease}.card-element-wrapper:hover{border-color:#667eea}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.9rem}.pay-button{width:100%;background:#667eea;color:#fff;border:none;padding:16px 32px;font-size:1.2rem;border-radius:30px;cursor:pointer;font-weight:600;transition:all .3s ease;margin-top:20px}.pay-button:hover:not(:disabled){background:#5a67d8;transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.pay-button:disabled{opacity:.6;cursor:not-allowed}.payment-info{text-align:center;margin-top:20px;color:#666;font-size:.9rem}.payment-footer{text-align:center;margin-top:30px;padding-top:30px;border-top:1px solid #e0e0e0;color:#666;font-size:.85rem}.payment-footer p{margin:5px 0}.success-message{text-align:center;padding:20px;color:#3416d8}.success-message h2{color:#fae0df;margin-bottom:20px}.email-display{font-weight:600;color:#333;font-size:1.1rem;margin:10px 0 30px}.token-preview{background:#f5f5f5;padding:25px;border-radius:12px;margin:30px 0}.preview-label{color:#666;margin-bottom:10px;font-size:.9rem}.token-display{display:block;background:#333;color:#4caf50;padding:15px;border-radius:8px;font-family:Courier New,monospace;font-size:1.1rem;margin:10px 0;word-break:break-all}.preview-note{color:#999;font-size:.85rem;font-style:italic;margin-top:10px}.next-steps{background:#e8f5e9;padding:25px;border-radius:12px;margin:30px 0;text-align:left}.next-steps h3{color:#2e7d32;margin-bottom:15px}.next-steps ol{margin:0;padding-left:20px;color:#555}.next-steps li{margin:8px 0}.token-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;border-radius:30px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.token-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.token-info-box{background:#fae0df;padding:20px;border-radius:12px;margin-top:20px}.token-info-box h3{color:#1976d2;margin-bottom:10px;font-size:1rem}.token-info-box p{margin:0;color:#666;font-size:.95rem;line-height:1.5}.email-notice{background:#e1f5fe;padding:25px;border-radius:12px;margin:30px 0;border:1px solid #0288d1}.email-notice h3{color:#0277bd;margin-bottom:15px}.email-notice p{color:#555;margin:8px 0}.spam-notice{font-style:italic;font-size:.9rem;color:#666;margin-top:15px!important}.back-to-map-button{background:#fff;color:#667eea;border:2px solid #667eea;padding:14px 28px;border-radius:30px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:15px}.back-to-map-button:hover{background:#f5f5ff;transform:translateY(-2px);box-shadow:0 5px 15px #667eea33}@media (max-width: 768px){.payment-content{padding:30px 20px}.purchase-summary{padding:20px}.payment-content h1{font-size:1.6rem}.district-stats{grid-template-columns:repeat(2,1fr);gap:15px}.stat-item{padding:0!important}.stat-icon,.stat-number{font-size:1.5rem}.included-row{display:flex;align-items:center;width:60%!important;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;font-size:13px;color:#3416d8;font-weight:400;letter-spacing:.01em;flex-wrap:wrap;margin-top:12px}}.payment-back-btn{position:sticky;top:18px;left:18px;z-index:5000}@media (max-width: 768px){body.payment-page,#root.payment-container{position:static!important;height:auto!important;overflow:auto!important}}.payment-container-new{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.included-row{display:flex;align-items:center;width:60%!important;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;font-size:13px;color:#3416d8;font-weight:400;letter-spacing:.01em;flex-wrap:wrap;margin-top:12px}.included-row .stat-number{font-size:13px;font-weight:400;margin-right:6px;color:#3416d8;text-align:center;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif}.included-row .stat-label{font-size:13px;font-weight:400;margin-right:24px;color:#3416d8}.fallback-indicator{font-size:12px;color:#ff6b35;margin-top:4px;font-weight:500;text-align:center}.email-test-container{n padding: 40px 20px;n max-width: 800px;n margin: 0 auto;n min-height: 100vh;n background: linear-gradient(135deg,#FFFF00 0%,#FF6B6B 100%);n display: flex;n align-items: center;n justify-content: center;n}nn.email-test-card{n background: white;n border-radius: 12px;n padding: 40px;n box-shadow: 0 10px 30px rgba(0,0,0,.2);n border: 3px solid #000;n width: 100%;n max-width: 600px;n}nn.email-test-card h2{n color: #000;n margin-bottom: 10px;n font-size: 28px;n font-weight: 900;n text-align: center;n}nn.email-test-card p{n color: #666;n text-align: center;n margin-bottom: 30px;n font-size: 16px;n}nn.form-group{n margin-bottom: 20px;n}nn.form-group label{n display: block;n margin-bottom: 8px;n font-weight: bold;n color: #333;n font-size: 14px;n}nn.form-group input,n.form-group select{n width: 100%;n padding: 12px 16px;n border: 2px solid #000;n border-radius: 6px;n font-size: 16px;n background: #f8f9fa;n transition: all .3s ease;n}nn.form-group input:focus,n.form-group select:focus{n outline: none;n border-color: #0066FF;n background: white;n box-shadow: 0 0 0 3px rgba(0,102,255,.1);n}nn.button-group{n display: grid;n grid-template-columns: 1fr 1fr;n gap: 15px;n margin: 30px 0;n}nn.test-button,n.token-button{n padding: 15px 25px;n border: 2px solid #000;n border-radius: 6px;n font-size: 16px;n font-weight: bold;n cursor: pointer;n transition: all .3s ease;n text-align: center;n}nn.test-button{n background: #96CEB4;n color: #000;n}nn.test-button:hover:not(:disabled){n background: #7fb69a;n transform: translateY(-2px);n box-shadow: 0 5px 15px rgba(0,0,0,.2);n}nn.token-button{n background: #0066FF;n color: white;n}nn.token-button:hover:not(:disabled){n background: #0052cc;n transform: translateY(-2px);n box-shadow: 0 5px 15px rgba(0,102,255,.3);n}nn.test-button:disabled,n.token-button:disabled{n opacity: .6;n cursor: not-allowed;n transform: none;n}nn.result{n margin: 25px 0;n padding: 20px;n border-radius: 8px;n border: 2px solid;n}nn.result.success{n background: #d4edda;n border-color: #28a745;n color: #155724;n}nn.result.error{n background: #f8d7da;n border-color: #dc3545;n color: #721c24;n}nn.result h3{n margin: 0 0 10px 0;n font-size: 18px;n}nn.result p{n margin: 5px 0;n text-align: left;n}nn.result code{n background: rgba(0,0,0,.1);n padding: 2px 6px;n border-radius: 4px;n font-family: "Courier New",monospace;n font-size: 14px;n}nn.info-section{n margin-top: 40px;n padding-top: 30px;n border-top: 2px solid #eee;n}nn.info-section h3{n color: #333;n margin-bottom: 15px;n font-size: 20px;n}nn.info-section h4{n color: #555;n margin: 20px 0 10px 0;n font-size: 16px;n}nn.info-section ul{n padding-left: 20px;n color: #666;n}nn.info-section li{n margin-bottom: 8px;n line-height: 1.5;n}nn.env-note{n background: #f8f9fa;n padding: 15px;n border-radius: 6px;n border: 1px solid #dee2e6;n margin-top: 20px;n}nn.env-note p{n margin: 5px 0;n font-family: "Courier New",monospace;n font-size: 14px;n color: #495057;n}nn@media (max-width: 768px){n .email-test-container{n padding: 20px 10px;n}n n .email-test-card{n padding: 25px;n}n n .button-group{n grid-template-columns: 1fr;n}n n .email-test-card h2{n font-size: 24px;n}n}.quick-test{padding:20px;max-width:800px;margin:0 auto;font-family:Arial,sans-serif}.test-section{margin:20px 0;padding:20px;border:1px solid #ddd;border-radius:8px;background:#f9f9f9}.test-button{background:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px}.test-button:hover{background:#0056b3}.test-button:disabled{background:#6c757d;cursor:not-allowed}.test-results{margin-top:15px;padding:15px;background:#fff;border-radius:4px;border:1px solid #dee2e6}.test-results h4{margin-top:0;color:#495057}.test-results h5{color:#6c757d;margin:15px 0 5px}.test-results pre{background:#f8f9fa;padding:10px;border-radius:4px;overflow-x:auto;font-size:12px;border:1px solid #e9ecef}.error{color:#dc3545;background:#f8d7da;padding:10px;border-radius:4px;border:1px solid #f5c6cb}.dynamic-pricing{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;max-width:600px;margin:0 auto;padding:20px}.pricing-title{font-size:24px;font-weight:700;margin:0 0 24px;color:#1a1a1a;text-align:center}.pricing-options{display:flex;flex-direction:column;gap:12px}.pricing-option{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border:1px solid #e1e5e9;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease;position:relative}.pricing-option:hover{border-color:#6366f1;box-shadow:0 2px 8px #6366f11a}.pricing-option.selected{border-color:#6366f1;background:#f8fafc;box-shadow:0 2px 8px #6366f126}.pricing-option.default{border-color:#6366f1;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.price-info{flex:1;display:flex;flex-direction:column;gap:4px}.price-amount{font-size:20px;font-weight:700;color:#6366f1;line-height:1.2}.price-interval{font-size:14px;color:#6b7280;font-weight:400}.price-badge{margin:0 16px}.badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.default-badge{background:#dbeafe;color:#2563eb}.alternative-badge{background:#f3f4f6;color:#6b7280}.price-actions{display:flex;align-items:center}.more-options-btn{background:none;border:none;color:#9ca3af;font-size:18px;cursor:pointer;padding:4px;border-radius:4px;transition:color .2s ease}.more-options-btn:hover{color:#6b7280}.pricing-note{margin-top:16px;padding:12px 16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;text-align:center}.pricing-note p{margin:0;font-size:14px;color:#0369a1}.pricing-loading{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 20px}.loading-spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top:3px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pricing-loading p{margin:0;color:#6b7280;font-size:14px}.pricing-error{text-align:center;padding:40px 20px;color:#dc2626}.pricing-error p{margin:8px 0;font-size:14px}@media (max-width: 480px){.dynamic-pricing{padding:16px}.pricing-option{padding:14px 16px}.price-amount{font-size:18px}.price-interval{font-size:13px}.badge{padding:4px 8px;font-size:11px}}.dynamic-pricing-test{max-width:800px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.test-header{text-align:center;margin-bottom:32px}.test-header h1{font-size:32px;font-weight:700;color:#1a1a1a;margin:0 0 8px}.test-header p{font-size:16px;color:#6b7280;margin:0}.test-controls{display:flex;align-items:center;gap:12px;margin-bottom:32px;padding:16px;background:#f8fafc;border-radius:8px}.test-controls label{font-weight:600;color:#374151}.test-controls select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;cursor:pointer}.test-content{margin-bottom:32px}.selected-price-info{margin-bottom:32px;padding:20px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px}.selected-price-info h3{margin:0 0 16px;color:#0369a1;font-size:18px}.price-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.price-details p{margin:0;font-size:14px;color:#374151}.price-details strong{color:#1f2937}.test-instructions{padding:20px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.test-instructions h3{margin:0 0 12px;color:#1f2937;font-size:16px}.test-instructions ol{margin:0 0 24px;padding-left:20px}.test-instructions li{margin:8px 0;color:#4b5563;font-size:14px;line-height:1.5}.test-instructions code{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-family:Monaco,Menlo,monospace;font-size:13px;color:#dc2626}@media (max-width: 640px){.dynamic-pricing-test{padding:16px}.test-header h1{font-size:24px}.test-controls{flex-direction:column;align-items:stretch}.price-details{grid-template-columns:1fr}}.success-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:20px;font-family:Arial,sans-serif}.success-card{background:#fff;border-radius:24px;padding:40px 30px;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 40px #0000001a;position:relative}.success-header{margin-bottom:30px}.success-title{font-size:48px;font-weight:900;color:#4c2ffc;margin:0;line-height:1.1;text-transform:capitalize}.success-thank-you h2{font-size:20px;font-weight:600;color:#333;margin:0 0 16px}.success-thank-you p{font-size:16px;color:#666;margin:8px 0;line-height:1.5}.success-step-number{background:#4c2ffc;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;margin-right:16px;flex-shrink:0}.success-step-title{font-size:16px!important;font-weight:600;color:#333;margin:0}.success-button{background:#4c2ffc;color:#fff;border:none;padding:16px 40px;font-size:18px;font-weight:600;cursor:pointer;width:100%;transition:all .3s ease}@media (max-width: 480px){.success-container{padding:10px}.success-card{padding:30px 20px}.success-thank-you h2{font-size:18px}.success-thank-you p,.success-step-title{font-size:14px}}.success-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;font-family:Arial,sans-serif}.success-modal-content{background:#fff;border-radius:24px;padding:40px 30px;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 40px #0000001a;position:relative;max-height:90vh;overflow-y:auto}.success-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#f0f0f0;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:#666;transition:all .3s ease;z-index:10}.success-modal-close:hover{background:#e0e0e0;color:#333}.success-modal-close-icon{line-height:1}.success-header{margin-bottom:30px;margin-top:10px}.success-title{font-size:29px!important;color:#3416d8;margin:0;line-height:1.1;text-transform:capitalize;font-family:PPNeueMachina-PlainUltrabold,Arial,Helvetica,sans-serif}.success-thank-you{background:#fce4ec;padding:24px 20px;margin:30px 0}.success-thank-you h2{font-size:16px;font-weight:900;color:#3416d8;margin:0 0 16px;font-family:PPNeueMachina-PlainUltrabold,Arial,Helvetica,sans-serif}.success-thank-you p{font-size:14px;color:#3416d8;margin:8px 0;line-height:1.5;font-family:PPNeueMachina-PlainRegular,Arial,Helvetica,sans-serif}.success-steps{margin:30px 0}.success-step{background:#e3f2fd;padding:16px 20px;margin:12px 0;display:flex;align-items:center;text-align:left}.success-step-number{background:#4c2ffc;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;margin-right:16px;flex-shrink:0;font-family:PPNeueMachina-PlainUltrabold,Arial,Helvetica,sans-serif}.success-step-content{flex:1}.success-step-title{font-size:16px;font-weight:400;color:#3416d8;margin:0;font-family:PPNeueMachina-PlainRegular,Arial,Helvetica,sans-serif}.success-footer{margin-top:40px}.success-button{background:#4c2ffc;color:#fff;border:none;padding:16px 40px;font-size:18px;font-weight:900;cursor:pointer;width:100%;transition:all .3s ease;font-family:PPNeueMachina-PlainUltrabold,Arial,Helvetica,sans-serif}.success-button:hover{background:#3d24d9;transform:translateY(-2px);box-shadow:0 8px 20px #4c2ffc4d}@media (max-width: 480px){.success-modal-overlay{padding:10px}.success-modal-content{padding:30px 20px;max-height:95vh}.success-step-title{font-size:14px}.success-modal-close{top:12px;right:12px;width:28px;height:28px;font-size:18px}}.success-modal-content::-webkit-scrollbar{width:6px}.success-modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.success-modal-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.success-modal-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.activate-container{n min-height: 100vh;n display: flex;n align-items: center;n justify-content: center;n background: linear-gradient(135deg,#667eea 0%,#764ba2 100%);n padding: 20px;n}nn.activate-card{n background: white;n border-radius: 15px;n padding: 40px;n max-width: 500px;n width: 100%;n text-align: center;n box-shadow: 0 20px 40px rgba(0,0,0,.1);n border: 3px solid #000;n}nn.activate-card.success{n border-color: #28a745;n}nn.activate-card.error{n border-color: #dc3545;n}nn.loading-spinner{n width: 60px;n height: 60px;n border: 6px solid #f3f3f3;n border-top: 6px solid #007bff;n border-radius: 50%;n animation: spin 1s linear infinite;n margin: 0 auto 20px;n}nn@keyframes spin{n 0%{transform:rotate(0)}n 100%{transform:rotate(360deg)}n}nn.success-icon,.error-icon{n font-size: 60px;n margin-bottom: 20px;n}nn.activate-card h2{n color: #333;n margin-bottom: 15px;n font-size: 28px;n}nn.success-message{n color: #28a745;n font-size: 18px;n margin-bottom: 25px;n}nn.error-message{n color: #dc3545;n font-size: 18px;n margin-bottom: 25px;n}nn.access-details{n background: #f8f9fa;n border-radius: 10px;n padding: 20px;n margin: 20px 0;n border: 2px solid #28a745;n}nn.access-badge{n background: linear-gradient(135deg,#FFFF00 0%,#FF6B6B 100%);n color: #000;n padding: 10px 20px;n border-radius: 25px;n font-weight: bold;n font-size: 18px;n border: 2px solid #000;n display: inline-block;n margin-bottom: 10px;n}nn.expires{n color: #666;n font-size: 14px;n margin: 0;n}nn.redirect-info{n margin-top: 25px;n padding-top: 20px;n border-top: 1px solid #dee2e6;n}nn.explore-button{n background: #007bff;n color: white;n border: none;n padding: 15px 30px;n border-radius: 8px;n font-size: 16px;n font-weight: bold;n cursor: pointer;n border: 2px solid #000;n box-shadow: 3px 3px 0px #000;n margin-top: 15px;n transition: all .2s;n}nn.explore-button:hover{n background: #0056b3;n transform: translateY(-2px);n}nn.error-help{n text-align: left;n margin-top: 25px;n padding-top: 20px;n border-top: 1px solid #dee2e6;n}nn.error-help h3{n color: #333;n margin-bottom: 15px;n}nn.error-help ul{n color: #666;n margin-bottom: 20px;n}nn.error-help li{n margin-bottom: 8px;n}nn.home-button{n background: #6c757d;n color: white;n border: none;n padding: 12px 25px;n border-radius: 6px;n font-size: 14px;n cursor: pointer;n border: 2px solid #000;n}nn.home-button:hover{n background: #545b62;n}nn@media (max-width: 600px){n .activate-card{n padding: 30px 20px;n}n n .activate-card h2{n font-size: 24px;n}n}n .stats-map-flex{display:flex;background:#fff;align-items:center}.stat-row{display:flex;flex-direction:column;margin-left:10px;gap:10px}.stat-icon{font-size:24px;width:30px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}.stat-icon img{width:24px;height:24px;object-fit:contain}.stat-number{font-size:24px;font-weight:700;color:#3416d8;font-family:PPNeueMachina-PlainUltrabold,Arial,sans-serif;min-width:30px}@media (max-width: 768px){.stat-row{margin-left:8px}.stat-item{gap:8px}.stat-icon{font-size:20px;width:24px}.stat-icon img{width:20px;height:20px}.stat-number{font-size:20px;min-width:24px}.stat-label{font-size:20px}.map-preview-img{width:120px;height:120px}}@font-face{font-family:PP Neue Machina Plain Ultrabold;src:url(/fonts/PPNeueMachina-PlainUltrabold.otf) format("opentype");font-weight:800;font-style:normal}@font-face{font-family:PP Neue Machina Plain Regular;src:url(/fonts/PPNeueMachina-PlainRegular.otf) format("opentype");font-weight:400;font-style:normal}.region-detail-page{position:relative;width:100vw;min-height:100vh;z-index:1000;background:#f5f5f5;font-family:Inter,Arial,sans-serif;overflow-x:hidden;overflow-y:auto}.region-background-image{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1}.background-img{width:100%;object-fit:cover;z-index:2;position:relative}.background-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;background:#ef0;z-index:1}.placeholder-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 30%,rgba(255,255,255,.1) 2px,transparent 2px),radial-gradient(circle at 80% 20%,rgba(255,255,255,.1) 3px,transparent 3px),radial-gradient(circle at 40% 70%,rgba(255,255,255,.1) 2px,transparent 2px),radial-gradient(circle at 90% 80%,rgba(255,255,255,.1) 4px,transparent 4px),radial-gradient(circle at 10% 90%,rgba(255,255,255,.1) 2px,transparent 2px),radial-gradient(circle at 60% 10%,rgba(255,255,255,.1) 3px,transparent 3px);background-size:50px 50px;opacity:.6}.region-back-btn{position:sticky;left:20px;top:20px;background:#4f46e5;border:none;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #4f46e54d;transition:all .2s ease;z-index:10}.region-back-btn:hover{background:#3730a3;transform:scale(1.05)}.back-arrow{color:#fff;font-size:24px;font-weight:700;line-height:1}.back-arrow-img{width:24px;height:24px;display:block}.region-magic-link-btn{position:sticky;right:20px;top:20px;background:#4f46e5;border:none;border-radius:8px;padding:8px 16px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;box-shadow:0 2px 8px #4f46e54d;transition:all .2s ease;z-index:10;font-family:Inter,Arial,sans-serif;display:flex;align-items:center;gap:6px;float:right;margin-top:-68px;margin-right:20px;display:none}.region-magic-link-btn:hover{background:#3730a3;transform:scale(1.05)}.region-content-overlay{position:relative;margin-top:40vh;background:#c3f53c;padding:32px 24px 40px;z-index:5;min-height:80vh;display:flex;flex-direction:column}.tour-label{color:#3416d8;font-size:12px;margin-bottom:15px;text-transform:uppercase;font-family:PP Neue Machina Inktrap,Inter,Arial,sans-serif}.region-name{color:#3416d8;font-size:36px;font-weight:800;margin:0 0 20px;line-height:1;font-family:PP Neue Machina Plain Ultrabold,Inter,Arial,sans-serif}.region-description-box{background:#d2e3f2;padding:16px 20px;margin-bottom:12px}.region-description{color:#3416d8;font-size:16px;font-weight:500;margin:0;line-height:1.4;font-family:PP Neue Machina Plain,Inter,Arial,sans-serif}.stats-map-flex{display:flex;background:#fff;margin-bottom:10px;align-items:center}.stat-flex-item{flex:1}.stat-row{display:flex;flex-direction:column;margin-left:10px}.stat-item{display:flex;align-items:center;gap:12px}.stat-icon{font-size:24px;width:30px;text-align:center;flex-shrink:0}.stat-number{font-size:24px;font-weight:700;color:#3416d8;font-family:PPNeueMachina-PlainUltrabold,Arial,sans-serif;width:35px!important}.stat-label{font-size:24px;font-weight:400;color:#3416d8;font-family:PPNeueMachina-PlainUltrabold,Arial,sans-serif;text-transform:uppercase}.map-flex-item{flex:0 0 auto}.map-preview-img{width:148px;height:148px;object-fit:cover;background:#f0f0f0}.get-it-now-btn{font-family:PP Neue Machina Inktrap Ultrabold,Inter,Arial,sans-serif;font-size:17px;background:#3416d8;color:#fff;border:none;padding:18px 32px;cursor:pointer;font-weight:800;text-align:center;transition:background .2s;display:block;width:70%;margin:20px auto 0}.get-it-now-btn:hover{background:#2200b8}@media (max-width: 600px){.map-flex-item{align-self:center}.map-preview-img{width:148px;height:148px}}@media (max-width: 480px){.region-content-overlay{padding:24px 20px 32px;min-height:55vh}.region-name{font-size:40px}.stat-number,.stat-label,.stat-icon{font-size:20px}.map-preview-img{width:148px;height:148px}}@media (max-width: 380px){.region-content-overlay{padding:20px 16px 28px}.region-name{font-size:36px}.stat-number,.stat-label,.stat-icon{font-size:18px}.map-preview-img{width:100px;height:80px}}@font-face{font-family:PP Neue Machina Inktrap;src:url(/fonts/PPNeueMachina-InktrapRegular.otf) format("opentype");font-weight:400;font-style:normal}@font-face{font-family:PP Neue Machina Plain Ultrabold;src:url(/fonts/PPNeueMachina-PlainUltrabold.otf) format("opentype");font-weight:800;font-style:normal}.info-icon{font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif;font-size:25px;font-weight:800}.info-button{background:#3416d8}@media (max-width: 600px){.region-content-overlay{margin-top:30vh;padding:24px 20px 60px;min-height:90vh}}@media (max-width: 480px){.region-content-overlay{margin-top:25vh;padding:20px 16px 80px;min-height:95vh}.get-it-now-btn{font-size:16px;padding:16px 32px}}@media (max-width: 380px){.region-content-overlay{margin-top:20vh;padding:16px 12px 100px;min-height:100vh}.get-it-now-btn{font-size:14px;padding:14px 28px}}@media (max-width: 768px){body.region-detail-page,#root.region-detail-container{position:static!important;height:auto!important;overflow:auto!important}}*{-webkit-overflow-scrolling:touch}.region-detail-page{scroll-behavior:smooth}.main-title{font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif}@font-face{font-family:PPNeueMachina-PlainLight;src:url(/fonts/PPNeueMachina-PlainLight.otf) format("opentype");font-weight:300;font-style:normal}.modal-main-title-info{padding-top:9px}.info-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:#00000080;z-index:9999;display:flex;align-items:center;justify-content:center;padding:0}.legal-text{margin-bottom:20px;font-size:11px;line-height:1.5;font-weight:400;color:#3416d8;font-family:PPNeueMachina-PlainLight,PPNeueMachina,Arial,sans-serif}.info-modal-content{background:#fae0df;border-radius:0;width:100vw;height:100vh;overflow-y:auto;position:relative;padding:20px 24px 32px;font-family:PP Neue Machina,Inter,Arial,sans-serif}.info-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.modal-subtitle{font-size:10px;font-weight:400;color:#333;line-height:1.2;margin:0;font-family:PP Neue Machina Inktrap,Inter,Arial,sans-serif}.close-button{position:fixed;top:20px;right:24px;width:44px;height:44px;border-radius:50%;background:#4338ca;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;z-index:10001}.close-icon{color:#fff;font-size:24px;font-weight:400;line-height:1}.modal-main-title{font-size:34px;color:#3416d8;margin:0 0 32px;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif;line-height:30px}.modal-body{color:#3416d8;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;font-size:18px}.intro-text{font-size:16px;line-height:1.5;margin:0 0 24px;font-weight:400}.description-text{font-size:18px;line-height:1.5;margin:0 0 24px;font-weight:400;color:#3416d8;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif}.closing-text{font-size:16px;line-height:1.5;margin:0 0 32px}.divider{height:1px;background:#3333;margin:32px 0}.contact-section{margin:24px 0}.contact-title{font-size:18px;font-weight:700;color:#3416d8;margin:0 0 8px;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif}.contact-email{color:#3416d8;text-decoration:underline;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;font-size:15px}.contact-email:hover{text-decoration:none}.footer-logos{display:flex;align-items:center;gap:16px;margin:0 auto;justify-content:center;gap:36px}.footer-logo{height:40px;width:auto;object-fit:contain}@media (max-width: 430px){.info-modal-content{padding:16px 20px 24px}.modal-main-title{font-size:34px!important;margin-bottom:24px;margin-top:0;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif;line-height:30px}.intro-text,.closing-text{font-size:15px}.description-text{font-size:18px}.legal-text{font-size:11px}.contact-title{font-size:16px}.contact-email{font-size:13px}}.info-modal-content::-webkit-scrollbar{width:6px}.info-modal-content::-webkit-scrollbar-track{background:#0000001a;border-radius:3px}.info-modal-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.info-modal-content::-webkit-scrollbar-thumb:hover{background:#0000004d}@font-face{font-family:PP Neue Machina Plain;src:url(/fonts/PPNeueMachina-PlainRegular.otf) format("opentype");font-weight:400;font-style:normal}@font-face{font-family:PP Neue Machina Inktrap;src:url(/fonts/PPNeueMachina-InktrapRegular.otf) format("opentype");font-weight:400;font-style:normal}.modal-body,.intro-text,.description-text,.closing-text,.contact-section,.contact-email{font-family:PP Neue Machina Plain,Inter,Arial,sans-serif}.already-verified-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.already-verified-modal{background:#fff;border-radius:16px;padding:32px;max-width:480px;width:100%;box-shadow:0 20px 40px #0000004d;text-align:center;animation:modalSlideIn .3s ease-out}.modal-header{margin-bottom:24px}.success-icon{font-size:48px;margin-bottom:16px}.modal-header h2{color:#3416d8;font-family:PPNeueMachina-PlainUltrabold,Arial,sans-serif;font-size:28px;margin:0;font-weight:800}.modal-content{margin-bottom:32px}.welcome-message{font-size:18px;color:#333;margin-bottom:16px;line-height:1.5;font-family:PPNeueMachina-PlainRegular,Arial,sans-serif}.email-info{background:#f8f9fa;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px;color:#666;border-left:4px solid #3416D8}.email-info strong{color:#3416d8;font-weight:600}.access-info{text-align:left;background:#f8f9fa;padding:20px;border-radius:12px;border:1px solid #e9ecef}.access-info p{margin:0 0 12px;font-weight:600;color:#333;font-size:16px}.access-info ul{margin:0;padding-left:20px;list-style:none}.access-info li{margin-bottom:8px;font-size:14px;color:#555;line-height:1.4}.modal-actions{display:flex;justify-content:center}.continue-btn{background:#3416d8;color:#fff;border:none;padding:14px 32px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:PPNeueMachina-PlainRegular,Arial,sans-serif}.continue-btn:hover{background:#2a12b0;transform:translateY(-1px);box-shadow:0 4px 12px #3416d84d}.continue-btn:active{transform:translateY(0)}@media (max-width: 768px){.already-verified-modal{padding:24px;margin:20px}.modal-header h2{font-size:24px}.welcome-message{font-size:16px}.continue-btn{padding:12px 24px;font-size:14px}}.header-row{display:flex;justify-content:space-between;align-items:center;width:100%}.header-left{display:flex;align-items:center;gap:15px}.header-right{display:flex;align-items:center;gap:12px}.magic-link-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:12px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #3b82f64d;display:none}.magic-link-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666;background:linear-gradient(135deg,#2563eb,#3416d8)}.info-button{background:#ffffffe6;border:2px solid #000;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.info-button:hover{background:#000;color:#fff}.info-icon{font-weight:700;font-size:16px}@media (max-width: 768px){.header-right{gap:8px}.magic-link-button{padding:8px 12px;font-size:12px}.info-button{width:36px;height:36px}}.payment-success-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:4000;padding:20px}.payment-success-modal{background:#fff;padding:20px;max-width:400px;width:100%;text-align:center;box-shadow:0 20px 40px #0003;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.success-icon{font-size:60px;margin-bottom:20px}.success-title{color:#3416d8;font-size:28px;font-weight:800;margin:0 0 20px}.success-message{background-color:#fae0df;border-radius:0!important;border:none!important;color:#3416d8;font-size:14px;line-height:1.5;margin:8px 0;font-family:PPNeueMachina-PlainRegular,Arial,sans-serif;text-align:left}.success-steps{display:flex;flex-direction:column;gap:12px;margin-bottom:30px;text-align:left}.step{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#d2e3f2;border-radius:0;border:1px solid #D2E3F2}.step-number{background:#3416d8;color:#fff;font-weight:700;font-size:18px;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:PPNeueMachina-PlainUltrabold,Arial,sans-serif}.step-text{color:#3416d8;font-size:16px;font-family:PPNeueMachina-PlainRegular,Arial,sans-serif}.close-success-btn{background:#3416d8;color:#fff;border:none;border-radius:0;padding:14px 32px;font-size:18px;font-weight:600;cursor:pointer;font-family:PPNeueMachina-InktrapUltrabold,Arial,sans-serif;width:100%}.close-success-btn:hover{background:#1d4ed8;transform:translateY(-1px)}@media (max-width: 480px){.payment-success-modal{padding:32px 24px;margin:20px}.success-message p{font-size:15px;padding-top:10px;padding-bottom:10px}}.landing-container{min-height:100vh;background:#fff;color:#222;padding:0;margin:0;font-family:Inter,Arial,sans-serif}.landing-content{max-width:480px;margin:0 auto;padding:0 0 32px}.landing-header{text-align:left;padding:32px 0 16px 24px}.landing-header img{width:56px;height:auto}.region-list{display:flex;flex-direction:column;gap:20px;padding:0 16px}.region-card{background:#f3f3f3;border-radius:16px;min-height:120px;box-shadow:0 1px 4px #0000000a;display:flex;flex-direction:column;justify-content:flex-end;position:relative;padding:0;overflow:hidden}.region-info{padding:20px 24px 16px}.region-title{font-size:1.2rem;font-weight:700;margin-bottom:6px;color:#222}.region-desc{font-size:1rem;color:#666;margin-bottom:0}.get-now-btn{position:absolute;right:24px;bottom:18px;background:none;border:none;color:#888;font-size:1.05rem;font-weight:600;cursor:pointer;padding:0;transition:color .2s;box-shadow:none}.get-now-btn:hover{color:#222}.map-preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000002e;z-index:1000;display:flex;align-items:center;justify-content:center}.modal-content{background:#fff;max-width:90vw;width:350px;position:relative;text-align:center}.close-btn{position:absolute;top:16px;right:18px;background:none;border:none;font-size:2rem;color:#888;cursor:pointer}.locked-label{color:#c62828;font-weight:600;margin:18px 0 0}@media (max-width: 600px){.landing-content{max-width:100vw;padding:0 0 24px}.region-card{min-height:100px}.modal-content{padding:0 8px 16px}}.landing-mobile-container{background:#fff;min-height:100vh;padding:0;font-family:Inter,Arial,sans-serif;max-width:430px;margin:0 auto;position:static!important;overflow-y:auto!important;height:auto!important}.landing-mobile-header{padding:24px 0 12px 18px;background:#fff}.landing-mobile-logo{width:60px;height:auto}.landing-mobile-card-list{background:#f5f5f5;padding:16px 0 32px;min-height:calc(100vh - 96px)}.landing-mobile-card{background:#e8e8e8;border-radius:16px;margin:0 12px 20px;padding:0;position:relative;overflow:hidden;box-shadow:0 1px 4px #0000000a;display:flex;flex-direction:column}.landing-mobile-card.free-region{border:2px solid #4CAF50;background:#f1f8e9}.landing-mobile-card-image{width:100%;height:120px;background:#ccc;display:flex;align-items:center;justify-content:center;position:relative}.free-badge{position:absolute;top:8px;right:8px;background:#4caf50;color:#fff;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.5px}.landing-mobile-card-content{padding:18px 18px 38px}.landing-mobile-card-title{font-size:1.3rem;font-weight:600;color:#555;margin-bottom:4px}.landing-mobile-card-subtitle{color:#888;font-size:1rem}.landing-mobile-get-btn{background:none;border:none;color:#888;font-weight:600;font-size:1.05rem;position:absolute;right:18px;bottom:18px;padding:0;border-bottom:3px solid #ff2d2d;border-radius:0;transition:color .2s;z-index:2}.landing-mobile-get-btn:hover{color:#c62828;border-bottom:3px solid #c62828}.landing-mobile-get-btn.free-btn{color:#4caf50;border-bottom:3px solid #4CAF50}.landing-mobile-get-btn.free-btn:hover{color:#2e7d32;border-bottom:3px solid #2E7D32}.landing-new-container{position:relative;background:#ef0;min-height:100vh;padding:0;margin:0;font-family:Inter,Arial,sans-serif;position:static!important;overflow-y:auto!important;height:auto!important}.landing-new-header{padding:20px 24px 32px;background:#ef0}.header-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.sama-logo{width:80px;height:auto;flex-shrink:0}.header-text{display:flex;flex-direction:column;align-items:flex-start;margin-left:16px;flex:1}.sama-subtitle{font-size:10px;font-weight:400;color:#333;line-height:1.2;margin:0}.info-button{width:44px;height:44px;border-radius:50%;background:#4338ca;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.info-icon{color:#fff;font-size:20px;font-weight:700}.title-line{font-size:48px;font-weight:900;color:#06f;margin:0;font-family:PPNeueMachina-PlainUltrabold,PPNeueMachina,Arial,sans-serif!important}.region-cards-container{display:flex;flex-direction:column;margin:20px;padding:0 0 40px}.region-card-new{background:#fff;overflow:hidden;margin:0 0 10px;width:100%;display:flex;flex-direction:column}.region-card-content{padding:24px 24px 0}.region-title-new{font-size:28px;margin-bottom:4px;color:#3416d8;font-family:PP Neue Machina Inktrap Ultrabold,Inter,Arial,sans-serif}.region-description-new{font-size:1rem;color:#333;margin:0 0 16px;line-height:1.4}.region-image-container:hover{box-shadow:0 4px 16px #00000021}.region-action-btn.region-action-btn-overlay{position:absolute;left:50%;top:88%;transform:translate(-50%,-50%);width:80%;min-height:38px;background:#2d2df6;color:#fff;font-weight:700;font-size:1rem;border:none;box-shadow:none;text-align:center;z-index:2;padding:8px 12px;margin:0;transition:background .15s;font-family:PP Neue Machina Inktrap,Inter,Arial,sans-serif;font-size:17px}.region-action-btn.region-action-btn-overlay:hover,.region-action-btn.region-action-btn-overlay:focus{background:#1a1ad6}.region-action-btn.region-action-btn-overlay:disabled{background:#06f;color:#fff;cursor:not-allowed;opacity:1}.region-action-btn.region-action-btn-overlay:disabled:hover{background:#06f;transform:translate(-50%,-50%)}.region-action-btn.coming-soon{background:#2d2df6!important;color:#fff!important;cursor:not-allowed!important}.region-action-btn.coming-soon:hover{background:#2d2df6!important;transform:translate(-50%,-50%)}.region-image{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}.image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#f5f5f5,#e0e0e0);display:flex;align-items:center;justify-content:center}.placeholder-text{color:#999;font-size:14px;font-weight:500}@media (max-width: 430px){.landing-new-header{padding:16px 20px 24px}.title-line{font-size:40px}.region-title-new{font-size:28px}.region-card-content{padding:18px 12px 0}.region-action-btn{margin:12px 12px 18px;width:calc(100% - 24px)}.region-image-container{height:120px}}@media (max-width: 500px){.landing-mobile-container{max-width:100vw}.landing-mobile-card{margin:0 4vw 20px}.region-image-container{width:90px;height:90px;margin-bottom:0}.region-card-text{padding:20px 8px 12px 20px}.region-action-btn.region-action-btn-overlay{font-size:.95rem!important;width:90%!important;min-height:32px;padding:6px 8px;left:50%!important;top:93%!important;transform:translate(-50%,-50%)!important}}.region-detail-container{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;z-index:5000;font-family:Inter,Arial,sans-serif;overflow-y:auto}.region-back-btn{position:sticky;top:20px;left:20px;width:44px;height:44px;border-radius:50%;background:#4338ca;border:none;color:#fff;font-size:24px;font-weight:700;cursor:pointer;z-index:5001;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026;transition:all .2s ease}.region-back-btn:hover{background:#3730a3;transform:translateY(-1px)}.region-hero-section{position:relative;width:100%;height:100vh;overflow:hidden}.region-hero-image{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0}.hero-image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#f5f5f5,#e0e0e0);display:flex;align-items:center;justify-content:center;position:absolute;top:0;left:0}.placeholder-content{display:flex;flex-direction:column;align-items:center;gap:16px}.placeholder-emoji{font-size:64px}.placeholder-label{font-size:18px;color:#666;font-weight:500}.region-content-overlay{bottom:0;left:0;right:0;background:#ef0;padding:24px;min-height:50vh}.region-tour-label{font-size:14px;font-weight:600;color:#333;margin-bottom:8px;letter-spacing:.5px}.region-detail-title{font-size:48px;font-weight:900;color:#06f;margin:0 0 16px;line-height:.9;letter-spacing:-1px}.region-description-box{background:#add8e6cc;padding:16px;margin-bottom:12px}.region-detail-description{font-size:16px;color:#333;margin:0;line-height:1.4;font-weight:500}.region-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.stat-item{display:flex;gap:0px!important}.stat-icon{font-size:20px;text-align:center}.stat-number{font-size:13px;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif;color:#3416d8;font-weight:500}.stat-label{font-size:14px;color:#3416d8;font-family:PPNeueMachina-PlainRegular,PPNeueMachina,Arial,sans-serif}.map-preview-circle{position:absolute;bottom:120px;right:24px;width:80px;height:80px;background:#ffffffe6;border:2px solid #ddd;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.map-preview-content{text-align:center}.map-preview-text{font-size:12px;color:#666;font-weight:500;line-height:1.2}.region-card-row{display:flex;flex-direction:row;width:100%;min-height:120px}.region-card-text{flex:1 1 60%;padding:20px 8px 12px 20px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start}.region-card-image-action{flex:1 1 40%;display:flex;flex-direction:column;align-items:center;justify-content:center}.region-image-container{width:100%;height:300px;background:#f5f5f5;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}.spray-overlay{position:absolute;width:74vw;height:auto;z-index:0;pointer-events:none;right:0;top:-40px}.region-image{width:100%;height:100%;object-fit:cover}.region-action-btn{width:100%;margin:0;padding:8px 0;font-size:1rem}@media (max-width: 500px){.region-card-row{flex-direction:row;height:223px!important}.region-image-container{width:100%;height:100%;position:relative}.region-card-text{padding:20px 8px 12px 20px}}.yellow-overlay{position:absolute;top:0;left:0;width:60%;height:auto;max-width:100%;z-index:2;pointer-events:none}@media (max-width: 500px){.yellow-overlay{width:100%}}.region-lock-icon{width:24px;height:24px;margin-right:8px;vertical-align:middle}.region-lock-badge{position:absolute;left:16px;bottom:16px;width:32px;height:32px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:2}.region-lock-icon{width:20px;height:20px}.region-title-new{font-family:PP Neue Machina Inktrap Ultrabold,Inter,Arial,sans-serif;font-size:28px;color:#3416d8}.title-line{font-family:PP Neue Machina Inktrap Ultrabold,Inter,Arial,sans-serif;font-size:34px;color:#3416d8;line-height:30px}.main-title{display:flex;flex-direction:column;align-items:flex-start;margin:0;padding:0;font-size:34px!important}@font-face{font-family:PP Neue Machina Inktrap;src:url(/fonts/PPNeueMachina-InktrapRegular.otf) format("opentype");font-weight:400;font-style:normal}.region-description-new{font-family:PP Neue Machina Inktrap,Inter,Arial,sans-serif;font-size:18px;color:#000}.header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding:0}.header-left{display:flex;align-items:flex-start;gap:16px}.sama-logo,.modal-logo{width:80px;height:auto;flex-shrink:0}.header-text{display:flex;flex-direction:column;align-items:flex-start}.info-button,.close-button{width:44px;height:44px;border-radius:50%;background:#4338ca;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.sama-subtitle,.modal-subtitle{font-family:PP Neue Machina Inktrap,Inter,Arial,sans-serif}@font-face{font-family:PP Neue Machina Inktrap Ultrabold;src:url(/fonts/PPNeueMachina-InktrapUltrabold.otf) format("opentype");font-weight:800;font-style:normal}.region-action-btn.region-action-btn-overlay{font-family:PP Neue Machina Inktrap Ultrabold,Inter,Arial,sans-serif;font-size:17px}.open-map-btn{font-family:PP Neue Machina Inktrap Ultrabold,Inter,Arial,sans-serif;font-size:17px;background:#fae0df!important;border:none;color:#3416d8!important;font-weight:800;cursor:pointer;padding:0;margin:0}@font-face{font-family:PP Neue Machina Plain Ultrabold;src:url(/fonts/PPNeueMachina-PlainUltrabold.otf) format("opentype");font-weight:800;font-style:normal}@font-face{font-family:PP Neue Machina Plain Regular;src:url(/fonts/PPNeueMachina-PlainRegular.otf) format("opentype");font-weight:400;font-style:normal}.region-description-ultrabold{font-family:PP Neue Machina Plain Ultrabold,Inter,Arial,sans-serif;font-weight:800;margin:0}.region-description-regular{font-family:PP Neue Machina Plain Regular,Inter,Arial,sans-serif;font-weight:400;margin:0}.region-title-header{color:#3416d8;font-family:PP Neue Machina Plain Ultrabold,Inter,Arial,sans-serif;font-size:36px}.navigation-back-btn-container{position:fixed;top:18px;left:18px;z-index:5000;width:auto;display:flex;justify-content:flex-start;pointer-events:auto}.navigation-back-btn{background:#3416d8;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #5b2eff2e;transition:background .2s,transform .2s;font-size:2rem;color:#fff;font-weight:700;line-height:1;padding:0}.navigation-back-btn:hover{background:#3a1bb3;transform:scale(1.05)}.tag-graffiti{position:absolute;top:80px;left:86vw;z-index:1;pointer-events:none;-webkit-user-select:none;user-select:none;width:14vw}.tag1-graffiti{position:absolute;bottom:0;left:0;height:40vh;z-index:0;pointer-events:none;-webkit-user-select:none;user-select:none;width:auto}.no-access-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:10000;padding:20px}.no-access-prompt{background:#fff;border-radius:16px;max-width:800px;max-height:90vh;overflow-y:auto;padding:32px;box-shadow:0 20px 40px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-section{text-align:center;margin-bottom:32px}.welcome-section h1{margin:0 0 16px;color:#333;font-size:28px;font-weight:700}.welcome-description{color:#666;font-size:16px;line-height:1.5;margin:0}.regions-grid h2{text-align:center;margin:0 0 24px;color:#333;font-size:24px}.regions-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:32px}.region-card{border:2px solid #e0e0e0;border-radius:12px;padding:20px;background:#f9f9f9;transition:all .2s ease}.region-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.region-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.region-header h3{margin:0;color:#333;font-size:20px;font-weight:700}.region-price{background:#667eea;color:#fff;padding:4px 12px;border-radius:20px;font-weight:700;font-size:14px}.region-highlights{color:#666;font-size:14px;line-height:1.4;margin:0 0 16px}.buy-region-btn{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-weight:700;font-size:16px;cursor:pointer;transition:all .2s ease}.buy-region-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.existing-customer{text-align:center;padding:24px;background:#f0f4ff;border-radius:12px;margin-bottom:32px}.existing-customer h3{margin:0 0 8px;color:#333;font-size:20px}.existing-customer p{margin:0 0 16px;color:#666;font-size:14px}.magic-link-btn{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:700;font-size:16px;cursor:pointer;transition:all .2s ease}.magic-link-btn:hover{background:#218838;transform:translateY(-1px)}.why-premium{text-align:center}.why-premium h3{margin:0 0 16px;color:#333;font-size:20px}.premium-benefits{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}.premium-benefits li{background:#f8f9fa;padding:12px 16px;border-radius:8px;color:#333;font-size:14px;text-align:left;border-left:4px solid #667eea}@media (max-width: 768px){.no-access-prompt{padding:24px;margin:10px}.welcome-section h1{font-size:24px}.regions-list,.premium-benefits{grid-template-columns:1fr}}@media (max-width: 480px){.no-access-overlay{padding:10px}.no-access-prompt{padding:20px}.welcome-section h1,.regions-grid h2{font-size:20px}}.app{width:100%;height:100%;background-color:#ef0}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background-color:#f5f5f5}.loading-spinner{width:50px;height:50px;border:3px solid #e0e0e0;border-top-color:#333;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-message{position:fixed;top:20px;right:20px;z-index:10000;max-width:400px;border-radius:8px;box-shadow:0 4px 12px #0003;animation:slideIn .3s ease-out}.auth-message.success{background:#28a745;color:#fff}.auth-message.error{background:#dc3545;color:#fff}.auth-message-content{padding:16px 24px;position:relative;font-family:Arial,sans-serif}.auth-message-close{position:absolute;top:8px;right:12px;background:none;border:none;color:inherit;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;opacity:.7}.auth-message-close:hover{opacity:1;background:#ffffff1a}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.auth-message{top:10px;right:10px;left:10px;max-width:none}}*{margin:0;padding:0;box-sizing:border-box}html{height:100%;width:100%}body{height:100%;width:100%;margin:0;padding:0}#root{height:100%;width:100%;position:relative}html,body{height:100%;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}#root{width:100vw;height:100vh;position:relative;overflow:auto}.mapboxgl-map{width:100%!important;height:100%!important}@media (max-width: 768px){body:not(.region-detail-page){position:fixed;width:100%;height:100%}#root:not(.region-detail-container){position:fixed;top:0;left:0;right:0;bottom:0}.region-detail-page{position:relative;overflow-y:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 768px){button,.marker,.mapboxgl-ctrl-group button{min-height:44px;min-width:44px}}.mapboxgl-popup-content{padding:20px;border-radius:12px;box-shadow:0 8px 25px #0003;border:2px solid #000;background:#fff;max-width:300px}.mapboxgl-popup-close-button{font-size:20px;padding:5px 10px;color:#333;background:#f5f5f5;border-radius:50%;right:10px;top:10px}.mapboxgl-popup-close-button:hover{background:#e0e0e0;color:#000}.mapboxgl-ctrl-group{border-radius:8px;box-shadow:0 2px 4px #0000001a}
