.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:8px}.detail-item{display:flex;justify-content:space-between;font-size:14px}.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}.shape-rotation-controls{margin-top:16px;padding-top:12px;border-top:1px solid var(--border-primary)}.shape-rotation-label{display:block;color:var(--text-secondary);font-size:14px;font-weight:600;margin-bottom:8px}.shape-rotation-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:8px}.shape-rotation-btn{padding:4px 8px;font-size:12px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:background .15s,border-color .15s}.shape-rotation-btn:hover{background:var(--shadow-medium, rgba(0, 0, 0, .08));border-color:var(--text-secondary)}.shape-rotation-value{min-width:36px;text-align:center;font-size:13px;color:var(--text-primary);font-variant-numeric:tabular-nums}.shape-rotation-slider{width:100%;height:6px;margin:0;accent-color:var(--text-secondary);cursor:pointer}.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;position:relative;overflow:hidden}.theme-toggle:hover{background:var(--button-primary-hover);transform:scale(1.1)}.theme-toggle:active{transform:scale(1)}.theme-toggle:focus{outline:none}.theme-toggle.small{width:28px;height:28px}.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;width:16px!important;height:16px!important;max-width:none!important;max-height:none!important}.theme-toggle-icon svg[viewBox="0 0 48 48"]{width:16px!important;height:16px!important}.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}}@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)}.dark-theme .theme-toggle:hover{background:var(--accent-secondary)}.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}}.header{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 32px}.header-controls{display:flex;align-items:center;gap:16px}.header img{height:56px}.header svg{height:56px;width:156px}.logo-link{text-decoration:none}.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)}@media (max-width: 768px){.header{padding:8px 16px;flex-direction:row;text-align:left;gap:16px}.header img{height:48px}.header svg{height:48px}.nav-toggle{display:flex}}.desktop-nav{display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border-primary);border-top:1px solid var(--border-primary)}.nav-item{position:relative}.nav-link{color:var(--accent-primary);text-decoration:none;padding:12px 16px;border-radius:0;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}.nav-link.active{background-color:var(--accent-primary);color:var(--text-inverse);box-shadow:0 2px 8px #4a9eff4d}.nav-link.active .badge{background:rgba(255,255,255,.3);color:var(--text-inverse);border-color:#ffffff80}.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-bottom-left-radius:8px;border-bottom-right-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}.dropdown-item.active{background-color:var(--accent-primary);color:var(--text-inverse)}.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;display:flex;align-items:center;gap:.5rem}.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}.nav a.active .badge{background:rgba(255,255,255,.3);color:var(--text-inverse);border-color:#ffffff80}.mobile-only{display:none}@media (max-width: 768px){.desktop-nav{display:none}.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:0;display:block;width:100%}.nav-group-label{font-size:.85em;margin-bottom:12px;padding-left:16px}.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}}.footer{background:var(--bg-primary);border-top:1px solid var(--border-primary);margin-top:64px;padding:48px 0 0}.footer-content{max-width:1200px;margin:0 auto 48px;padding:0 32px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}.footer-logo{margin-bottom:16px}.footer-logo-svg{height:40px;width:auto}.footer-section h4{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin-bottom:20px;letter-spacing:-.01em}.footer-brand p{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin:0;opacity:.9}.footer-links{list-style:none;padding:0;margin:0}.footer-links li{margin-bottom:12px}.footer-links a{color:var(--text-secondary);text-decoration:none;font-size:.95rem;font-weight:500;transition:all .2s ease;display:inline-block;position:relative}.footer-links a:hover{color:var(--accent-primary)}.footer-links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent-primary);transition:width .2s ease}.footer-links a:hover:after{width:100%}.footer-bottom{background:var(--bg-secondary);border-top:1px solid var(--border-primary);padding:24px 0}.footer-bottom-content{max-width:1200px;margin:0 auto;padding:0 32px;display:flex;justify-content:space-between;align-items:center}.footer-bottom p{color:var(--text-secondary);font-size:.9rem;margin:0;opacity:.8}.footer-social{color:var(--text-secondary);font-size:.9rem;opacity:.8}@media (max-width: 768px){.footer{margin-top:48px;padding:32px 0 0}.footer-content{grid-template-columns:1fr;gap:32px;padding:0 24px;margin-bottom:32px}.footer-logo{margin-bottom:12px}.footer-logo-svg{height:32px}.footer-section h4{font-size:1rem;margin-bottom:16px}.footer-brand p{font-size:.9rem;line-height:1.5}.footer-links li{margin-bottom:10px}.footer-links a{font-size:.9rem}.footer-bottom{padding:20px 0}.footer-bottom-content{flex-direction:column;gap:12px;padding:0 24px;text-align:center}.footer-bottom p,.footer-social{font-size:.85rem}}@media (max-width: 1024px) and (min-width: 769px){.footer-content{grid-template-columns:1fr 1fr;gap:40px}.footer-section:first-child{grid-column:1 / -1}}.layout{line-height:1.6;padding:8px 24px;max-width:1400px;margin:0 auto;background-color:var(--bg-secondary);min-height:100vh;display:flex;flex-direction:column}.card{background:var(--bg-primary);border-radius:12px;box-shadow:0 4px 20px var(--shadow-light);display:flex;flex-direction:column;flex:1}.content-padding{padding:48px 16px}.content-padding-x{padding-left:48px;padding-right:48px}.content-padding-y{padding:48px 0}main{flex:1;display:flex;flex-direction:column}.main-content{max-width:900px;margin:0 auto}.full-width-line{width:100%;height:3px;background:linear-gradient(to right,transparent 0%,var(--accent-primary) 20%,var(--accent-primary) 80%,transparent 100%);margin-top:4px;margin-bottom:48px}.main-content h1{text-align:center;color:var(--accent-primary);margin-top:8px;font-size:2.5em}.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:24px;border-left:4px solid var(--highlight-border);margin:24px 0;border-radius:0 8px 8px 0;box-shadow:0 2px 8px #4a9eff1a;h2,h3,h4,h5,h6 {padding-top: 0; margin-top: 0;} ol {padding-left: 24px;}}.feature-list li{margin-bottom:12px;line-height:1.6}.faq-item{margin-bottom:32px;padding:24px;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;h2 {margin-top: 0;}}.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:24px;border-left:4px solid var(--step-border);margin:32px 0;border-radius:0 8px 8px 0;box-shadow:0 2px 8px var(--shadow-light);h1,h2,h3,h4,h5,h6 {padding-top: 0; margin-top: 0;}}.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}.tooltip-container{position:relative;display:inline-flex;align-items:center;gap:4px}.tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background-color:var(--accent-primary);color:#fff;border-radius:50%;font-size:10px;font-weight:700;cursor:help;transition:background-color .2s ease}.tooltip-icon:hover{background-color:var(--accent-secondary)}.tooltip-content{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:var(--bg-primary);color:var(--text-primary);padding:8px 12px;border-radius:6px;font-size:12px;white-space:nowrap;box-shadow:0 4px 12px var(--shadow-medium);border:1px solid var(--border-primary);opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;z-index:10000;margin-bottom:8px;display:block;pointer-events:none;background-color:#fff;color:#333;border:1px solid #e0e0e0}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#fff}.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:24px;border-radius:8px;margin:32px 0;box-shadow:0 2px 8px #ffc1071a;h2,h3,h4,h5,h6 {padding-top: 0; margin-top: 0;}}.insights h3{margin-top:0;color:#856404;font-size:1.3em;font-weight:600}@media (max-width: 768px){.layout{padding:8px}.card{border-radius:8px}.content-padding{padding:32px 24px}.content-padding-x{padding:0 32px}@media (max-width: 968px){.content-padding-x{padding:0}}.content-padding-y{padding:24px 0}.main-content h1{font-size:1.8em;line-height:1.2em}.full-width-heading{width:calc(100% + 48px);margin-left:-24px;margin-right:-24px;padding:0 24px}.full-width-line{width:100%;margin-top:8px;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{padding:16px;margin:24px 0;h2,h3,h4,h5,h6 {padding-top: 0; margin-top: 0;}}.feature-list{padding:24px;margin:24px 0}.faq-item{padding:24px;margin-bottom:24px;h2,h3,h4,h5,h6 {padding-top: 0; margin-top: 0;}}.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}.cta-button{padding:14px 24px;margin:24px 0;font-size:1em;min-width:180px;border-radius:10px}.insights{padding:24px;margin:24px 0}}.ad{padding:16px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-primary);text-align:center;min-height:90px;display:flex;align-items:center;justify-content:center}.adsense-ad{width:100%;min-height:90px}.city-details-ad{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-primary)}.about-page-ad,.faq-page-ad,.contact-page-ad,.how-to-use-ad,.compare-page-ad{margin:24px 0}@media (max-width: 768px){.ad{margin:16px 0;padding:12px}.adsense-ad{min-height:60px}}.tooltip-container{position:relative;display:flex;align-content:center;align-items:center}.tooltip-icon{display:inline-block;width:16px;height:16px;background-color:#666;color:#fff;border-radius:50%;text-align:center;line-height:16px;font-size:12px;margin-left:4px;cursor:help;vertical-align:middle}.tooltip-content{position:absolute;bottom:125%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:8px 12px;border-radius:4px;font-size:14px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;z-index:1000;box-shadow:0 2px 8px #0003;text-transform:none}.tooltip-content:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#333}.tooltip-container:hover .tooltip-content{opacity:1;visibility:visible}.tooltip-container:hover .tooltip-icon{background-color:#333}.table-container{overflow-x:auto;overflow-y:visible;margin:32px 0;border-radius:8px;box-shadow:0 4px 12px var(--shadow-medium)}.table{width:100%;min-width:600px;border-collapse:collapse;border-radius:8px;overflow:visible}.table th,.table td{padding:16px;text-align:left;border-bottom:1px solid var(--border-primary)}.table th{background-color:var(--table-header-bg);color:var(--table-header-text);font-weight:600;font-size:12px!important;text-transform:uppercase;letter-spacing:.5px;overflow:visible;position:relative;z-index:1}.table tr:nth-child(2n){background-color:var(--table-row-even)}.table tr:hover{background-color:var(--table-row-hover);transition:background-color .2s ease}.table tr:last-child td{border-bottom:none}.table-cell-rank{font-weight:700;color:#1e90ff;width:60px;font-size:1.1em}.table-cell-primary{font-weight:700;color:#333;font-size:1.05em}.table-cell-secondary{color:#666;font-size:.95em;font-weight:500}.table th .tooltip-container{position:relative;z-index:10}.table th .tooltip-content{z-index:10001;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);white-space:nowrap}@media (max-width: 768px){.table{margin:24px 0;font-size:14px}.table th,.table td{padding:12px 8px}}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:.75rem;font-weight:600;line-height:1;color:var(--text-inverse);background:var(--accent-primary);border:1px solid transparent;box-sizing:border-box;vertical-align:middle;margin-left:.5rem}.badge-default{background:var(--text-secondary);color:var(--text-inverse)}.badge-primary{background:var(--accent-primary);color:var(--text-inverse)}.badge-success{background:var(--accent-success);color:var(--text-inverse)}.badge-warning{background:var(--accent-warning);color:var(--text-inverse)}.badge-danger{background:var(--accent-danger);color:var(--text-inverse)}.dark-theme .badge-default{background:var(--text-secondary)}.dark-theme .badge-primary{background:var(--accent-primary)}.dark-theme .badge-success{background:var(--accent-success)}.dark-theme .badge-warning{background:var(--accent-warning)}.dark-theme .badge-danger{background:var(--accent-danger)}.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}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.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}}.sidebar{position:absolute;top:8px;left:8px;width:350px;border:1px solid var(--sidebar-border);overflow-y:auto;display:flex;flex-direction:column;height:calc(100vh - 40px);padding:16px;gap:16px;border-radius:16px;-webkit-box-shadow:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.08);-moz-box-shadow:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.08);box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;z-index:1000;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.sidebar::-webkit-scrollbar{display:none}.sidebar h1{margin:0 0 10px;color:var(--text-primary);font-size:24px;font-weight:600}.sidebar p{margin:0 0 16px;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{padding:16px;background:var(--card-bg);border-top-right-radius:8px;border-bottom-right-radius:8px;border-left:4px solid #007bff;position:relative;box-shadow:var(--card-shadow);transition:all .2s ease,transform .1s ease-out;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{width:100%;background:var(--accent-danger);color:var(--text-inverse);border:none;padding:8px;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}.header-section{display:flex;align-items:center;justify-content:space-between;margin-bottom:0;flex-shrink:0}.header-controls{display:flex;align-items:center;gap:12px;flex-shrink:0}.header-section a{display:flex;align-items:center;text-decoration:none;flex:1;min-width:0}.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;display:block}.header-section svg{max-width:100%;height:auto;max-height:60px;width:auto;display:block}.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:8px;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;padding:16px;border:1px solid var(--border-primary);box-shadow:var(--card-shadow)}.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{padding-top:16px;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{border:1px solid var(--border-primary);background:var(--card-bg);border-radius:8px;padding-bottom:16px;margin-top:auto}.static-links h4{color:var(--text-primary);font-size:16px;padding:16px 16px 8px;font-weight:600}.links-grid{display:grid;grid-template-columns:1fr;gap:4px}.static-link{color:var(--text-muted);text-decoration:none;padding:4px 20px;font-size:13px;font-weight:500;transition:background-color .2s;text-align:left;display:flex;align-items:center;justify-content:space-between}.static-link:hover{background-color:var(--static-link-hover);text-decoration:none}.logo{color:var(--text-primary)}.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}.city-info.city-dragging{transform:scale(1.02);box-shadow:0 6px 12px #00000026}.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){.sidebar{display:none}.header-section{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:8px}.header-section a{flex:none;width:100%}.header-section h1{font-size:20px}.help-btn{align-self:flex-end}.help-tooltip-content{padding:8px}.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:16px}.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}.city-info{min-height:60px;display:flex;flex-direction:column;justify-content:center}.city-info.city-dragging{min-height:65px;transform:scale(1.01);box-shadow:0 4px 8px #0000001f}.city-reset-btn{min-width:32px;min-height:32px}}.breadcrumbs{margin-bottom:1rem;padding:.5rem 0}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;list-style:none;margin:0;padding:0;font-size:.875rem;color:#666}.breadcrumb-item{display:flex;align-items:center}.breadcrumb-link{color:#1e90ff;text-decoration:none;transition:color .2s ease}.breadcrumb-link:hover{color:#06c;text-decoration:underline}.breadcrumb-current{color:#333;font-weight:500}.breadcrumb-separator{margin:0 .5rem;color:#999}@media (max-width: 768px){.breadcrumbs{margin-bottom:.75rem}.breadcrumb-list{font-size:.8rem}}.city-rankings__list{list-style:none;padding-left:0}.city-rankings__list li{margin-bottom:16px}.city-rankings__link{color:var(--accent-primary);font-weight:600;text-decoration:none}.city-rankings__link:hover{color:var(--accent-secondary);text-decoration:underline}.app{position:relative;height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.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{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;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);z-index:1}@media (min-width: 769px){.map-container{left:366px;width:calc(100% - 366px)}}.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}.mobile-header{display:block!important}.map-container{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}input,textarea,select{font-size:16px!important}}.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:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;background:var(--bg-secondary);overflow:hidden;transition:all .2s ease;z-index:1}.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}.mapboxgl-canvas:hover{transition:cursor .1s ease}.mapboxgl-canvas[style*="cursor: grab"]:hover{cursor:grab!important}.mapboxgl-canvas[style*="cursor: grabbing"]{cursor:grabbing!important}.map-container{touch-action:manipulation}.map-container.dragging{touch-action:none}.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%;margin:0 16px;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;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:16px}.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:flex;align-items:center;justify-content:space-between;width:100%;background:transparent;gap:.5rem}.static-nav-link:hover{background-color:var(--static-link-hover);text-decoration:none}.static-nav-link:active{background-color:var(--bg-tertiary)}.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:100%}.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: #10b981;--accent-warning: #ffc107;--accent-danger: #dc3545;--accent-info: #17a2b8;--accent-purple: #8b5cf6;--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;--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-title: #856404;--admin-shadow-light: rgba(0, 0, 0, .04);--admin-shadow-medium: rgba(0, 0, 0, .08);--admin-shadow-heavy: rgba(0, 0, 0, .1);--admin-accent-shadow: rgba(30, 144, 255, .2);--admin-accent-shadow-hover: rgba(30, 144, 255, .3);--admin-accent-glow: rgba(30, 144, 255, .1);--admin-success-glow: rgba(16, 185, 129, .1);--admin-warning-glow: rgba(255, 193, 7, .1);--admin-danger-glow: rgba(220, 53, 69, .1);--admin-purple-glow: rgba(139, 92, 246, .1);--admin-topbar-bg: rgba(255, 255, 255, .95)}.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: #10b981;--accent-warning: #ff9800;--accent-danger: #f44336;--accent-info: #2196f3;--accent-purple: #a78bfa;--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;--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 2px 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-title: #dea500;--admin-shadow-light: rgba(0, 0, 0, .3);--admin-shadow-medium: rgba(0, 0, 0, .4);--admin-shadow-heavy: rgba(0, 0, 0, .5);--admin-accent-shadow: rgba(74, 158, 255, .3);--admin-accent-shadow-hover: rgba(74, 158, 255, .4);--admin-accent-glow: rgba(74, 158, 255, .15);--admin-success-glow: rgba(16, 185, 129, .15);--admin-warning-glow: rgba(255, 152, 0, .15);--admin-danger-glow: rgba(244, 67, 54, .15);--admin-purple-glow: rgba(167, 139, 250, .15);--admin-topbar-bg: rgba(26, 26, 26, .95)}*{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)}.dark-theme .ant-input,.dark-theme .ant-input-affix-wrapper,.dark-theme .ant-input-number,.dark-theme .ant-input-number-input{color:var(--text-primary)!important;background-color:var(--input-bg)!important;border-color:var(--input-border)!important}.dark-theme .ant-input::placeholder,.dark-theme .ant-input-affix-wrapper input::placeholder,.dark-theme .ant-input-number-input::placeholder{color:var(--text-muted)!important}.dark-theme .ant-input-affix-wrapper input{color:var(--text-primary)!important;background:transparent!important}.dark-theme .ant-input-focused,.dark-theme .ant-input-affix-wrapper-focused,.dark-theme .ant-input:focus,.dark-theme .ant-input-affix-wrapper:focus-within{border-color:var(--input-focus)!important;box-shadow:0 0 0 2px #4a9eff1a!important}.dark-theme .ant-select-selector,.dark-theme .ant-picker,.dark-theme .ant-picker-input>input{color:var(--text-primary)!important;background-color:var(--input-bg)!important;border-color:var(--input-border)!important}.dark-theme .ant-select-selection-placeholder,.dark-theme .ant-picker-input input::placeholder{color:var(--text-muted)!important}.dark-theme .ant-select-dropdown,.dark-theme .ant-picker-dropdown{background-color:var(--card-bg)!important}.dark-theme .ant-select-item,.dark-theme .ant-picker-cell{color:var(--text-primary)!important}.dark-theme .ant-select-item-option-active,.dark-theme .ant-picker-cell:hover{background-color:var(--bg-tertiary)!important}.dark-theme .ant-checkbox-inner,.dark-theme .ant-radio-inner{background-color:var(--input-bg)!important;border-color:var(--input-border)!important}.dark-theme .ant-form-item-label>label{color:var(--text-primary)!important}.dark-theme .ant-card{background-color:var(--card-bg)!important;border-color:var(--border-primary)!important}.dark-theme .ant-card-head{color:var(--text-primary);border-color:var(--border-primary)}.dark-theme .ant-table,.dark-theme .ant-table-thead>tr>th,.dark-theme .ant-table-tbody>tr>td,.dark-theme .ant-table-placeholder{background-color:var(--card-bg)!important;color:var(--text-primary)!important;border-color:var(--border-primary)!important}.dark-theme .ant-table-tbody>tr:hover>td{background-color:var(--table-row-hover)!important}.dark-theme .ant-modal-content,.dark-theme .ant-drawer-content,.dark-theme .ant-drawer-header{background-color:var(--card-bg)!important;color:var(--text-primary);border-color:var(--border-primary)}.dark-theme .ant-drawer-title,.dark-theme .ant-modal-title{color:var(--text-primary)!important}.dark-theme .ant-menu,.dark-theme .ant-menu-sub{background:transparent!important;color:var(--text-primary)!important}.dark-theme .ant-menu-item,.dark-theme .ant-menu-submenu-title{color:var(--text-secondary)!important}.dark-theme .ant-menu-item-selected,.dark-theme .ant-menu-item:hover,.dark-theme .ant-menu-submenu-title:hover{color:var(--accent-primary)!important}.dark-theme .ant-breadcrumb a,.dark-theme .ant-breadcrumb span{color:var(--text-secondary)!important}.dark-theme .ant-breadcrumb a:hover{color:var(--accent-primary)!important}.dark-theme .ant-divider{border-color:var(--border-primary)!important}.dark-theme .ant-typography{color:var(--text-primary)}.dark-theme .ant-alert-message,.dark-theme .ant-alert-description{color:inherit}.dark-theme .ant-collapse,.dark-theme .ant-collapse-item,.dark-theme .ant-collapse-header{background-color:var(--card-bg)!important;border-color:var(--border-primary)!important;color:var(--text-primary)!important}.dark-theme .ant-collapse-content{background-color:var(--bg-secondary)!important;border-color:var(--border-primary)!important}.dark-theme .ant-popover-inner,.dark-theme .ant-tooltip-inner,.dark-theme .ant-dropdown{background-color:var(--card-bg)!important;color:var(--text-primary)}.dark-theme .ant-popconfirm-buttons .ant-btn-default{background-color:var(--input-bg)!important;border-color:var(--input-border)!important;color:var(--text-primary)!important}.dark-theme .admin-force-light{--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;--card-bg: #ffffff;--input-bg: #ffffff;--input-border: #e0e0e0;--input-focus: #1e90ff;--shadow-light: rgba(0, 0, 0, .1);--shadow-medium: rgba(0, 0, 0, .15);--shadow-heavy: rgba(0, 0, 0, .2);--admin-shadow-light: rgba(0, 0, 0, .04);--admin-shadow-medium: rgba(0, 0, 0, .08);--admin-shadow-heavy: rgba(0, 0, 0, .1);--admin-accent-shadow: rgba(30, 144, 255, .2);--admin-accent-shadow-hover: rgba(30, 144, 255, .3);--admin-accent-glow: rgba(30, 144, 255, .1);--admin-success-glow: rgba(16, 185, 129, .1);--admin-warning-glow: rgba(255, 193, 7, .1);--admin-danger-glow: rgba(220, 53, 69, .1);--admin-purple-glow: rgba(139, 92, 246, .1);--admin-topbar-bg: rgba(255, 255, 255, .95);--table-row-hover: #e3f2fd}.releases-section{margin:2rem 0}.section-heading{margin-top:2rem;margin-bottom:1rem;color:var(--text-primary)}.release-item,.release-highlight{background:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:2rem;transition:box-shadow .2s ease}.release-highlight{background:var(--highlight-background, rgba(30, 144, 255, .05));border-color:var(--highlight-border, #1e90ff);box-shadow:0 2px 8px #1e90ff1a}.release-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.release-date{font-size:.9rem;color:var(--text-secondary);font-weight:500}.release-type{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.release-type-feature{background:#4CAF50;color:#fff}.release-type-improvement{background:#2196F3;color:#fff}.release-type-bugfix{background:#FF9800;color:#fff}.release-item h2,.release-highlight h2{margin-top:0;margin-bottom:1rem;color:var(--text-primary)}.release-content{margin-bottom:1.5rem;line-height:1.6;color:var(--text-primary)}.release-features,.release-benefits{margin:1.5rem 0}.release-features h3,.release-benefits h3{margin-bottom:.75rem;color:var(--text-primary);font-size:1.1rem}.release-features ul,.release-benefits ul{margin-left:1.5rem;line-height:1.8}.release-features li,.release-benefits li{margin-bottom:.5rem;color:var(--text-primary)}.release-cta{margin-top:1.5rem;font-size:1.1rem}.last-updated{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color);text-align:center;color:var(--text-secondary)}@media (max-width: 768px){.release-header{flex-direction:column;align-items:flex-start}.release-item,.release-highlight{padding:1rem}}.stop-block{margin:2rem 0;height:0;width:100%;border:none;background:none}.stop-block-line{border-top:1px solid var(--border-primary, #e0e0e0);height:0}.stop-block-dashed{border-top:1px dashed var(--border-primary, #e0e0e0);height:0}.stop-block-dotted{border-top:1px dotted var(--border-primary, #e0e0e0);height:0}.stop-block-double{border-top:3px double var(--border-primary, #e0e0e0);height:0}.feature-list{background:var(--feature-list-bg);padding:24px;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;color:var(--text-secondary)}.feature-list li strong{color:var(--text-primary)}.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:24px;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}.feature-card p{color:var(--text-secondary);margin:0;line-height:1.6}.article-page-wrapper{max-width:900px;margin:0 auto;padding:0 16px}.article-page-wrapper .breadcrumbs{margin-bottom:32px;padding:0}.article-meta{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.article-type{display:inline-block;padding:6px 14px;background:var(--accent-primary);background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#fff;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;box-shadow:0 2px 4px #1e90ff33}.article-date{color:var(--text-secondary);font-size:14px;font-weight:400}.article-title{font-size:42px;font-weight:700;line-height:1.2;margin:24px 0 20px;color:var(--text-primary);letter-spacing:-.5px}.article-excerpt{font-size:20px;line-height:1.7;color:var(--text-secondary);margin:0;font-style:italic;font-weight:400;padding:16px 0}.article-content{font-size:18px;line-height:1.85;color:var(--text-primary);margin-bottom:64px;word-wrap:break-word;overflow-wrap:break-word}.article-content h1,.article-content h2,.article-content h3,.article-content h4,.article-content h5,.article-content h6{margin-bottom:20px;font-weight:600;line-height:1.3;color:var(--text-primary);letter-spacing:-.3px}.article-content h1{font-size:36px;margin-top:56px}.article-content h2{color:var(--text-primary);margin-top:40px;margin-bottom:20px;font-size:1.5em;font-weight:600}.article-content h3{font-size:24px}.article-content h4{font-size:20px}.article-content h5{font-size:18px}.article-content h6{font-size:16px}.article-content p{color:var(--text-secondary);margin-bottom:20px;line-height:1.7;font-size:1.05em}.article-content ul,.article-content ol{color:var(--text-secondary);margin-bottom:24px;padding-left:24px}.article-content li{margin-bottom:12px;line-height:1.6}.article-content a{color:var(--accent-primary);text-decoration:none;border-bottom:2px solid transparent;transition:all .2s ease;font-weight:500}.article-content a:hover{color:var(--accent-secondary);border-bottom-color:var(--accent-secondary)}.article-content img{max-width:100%;height:auto;border-radius:12px;margin:32px 0;box-shadow:0 4px 16px var(--shadow-light);display:block}.article-content blockquote{margin:32px 0;padding:20px 28px;border-left:4px solid var(--accent-primary);background:var(--bg-secondary);border-radius:8px;font-style:italic;color:var(--text-secondary);box-shadow:0 2px 8px var(--shadow-light)}.article-content code{background:var(--bg-secondary);padding:3px 8px;border-radius:4px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:15px;color:var(--accent-danger);font-weight:500}.article-content pre{background:var(--bg-secondary);padding:20px;border-radius:8px;overflow-x:auto;margin:32px 0;box-shadow:0 2px 8px var(--shadow-light);border:1px solid var(--border-primary)}.article-content pre code{background:none;padding:0;color:#262626}.article-content table:not(.table){width:100%;border-collapse:collapse;margin:24px 0}.article-content table:not(.table) th,.article-content table:not(.table) td{padding:14px 16px;border:1px solid var(--border-primary);text-align:left}.article-content table:not(.table) th{background:var(--bg-secondary);font-weight:600;color:var(--text-primary)}.article-content hr{border:none;border-top:2px solid var(--border-primary);margin:40px 0}.block-renderer{margin:0}.block-renderer>*{margin-bottom:24px}.block-renderer>*:last-child{margin-bottom:0}.article-content .highlight{background-color:var(--highlight-bg);padding:24px;border-left:4px solid var(--highlight-border);margin:24px 0;border-radius:0 8px 8px 0;box-shadow:0 2px 8px #4a9eff1a}.article-content .highlight h2,.article-content .highlight h3,.article-content .highlight h4,.article-content .highlight h5,.article-content .highlight h6{padding-top:0;margin-top:0;margin-bottom:1rem;color:var(--text-primary)}.article-content .highlight p{margin-bottom:1rem;line-height:1.6;color:var(--text-secondary)}.article-content .highlight p:last-child{margin-bottom:0}.article-content .highlight ol{padding-left:24px}.article-content .table-block{margin:2rem 0}.article-content .table-block .table-container{margin:32px 0!important;overflow-x:auto!important;overflow-y:visible!important;border-radius:8px!important;box-shadow:0 4px 12px var(--shadow-medium)!important}.article-content .table-block .table{width:100%!important;min-width:600px!important;border-collapse:collapse!important;border-radius:8px!important;overflow:visible!important;margin:0!important}.article-content .table-block .table th,.article-content .table-block .table td{padding:16px!important;text-align:left!important;border-bottom:1px solid var(--border-primary)!important;border:none!important}.article-content .table-block .table th{background-color:var(--table-header-bg)!important;color:var(--table-header-text)!important;font-weight:600!important;font-size:12px!important;text-transform:uppercase!important;letter-spacing:.5px!important;overflow:visible!important;position:relative!important;z-index:1!important}.article-content .table-block .table tr:nth-child(2n){background-color:var(--table-row-even)!important}.article-content .table-block .table tr:hover{background-color:var(--table-row-hover)!important;transition:background-color .2s ease!important}.article-content .table-block .table tr:last-child td{border-bottom:none!important}.article-content .table-block .table-cell-rank,.article-content .table-block td.table-cell-rank{font-weight:700!important;color:#1e90ff!important;width:60px!important;font-size:1.1em!important}.article-content .table-block .table-cell-primary,.article-content .table-block td.table-cell-primary{font-weight:700!important;color:#333!important;font-size:1.05em!important}.article-content .table-block .table-cell-secondary,.article-content .table-block td.table-cell-secondary{color:#666!important;font-size:.95em!important;font-weight:500!important}@media (max-width: 768px){.article-content .table-block .table{margin:24px 0!important;font-size:14px!important}.article-content .table-block .table th,.article-content .table-block .table td{padding:12px 8px!important}}.article-content .stop-block{margin:32px 0;height:0;width:100%;border:none;background:none}.article-content .stop-block-line{border-top:1px solid var(--border-primary);height:0}.article-content .stop-block-dashed{border-top:1px dashed var(--border-primary);height:0}.article-content .stop-block-dotted{border-top:1px dotted var(--border-primary);height:0}.article-content .stop-block-double{border-top:3px double var(--border-primary);height:0}.article-footer{margin-top:64px;padding-top:32px;border-top:2px solid var(--border-primary)}.article-updated{color:var(--text-secondary);font-size:14px;margin:0;font-style:italic}.error-page{text-align:center;padding:64px 0}.error-page h1{font-size:2.5em;font-weight:700;line-height:1.2;margin:0 0 24px;color:var(--text-primary)}.error-description{font-size:1.05em;line-height:1.7;color:var(--text-secondary);max-width:600px;margin:0 auto 48px}.error-action{margin:0}.error-link{color:var(--accent-primary);font-weight:600;text-decoration:none;font-size:1.05em;transition:color .2s ease;border-bottom:2px solid transparent;padding-bottom:2px}.error-link:hover{color:var(--accent-secondary);border-bottom-color:var(--accent-secondary)}@media (max-width: 768px){.article-page-wrapper{padding:0 12px}.article-header{margin-bottom:32px;padding-bottom:24px}.article-title{font-size:32px;margin:20px 0 16px}.article-excerpt{font-size:18px;padding:12px 0}.article-content{font-size:16px;margin-bottom:48px}.article-content h1{font-size:26px}.article-content h2{font-size:22px}.article-content h3{font-size:20px}.article-content h1{font-size:28px;margin-top:40px}.article-content h2{font-size:24px}.article-content p{margin-bottom:20px}.article-content img{margin:24px 0;border-radius:8px}.article-content blockquote{margin:24px 0;padding:16px 20px}.article-footer{margin-top:48px;padding-top:24px}.article-meta{flex-direction:column;align-items:flex-start;gap:8px}.error-page{padding:48px 0}.error-page h1{font-size:2em}.error-description{font-size:1em;margin-bottom:32px}}@media (prefers-color-scheme: dark){.article-header{border-bottom-color:var(--border-primary)}.article-title{color:var(--text-primary)}.article-excerpt{color:var(--text-secondary)}.article-content,.article-content h1,.article-content h2,.article-content h3,.article-content h4,.article-content h5,.article-content h6{color:var(--text-primary)}.article-content h2{color:var(--accent-primary)}.article-content blockquote{background:var(--bg-secondary);border-left-color:var(--accent-primary);color:var(--text-secondary)}.article-content code{background:var(--bg-secondary);color:var(--accent-danger)}.article-content pre{background:var(--bg-secondary);border-color:var(--border-primary)}.article-content pre code{color:var(--text-primary)}.article-content table:not(.table) th,.article-content table:not(.table) td{border-color:var(--border-primary)}.article-content table:not(.table) th{background:var(--bg-secondary)}.article-content .table-block .table th{background-color:var(--table-header-bg)!important}.article-content .table-block .table th,.article-content .table-block .table td{border-color:var(--border-primary)!important}.article-content hr{border-top-color:var(--border-primary)}.article-content .highlight{padding:1rem}.article-footer{border-top-color:var(--border-primary)}.error-page h1{color:var(--text-primary)}.error-description{color:var(--text-secondary)}.error-link{color:var(--accent-primary)}.error-link:hover{color:var(--accent-secondary);border-bottom-color:var(--accent-secondary)}}.articles-page{max-width:900px;margin:0 auto;padding:0 16px}.articles-header{margin-bottom:40px}.articles-header h1{font-size:36px;font-weight:700;line-height:1.2;margin:0;color:var(--text-primary);letter-spacing:-.3px}.articles-filters{margin-bottom:32px;display:flex;flex-direction:column;gap:16px}.search-container{position:relative;width:100%}.search-input{width:100%;padding:12px 40px 12px 16px;font-size:15px;border:1px solid var(--border-primary);border-radius:6px;background:var(--card-bg);color:var(--text-primary);outline:none}.search-input:focus{border-color:var(--accent-primary)}.search-input:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.search-input::placeholder{color:var(--text-secondary);opacity:.6}.search-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.filter-buttons{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.filter-btn{padding:8px 16px;font-size:13px;font-weight:500;border:1px solid var(--border-primary);border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;outline:none}.filter-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.filter-btn:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--text-inverse)}.filter-btn.active:hover{background:var(--accent-secondary);border-color:var(--accent-secondary)}.filter-btn.active:focus-visible{outline:2px solid var(--text-inverse);outline-offset:2px}.results-count{margin-bottom:24px;font-size:13px;color:var(--text-secondary)}.articles-list{display:flex;flex-direction:column;gap:24px;margin-bottom:48px}.article-card{border:1px solid var(--border-primary);border-radius:8px;background:var(--card-bg);position:relative;overflow:hidden}.article-card-link{display:block;padding:32px;text-decoration:none;color:inherit;outline:none}.article-card-link:focus-visible{outline:2px solid var(--accent-primary);outline-offset:-2px;border-radius:4px}.article-card-content{display:flex;flex-direction:column;gap:12px}.article-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.article-card-date{font-size:14px;color:var(--text-secondary);font-weight:400}.article-card-separator{color:var(--text-secondary);opacity:.5;font-size:14px}.article-card-type{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.article-card-title{font-size:28px;font-weight:600;line-height:1.3;margin:0;color:var(--text-primary);letter-spacing:-.2px}.article-card-link:hover .article-card-title{color:var(--accent-primary)}.article-card-excerpt{font-size:16px;line-height:1.7;color:var(--text-secondary);margin:0;max-width:100%}.article-card-footer{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-primary)}.article-card-read-more{display:inline-flex;align-items:center;font-size:14px;font-weight:600;color:var(--accent-primary);text-decoration:none}.articles-loading{display:flex;justify-content:center;align-items:center;min-height:400px;padding:64px 0}.articles-empty{text-align:center;padding:80px 20px;max-width:500px;margin:0 auto}.empty-icon{color:var(--text-secondary);opacity:.5;margin-bottom:24px}.articles-empty h2{font-size:24px;font-weight:600;margin:0 0 12px;color:var(--text-primary)}.articles-empty p{font-size:16px;line-height:1.6;color:var(--text-secondary);margin:0 0 24px}.clear-filters-btn{padding:12px 24px;font-size:14px;font-weight:600;border:2px solid var(--accent-primary);border-radius:8px;background:var(--accent-primary);color:var(--text-inverse);cursor:pointer;outline:none}.clear-filters-btn:hover{background:var(--accent-secondary);border-color:var(--accent-secondary)}.clear-filters-btn:focus-visible{outline:2px solid var(--text-inverse);outline-offset:2px}@media (max-width: 768px){.articles-page{padding:0 12px}.articles-header{margin-bottom:32px}.articles-header h1{font-size:28px}.articles-filters{margin-bottom:24px}.filter-buttons{gap:6px}.filter-btn{padding:6px 12px;font-size:12px}.article-card-link{padding:24px}.articles-list{gap:16px}.article-card-title{font-size:22px}.article-card-excerpt{font-size:15px;line-height:1.6}.articles-empty{padding:60px 20px}.articles-empty h2{font-size:20px}}@media (max-width: 480px){.articles-header h1{font-size:24px}.filter-buttons{flex-direction:column;align-items:stretch}.filter-btn{width:100%;text-align:center}.article-card-meta{flex-direction:column;align-items:flex-start;gap:4px}.article-card-separator{display:none}.article-card-title{font-size:20px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media (prefers-color-scheme: dark){.search-input{background:var(--card-bg);border-color:var(--border-primary)}.search-input:focus{border-color:var(--accent-primary)}.filter-btn,.article-card{background:var(--card-bg);border-color:var(--border-primary)}}html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Roboto,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-secondary);color:var(--text-primary)}.pt-8{padding-top:8px!important}.p-0{padding:0!important}.pt-0{padding-top:0!important}.pb-0{padding-bottom:0!important}.pl-8{padding-left:8px!important}.pr-8{padding-right:8px!important}#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}
