.maplibre-gl-bookmark-control{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.maplibre-gl-bookmark-control .bookmark-button{display:flex;align-items:center;justify-content:center;width:29px;height:29px;padding:0;border:none;border-radius:4px;background:#fff;cursor:pointer;box-shadow:0 0 0 2px #0000001a;transition:background-color .15s ease}.maplibre-gl-bookmark-control .bookmark-button:hover{background-color:#f3f4f6}.maplibre-gl-bookmark-control .bookmark-button.active{background-color:#3b82f6;color:#fff}.maplibre-gl-bookmark-control .bookmark-button svg{width:18px;height:18px}.maplibre-gl-bookmark-control .bookmark-panel{position:absolute;top:0;background:#fffffff2;border-radius:4px;box-shadow:0 2px 8px #00000026;overflow:hidden;z-index:1}.maplibre-gl-bookmark-control .bookmark-panel.left{right:calc(100% + 8px)}.maplibre-gl-bookmark-control .bookmark-panel.right{left:calc(100% + 8px)}.maplibre-gl-bookmark-control .bookmark-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:13px;color:#374151}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-close{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:none;background-color:transparent;cursor:pointer;color:#6b7280;border-radius:3px;transition:all .15s ease}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-close:hover{background-color:#f3f4f6;color:#374151}.maplibre-gl-bookmark-control .bookmark-close svg{width:14px;height:14px}.maplibre-gl-bookmark-control .bookmark-content{padding:10px}.maplibre-gl-bookmark-control .bookmark-add-form{display:flex;gap:6px;margin-bottom:10px}.maplibre-gl-bookmark-control .bookmark-name-input{flex:1;padding:8px 10px;border:1px solid #e5e7eb;border-radius:4px;font-size:12px;color:#374151;transition:border-color .15s ease}.maplibre-gl-bookmark-control .bookmark-name-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.maplibre-gl-bookmark-control .bookmark-name-input::placeholder{color:#9ca3af}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-add-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border:none;border-radius:4px;background-color:#3b82f6;color:#fff;cursor:pointer;transition:background-color .15s ease}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-add-btn:hover{background-color:#2563eb;color:#fff}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-add-btn:disabled{background-color:#9ca3af;cursor:not-allowed}.maplibre-gl-bookmark-control .bookmark-add-btn svg{width:16px;height:16px}.maplibre-gl-bookmark-control .bookmark-list{max-height:250px;overflow-y:auto}.maplibre-gl-bookmark-control .bookmark-empty{padding:20px;text-align:center;color:#9ca3af;font-size:12px}.maplibre-gl-bookmark-control .bookmark-empty svg{width:32px;height:32px;margin-bottom:8px;opacity:.5}.maplibre-gl-bookmark-control .bookmark-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:4px;margin-bottom:4px;cursor:pointer;transition:background-color .15s ease}.maplibre-gl-bookmark-control .bookmark-item:hover{background:#f3f4f6}.maplibre-gl-bookmark-control .bookmark-item.active{background:#eff6ff}.maplibre-gl-bookmark-control .bookmark-item:last-child{margin-bottom:0}.maplibre-gl-bookmark-control .bookmark-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f3f4f6;border-radius:4px;color:#6b7280;flex-shrink:0}.maplibre-gl-bookmark-control .bookmark-icon svg{width:14px;height:14px}.maplibre-gl-bookmark-control .bookmark-info{flex:1;min-width:0}.maplibre-gl-bookmark-control .bookmark-name{font-size:13px;font-weight:500;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.maplibre-gl-bookmark-control .bookmark-meta{font-size:10px;color:#9ca3af;margin-top:2px}.maplibre-gl-bookmark-control .bookmark-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s ease}.maplibre-gl-bookmark-control .bookmark-item:hover .bookmark-actions{opacity:1}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-action-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;background-color:transparent;cursor:pointer;color:#9ca3af;border-radius:4px;transition:all .15s ease}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-action-btn:hover{background-color:#e5e7eb;color:#374151}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-action-btn.delete:hover{background-color:#fef2f2;color:#dc2626}.maplibre-gl-bookmark-control .bookmark-action-btn svg{width:14px;height:14px}.maplibre-gl-bookmark-control .bookmark-footer{padding:8px 10px;border-top:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.maplibre-gl-bookmark-control .bookmark-footer-actions{display:flex;gap:4px}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-import-btn,.maplibre-gl-bookmark-control .bookmark-panel .bookmark-export-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid #d1d5db;border-radius:4px;background-color:transparent;cursor:pointer;font-size:11px;color:#4b5563;transition:all .15s ease}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-import-btn:hover,.maplibre-gl-bookmark-control .bookmark-panel .bookmark-export-btn:hover{background-color:#f3f4f6;border-color:#9ca3af;color:#4b5563}.maplibre-gl-bookmark-control .bookmark-import-btn svg,.maplibre-gl-bookmark-control .bookmark-export-btn svg{width:12px;height:12px}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-clear-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid #fecaca;border-radius:4px;background-color:transparent;cursor:pointer;font-size:11px;color:#dc2626;transition:all .15s ease}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-clear-btn:hover{background-color:#fef2f2;border-color:#fca5a5;color:#dc2626}.maplibre-gl-bookmark-control .bookmark-panel .bookmark-clear-btn:disabled{opacity:.5;cursor:not-allowed}.maplibre-gl-bookmark-control .bookmark-clear-btn svg{width:12px;height:12px}.maplibre-gl-bookmark-control .bookmark-thumbnail{width:40px;height:28px;border-radius:3px;object-fit:cover;background:#f3f4f6;flex-shrink:0}.maplibre-gl-bookmark-control .bookmark-rename-input{width:100%;padding:4px 6px;border:1px solid #3b82f6;border-radius:3px;font-size:13px;color:#374151}.maplibre-gl-bookmark-control .bookmark-rename-input:focus{outline:none;box-shadow:0 0 0 2px #3b82f633}
