.city-search{position:relative;width:100%}.search-input-container{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;outline:none;transition:all .2s ease;background-color:#fff;color:#333}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.search-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.loading-spinner{position:absolute;right:16px;width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.error-indicator{position:absolute;right:16px;font-size:18px;color:#dc3545;cursor:help}.suggestions{position:absolute;top:100%;left:0;right:0;background:white;border:2px solid #007bff;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 8px 16px #0000001a;z-index:1000;max-height:300px;overflow-y:auto;margin-top:-2px}.suggestion-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f8f9fa;transition:all .15s ease;display:flex;flex-direction:column;gap:4px}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:#f8f9fa}.suggestion-item.selected{background-color:#e3f2fd;border-left:4px solid #007bff}.suggestion-item:focus{outline:none;background-color:#e3f2fd}.suggestion-name{font-weight:600;color:#212529;font-size:16px;line-height:1.2}.suggestion-details{display:flex;align-items:center;gap:8px;font-size:14px;flex-wrap:wrap}.suggestion-type{color:#007bff;font-weight:500;text-transform:capitalize;background-color:#e3f2fd;padding:4px 8px;border-radius:12px;font-size:12px;white-space:nowrap}.suggestion-address-type{color:#6c757d;font-weight:500;text-transform:capitalize;background-color:#f8f9fa;padding:4px 8px;border-radius:12px;font-size:12px;white-space:nowrap}.suggestion-location{color:#6c757d;font-size:14px;line-height:1.3}.no-results{position:absolute;top:100%;left:0;right:0;background:white;border:2px solid #e1e5e9;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 6px #0000001a;z-index:1000;padding:16px;text-align:center;color:#6c757d;font-size:14px}.suggestions::-webkit-scrollbar{width:8px}.suggestions::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.suggestions::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.suggestions::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.suggestion-item:focus-visible{outline:2px solid #007bff;outline-offset:-2px}@media (max-width: 768px){.search-input{font-size:16px;padding:14px 16px}.suggestion-item{padding:14px 16px}.suggestion-name{font-size:16px}.suggestion-details{font-size:14px}}@media (prefers-color-scheme: dark){.search-input{background-color:#2d3748;border-color:#4a5568;color:#e2e8f0}.search-input:focus{border-color:#63b3ed;box-shadow:0 0 0 3px #63b3ed1a}.suggestions{background-color:#2d3748;border-color:#63b3ed}.suggestion-item{border-bottom-color:#4a5568}.suggestion-item:hover{background-color:#4a5568}.suggestion-item.selected{background-color:#2c5282;border-left-color:#63b3ed}.suggestion-name{color:#e2e8f0}.suggestion-type{background-color:#2c5282;color:#63b3ed}.suggestion-location{color:#a0aec0}.no-results{background-color:#2d3748;border-color:#4a5568;color:#a0aec0}}.google-ad-container{position:relative;width:100%;min-height:90px;display:flex;align-items:center;justify-content:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin:10px 0;overflow:hidden}.google-ad-container:hover{box-shadow:0 2px 8px #0000001a}.ad-loading{display:flex;flex-direction:column;align-items:center;gap:8px;color:#6c757d;font-size:14px}.ad-loading-spinner{width:20px;height:20px;border:2px solid #e9ecef;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ad-error{display:flex;flex-direction:column;align-items:center;gap:8px;color:#dc3545;font-size:14px;padding:16px}.ad-error span{margin-bottom:10px}.ad-not-configured{display:flex;align-items:center;justify-content:center;padding:16px;color:#6c757d;font-size:14px;background:#f8f9fa;border:1px dashed #dee2e6;border-radius:8px;min-height:90px}.adsbygoogle{display:block;width:100%;height:100%;min-height:90px}@media (max-width: 768px){.google-ad-container{min-height:100px}.ad-loading,.ad-error,.ad-not-configured{font-size:12px;padding:12px}}@media (max-width: 480px){.google-ad-container{margin:5px 0;border-radius:4px}.ad-loading,.ad-error{padding:10px;font-size:11px}}.google-ad-container ins{transition:opacity .3s ease-in-out}.google-ad-container ins iframe{border:none;border-radius:inherit}.google-ad-container[data-ad-slot]:before{content:"Advertisement";position:absolute;top:5px;left:10px;font-size:10px;color:#6c757d;opacity:.7;pointer-events:none;z-index:1}.google-ad-container:focus-within{outline:2px solid #007bff;outline-offset:2px}@media (prefers-color-scheme: dark){.google-ad-container{background:#2d3748;border-color:#4a5568}.ad-loading{color:#a0aec0}.ad-error{color:#fc8181}.ad-not-configured{background:#2d3748;border-color:#4a5568;color:#a0aec0}.ad-loading-spinner{border-color:#4a5568;border-top-color:#63b3ed}}.city-details-card{position:absolute;top:20px;right:20px;width:300px;background:white;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:20px;z-index:10;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.city-details-card h3{margin:0 0 16px;color:#212529;font-size:18px;border-bottom:1px solid #e9ecef;padding-bottom:12px}.details-grid{display:grid;grid-template-columns:1fr;gap:12px}.detail-item{display:flex;justify-content:space-between;font-size:14px;padding-bottom:8px;border-bottom:1px solid #f1f3f5}.detail-item:last-child{border-bottom:none}.detail-item strong{color:#495057;font-weight:600}.detail-item span{color:#212529}.country-info{display:flex;align-items:center;gap:8px}.country-flag{font-size:18px;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.country-info span{color:#212529;font-size:14px}.city-details-ad{margin-top:16px;padding-top:16px;border-top:1px solid #e9ecef}.city-details-ad .google-ad-container{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px;margin:0;min-height:120px;width:100%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.city-details-ad .google-ad-container:hover{border-color:#007bff;box-shadow:0 2px 4px #007bff1a}.city-details-ad .google-ad-container .adsbygoogle{display:block;width:100%;height:100%;min-height:120px}@media (max-width: 768px){.city-details-card{width:280px;right:10px;top:10px}.city-details-ad .google-ad-container{min-height:100px;padding:10px}.city-details-ad .google-ad-container .adsbygoogle{min-height:100px}}.close-button{border:none;border-radius:50%;cursor:pointer;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1;padding:0;text-align:center;background:transparent}.close-btn-small{width:20px;height:20px;font-size:12px}.close-btn-medium{width:24px;height:24px;font-size:14px}.close-btn-large{width:32px;height:32px;font-size:18px}.close-btn-default{background:#e9ecef;color:#6c757d}.close-btn-default:hover{background:#dc3545;color:#fff;transform:scale(1.1)}.close-btn-default:active{background:#c82333;transform:scale(1)}.close-btn-danger{background:#dc3545;color:#fff}.close-btn-danger:hover{background:#c82333;transform:scale(1.1)}.close-btn-danger:active{background:#bd2130;transform:scale(1)}.close-btn-light{background:#f8f9fa;color:#6c757d;border:1px solid #e9ecef}.close-btn-light:hover{background:#e9ecef;color:#495057;transform:scale(1.1)}.close-btn-light:active{background:#dee2e6;transform:scale(1)}.close-button:focus{outline:2px solid #007bff;outline-offset:2px}.close-button:focus:not(:focus-visible){outline:none}@media (max-width: 768px){.close-btn-small{width:24px;height:24px;font-size:14px}.close-btn-medium{width:28px;height:28px;font-size:16px}.close-btn-large{width:36px;height:36px;font-size:20px}}.close-button.city-reset-btn{position:absolute;top:8px;right:8px;z-index:10}.close-button.city-details-close-btn{position:absolute;top:12px;right:12px;z-index:10}.city-info .close-button{position:absolute;top:8px;right:8px;z-index:10}.city-details-card .close-button,.mobile-menu-content .close-button{position:absolute;top:12px;right:12px;z-index:10}.mobile-menu-header .close-button,.help-tooltip-header .close-button{position:relative;top:auto;right:auto;z-index:auto}.layout{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;padding:24px;max-width:900px;margin:0 auto;background-color:#f8f9fa;min-height:100vh}.container{background:white;padding:48px;border-radius:12px;box-shadow:0 4px 20px #00000014}.header{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e9ecef}.header img{height:56px}.logo-link{text-decoration:none}.desktop-nav{display:flex;align-items:center;gap:8px}.nav-item{position:relative}.nav-link{color:#1e90ff;text-decoration:none;padding:12px 16px;border-radius:6px;transition:all .2s ease;font-weight:500;white-space:nowrap;display:flex;align-items:center;gap:4px}.nav-link:hover{background-color:#e3f2fd;text-decoration:none;transform:translateY(-1px)}.nav-link.active{background-color:#1e90ff;color:#fff;box-shadow:0 2px 8px #1e90ff4d}.dropdown-toggle{cursor:pointer}.dropdown-arrow{transition:transform .2s ease}.dropdown:hover .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;background:white;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s ease;z-index:1000;padding:8px 0}.dropdown-menu.show{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-item{color:#1e90ff;text-decoration:none;padding:10px 16px;display:block;transition:all .2s ease;font-weight:500;font-size:14px}.dropdown-item:hover{background-color:#e3f2fd;text-decoration:none;transform:translate(4px)}.dropdown-item.active{background-color:#1e90ff;color:#fff}.nav-toggle{display:none;flex-direction:column;justify-content:space-around;width:30px;height:30px;background:transparent;border:none;cursor:pointer;padding:0;z-index:10}.nav-toggle span{width:30px;height:3px;background:#1e90ff;border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.nav-toggle.active span:first-child{transform:rotate(45deg)}.nav-toggle.active span:nth-child(2){opacity:0}.nav-toggle.active span:nth-child(3){transform:rotate(-45deg)}.header h1{color:#1e90ff;border-bottom:3px solid #1e90ff;padding-bottom:12px;margin:0}.nav{margin-bottom:40px;display:flex;flex-direction:column;gap:24px;padding:20px 0;border-bottom:1px solid #e9ecef}.nav-primary{display:flex;flex-wrap:wrap;gap:16px}.nav-secondary{display:flex;flex-wrap:wrap;gap:32px}.nav-group{display:flex;flex-direction:column;gap:8px}.nav-group-label{font-size:.9em;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.nav-group-links{display:flex;flex-wrap:wrap;gap:12px}.nav a{color:#1e90ff;text-decoration:none;padding:10px 16px;border-radius:6px;transition:all .2s ease;font-weight:500;white-space:nowrap}.nav a:hover{background-color:#e3f2fd;text-decoration:none;transform:translateY(-1px)}.nav a.active{background-color:#1e90ff;color:#fff;box-shadow:0 2px 8px #1e90ff4d}.main-content h1{color:#1e90ff;border-bottom:3px solid #1e90ff;padding-bottom:16px;margin-top:0;margin-bottom:32px;font-size:2.2em}.main-content h2{color:#333;margin-top:40px;margin-bottom:20px;font-size:1.5em;font-weight:600}.main-content h3{color:#1e90ff;margin-top:32px;margin-bottom:16px;font-size:1.2em;font-weight:600}.main-content p{color:#555;margin-bottom:20px;line-height:1.7;font-size:1.05em}.main-content ul{color:#555;margin-bottom:24px;padding-left:24px}.main-content li{margin-bottom:12px;line-height:1.6}.highlight{background-color:#e3f2fd;padding:28px;border-left:4px solid #1e90ff;margin:32px 0;border-radius:0 8px 8px 0;box-shadow:0 2px 8px #1e90ff1a}.feature-list{background:#f8f9fa;padding:28px;border-radius:8px;margin:32px 0;border:1px solid #e9ecef}.feature-list ul{margin:0;padding-left:24px}.feature-list li{margin-bottom:12px;line-height:1.6}.faq-item{margin-bottom:32px;padding:28px;border:1px solid #e0e0e0;border-radius:8px;background-color:#fafafa;box-shadow:0 2px 8px #0000000d;transition:all .2s ease}.faq-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.faq-question{font-weight:700;color:#1e90ff;margin-bottom:16px;font-size:1.2em;line-height:1.4}.faq-answer{color:#555;line-height:1.6}.step{background-color:#f8f9fa;padding:28px;border-left:4px solid #1e90ff;margin:32px 0;border-radius:0 8px 8px 0;box-shadow:0 2px 8px #0000000d}.step-number{background-color:#1e90ff;color:#fff;width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:700;margin-right:16px;font-size:1.1em;box-shadow:0 2px 8px #1e90ff4d}.tip{background-color:#fff3cd;border:1px solid #ffeaa7;padding:20px;border-radius:8px;margin:24px 0;box-shadow:0 2px 8px #ffc1071a}.tip:before{content:"💡 ";font-weight:700;font-size:1.1em}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin:32px 0}.feature-card{background:#f8f9fa;padding:28px;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000d;transition:all .2s ease}.feature-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.feature-card h4{color:#1e90ff;margin-top:0;margin-bottom:16px;font-size:1.2em;font-weight:600}.city-table{width:100%;border-collapse:collapse;margin:32px 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.city-table th,.city-table td{padding:16px;text-align:left;border-bottom:1px solid #e9ecef}.city-table th{background-color:#1e90ff;color:#fff;font-weight:600;font-size:1.05em;text-transform:uppercase;letter-spacing:.5px}.city-table tr:nth-child(2n){background-color:#f8f9fa}.city-table tr:hover{background-color:#e3f2fd;transition:background-color .2s ease}.city-table tr:last-child td{border-bottom:none}.rank{font-weight:700;color:#1e90ff;width:60px;font-size:1.1em}.area{font-weight:700;color:#333;font-size:1.05em}.continent{color:#666;font-size:.95em;font-weight:500}.cta-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#1e90ff 0%,#4169e1 100%);color:#fff;padding:16px 32px;text-decoration:none;border-radius:12px;font-weight:600;margin:32px 0;font-size:1.1em;transition:all .3s ease;box-shadow:0 4px 16px #1e90ff40;border:none;cursor:pointer;position:relative;overflow:hidden;min-width:200px}.cta-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.cta-button:hover:before{left:100%}.cta-button:hover{background:linear-gradient(135deg,#1976d2 0%,#3f51b5 100%);transform:translateY(-3px);box-shadow:0 8px 25px #1e90ff59}.cta-button:active{transform:translateY(-1px);box-shadow:0 4px 16px #1e90ff4d}.cta-button:focus{outline:none;box-shadow:0 0 0 3px #1e90ff4d,0 4px 16px #1e90ff40}.cta-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 2px 8px #1e90ff33}.cta-button:disabled:hover{transform:none;box-shadow:0 2px 8px #1e90ff33}.insights{background-color:#fff3cd;border:1px solid #ffeaa7;padding:28px;border-radius:8px;margin:32px 0;box-shadow:0 2px 8px #ffc1071a}.insights h3{margin-top:0;color:#856404;font-size:1.3em;font-weight:600}@media (max-width: 768px){.layout{padding:16px}.container{padding:32px 24px;border-radius:8px}.header{flex-direction:row;text-align:left;gap:16px;margin-bottom:24px;padding-bottom:20px}.header img{height:48px}.desktop-nav{display:none}.nav-toggle{display:flex}.nav{position:relative;max-height:0;overflow:hidden;transition:max-height .3s ease-in-out;margin-bottom:0;padding:0;border-bottom:none}.nav.nav-open{max-height:1000px;margin-bottom:32px;padding:20px 0;border-bottom:1px solid #e9ecef}.nav-primary{flex-direction:column;gap:12px;margin-bottom:24px}.nav-secondary{flex-direction:column;gap:24px}.nav-group-links{flex-direction:column;gap:8px}.nav a{font-size:16px;padding:12px 16px;border-radius:6px;display:block;width:100%}.nav-group-label{font-size:.85em;margin-bottom:12px;padding-left:16px}.main-content h1{font-size:1.8em;margin-bottom:24px}.main-content h2{font-size:1.3em;margin-top:32px;margin-bottom:16px}.main-content h3{font-size:1.1em;margin-top:24px;margin-bottom:12px}.main-content p{font-size:1em;margin-bottom:16px}.main-content ul{padding-left:20px;margin-bottom:20px}.main-content li{margin-bottom:10px}.highlight,.feature-list{padding:24px;margin:24px 0}.faq-item{padding:24px;margin-bottom:24px}.step{padding:24px;margin:24px 0}.tip{padding:16px;margin:20px 0}.feature-grid{grid-template-columns:1fr;gap:20px;margin:24px 0}.feature-card{padding:24px}.city-table{margin:24px 0;font-size:14px}.city-table th,.city-table td{padding:12px 8px}.cta-button{padding:14px 24px;margin:24px 0;font-size:1em;min-width:180px;border-radius:10px}.insights{padding:24px;margin:24px 0}.mobile-only{display:block}}@media (min-width: 769px) and (max-width: 1024px){.nav-secondary{gap:24px}.nav-group-links{gap:8px}.nav a{padding:8px 12px;font-size:14px}}.mobile-only{display:none}@media (max-width: 768px){.mobile-only{display:block}}.app{display:flex;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.sidebar{height:100vh;width:350px;background:#f8f9fa;border-right:1px solid #e9ecef;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.sidebar h1{margin:0 0 10px;color:#212529;font-size:24px;font-weight:600}.sidebar p{margin:0 0 20px;color:#6c757d;line-height:1.5}.curvature-note{background:#e8f5e8;border:1px solid #4caf50;border-radius:6px;padding:8px 12px;color:#2e7d32!important;font-size:13px;font-weight:500;margin-bottom:20px!important}.search-section{background:white;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.search-section h3{margin:0 0 12px;color:#212529;font-size:16px;font-weight:600}.search-section-hint{font-size:12px;color:#6c757d;margin:-8px 0 16px}.city-info{margin-top:12px;padding:12px;background:white;border-radius:8px;border-left:4px solid #007bff;position:relative;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;cursor:pointer}.city-info:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.city-info h4{margin:0 0 8px;color:#212529;font-size:14px;font-weight:600}.city-info p{margin:0 0 4px;color:#6c757d;font-size:12px}.show-on-map-btn{background:#007bff;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s;margin-top:8px;width:100%}.show-on-map-btn:hover{background:#0069d9}.drag-hint{margin-top:8px!important;padding:6px 8px;background:#e3f2fd;border-radius:4px;color:#1976d2!important;font-size:11px!important;font-weight:500;border-left:2px solid #2196f3}.controls{display:flex;gap:10px}.reset-btn{background:#dc3545;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.reset-btn:hover:not(:disabled){background:#c82333}.reset-btn:disabled{background:#6c757d;cursor:not-allowed}.instructions{background:white;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.instructions h3{margin:0 0 12px;color:#212529;font-size:16px;font-weight:600}.instructions ul{margin:0;padding-left:20px;color:#6c757d;font-size:14px;line-height:1.5}.instructions li{margin-bottom:6px}.error-message{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;padding:12px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:#721c24;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px}.setup-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:40px;text-align:center;background:#f8f9fa}.setup-message h1{color:#212529;margin-bottom:20px}.setup-message ol{text-align:left;max-width:500px}.setup-message code{background:#e9ecef;padding:2px 6px;border-radius:4px;font-family:Monaco,Menlo,monospace}.map-container{flex:1;position:relative;touch-action:pan-x pan-y;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.map-container .mapboxgl-map{width:100%;height:100%}.map-container .mapboxgl-canvas,.map-container .mapboxgl-canvas.mapboxgl-interactive{cursor:default}.map-container .mapboxgl-canvas.mapboxgl-interactive:active{cursor:grabbing}.map-container.dragging .mapboxgl-canvas{cursor:grabbing!important}.curvature-info{font-size:.8em;color:#666;font-style:italic;margin:5px 0}.latitude-display{font-size:.9em;color:#555;margin:3px 0}.zooming-indicator{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.7);color:#fff;padding:8px 12px;border-radius:4px;font-size:.9em;z-index:1000;animation:fadeInOut 2s ease-in-out}@keyframes fadeInOut{0%{opacity:0}20%{opacity:1}80%{opacity:1}to{opacity:0}}@media (max-width: 768px){.app{padding-top:56px;flex-direction:column}.mobile-header{display:block!important}.sidebar{display:none}.map-container{flex:1;height:calc(100vh - 56px);touch-action:pan-x pan-y pinch-zoom}.setup-message{padding:20px}.setup-message h1{font-size:20px}.setup-message p,.setup-message li{font-size:14px}.header-section{flex-direction:column;align-items:flex-start;gap:10px}.header-section h1{font-size:20px}.help-btn{align-self:flex-end}.help-tooltip-content{padding:12px}.help-tooltip-header h3{font-size:14px}.help-tooltip ul{font-size:13px}.help-tip{font-size:12px}.copyright{margin-top:15px;padding-top:15px}.copyright p{font-size:11px}.static-links{padding:12px}.static-links h4{font-size:14px}.links-grid{grid-template-columns:1fr;gap:6px}.static-link{font-size:12px;padding:6px 10px}.mobile-menu-content .search-section{margin-bottom:20px}.mobile-menu-content .city-info{margin-bottom:12px}.mobile-menu-content .controls{margin-top:20px}.mobile-menu-content .reset-btn{width:100%;padding:12px;font-size:16px}input,textarea,select{font-size:16px!important}}.city-draggable{cursor:grab}.city-dragging{cursor:grabbing!important;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.city-info.city-dragging{transform:scale(1.02) translateY(-2px);box-shadow:0 8px 16px #00000026;opacity:.9;z-index:1000}.mapboxgl-canvas[style*="cursor: grab"]{cursor:grab!important}@media (hover: none) and (pointer: coarse){.mapboxgl-canvas{cursor:default!important}.city-dragging{cursor:grabbing!important}.map-container.dragging{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}}.map-container{position:relative;flex:1;background:#f8f9fa;overflow:hidden;transition:all .2s ease}.map-container.dragging{transform:scale(1.001);transition:all .1s ease}.map-container.dragging *{pointer-events:none}.map-container.dragging .mapboxgl-canvas{pointer-events:auto}.city-info{transition:all .2s ease,transform .1s ease-out}.city-info.city-dragging{transform:scale(1.02);box-shadow:0 6px 12px #00000026}.mapboxgl-canvas:hover{transition:cursor .1s ease}.mapboxgl-canvas[style*="cursor: grab"]:hover{cursor:grab!important}.mapboxgl-canvas[style*="cursor: grabbing"]{cursor:grabbing!important}@media (max-width: 768px){.city-info.city-dragging{transform:scale(1.01);box-shadow:0 4px 8px #0000001f}}.map-container{touch-action:manipulation}.map-container.dragging{touch-action:none}.city-dragging{position:relative}.city-dragging:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(45deg,transparent,rgba(0,123,255,.1),transparent);border-radius:8px;animation:dragPulse 1.5s ease-in-out infinite;pointer-events:none;z-index:-1}@keyframes dragPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.02)}}.city-info:focus{outline:2px solid #007bff;outline-offset:2px}.city-info.city-dragging:focus{outline:2px solid #0056b3;outline-offset:2px}@media (max-width: 768px){.city-info{min-height:60px;display:flex;flex-direction:column;justify-content:center}.city-info.city-dragging{min-height:65px}.city-reset-btn{min-width:32px;min-height:32px}}.google-ad-container{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:4px;margin:10px 0;text-align:center;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.google-ad-container:hover{border-color:#007bff;box-shadow:0 2px 4px #007bff1a}.google-ad-container .adsbygoogle{display:block;width:100%;height:32px}.google-ad-container:empty:before{content:"Advertisement";color:#6c757d;font-size:12px;font-style:italic}@media (max-width: 768px){.google-ad-container{margin:6px 0;height:28px;padding:2px}.google-ad-container .adsbygoogle{height:28px}}.header-section{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.header-section h1{margin:0;color:#212529;font-size:24px;font-weight:600}.header-section img{max-width:100%;height:auto;max-height:60px;width:auto}.help-btn{background:#007bff;color:#fff;border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #007bff33}.help-btn:hover{background:#0056b3;transform:scale(1.1);box-shadow:0 4px 8px #007bff4d}.help-btn:active{transform:scale(1)}.help-tooltip{position:relative;margin-bottom:20px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.help-tooltip-content{background:white;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:16px;border:1px solid #e9ecef}.help-tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e9ecef}.help-tooltip-header h3{margin:0;color:#212529;font-size:16px;font-weight:600}.help-tooltip ul{margin:0 0 12px;padding-left:20px;color:#6c757d;font-size:14px;line-height:1.5}.help-tip{margin-top:12px;padding:8px 12px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;font-size:13px;color:#605656}.help-contact{margin-top:15px;padding-top:15px;border-top:1px solid #e0e0e0;text-align:center}.help-contact p{margin-bottom:5px;font-size:13px;color:#666}.help-contact-link{display:inline-block;background:none;color:#1e90ff;text-decoration:underline;padding:0;border-radius:0;font-size:13px;font-weight:500;transition:all .3s ease;border:none}.help-contact-link:hover{color:#0056b3;text-decoration:underline;transform:none;box-shadow:none}.copyright{margin-top:auto;padding-top:20px;border-top:1px solid #e9ecef;text-align:center}.copyright p{margin:0;color:#6c757d;font-size:12px;font-weight:400}.static-links{background:white;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a;margin-top:auto}.static-links h4{margin:0 0 12px;color:#212529;font-size:16px;font-weight:600}.links-grid{display:grid;grid-template-columns:1fr;gap:8px}.static-link{color:#007bff;text-decoration:none;padding:8px 12px;border-radius:4px;font-size:13px;font-weight:500;transition:background-color .2s;text-align:left}.static-link:hover{background-color:#e3f2fd;text-decoration:none}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;z-index:1000;background:white;border-bottom:1px solid #e9ecef;box-shadow:0 2px 8px #0000001a;min-height:56px}.mobile-header-content{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;max-width:100%}.mobile-logo-container{display:flex;align-items:center;justify-content:center;flex:1}.mobile-logo{height:32px;width:auto}.mobile-title{font-size:18px;font-weight:600;color:#1e90ff;white-space:nowrap}.mobile-nav-btn{display:flex;flex-direction:column;justify-content:space-around;width:30px;height:30px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001;flex-shrink:0}.mobile-nav-btn span{width:30px;height:3px;background:#1e90ff;border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.mobile-add-city-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#1e90ff;border:none;border-radius:50%;cursor:pointer;color:#fff;transition:all .2s ease;flex-shrink:0;box-shadow:0 2px 8px #1e90ff4d}.mobile-add-city-btn:hover{background:#007acc;transform:scale(1.05);box-shadow:0 4px 12px #1e90ff66}.mobile-add-city-btn:active{transform:scale(1)}.mobile-menu-btn{display:flex;flex-direction:column;justify-content:space-around;width:30px;height:30px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.mobile-menu-btn span{width:30px;height:3px;background:#1e90ff;border-radius:10px;transition:all .3s linear;position:relative;transform-origin:1px}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:999;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;overflow-y:auto}.mobile-menu-content{background:white;width:100%;max-width:400px;height:calc(100vh - 60px);border-radius:12px 12px 0 0;padding:24px;overflow-y:auto;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e9ecef}.mobile-menu-header h2{margin:0;color:#1e90ff;font-size:1.5em;font-weight:600}.mobile-help-section{margin-top:32px;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.mobile-help-section h3{margin:0 0 16px;color:#1e90ff;font-size:1.2em;font-weight:600}.mobile-help-section ul{margin:0 0 16px;padding-left:20px;color:#6c757d;font-size:14px;line-height:1.5}.mobile-help-section li{margin-bottom:8px}.mobile-help-section .help-tip{background:#fff3cd;border:1px solid #ffeaa7;padding:12px;border-radius:6px;font-size:13px;color:#856404}.static-nav-links{display:flex;flex-direction:column;gap:24px}.static-nav-links .nav-group{display:flex;flex-direction:column;gap:8px}.static-nav-links .nav-group-label{font-size:.9em;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-left:4px}.static-nav-links .nav-group-links{display:flex;flex-direction:column;gap:4px}.static-nav-link{color:#1e90ff;text-decoration:none;padding:12px 16px;border-radius:6px;transition:all .2s ease;font-weight:500;font-size:16px;display:block;width:100%;background:transparent}.static-nav-link:hover{background-color:#e3f2fd;text-decoration:none;transform:translate(4px)}.static-nav-link:active{background-color:#bbdefb;transform:translate(2px)}.contact-form{max-width:800px;margin:0 auto}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s ease;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#1e90ff;box-shadow:0 0 0 3px #1e90ff1a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.form-group textarea{resize:vertical;min-height:120px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.error-message{color:#dc3545;font-size:14px;font-weight:500;margin-top:8px}.char-count{text-align:right;font-size:12px;color:#666;margin-top:8px}.alert{padding:16px 20px;border-radius:8px;margin-bottom:24px;font-weight:500}.alert.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.feedback-section{margin:3rem 0;padding:2rem;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-radius:12px;border-left:4px solid #28a745;text-align:center}.feedback-section h2{color:#2c3e50;margin-bottom:1rem;font-size:1.8rem}.feedback-section p{color:#495057;margin-bottom:1.5rem;font-size:1.1rem;line-height:1.6}.feedback-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.feedback-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:10px;text-decoration:none;font-weight:600;font-size:1rem;transition:all .3s ease;border:none;cursor:pointer;position:relative;overflow:hidden;min-width:160px;box-shadow:0 4px 12px #00000026}.feedback-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.feedback-btn:hover:before{left:100%}.feedback-btn.primary{background:linear-gradient(135deg,#dc3545 0%,#c82333 100%);color:#fff}.feedback-btn.primary:hover{background:linear-gradient(135deg,#c82333 0%,#bd2130 100%);transform:translateY(-3px);box-shadow:0 8px 20px #dc354566}.feedback-btn.secondary{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff}.feedback-btn.secondary:hover{background:linear-gradient(135deg,#20c997 0%,#17a2b8 100%);transform:translateY(-3px);box-shadow:0 8px 20px #28a74566}.feedback-btn:active{transform:translateY(-1px)}.feedback-btn:focus{outline:none;box-shadow:0 0 0 3px #ffffff4d,0 4px 12px #00000026}.feedback-btn span{font-size:1.2rem}@media (max-width: 768px){.form-row{grid-template-columns:1fr;gap:16px}.contact-form{max-width:100%}.form-group{margin-bottom:20px}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;font-size:16px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{height:100vh;width:100vw}.mapboxgl-map{height:100%;width:100%}.mapboxgl-ctrl-geocoder{min-width:100%}.mapboxgl-ctrl-geocoder--input{height:40px;padding:8px 12px;font-size:14px}.mapboxgl-ctrl-geocoder--suggestion{padding:8px 12px;font-size:14px}.mapboxgl-ctrl-geocoder--suggestion-title{font-weight:600}.mapboxgl-ctrl-geocoder--suggestion-address{color:#666;font-size:12px}
