:root{--primary-color: #2563eb;--primary-dark: #1d4ed8;--shadow-soft: 0 4px 12px rgba(0, 0, 0, .1);--bg-glass: rgba(255, 255, 255, .95)}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden}#map{width:100%;height:100dvh;position:absolute;top:0;left:0;z-index:1}#header-box{position:absolute;top:15px;left:15px;z-index:1000;background:var(--bg-glass);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:12px 20px;border-radius:12px;box-shadow:var(--shadow-soft);display:flex;align-items:center;gap:12px;cursor:pointer;transition:transform .2s}#header-box:hover{transform:translateY(-2px)}.logo-img{height:40px;width:auto;-o-object-fit:contain;object-fit:contain;margin-right:10px}.app-title{font-weight:700;font-size:1.1rem;color:#333;line-height:1.2}.app-subtitle{font-size:.75rem;color:#666;font-weight:500;display:block}.dropdown-arrow{font-size:.8rem;color:#999;margin-left:5px;transition:transform .3s}.dropdown-arrow.open{transform:rotate(180deg)}#menu-dropdown{position:absolute;top:90px;left:15px;z-index:1001;background:#fff;border-radius:10px;padding:8px 0;box-shadow:0 8px 24px #00000026;min-width:220px;display:none;transform-origin:top left;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.menu-item{display:flex;align-items:center;padding:12px 20px;text-decoration:none;color:#444;font-size:.95rem;transition:background .2s}.menu-item:hover{background:#f8f9fa;color:var(--primary-color)}.menu-item i{width:24px;text-align:center;margin-right:10px}#coord-box{position:absolute;bottom:25px;right:15px;z-index:1000;background:#ffffffd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.5);padding:8px 16px;border-radius:50px;box-shadow:0 4px 15px #00000014;display:flex;align-items:center;gap:12px;transition:transform .2s ease}#coord-box:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f}.coord-item{display:flex;align-items:center;gap:6px}.coord-icon{color:var(--primary-color);font-size:.8rem;margin-right:2px}.coord-label{font-size:.65rem;font-weight:700;color:#8898aa;letter-spacing:.5px;margin-top:1px}.coord-num{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:.85rem;font-weight:600;color:#333;min-width:65px;font-variant-numeric:tabular-nums}.coord-divider{width:1px;height:16px;background-color:#ddd}#search-wrapper{position:absolute;top:15px;left:255px;z-index:1000;width:30vw;transition:all .3s}.leaflet-control-search{border:none!important;background:transparent!important;box-shadow:none!important;margin:0!important;width:100%}.leaflet-control-search .search-input{display:none;width:100%!important;max-width:100%!important;padding:5px 20px 5px 40px!important;margin:0!important;border:none!important;border-radius:8px!important;background:var(--bg-glass)!important;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);font-size:.95rem!important;color:#333;box-shadow:var(--shadow-soft)!important;outline:none;height:auto!important;float:none!important}.leaflet-control-search .search-input:focus{box-shadow:0 6px 16px #00000026!important}.leaflet-control-search .search-cancel{position:absolute;right:15px;top:50%;transform:translateY(-50%);margin:0!important;display:none;color:#999;text-decoration:none;font-size:18px;background:none!important}.leaflet-control-search .search-cancel:after{content:"×";font-weight:700;display:none}.leaflet-control-search .search-button{display:none!important}#search-wrapper:before{content:"";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#999;z-index:1002;pointer-events:none;font-size:1rem}.leaflet-control-search .search-tooltip{position:absolute;top:100%!important;left:0!important;margin-top:10px!important;background:#fff!important;border-radius:12px!important;box-shadow:0 4px 20px #00000026!important;border:none!important;width:100%!important;max-height:300px;overflow-y:auto;z-index:1001;padding:5px 0}.leaflet-control-search .search-tip{margin:0!important;padding:10px 20px!important;border-radius:0!important;border-bottom:1px solid #f0f0f0;color:#444;font-size:.9rem;cursor:pointer;background:#fff}.leaflet-control-search .search-tip-select,.leaflet-control-search .search-tip:hover{background-color:#f8f9fa!important;color:var(--primary-color)}.leaflet-control-search .search-alert{display:none!important}.leaflet-left{left:5px}.leaflet-control-container .leaflet-top{top:0}.leaflet-bar a{width:36px!important;height:36px!important;line-height:36px!important;background:#fff;color:#444;border-bottom:1px solid #f0f0f0;transition:.2s}.leaflet-bar a:hover{background:#f8f9fa;color:var(--primary-color)}.leaflet-bar a:last-child{border-bottom:none}.leaflet-top.leaflet-left{top:85px!important}.leaflet-bar{border:none!important;box-shadow:var(--shadow-soft)!important;border-radius:8px!important;overflow:hidden}.custom-btn{background:#fff;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-soft);margin-bottom:10px;color:#555;transition:.2s}.custom-btn:hover{color:var(--primary-color);background:#fff}.leaflet-top.leaflet-right{display:flex;flex-direction:column;align-items:flex-end;gap:15px;padding-top:15px;padding-right:15px;pointer-events:none;height:100dvh;max-height:100dvh}.leaflet-top.leaflet-right .leaflet-control{pointer-events:auto;margin:0!important}.leaflet-panel-layers{background:var(--bg-glass)!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;border:1px solid rgba(255,255,255,.6)!important;border-radius:12px!important;box-shadow:0 10px 30px #00000026!important;padding:15px 10px 15px 15px!important;width:385px!important;min-width:385px!important;max-width:385px!important;box-sizing:border-box!important;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s!important;transform:translate(120%);opacity:0;overflow:hidden!important}.panel-slide-in{transform:translate(0)!important;opacity:1!important}.leaflet-panel-layers-list{max-height:80dvh!important;overflow-y:auto!important;overflow-x:hidden!important;padding-right:5px}.leaflet-panel-layers-group{font-weight:700!important;text-transform:uppercase!important;font-size:11px!important;letter-spacing:.5px;color:#444!important;background-color:#00000008!important;padding:10px 12px!important;margin-bottom:8px!important;border-radius:8px;border:1px solid rgba(0,0,0,.05)!important}.leaflet-panel-layers-item{background:#fff;padding:8px 12px!important;margin-bottom:6px;border-radius:8px;border:1px solid #eee;transition:all .2s;box-sizing:border-box!important;width:100%!important}.leaflet-panel-layers-item:hover{background-color:#f8f9fa;border-color:#ddd}.leaflet-panel-layers-item label{display:flex!important;align-items:flex-start!important;width:100%!important;gap:8px}.leaflet-panel-layers-item input[type=checkbox]{margin-top:4px!important;flex-shrink:0!important}.leaflet-panel-layers-item span{white-space:normal!important;word-wrap:break-word!important;overflow-wrap:break-word!important;line-height:1.4!important;flex-grow:1}.leaflet-panel-layers-item-inject{display:flex;align-items:center;gap:10px;margin-top:6px;padding-top:6px;border-top:1px dashed #eee;width:100%!important;box-sizing:border-box!important}.custom-toggle-switch{position:relative;display:inline-block;width:34px;height:18px;flex-shrink:0!important;margin:0;cursor:pointer}.custom-toggle-switch input{opacity:0;width:0;height:0}.custom-toggle-slider{position:absolute;inset:0;background-color:#cbd5e1;transition:.3s;border-radius:18px}.custom-toggle-slider:before{position:absolute;content:"";height:14px;width:14px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%}.custom-toggle-switch input:checked+.custom-toggle-slider{background-color:#2563eb}.custom-toggle-switch input:checked+.custom-toggle-slider:before{transform:translate(16px)}.leaflet-panel-layers-item-inject span{font-size:10px!important;font-weight:600;color:#64748b;cursor:pointer;white-space:nowrap!important;flex-grow:1}.panel-layer-search{padding:12px 10px 8px;background:transparent;border-top:1px dashed rgba(0,0,0,.1);margin-top:5px;position:sticky;top:0;z-index:10}.panel-layer-search input{width:100%;padding:8px 12px 8px 32px;border:1px solid #d1d5db;border-radius:8px;font-size:11.5px;font-family:inherit;color:#333;outline:none;transition:all .2s ease;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512' width='13' height='13' fill='%239ca3af'%3E%3Cpath d='M416 208c0 45.9-14.9 88.3-40 122.7L502.6 457.4c12.5 12.5 12.5 32.8 0 45.3s-32.8 12.5-45.3 0L330.7 376c-34.4 25.2-76.8 40-122.7 40C93.1 416 0 322.9 0 208S93.1 0 208 0S416 93.1 416 208zM208 352a144 144 0 1 0 0-288 144 144 0 1 0 0 288z'/%3E%3C/svg%3E") no-repeat 10px center}.panel-layer-search input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb26}.leaflet-popup-content{margin:0!important;padding:0!important;width:auto!important}.professional-popup .leaflet-popup-content-wrapper{background:#fff;border-radius:8px;padding:0;overflow:hidden;box-shadow:0 3px 14px #0006}.professional-popup .leaflet-popup-close-button{color:#fff!important;top:12px!important;right:12px!important;font-size:18px!important;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:all .2s}.professional-popup .leaflet-popup-close-button:hover{color:#f0f0f0!important}.professional-popup .leaflet-popup-tip{background:#fff}.polygon-label{background:transparent;border:none;padding:2px 8px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;pointer-events:none;text-shadow:-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,1px 1px 0 #000}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{display:none!important}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#64748bcc}.scrollable-area{max-height:65dvh;overflow-y:auto;overflow-x:hidden;padding-right:4px}.btn-walkthrough{position:absolute;bottom:25px;left:15px;z-index:1000;background:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:50px;display:flex;align-items:center;justify-content:center;gap:10px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2563eb66}.btn-walkthrough:hover{transform:translateY(-3px);box-shadow:0 8px 25px #2563eb99!important;background-color:var(--primary-dark);color:#fff}.walkthrough-pulse{position:absolute;top:50%;left:18px;transform:translateY(-50%);width:12px;height:12px;background:#fff;border-radius:50%;animation:pulseWalkthrough 2s infinite}@keyframes pulseWalkthrough{0%{box-shadow:0 0 #ffffffb3}70%{box-shadow:0 0 0 10px #fff0}to{box-shadow:0 0 #fff0}}.btn-walkthrough i{margin-left:20px;font-size:1.1rem}@media(max-width:768px){#search-wrapper{left:15px;top:90px;width:40vw}.leaflet-control-container .leaflet-top.leaflet-left{top:150px}#header-box{width:auto;max-width:80%}#coord-box{bottom:10px;left:auto;right:15px;transform:none;width:-moz-max-content;width:max-content;padding:6px 12px;background:#ffffffe6}.coord-label{display:none}.leaflet-top.leaflet-right{top:89px;right:10px;width:100vw;padding-top:0;padding-right:0}.leaflet-top.leaflet-right .leaflet-panel-layers{width:84vw!important;min-width:84vw!important;max-width:84vw!important}.leaflet-top.leaflet-left{top:128px!important}.leaflet-panel-layers-list{height:60dvh!important}.btn-walkthrough{bottom:15px;left:15px;width:45px;height:45px;padding:0;border-radius:50%}.walkthrough-text{display:none}.walkthrough-pulse{left:16px}.btn-walkthrough i{margin-left:0;font-size:1.1rem}}.label-toggle-wrapper{display:flex;align-items:center;gap:10px;margin-top:8px;padding:6px 10px;background:#f1f5f9;border-radius:8px;border:1px solid #e2e8f0}.btn-label-toggle{width:26px;height:26px;background:#e2e8f0;color:#94a3b8;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease-in-out;font-size:11px}.btn-label-toggle:hover{background:#cbd5e1;color:#475569}.btn-label-toggle.active{background:#3b82f6;color:#fff;box-shadow:0 2px 4px #3b82f64d}.label-toggle-text{font-size:10px;font-weight:600;color:#64748b;letter-spacing:.3px;cursor:pointer}.d-none{display:none}#info-panel{position:absolute;top:60px;right:15px;z-index:1001;background:var(--bg-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.6);border-radius:12px;box-shadow:0 10px 30px #00000026;width:385px;min-width:385px;max-width:385px;max-height:85dvh;display:none;flex-direction:column;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s;transform:translate(120%);opacity:0;overflow:hidden}#info-panel.panel-slide-in{transform:translate(0);opacity:1}.info-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#00000008;border-bottom:1px solid #eee}.info-panel-title{font-weight:700;font-size:13px;color:#444;text-transform:uppercase;letter-spacing:.5px}.btn-close-info{background:#fff;border:1px solid #ddd;border-radius:50%;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s;box-shadow:0 2px 4px #0000000d}.btn-close-info:hover{background:#ef4444;color:#fff;border-color:#ef4444}.info-panel-content{overflow-y:auto;overflow-x:hidden;flex-grow:1}.info-panel-content>div{max-width:100%!important;min-width:100%!important}@media(max-width:768px){#info-panel{top:135px;right:10px;width:84vw!important;min-width:84vw!important;max-width:84vw!important;max-height:70dvh}}.panel-pagination-container{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:4px;padding-top:10px;margin-top:5px;border-top:1px dashed rgba(0,0,0,.1);position:sticky;bottom:0;background:#fff;z-index:10}.btn-panel-page{background:#f1f5f9;border:1px solid #cbd5e1;color:#475569;border-radius:4px;min-width:26px;height:26px;font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-panel-page:hover:not(.disabled){background:#e2e8f0;border-color:#94a3b8}.btn-panel-page.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-panel-page.disabled{opacity:.4;cursor:not-allowed}.leaflet-panel-layers-item.hidden-by-pagination{display:none!important}
