.maplibregl-ctrl-layer-control{background:#fff;border-radius:4px;box-shadow:0 0 0 2px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.maplibregl-ctrl-layer-control button{background:none;border:none;padding:0;width:29px;height:29px;display:flex;align-items:center;justify-content:center;cursor:pointer;outline:none;color:#1f2a37}.maplibregl-ctrl-layer-control button:hover{background-color:#0000000d}.maplibregl-ctrl-layer-control .layer-control-icon{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;line-height:0}.maplibregl-ctrl-layer-control .layer-control-icon svg{width:22px;height:22px;display:block;stroke:currentColor;fill:none}.layer-control-panel{position:absolute;top:100%;margin-top:5px;background:#fff;border-radius:4px;box-shadow:0 0 0 2px #0000001a;min-width:240px;max-width:420px;max-height:600px;overflow-y:auto;z-index:1000;padding:8px;font-size:12px;line-height:1.4;display:none}.maplibregl-ctrl-top-left .layer-control-panel,.maplibregl-ctrl-bottom-left .layer-control-panel{left:0}.maplibregl-ctrl-top-right .layer-control-panel,.maplibregl-ctrl-bottom-right .layer-control-panel{right:0}.layer-control-panel.expanded{display:block}.layer-control-panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:600;color:#333;padding:4px 0 8px;border-bottom:1px solid #e0e0e0;margin-bottom:8px}.layer-control-panel-title{flex:1 1 auto;font-size:13px}.layer-control-width-control{display:flex;align-items:center;gap:6px;font-weight:500;font-size:11px;color:#5c6a7d;flex-shrink:0;margin-left:auto}.layer-control-width-slider{position:relative;width:130px;height:16px;border-radius:8px;cursor:ew-resize;display:flex;align-items:center;justify-content:center;touch-action:none;background:transparent;padding:0 8px;box-sizing:border-box}.layer-control-width-value{min-width:44px;text-align:right;font-feature-settings:"tnum";color:#3a4756}.layer-control-width-track{position:absolute;left:8px;right:8px;height:4px;border-radius:2px;background:linear-gradient(90deg,#d0d7e2,#2f6fed);pointer-events:none}.layer-control-width-thumb{position:absolute;top:50%;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid #2f6fed;transform:translateY(-50%);box-shadow:0 1px 2px #00000040;pointer-events:none}.layer-control-actions{display:flex;gap:8px;padding-bottom:6px;border-bottom:1px solid #e0e0e0;margin-bottom:4px}.layer-control-action-btn{flex:1;padding:3px 8px;font-size:11px;font-weight:600;color:#fff!important;background:#2f6fed!important;border:1px solid #2f6fed!important;border-radius:4px;cursor:pointer;transition:all .15s ease;width:auto;height:auto}.layer-control-action-btn:hover{background:#1d5bd6!important;border-color:#1d5bd6!important;color:#fff!important}.layer-control-action-btn:active{background:#1a4fc2!important;border-color:#1a4fc2!important}.layer-control-item{display:flex;flex-direction:column;gap:6px;padding:4px 0;border-bottom:1px solid #f0f0f0;box-sizing:border-box}.layer-control-item:last-child{border-bottom:none}.layer-control-row{display:flex;align-items:center;gap:8px;width:100%;box-sizing:border-box;min-height:20px}.layer-control-checkbox{margin:0;cursor:pointer}.layer-control-name{margin:0;flex:1 1 auto;min-width:120px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-control-symbol{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}.layer-control-symbol svg{width:16px;height:16px;display:block}.layer-control-opacity{flex:0 0 140px;height:16px;margin:0;cursor:pointer;background:linear-gradient(to right,#ddd,#333);border-radius:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;width:auto}.layer-control-opacity::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#fff;border:2px solid #333;border-radius:50%;cursor:pointer}.layer-control-opacity::-moz-range-thumb{width:16px;height:16px;background:#fff;border:2px solid #333;border-radius:50%;cursor:pointer}.layer-control-style-button{width:20px;height:20px;border-radius:4px;border:none;background:none;cursor:pointer;font-size:16px;color:#444;display:flex;align-items:center;justify-content:center;transition:background-color .1s ease;flex-shrink:0}.layer-control-style-button:hover{background-color:#00000012}.layer-control-style-button[disabled]{cursor:not-allowed;opacity:.45}.layer-control-style-editor{display:none;width:100%;background:#f7f9fc;border:1px solid #dfe3eb;border-radius:6px;padding:10px;margin-top:6px;box-shadow:inset 0 0 0 1px #fff9;align-self:stretch;box-sizing:border-box}.layer-control-style-editor.expanded{display:block}.layer-control-style-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:12px;margin-bottom:8px;color:#2f3c4a}.layer-control-style-close,.layer-control-style-close-secondary{border:none;background:none;cursor:pointer;color:#556372;font-size:14px}.layer-control-style-controls{display:flex;flex-direction:column;gap:8px}.layer-style-control{display:flex;flex-direction:column;gap:4px;font-size:11px}.layer-style-control label{font-weight:500;color:#3a4756}.layer-style-color-group{display:flex;align-items:center;gap:6px}.layer-style-color{width:36px;height:20px;padding:0;border:none;cursor:pointer}.layer-style-color-text{flex:1;height:22px;border:1px solid #d0d7e2;border-radius:4px;padding:2px 6px;font-family:monospace;font-size:11px;background-color:#fff}.layer-style-slider-wrapper{display:flex;align-items:center;gap:6px}.layer-style-slider{flex:1;cursor:pointer}.layer-style-value{min-width:38px;text-align:right;font-family:monospace;color:#3a4756}.layer-control-style-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:10px}.layer-control-style-action{border:none;padding:5px 12px;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500}.layer-control-style-apply{background-color:#2f6fed;color:#fff}.layer-control-style-apply:hover{background-color:#2557b8}.layer-control-style-reset{background-color:#e4e8f1;color:#2f3c4a;border:1px solid #c6cedd}.layer-control-style-reset:hover{background-color:#d7deed}.layer-control-style-close-secondary{background-color:#f7f9fc;color:#2f3c4a;border:1px solid #d7deed}.layer-control-style-close-secondary:hover{background-color:#e9edf7}.layer-control-style-empty{margin:0;font-size:11px;color:#5c6a7d}.style-control-group{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.style-control-group:last-child{margin-bottom:0}.style-control-label{font-size:11px;font-weight:600;color:#3a4756;margin:0}.style-control-input-wrapper{display:flex;align-items:center;gap:8px}.style-control-slider{flex:1;height:18px;cursor:pointer;background:linear-gradient(to right,#e0e6ed,#2f6fed);border-radius:9px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.style-control-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#fff;border:2px solid #2f6fed;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0003}.style-control-slider::-moz-range-thumb{width:16px;height:16px;background:#fff;border:2px solid #2f6fed;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0003}.style-control-value{min-width:48px;text-align:right;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;color:#3a4756;font-weight:500}.style-control-color-group{display:flex;align-items:center;gap:8px}.style-control-color-picker{width:40px;height:28px;padding:2px;border:1px solid #d0d7e2;border-radius:4px;cursor:pointer;background:#fff}.style-control-color-value{flex:1;height:28px;padding:4px 8px;border:1px solid #d0d7e2;border-radius:4px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:11px;color:#3a4756;background:#fff;text-align:center;font-weight:500}.layer-control-panel::-webkit-scrollbar{width:6px}.layer-control-panel::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.layer-control-panel::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.layer-control-panel::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.layer-control-style-button{flex:0 0 auto;width:20px;height:20px;border:1px solid #ddd;border-radius:3px;background:#fff;color:#666;cursor:pointer;font-size:16px;padding:0;line-height:1;transition:all .2s ease}.layer-control-style-button:hover{background:#f5f5f5;border-color:#2f6fed;color:#2f6fed}.layer-control-style-button:active{background:#e8e8e8}.layer-control-style-editor{display:block;margin-top:8px;padding:12px;background:#f7fafc;border:1px solid #e0e6ed;border-radius:4px;box-shadow:inset 0 1px 3px #0000000d}.style-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e0e6ed}.style-editor-title{font-size:13px;font-weight:600;color:#333}.style-editor-close{width:20px;height:20px;border:none;background:transparent;color:#999;font-size:20px;line-height:1;cursor:pointer;padding:0;transition:color .2s ease}.style-editor-close:hover{color:#333}.style-editor-controls{margin-bottom:12px;min-height:40px;color:#666;font-size:12px}.style-editor-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:8px;border-top:1px solid #e0e6ed}.style-editor-button{padding:8px 16px;min-width:70px;border:1px solid #ddd;border-radius:3px;background:#fff;color:#333;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.style-editor-button:hover{background:#f5f5f5;border-color:#bbb}.style-editor-button:active{background:#e0e0e0}.layer-control-style-editor .style-editor-button-reset{background:#fb923c!important;color:#fff!important;border-color:#f97316!important;font-weight:600}.layer-control-style-editor .style-editor-button-reset:hover{background:#f97316!important;border-color:#ea580c!important;color:#fff!important}.layer-control-style-editor .style-editor-button-close{background:#6b7280!important;color:#fff!important;border-color:#4b5563!important;font-weight:600}.layer-control-style-editor .style-editor-button-close:hover{background:#4b5563!important;border-color:#374151!important;color:#fff!important}.layer-control-background-legend{display:block;margin-top:8px;padding:10px;background:#f7fafc;border:1px solid #e0e6ed;border-radius:4px;box-shadow:inset 0 1px 3px #0000000d}.background-legend-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #e0e6ed}.background-legend-title{font-size:12px;font-weight:600;color:#333}.background-legend-close{width:18px;height:18px;border:none;background:transparent;color:#999;font-size:18px;line-height:1;cursor:pointer;padding:0;transition:color .2s ease}.background-legend-close:hover{color:#333}.background-legend-actions{display:flex;gap:6px;margin-bottom:8px}.layer-control-background-legend .background-legend-action-btn{flex:1;padding:5px 10px;border:1px solid #2f6fed;border-radius:3px;background:#2f6fed;color:#fff;font-size:10px;font-weight:600;cursor:pointer;transition:all .15s ease;width:auto;height:auto}.layer-control-background-legend .background-legend-action-btn:hover{background:#1d5bd6!important;background-color:#1d5bd6!important;border-color:#1d5bd6;color:#fff}.layer-control-background-legend .background-legend-action-btn:active{background:#1a4fc2!important;background-color:#1a4fc2!important;border-color:#1a4fc2}.background-legend-filter{display:flex;align-items:center;gap:6px;margin-bottom:8px;padding:6px 8px;background:#eef2f7;border-radius:3px}.background-legend-filter-checkbox{margin:0;cursor:pointer}.background-legend-filter-label{font-size:11px;color:#444;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none}.background-legend-layer-list{max-height:200px;overflow-y:auto;padding-right:4px}.background-legend-layer-row{display:flex;align-items:center;gap:6px;padding:4px 0;border-bottom:1px solid #f0f4f8}.background-legend-layer-row:last-child{border-bottom:none}.background-legend-checkbox{margin:0;cursor:pointer;flex-shrink:0}.background-legend-layer-symbol{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;flex-shrink:0}.background-legend-layer-symbol svg{width:14px;height:14px;display:block}.background-legend-layer-name{flex:1;font-size:11px;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.background-legend-layer-type{flex-shrink:0;font-size:9px;color:#888;background:#e8ecf0;padding:2px 5px;border-radius:3px;text-transform:uppercase;font-weight:500}.background-legend-empty{font-size:11px;color:#888;text-align:center;padding:12px;margin:0}.layer-control-background-legend-button.active{background:#e8ecf0;border-color:#2f6fed;color:#2f6fed}.background-legend-layer-list::-webkit-scrollbar{width:4px}.background-legend-layer-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.background-legend-layer-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.background-legend-layer-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.layer-control-custom-info-text{margin:0;padding:8px;font-size:11px;line-height:1.5;color:#666;background:#f0f4f8;border-radius:4px;border-left:3px solid #2f6fed}
