.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 var(--border-primary);border-radius:8px;font-size:16px;outline:none;transition:all .2s ease;background-color:var(--bg-primary);color:var(--text-primary)}.search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #4a9eff1a}.search-input:disabled{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.loading-spinner{position:absolute;right:16px;width:20px;height:20px;border:2px solid var(--border-secondary);border-top:2px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.error-indicator{position:absolute;right:16px;font-size:18px;color:var(--accent-danger);cursor:help}.suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:2px solid var(--accent-primary);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 8px 16px var(--shadow-medium);z-index:1000;max-height:300px;overflow-y:auto;margin-top:-2px}.suggestion-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border-primary);transition:all .15s ease;display:flex;flex-direction:column;gap:4px}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:var(--bg-secondary)}.suggestion-item.selected{background-color:var(--bg-tertiary);border-left:4px solid var(--accent-primary)}.suggestion-item:focus{outline:none;background-color:var(--bg-tertiary)}.suggestion-name{font-weight:600;color:var(--text-primary);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:var(--accent-primary);font-weight:500;text-transform:capitalize;background-color:var(--bg-tertiary);padding:4px 8px;border-radius:12px;font-size:12px;white-space:nowrap}.suggestion-address-type{color:var(--text-muted);font-weight:500;text-transform:capitalize;background-color:var(--bg-secondary);padding:4px 8px;border-radius:12px;font-size:12px;white-space:nowrap}.suggestion-location{color:var(--text-secondary);font-size:14px;line-height:1.3}.no-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:2px solid var(--border-primary);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 6px var(--shadow-light);z-index:1000;padding:16px;text-align:center;color:var(--text-secondary);font-size:14px}.suggestions::-webkit-scrollbar{width:8px}.suggestions::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.suggestions::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.suggestions::-webkit-scrollbar-thumb:hover{background:var(--border-primary)}.suggestion-item:focus-visible{outline:2px solid var(--accent-primary);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}}.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:var(--bg-secondary);color:var(--text-secondary)}.close-btn-default:hover{background:var(--accent-danger);color:#fff;transform:scale(1.1)}.close-btn-default:active{background:var(--accent-danger-dark);transform:scale(1)}.close-btn-danger{background:var(--accent-danger);color:#fff}.close-btn-danger:hover{background:var(--accent-danger-dark);transform:scale(1.1)}.close-btn-danger:active{background:var(--accent-danger-darker);transform:scale(1)}.close-btn-light{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-primary)}.close-btn-light:hover{background:var(--bg-secondary);color:var(--text-primary);transform:scale(1.1)}.close-btn-light:active{background:var(--border-primary);transform:scale(1)}.close-button:focus{outline:2px solid var(--accent-primary);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}.theme-toggle{background:var(--button-primary-bg);color:var(--text-inverse);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px var(--shadow-light);position:relative;overflow:hidden}.theme-toggle:hover{background:var(--button-primary-hover);transform:scale(1.1);box-shadow:0 4px 12px var(--shadow-medium)}.theme-toggle:active{transform:scale(1)}.theme-toggle:focus{outline:none;box-shadow:0 0 0 3px #4a9eff4d,0 2px 8px var(--shadow-light)}.theme-toggle.small{width:32px;height:32px}.theme-toggle.medium{width:40px;height:40px}.theme-toggle.large{width:48px;height:48px}.theme-toggle-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.theme-toggle-icon svg{transition:transform .3s ease}.theme-toggle:hover .theme-toggle-icon svg{transform:rotate(15deg)}.sun-icon{animation:sunRise .3s ease-out}.moon-icon{animation:moonRise .3s ease-out}.system-icon{animation:systemPulse .3s ease-out}@keyframes sunRise{0%{transform:scale(.8) rotate(-15deg);opacity:.7}to{transform:scale(1) rotate(0);opacity:1}}@keyframes moonRise{0%{transform:scale(.8) rotate(15deg);opacity:.7}to{transform:scale(1) rotate(0);opacity:1}}@keyframes systemPulse{0%{transform:scale(.8);opacity:.7}to{transform:scale(1);opacity:1}}.theme-toggle.system-mode{background:linear-gradient(135deg,var(--button-primary-bg) 0%,var(--accent-primary) 100%);border:2px solid var(--accent-secondary)}.theme-toggle.system-mode:hover{background:linear-gradient(135deg,var(--button-primary-hover) 0%,var(--accent-secondary) 100%);border-color:var(--accent-primary)}@keyframes systemRotate{0%,to{transform:rotate(0)}50%{transform:rotate(180deg)}}.theme-toggle:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(255,255,255,.3);transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.theme-toggle:active:before{width:100%;height:100%}.dark-theme .theme-toggle{background:var(--accent-primary);box-shadow:0 2px 8px #0000004d}.dark-theme .theme-toggle:hover{background:var(--accent-secondary);box-shadow:0 4px 12px #0006}.dark-theme .theme-toggle:focus{box-shadow:0 0 0 3px #4a9eff4d,0 2px 8px #0000004d}.dark-theme .theme-toggle.system-mode{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-color:var(--accent-primary)}.dark-theme .theme-toggle.system-mode:hover{background:linear-gradient(135deg,var(--accent-secondary) 0%,var(--accent-primary) 100%);border-color:var(--accent-secondary)}@media (max-width: 768px){.theme-toggle.medium{width:36px;height:36px}.theme-toggle.large{width:44px;height:44px}}@media (prefers-contrast: high){.theme-toggle{border:2px solid var(--text-primary)}.theme-toggle:hover{border-color:var(--accent-primary)}}@media (prefers-reduced-motion: reduce){.theme-toggle,.theme-toggle-icon svg,.theme-toggle:before{transition:none}.theme-toggle:hover .theme-toggle-icon svg{transform:none}.sun-icon,.moon-icon,.system-icon,.theme-toggle.system-mode .system-icon{animation:none}}.google-ad-container{position:relative;width:100%;min-height:90px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;margin:10px 0;overflow:hidden}.google-ad-container:hover{box-shadow:0 2px 8px var(--shadow-light)}.ad-loading{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px}.ad-loading-spinner{width:20px;height:20px;border:2px solid var(--border-primary);border-top:2px solid var(--accent-primary);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:var(--accent-danger);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:var(--text-secondary);font-size:14px;background:var(--bg-secondary);border:1px dashed var(--border-primary);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:var(--text-secondary);opacity:.7;pointer-events:none;z-index:1}.ad-blocker-message,.ads-disabled-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;color:var(--text-secondary);font-size:14px;background:var(--bg-secondary);border:1px dashed var(--border-primary);border-radius:8px;min-height:90px;text-align:center}.ad-blocker-message p,.ads-disabled-message p{margin:0 0 8px;color:var(--text-secondary)}.ad-blocker-message:hover,.ads-disabled-message:hover{border-color:var(--accent-primary);box-shadow:0 2px 4px var(--shadow-light)}.google-ad-container:focus-within{outline:2px solid var(--accent-primary);outline-offset:2px}.city-details-card{position:absolute;top:20px;right:20px;width:300px;background:var(--bg-primary);border-radius:8px;box-shadow:0 4px 12px var(--shadow-medium);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:var(--text-primary);font-size:18px;border-bottom:1px solid var(--border-primary);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 var(--border-primary)}.detail-item:last-child{border-bottom:none}.detail-item strong{color:var(--text-secondary);font-weight:600}.detail-item span{color:var(--text-primary)}.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:var(--text-primary);font-size:14px}.city-details-ad{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-primary)}.city-details-ad .google-ad-container{background:var(--bg-secondary);border:1px solid var(--border-primary);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:var(--accent-primary);box-shadow:0 2px 4px #4a9eff1a}.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}}.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:var(--bg-secondary);min-height:100vh}.container{background:var(--bg-primary);padding:48px;border-radius:12px;box-shadow:0 4px 20px var(--shadow-light)}.header{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-primary)}.header-controls{display:flex;align-items:center;gap:16px}.header img{height:56px}.header svg{height:56px}.logo-link{text-decoration:none}.desktop-nav{display:flex;align-items:center;gap:8px}.nav-item{position:relative}.nav-link{color:var(--accent-primary);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:var(--static-link-hover);text-decoration:none;transform:translateY(-1px)}.nav-link.active{background-color:var(--accent-primary);color:var(--text-inverse);box-shadow:0 2px 8px #4a9eff4d}.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:var(--nav-dropdown-bg);border:1px solid var(--border-primary);border-radius:8px;box-shadow:var(--nav-dropdown-shadow);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:var(--accent-primary);text-decoration:none;padding:10px 16px;display:block;transition:all .2s ease;font-weight:500;font-size:14px}.dropdown-item:hover{background-color:var(--static-link-hover);text-decoration:none;transform:translate(4px)}.dropdown-item.active{background-color:var(--accent-primary);color:var(--text-inverse)}.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:var(--accent-primary);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:var(--accent-primary);border-bottom:3px solid var(--accent-primary);padding-bottom:12px;margin:0}.nav{margin-bottom:40px;display:flex;flex-direction:column;gap:24px;padding:20px 0;border-bottom:1px solid var(--border-primary)}.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:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.nav-group-links{display:flex;flex-wrap:wrap;gap:12px}.nav a{color:var(--accent-primary);text-decoration:none;padding:10px 16px;border-radius:6px;transition:all .2s ease;font-weight:500;white-space:nowrap}.nav a:hover{background-color:var(--static-link-hover);text-decoration:none;transform:translateY(-1px)}.nav a.active{background-color:var(--accent-primary);color:var(--text-inverse);box-shadow:0 2px 8px #4a9eff4d}.main-content h1{color:var(--accent-primary);border-bottom:3px solid var(--accent-primary);padding-bottom:16px;margin-top:0;margin-bottom:32px;font-size:2.2em}.main-content h2{color:var(--text-primary);margin-top:40px;margin-bottom:20px;font-size:1.5em;font-weight:600}.main-content h3{color:var(--accent-primary);margin-top:32px;margin-bottom:16px;font-size:1.2em;font-weight:600}.main-content p{color:var(--text-secondary);margin-bottom:20px;line-height:1.7;font-size:1.05em}.main-content ul{color:var(--text-secondary);margin-bottom:24px;padding-left:24px}.main-content li{margin-bottom:12px;line-height:1.6}.highlight{background-color:var(--highlight-bg);padding:28px;border-left:4px solid var(--highlight-border);margin:32px 0;border-radius:0 8px 8px 0;box-shadow:0 2px 8px #4a9eff1a}.feature-list{background:var(--feature-list-bg);padding:28px;border-radius:8px;margin:32px 0;border:1px solid var(--feature-list-border)}.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 var(--faq-item-border);border-radius:8px;background-color:var(--faq-item-bg);box-shadow:0 2px 8px var(--shadow-light);transition:all .2s ease}.faq-item:hover{box-shadow:0 4px 12px var(--shadow-medium);transform:translateY(-1px)}.faq-question{font-weight:700;color:var(--accent-primary);margin-bottom:16px;font-size:1.2em;line-height:1.4}.faq-answer{color:var(--text-secondary);line-height:1.6}.step{background-color:var(--step-bg);padding:28px;border-left:4px solid var(--step-border);margin:32px 0;border-radius:0 8px 8px 0;box-shadow:0 2px 8px var(--shadow-light)}.step-number{background-color:var(--accent-primary);color:var(--text-inverse);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 #4a9eff4d}.tip{background-color:var(--tip-bg);border:1px solid var(--tip-border);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:var(--feature-card-bg);padding:28px;border-radius:8px;border:1px solid var(--feature-card-border);box-shadow:0 2px 8px var(--shadow-light);transition:all .2s ease}.feature-card:hover{box-shadow:0 4px 12px var(--shadow-medium);transform:translateY(-2px)}.feature-card h4{color:var(--accent-primary);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 var(--shadow-medium)}.city-table th,.city-table td{padding:16px;text-align:left;border-bottom:1px solid var(--border-primary)}.city-table th{background-color:var(--table-header-bg);color:var(--table-header-text);font-weight:600;font-size:1.05em;text-transform:uppercase;letter-spacing:.5px}.city-table tr:nth-child(2n){background-color:var(--table-row-even)}.city-table tr:hover{background-color:var(--table-row-hover);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}.header svg{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;background-color:var(--bg-primary);color:var(--text-primary)}.sidebar{height:100vh;width:350px;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.sidebar h1{margin:0 0 10px;color:var(--text-primary);font-size:24px;font-weight:600}.sidebar p{margin:0 0 20px;color:var(--text-secondary);line-height:1.5}.curvature-note{background:var(--curvature-note-bg);border:1px solid var(--curvature-note-border);border-radius:6px;padding:8px 12px;color:var(--curvature-note-text)!important;font-size:13px;font-weight:500;margin-bottom:20px!important}.search-section{background:var(--card-bg);border-radius:8px;padding:16px;box-shadow:var(--card-shadow)}.search-section h3{margin:0 0 12px;color:var(--text-primary);font-size:16px;font-weight:600}.search-section-hint{font-size:12px;color:var(--text-secondary);margin:-8px 0 16px}.city-info{margin-top:12px;padding:12px;background:var(--card-bg);border-radius:8px;border-left:4px solid #007bff;position:relative;box-shadow:var(--card-shadow);transition:all .2s ease;cursor:pointer}.city-info:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.city-info h4{margin:0 0 8px;color:var(--text-primary);font-size:14px;font-weight:600}.city-info p{margin:0 0 4px;color:var(--text-secondary);font-size:12px}.show-on-map-btn{background:var(--button-primary-bg);color:var(--text-inverse);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:var(--button-primary-hover)}.drag-hint{margin-top:8px!important;padding:6px 8px;background:var(--drag-hint-bg);border-radius:4px;color:var(--drag-hint-text)!important;font-size:11px!important;font-weight:500;border-left:2px solid var(--drag-hint-border)}.controls{display:flex;gap:10px}.reset-btn{background:var(--accent-danger);color:var(--text-inverse);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:var(--button-secondary-bg);cursor:not-allowed}.instructions{background:var(--card-bg);border-radius:8px;padding:16px;box-shadow:var(--card-shadow)}.instructions h3{margin:0 0 12px;color:var(--text-primary);font-size:16px;font-weight:600}.instructions ul{margin:0;padding-left:20px;color:var(--text-secondary);font-size:14px;line-height:1.5}.instructions li{margin-bottom:6px}.error-message{background:var(--error-bg);color:var(--error-text);border:1px solid var(--error-border);border-radius:6px;padding:12px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:var(--error-text);color:var(--text-inverse);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:var(--bg-secondary)}.setup-message h1{color:var(--text-primary);margin-bottom:20px}.setup-message ol{text-align:left;max-width:500px}.setup-message code{background:var(--bg-tertiary);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;background:var(--map-bg)}.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:var(--text-muted);font-style:italic;margin:5px 0}.latitude-display{font-size:.9em;color:var(--text-secondary);margin:3px 0}.zooming-indicator{position:absolute;top:10px;right:10px;background:var(--shadow-heavy);color:var(--text-inverse);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}.nav-group{margin-top:48px}.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:var(--bg-secondary);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(74,158,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 var(--accent-primary);outline-offset:2px}.city-info.city-dragging:focus{outline:2px solid var(--accent-primary-dark);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:var(--google-ad-bg);border:1px solid var(--google-ad-border);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:var(--accent-primary);box-shadow:0 2px 4px #4a9eff1a}.google-ad-container .adsbygoogle{display:block;width:100%;height:32px}.google-ad-container:empty:before{content:"Advertisement";color:var(--google-ad-placeholder);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-controls{display:flex;align-items:center;gap:12px}.header-section h1{margin:0;color:var(--text-primary);font-size:24px;font-weight:600}.header-section img{max-width:100%;height:auto;max-height:60px;width:auto}.header-section svg{max-width:100%;height:auto;max-height:60px;width:auto}.help-btn{background:var(--button-primary-bg);color:var(--text-inverse);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 #4a9eff33}.help-btn:hover{background:var(--button-primary-hover);transform:scale(1.1);box-shadow:0 4px 8px #4a9eff4d}.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:var(--help-tooltip-bg);border-radius:8px;box-shadow:var(--nav-dropdown-shadow);padding:16px;border:1px solid var(--border-primary)}.help-tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-primary)}.help-tooltip-header h3{margin:0;color:var(--text-primary);font-size:16px;font-weight:600}.help-tooltip ul{margin:0 0 12px;padding-left:20px;color:var(--text-secondary);font-size:14px;line-height:1.5}.help-tip{margin-top:12px;padding:8px 12px;background:var(--help-tip-bg);border:1px solid var(--help-tip-border);border-radius:4px;font-size:13px;color:var(--help-tip-text)}.help-contact{margin-top:15px;padding-top:15px;border-top:1px solid var(--border-primary);text-align:center}.help-contact p{margin-bottom:5px;font-size:13px;color:var(--text-secondary)}.help-contact-link{display:inline-block;background:none;color:var(--accent-primary);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:var(--accent-secondary);text-decoration:underline;transform:none;box-shadow:none}.copyright{margin-top:auto;padding-top:20px;border-top:1px solid var(--border-primary);text-align:center}.copyright p{margin:0;color:var(--copyright-text);font-size:12px;font-weight:400}.static-links{background:var(--card-bg);border-radius:8px;padding:16px;box-shadow:var(--card-shadow);margin-top:auto}.static-links h4{margin:0 0 12px;color:var(--text-primary);font-size:16px;font-weight:600}.links-grid{display:grid;grid-template-columns:1fr;gap:8px}.static-link{color:var(--accent-primary);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:var(--static-link-hover);text-decoration:none}.logo{color:var(--text-primary)}.mobile-logo{color:var(--text-primary);height:32px;width:auto}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--mobile-header-bg);border-bottom:1px solid var(--mobile-header-border);box-shadow:0 2px 8px var(--shadow-light);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:var(--accent-primary);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:var(--accent-primary);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:var(--accent-primary);border:none;border-radius:50%;cursor:pointer;color:var(--text-inverse);transition:all .2s ease;flex-shrink:0;box-shadow:0 2px 8px #4a9eff4d}.mobile-add-city-btn:hover{background:var(--accent-secondary);transform:scale(1.05);box-shadow:0 4px 12px #4a9eff66}.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:var(--accent-primary);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:var(--mobile-menu-overlay);z-index:999;display:flex;align-items:flex-start;justify-content:center;padding-top:80px;overflow-y:auto}.mobile-menu-content{background:var(--mobile-menu-bg);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 var(--border-primary)}.mobile-menu-header h2{margin:0;color:var(--accent-primary);font-size:1.5em;font-weight:600}.mobile-help-section{margin-top:32px;padding:20px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-primary)}.mobile-help-section h3{margin:0 0 16px;color:var(--accent-primary);font-size:1.2em;font-weight:600}.mobile-help-section ul{margin:0 0 16px;padding-left:20px;color:var(--text-secondary);font-size:14px;line-height:1.5}.mobile-help-section li{margin-bottom:8px}.mobile-help-section .help-tip{background:var(--help-tip-bg);border:1px solid var(--help-tip-border);padding:12px;border-radius:6px;font-size:13px;color:var(--help-tip-text)}.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:var(--text-muted);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:var(--accent-primary);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:var(--static-link-hover);text-decoration:none;transform:translate(4px)}.static-nav-link:active{background-color:var(--bg-tertiary);transform:translate(2px)}.mobile-theme-toggle{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:6px;transition:all .2s ease;background:transparent}.mobile-theme-toggle:hover{background-color:var(--static-link-hover)}.theme-toggle-label{color:var(--accent-primary);font-weight:500;font-size:16px}.contact-form{max-width:800px;margin:0 auto}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;color:var(--text-primary);font-weight:600}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid var(--input-border);border-radius:8px;font-size:16px;transition:border-color .3s ease;font-family:inherit;background-color:var(--input-bg);color:var(--text-primary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px #4a9eff1a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--accent-danger);box-shadow:0 0 0 3px #f443361a}.form-group textarea{resize:vertical;min-height:120px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.error-message{color:var(--accent-danger);font-size:14px;font-weight:500;margin-top:8px}.char-count{text-align:right;font-size:12px;color:var(--text-muted);margin-top:8px}.alert{padding:16px 20px;border-radius:8px;margin-bottom:24px;font-weight:500}.alert.success{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success-text)}.alert.error{background:var(--error-bg);border:1px solid var(--error-border);color:var(--error-text)}.alert.warning{background:var(--warning-bg);border:1px solid var(--warning-border);color:var(--warning-text)}.feedback-section{margin:3rem 0;padding:2rem;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-radius:12px;border-left:4px solid var(--accent-success);text-align:center}.feedback-section h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.8rem}.feedback-section p{color:var(--text-secondary);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}.mobile-theme-toggle{padding:16px}.theme-toggle-label{font-size:18px}}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--bg-overlay: rgba(255, 255, 255, .95);--text-primary: #212529;--text-secondary: #6c757d;--text-muted: #495057;--text-inverse: #ffffff;--border-primary: #e9ecef;--border-secondary: #dee2e6;--border-accent: #1e90ff;--accent-primary: #1e90ff;--accent-secondary: #007bff;--accent-success: #28a745;--accent-warning: #ffc107;--accent-danger: #dc3545;--accent-info: #17a2b8;--shadow-light: rgba(0, 0, 0, .1);--shadow-medium: rgba(0, 0, 0, .15);--shadow-heavy: rgba(0, 0, 0, .2);--map-bg: #f8f9fa;--map-style: "mapbox://styles/mapbox/light-v11";--card-bg: #ffffff;--card-shadow: 0 1px 3px rgba(0, 0, 0, .1);--card-shadow-hover: 0 4px 8px rgba(0, 0, 0, .1);--input-bg: #ffffff;--input-border: #e0e0e0;--input-focus: #1e90ff;--button-primary-bg: #1e90ff;--button-primary-hover: #007acc;--button-secondary-bg: #6c757d;--button-secondary-hover: #5a6268;--sidebar-bg: #f8f9fa;--sidebar-border: #e9ecef;--mobile-header-bg: #ffffff;--mobile-header-border: #e9ecef;--help-tooltip-bg: #ffffff;--help-tip-bg: #fff3cd;--help-tip-border: #ffeaa7;--help-tip-text: #856404;--error-bg: #f8d7da;--error-border: #f5c6cb;--error-text: #721c24;--warning-bg: #fff3cd;--warning-border: #ffeaa7;--warning-text: #856404;--success-bg: #d4edda;--success-border: #c3e6cb;--success-text: #155724;--curvature-note-bg: #e8f5e8;--curvature-note-border: #4caf50;--curvature-note-text: #2e7d32;--drag-hint-bg: #e3f2fd;--drag-hint-border: #2196f3;--drag-hint-text: #1976d2;--google-ad-bg: #f8f9fa;--google-ad-border: #e9ecef;--google-ad-placeholder: #6c757d;--copyright-text: #6c757d;--static-link-hover: #e3f2fd;--mobile-menu-bg: #ffffff;--mobile-menu-overlay: rgba(0, 0, 0, .5);--nav-dropdown-bg: #ffffff;--nav-dropdown-shadow: 0 4px 12px rgba(0, 0, 0, .15);--highlight-bg: #e3f2fd;--highlight-border: #1e90ff;--feature-list-bg: #f8f9fa;--feature-list-border: #e9ecef;--faq-item-bg: #fafafa;--faq-item-border: #e0e0e0;--step-bg: #f8f9fa;--step-border: #1e90ff;--tip-bg: #fff3cd;--tip-border: #ffeaa7;--feature-card-bg: #f8f9fa;--feature-card-border: #e0e0e0;--table-header-bg: #1e90ff;--table-header-text: #ffffff;--table-row-even: #f8f9fa;--table-row-hover: #e3f2fd;--insights-bg: #fff3cd;--insights-border: #ffeaa7;--insights-text: #856404}.dark-theme{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #404040;--bg-overlay: rgba(26, 26, 26, .95);--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-muted: #888888;--text-inverse: #1a1a1a;--border-primary: #404040;--border-secondary: #555555;--border-accent: #4a9eff;--accent-primary: #4a9eff;--accent-secondary: #5bb3ff;--accent-success: #4caf50;--accent-warning: #ff9800;--accent-danger: #f44336;--accent-info: #2196f3;--shadow-light: rgba(0, 0, 0, .3);--shadow-medium: rgba(0, 0, 0, .4);--shadow-heavy: rgba(0, 0, 0, .5);--map-bg: #3a3a3a;--map-style: "mapbox://styles/mapbox/dark-v11";--card-bg: #2d2d2d;--card-shadow: 0 1px 3px rgba(0, 0, 0, .3);--card-shadow-hover: 0 4px 8px rgba(0, 0, 0, .4);--input-bg: #404040;--input-border: #555555;--input-focus: #4a9eff;--button-primary-bg: #4a9eff;--button-primary-hover: #5bb3ff;--button-secondary-bg: #666666;--button-secondary-hover: #777777;--sidebar-bg: #2d2d2d;--sidebar-border: #404040;--mobile-header-bg: #2d2d2d;--mobile-header-border: #404040;--help-tooltip-bg: #2d2d2d;--help-tip-bg: #3d3d1a;--help-tip-border: #555533;--help-tip-text: #cccc88;--error-bg: #3d1a1a;--error-border: #555533;--error-text: #ff8888;--warning-bg: #3d3d1a;--warning-border: #555533;--warning-text: #cccc88;--success-bg: #1a3d1a;--success-border: #335533;--success-text: #88ff88;--curvature-note-bg: #1a3d1a;--curvature-note-border: #4caf50;--curvature-note-text: #88ff88;--drag-hint-bg: #1a3d4d;--drag-hint-border: #4a9eff;--drag-hint-text: #88ccff;--google-ad-bg: #2d2d2d;--google-ad-border: #404040;--google-ad-placeholder: #888888;--copyright-text: #888888;--static-link-hover: #1a3d4d;--mobile-menu-bg: #2d2d2d;--mobile-menu-overlay: rgba(0, 0, 0, .7);--nav-dropdown-bg: #2d2d2d;--nav-dropdown-shadow: 0 4px 12px rgba(0, 0, 0, .5);--highlight-bg: #1a3d4d;--highlight-border: #4a9eff;--feature-list-bg: #2d2d2d;--feature-list-border: #404040;--faq-item-bg: #333333;--faq-item-border: #404040;--step-bg: #2d2d2d;--step-border: #4a9eff;--tip-bg: #3d3d1a;--tip-border: #555533;--feature-card-bg: #2d2d2d;--feature-card-border: #404040;--table-header-bg: #4a9eff;--table-header-text: #ffffff;--table-row-even: #333333;--table-row-hover: #1a3d4d;--insights-bg: #3d3d1a;--insights-border: #555533;--insights-text: #cccc88}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.mapboxgl-map,.mapboxgl-canvas,.mapboxgl-marker,.mapboxgl-popup{transition:none!important}.dark-theme a{color:#4a9eff}.dark-theme a:hover{color:#5bb3ff}.dark-theme input,.dark-theme textarea,.dark-theme select{color:var(--text-primary);background-color:var(--input-bg);border-color:var(--input-border)}.dark-theme input:focus,.dark-theme textarea:focus,.dark-theme select:focus{border-color:var(--input-focus);box-shadow:0 0 0 3px #4a9eff1a}.dark-theme input::placeholder,.dark-theme textarea::placeholder{color:var(--text-muted)}.dark-theme button:disabled{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.dark-theme code,.dark-theme pre{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary)}.dark-theme blockquote{border-left-color:var(--border-accent);background-color:var(--bg-secondary)}.dark-theme hr{border-color:var(--border-primary)}.dark-theme mark{background-color:var(--accent-warning);color:var(--text-inverse)}.dark-theme ::selection{background-color:var(--accent-primary);color:var(--text-inverse)}.dark-theme ::-moz-selection{background-color:var(--accent-primary);color:var(--text-inverse)}*{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:var(--bg-secondary);color:var(--text-primary)}#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:var(--text-muted);font-size:12px}
